freedombone 466KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594
  1. #!/bin/bash
  2. #
  3. # .---. . .
  4. # | | |
  5. # |--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-.
  6. # | | (.-' (.-' ( | ( )| | | | )( )| | (.-'
  7. # ' ' --' --' -' - -' ' ' -' -' -' ' - --'
  8. #
  9. # Freedom in the Cloud
  10. #
  11. # This install script is intended for use with Debian Jessie
  12. #
  13. # Please note that the various hashes and download archives
  14. # for systems such as Owncloud and Dokuwiki may need to be updated
  15. #
  16. # License
  17. # =======
  18. #
  19. # Copyright (C) 2014-2015 Bob Mottram <bob@robotics.uk.to>
  20. #
  21. # This program is free software: you can redistribute it and/or modify
  22. # it under the terms of the GNU General Public License as published by
  23. # the Free Software Foundation, either version 3 of the License, or
  24. # (at your option) any later version.
  25. #
  26. # This program is distributed in the hope that it will be useful,
  27. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  28. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  29. # GNU General Public License for more details.
  30. #
  31. # You should have received a copy of the GNU General Public License
  32. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  33. #
  34. # Summary
  35. # =======
  36. #
  37. # This script is intended to be run on the target device, which
  38. # is typically a Beaglebone Black.
  39. #
  40. # To be able to run this script you need to get to a condition
  41. # where you have Debian Jessie installed, with at least one
  42. # unprivileged user account and at least one subdomain created on
  43. # https://freedns.afraid.org/. If you're not installing on a
  44. # Beaglebone Black then set the variable INSTALLING_ON_BBB to "no"
  45. #
  46. # Note on dynamic dns
  47. # ===================
  48. #
  49. # I'm not particularly trying to promote freedns.afraid.org
  50. # as a service, it just happens to be a dynamic DNS system which
  51. # provides free (as in beer) accounts, and I'm trying to make the
  52. # process of setting up a working server as trivial as possible.
  53. # Other dynamic DNS systems are available, and if you're using
  54. # something different then comment out the section within
  55. # argument_checks and the call to dynamic_dns_freedns.
  56. #
  57. # Prerequisites
  58. # =============
  59. #
  60. # You will need to initially prepare a microSD card with a Debian
  61. # image on it. This can be done using the initial_setup.sh script.
  62. #
  63. # If you are not using a Beaglebone Black then just prepare the
  64. # target system with a fresh installation of Debian Jessie.
  65. #
  66. # Configuration file
  67. # ==================
  68. # If you don't want to edit this script directly then you can
  69. # create a configuration file called freedombone.cfg, which should
  70. # be in the same directory as install-freedombone.sh.
  71. # Within the configuration file you can specify the main settings
  72. # such as:
  73. #
  74. # INSTALLING_ON_BBB=yes
  75. # SSH_PORT=2222
  76. # MICROBLOG_DOMAIN_NAME=mydomain
  77. # MICROBLOG_FREEDNS_SUBDOMAIN_CODE=[code]
  78. # ...
  79. #
  80. # Note that there are no spaces around the equals.
  81. NO_OF_ARGS=$#
  82. DOMAIN_NAME=
  83. MY_USERNAME=
  84. FREEDNS_SUBDOMAIN_CODE=
  85. SYSTEM_TYPE=
  86. # Are we installing on a Beaglebone Black (BBB) or some other system?
  87. INSTALLING_ON_BBB="no"
  88. # Version number of this script
  89. VERSION="1.00"
  90. # Different system variants which may be specified within
  91. # the SYSTEM_TYPE option
  92. VARIANT_FULL="full"
  93. VARIANT_WRITER="writer"
  94. VARIANT_CLOUD="cloud"
  95. VARIANT_CHAT="chat"
  96. VARIANT_MAILBOX="mailbox"
  97. VARIANT_NONMAILBOX="nonmailbox"
  98. VARIANT_SOCIAL="social"
  99. VARIANT_MEDIA="media"
  100. VARIANT_TOR_DONGLE="tordongle"
  101. # An optional configuration file which overrides some of these variables
  102. CONFIGURATION_FILE="freedombone.cfg"
  103. SSH_PORT=2222
  104. # parameters used when adding a new domain
  105. DDNS_PROVIDER="default@freedns.afraid.org"
  106. DDNS_USERNAME=
  107. DDNS_PASSWORD=
  108. CURRENT_DDNS_DOMAIN=
  109. CURRENT_DDNS_CODE=
  110. # Minimum number of characters in a password
  111. MINIMUM_PASSWORD_LENGTH=10
  112. # number of CPU cores
  113. CPU_CORES=1
  114. # The static IP address of the system within the local network
  115. LOCAL_NETWORK_STATIC_IP_ADDRESS="192.168.1.60"
  116. # IP address of the router (gateway)
  117. ROUTER_IP_ADDRESS="192.168.1.254"
  118. # whether to route outgoing traffic through Tor
  119. ROUTE_THROUGH_TOR="no"
  120. # Why use Google as a time source?
  121. # The thinking here is that it's likely to be reliable and fast.
  122. # The ping doesn't reveal any information other than that the server
  123. # is running, and if anyone maliciously alters the time on Google's
  124. # servers then that would certainly be newsworthy and they'd be
  125. # likely to do something about it quickly.
  126. # If you have better time sources then change them here.
  127. TLS_TIME_SOURCE1="google.com"
  128. TLS_TIME_SOURCE2="www.ptb.de"
  129. # kernel specifically tweaked for the Beaglebone Black
  130. # See http://rcn-ee.net/deb/jessie-armhf/
  131. KERNEL_VERSION="v3.15.10-bone8"
  132. # Whether or not to use the beaglebone's hardware random number generator
  133. USE_HWRNG="yes"
  134. # Whether this system is being installed within a docker container
  135. INSTALLED_WITHIN_DOCKER="no"
  136. # If you want to run a public mailing list specify its name here.
  137. # There should be no spaces in the name
  138. PUBLIC_MAILING_LIST=
  139. # Optional different domain name for the public mailing list
  140. PUBLIC_MAILING_LIST_DOMAIN_NAME=
  141. # Directory where the public mailing list data is stored
  142. PUBLIC_MAILING_LIST_DIRECTORY="/var/spool/mlmmj"
  143. # If you want to run an encrypted mailing list specify its name here.
  144. # There should be no spaces in the name
  145. PRIVATE_MAILING_LIST=
  146. # Domain name or freedns subdomain for mediagoblin installation
  147. MEDIAGOBLIN_DOMAIN_NAME=
  148. MEDIAGOBLIN_FREEDNS_SUBDOMAIN_CODE=
  149. MEDIAGOBLIN_REPO=""
  150. MEDIAGOBLIN_ADMIN_PASSWORD=
  151. # Domain name or freedns subdomain for microblog installation
  152. MICROBLOG_DOMAIN_NAME=
  153. MICROBLOG_FREEDNS_SUBDOMAIN_CODE=
  154. MICROBLOG_REPO="git://gitorious.org/social/mainline.git"
  155. MICROBLOG_ADMIN_PASSWORD=
  156. # Domain name or redmatrix installation
  157. REDMATRIX_DOMAIN_NAME=
  158. REDMATRIX_FREEDNS_SUBDOMAIN_CODE=
  159. REDMATRIX_REPO="https://github.com/friendica/red.git"
  160. REDMATRIX_ADDONS_REPO="https://github.com/friendica/red-addons.git"
  161. REDMATRIX_ADMIN_PASSWORD=
  162. # Domain name and freedns subdomain for Owncloud installation
  163. OWNCLOUD_DOMAIN_NAME=
  164. OWNCLOUD_FREEDNS_SUBDOMAIN_CODE=
  165. OWNCLOUD_ADMIN_PASSWORD=
  166. # Domain name and freedns subdomain for your wiki
  167. WIKI_DOMAIN_NAME=
  168. WIKI_FREEDNS_SUBDOMAIN_CODE=
  169. WIKI_ADMIN_PASSWORD=
  170. WIKI_TITLE="Freedombone Wiki"
  171. # Domain name and freedns subdomain for your blog
  172. FULLBLOG_DOMAIN_NAME=
  173. FULLBLOG_FREEDNS_SUBDOMAIN_CODE=
  174. MY_BLOG_TITLE="My Blog"
  175. MY_BLOG_SUBTITLE="Another Freedombone Blog"
  176. GPG_KEYSERVER="hkp://keys.gnupg.net"
  177. # whether to encrypt all incoming email with your public key
  178. GPG_ENCRYPT_STORED_EMAIL="yes"
  179. # gets set to yes if gpg keys are imported from usb
  180. GPG_KEYS_IMPORTED="no"
  181. # optionally you can provide your exported GPG key pair here
  182. # Note that the private key file will be deleted after use
  183. # If these are unspecified then a new GPG key will be created
  184. MY_GPG_PUBLIC_KEY=
  185. MY_GPG_PRIVATE_KEY=
  186. # optionally specify your public key ID
  187. MY_GPG_PUBLIC_KEY_ID=
  188. # If you have existing mail within a Maildir
  189. # you can specify the directory here and the files
  190. # will be imported
  191. IMPORT_MAILDIR=
  192. # The Debian package repository to use.
  193. DEBIAN_REPO="ftp.us.debian.org"
  194. DEBIAN_VERSION="jessie"
  195. # Directory where source code is downloaded and compiled
  196. INSTALL_DIR=$HOME/build
  197. # device name for an attached usb drive
  198. USB_DRIVE=/dev/sda1
  199. # Location where the USB drive is mounted to
  200. USB_MOUNT=/mnt/usb
  201. # name of a script used to upgrade the system
  202. UPGRADE_SCRIPT_NAME="freedombone-upgrade"
  203. # name of a script which keeps running processes going even if they crash
  204. WATCHDOG_SCRIPT_NAME="keepon"
  205. # Name of a script used to create a backup of the system on usb drive
  206. BACKUP_SCRIPT_NAME="backup"
  207. # Name of a script used to restore the system from usb drive
  208. RESTORE_SCRIPT_NAME="restore"
  209. # name of a script used to backup to friends servers
  210. BACKUP_TO_FRIENDS_SCRIPT_NAME="backup2friends"
  211. # name of a script used to restore backed up data from a friend
  212. RESTORE_FROM_FRIEND_SCRIPT_NAME="restorefromfriend"
  213. # Location of the certificate used to encrypt backups
  214. BACKUP_CERTIFICATE=/etc/ssl/private/backup.key
  215. # memory limit for php in MB
  216. MAX_PHP_MEMORY=64
  217. # default MariaDB password
  218. MARIADB_PASSWORD=
  219. # Directory where XMPP settings are stored
  220. XMPP_DIRECTORY="/var/lib/prosody"
  221. # file containing a list of remote locations to backup to
  222. # Format: [username@friendsdomain//home/username] [ssh_password]
  223. # With the only space character being between the server and the password
  224. FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
  225. # list of encryption protocols
  226. SSL_PROTOCOLS="TLSv1 TLSv1.1 TLSv1.2"
  227. # list of ciphers to use. See bettercrypto.org recommendations
  228. SSL_CIPHERS="EDH+CAMELLIA:EDH+aRSA:EECDH+aRSA+AESGCM:EECDH+aRSA+SHA384:EECDH+aRSA+SHA256:EECDH:+CAMELLIA256:+AES256:+CAMELLIA128:+AES128:+SSLv3:!aNULL:!eNULL:!LOW:!3DES:!MD5:!EXP:!PSK:!DSS:!RC4:!SEED:!ECDSA:CAMELLIA256-SHA:AES256-SHA:CAMELLIA128-SHA:AES128-SHA"
  229. # ssh ciphers
  230. SSH_CIPHERS="aes256-gcm@openssh.com,aes128-gcm@openssh.com,aes256-ctr,aes128-ctr"
  231. SSH_MACS="hmac-sha2-512-etm@openssh.com,hmac-sha2-256-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-512,hmac-sha2-256,hmac-ripemd160"
  232. SSH_KEX="diffie-hellman-group-exchange-sha256,diffie-hellman-group14-sha1,diffie-hellman-group-exchange-sha1"
  233. # xmpp ciphers and curve
  234. XMPP_CIPHERS='"EDH+CAMELLIA:EDH+aRSA:EECDH+aRSA+AESGCM:EECDH+aRSA+SHA256:EECDH:+CAMELLIA128:+AES128:+SSLv3:!aNULL:!eNULL:!LOW:!3DES:!MD5:!EXP:!PSK:!DSS:!RC4:!SEED:!IDEA:!ECDSA:kEDH:CAMELLIA128-SHA:AES128-SHA"'
  235. XMPP_ECC_CURVE='"secp384r1"'
  236. # the default email address
  237. MY_EMAIL_ADDRESS=$MY_USERNAME@$DOMAIN_NAME
  238. # optionally specify your name to appear on the blog
  239. MY_NAME=$DOMAIN_NAME
  240. export DEBIAN_FRONTEND=noninteractive
  241. # logging level for Nginx
  242. WEBSERVER_LOG_LEVEL='crit'
  243. # used to limit CPU usage
  244. CPULIMIT='/usr/bin/cpulimit -l 20 -e'
  245. # command to create a git repository
  246. CREATE_GIT_PROJECT_COMMAND='create-project'
  247. # File which keeps track of what has already been installed
  248. COMPLETION_FILE=$HOME/freedombone-completed.txt
  249. if [ ! -f $COMPLETION_FILE ]; then
  250. touch $COMPLETION_FILE
  251. fi
  252. # Your github username
  253. GITHUB_USERNAME=
  254. # Directory where github projects will be backed up
  255. GITHUB_BACKUP_DIRECTORY=/var/backups/github
  256. # Used to indicate whether the backup contains MariaDB databases or not
  257. BACKUP_INCLUDES_DATABASES="no"
  258. # contains the mysql root password which
  259. # is used for backups and repair
  260. DATABASE_PASSWORD_FILE=/root/dbpass
  261. # log file where details of remote backups are stored
  262. REMOTE_BACKUPS_LOG=/var/log/remotebackups.log
  263. # message if something fails to install
  264. CHECK_MESSAGE="Check your internet connection, /etc/network/interfaces and /etc/resolv.conf, then delete $COMPLETION_FILE, run 'rm -fR /var/lib/apt/lists/* && apt-get update --fix-missing' and run this script again. If hash sum mismatches persist then try setting $DEBIAN_REPO to a different mirror and also change /etc/apt/sources.list."
  265. # cjdns settings
  266. ENABLE_CJDNS="no"
  267. CJDNS_PRIVATE_KEY=
  268. CJDNS_PUBLIC_KEY=
  269. CJDNS_IPV6=
  270. CJDNS_PASSWORD=
  271. CJDNS_PORT=
  272. function show_help {
  273. echo ''
  274. echo 'freedombone -d [domain] -u [username] -c [FreeDNS subdomain code] -s [system type]'
  275. echo ''
  276. echo ' -h --help Show help'
  277. echo ' menuconfig Easy interactive installation'
  278. echo ' --bbb Installing on Beaglebone Black'
  279. echo ' -u --user User to install the system as'
  280. echo ' -d --domain Default domain name'
  281. echo ' -s --system System type'
  282. echo ' --ip Static LAN IP address of the system'
  283. echo ' --iprouter LAN IP address of the internet router'
  284. echo ' --ddns Dynamic DNS provider domain'
  285. echo ' --ddnsuser Dynamic DNS provider username'
  286. echo ' --ddnspass Dynamic DNS provider password'
  287. echo ''
  288. echo ' -c --code Default domain FreeDNS code'
  289. echo ' --microblogcode Microblog FreeDNS code'
  290. echo ' --wikicode Wiki FreeDNS code'
  291. echo ' --owncloudcode Owncloud FreeDNS code'
  292. echo ' --redmatrixcode Redmatrix FreeDNS code'
  293. echo ' --blogcode Blog FreeDNS code'
  294. echo ''
  295. echo ' --microblogdomain Microblog domain name'
  296. echo ' --wikidomain Wiki domain name'
  297. echo ' --blogdomain Blog domain name'
  298. echo ' --ownclouddomain Owncloud domain name'
  299. echo ' --redmatrixdomain Redmatrix domain name'
  300. echo ' -t --time Domain used as a TLS time source'
  301. echo ' --ssh ssh port number'
  302. echo ' --list Public mailing list name'
  303. echo ' --cores Number of CPU cores'
  304. echo ' --name Your name'
  305. echo ' --email Your email address'
  306. echo ' --usb Path for the USB drive (eg. /dev/sdb1)'
  307. echo ' --cjdns Enable CJDNS'
  308. echo ''
  309. echo 'system types'
  310. echo '------------'
  311. echo 'This can either be blank if you wish to install the full system,'
  312. echo "or for more specialised variants you can specify '$VARIANT_MAILBOX', '$VARIANT_CLOUD',"
  313. echo "'$VARIANT_CHAT', '$VARIANT_SOCIAL', '$VARIANT_MEDIA', '$VARIANT_TOR_DONGLE' or '$VARIANT_WRITER'."
  314. echo "If you wish to install everything except email then use the '$VARIANT_NONMAILBOX' variaint."
  315. echo ''
  316. exit 0
  317. }
  318. function interactive_configuration_remote_backups {
  319. # clear any existing list
  320. if [ -f $FRIENDS_SERVERS_LIST ]; then
  321. rm -f $FRIENDS_SERVERS_LIST
  322. touch $FRIENDS_SERVERS_LIST
  323. fi
  324. # number of entries made
  325. entering_remote_backups_ctr=1
  326. entering_remote_backups_done="no"
  327. while [[ $entering_remote_backups_done == "no" ]]
  328. do
  329. data=$(tempfile 2>/dev/null)
  330. trap "rm -f $data" 0 1 2 5 15
  331. dialog --backtitle "Freedombone Configuration" \
  332. --title "Remote Backup ${entering_remote_backups_ctr}" \
  333. --form "\nPlease specify the SSH login details:" 11 55 4 \
  334. "Username:" 1 1 "" 1 16 16 15 \
  335. "Domain:" 2 1 "" 2 16 16 15 \
  336. "SSH port:" 3 1 "22" 3 16 5 4 \
  337. "Password:" 4 1 "" 4 16 20 100 \
  338. 2> $data
  339. sel=$?
  340. case $sel in
  341. 1) entering_remote_backups_done="yes";;
  342. 255) entering_remote_backups_done="yes";;
  343. esac
  344. remote_ssh_username=$(cat $data | sed -n 1p)
  345. remote_ssh_domain=$(cat $data | sed -n 2p)
  346. remote_ssh_port=$(cat $data | sed -n 3p)
  347. remote_ssh_password=$(cat $data | sed -n 4p)
  348. if [[ $remote_ssh_username != "" && \
  349. $remote_ssh_domain != "" && \
  350. $remote_ssh_port != "" && \
  351. $remote_ssh_password != "" ]]; then
  352. if [ ${#remote_ssh_password} -lt $MINIMUM_PASSWORD_LENGTH ]; then
  353. dialog --title "Password quality check" --msgbox "The password given was too short. It must be at least $MINIMUM_PASSWORD_LENGTH characters" 6 40
  354. else
  355. echo "$remote_ssh_username@$remote_ssh_domain:$remote_ssh_port//home/$remote_ssh_username $remote_ssh_password" >> $FRIENDS_SERVERS_LIST
  356. entering_remote_backups_ctr=$((entering_remote_backups_ctr + 1))
  357. fi
  358. else
  359. entering_remote_backups_done="yes"
  360. fi
  361. done
  362. if [ -f $FRIENDS_SERVERS_LIST ]; then
  363. chown $MY_USERNAME:$MY_USERNAME $FRIENDS_SERVERS_LIST
  364. fi
  365. }
  366. function save_configuration_file {
  367. echo "MY_USERNAME=$MY_USERNAME" > freedombone.cfg
  368. echo "DOMAIN_NAME=$DOMAIN_NAME" >> freedombone.cfg
  369. echo "MY_EMAIL_ADDRESS=$MY_EMAIL_ADDRESS" >> freedombone.cfg
  370. echo "SYSTEM_TYPE=$SYSTEM_TYPE" >> freedombone.cfg
  371. echo "INSTALLING_ON_BBB=$INSTALLING_ON_BBB" >> freedombone.cfg
  372. echo "DDNS_PROVIDER=$DDNS_PROVIDER" >> freedombone.cfg
  373. echo "DDNS_USERNAME=$DDNS_USERNAME" >> freedombone.cfg
  374. # does this need to be saved?
  375. echo "DDNS_PASSWORD=$DDNS_PASSWORD" >> freedombone.cfg
  376. echo "MY_NAME=$MY_NAME" >> freedombone.cfg
  377. echo "LOCAL_NETWORK_STATIC_IP_ADDRESS=$LOCAL_NETWORK_STATIC_IP_ADDRESS" >> freedombone.cfg
  378. echo "ROUTER_IP_ADDRESS=$ROUTER_IP_ADDRESS" >> freedombone.cfg
  379. echo "ENABLE_CJDNS=$ENABLE_CJDNS" >> freedombone.cfg
  380. if [ $WIKI_TITLE ]; then
  381. echo "WIKI_TITLE=$WIKI_TITLE" >> freedombone.cfg
  382. fi
  383. if [ $WIKI_DOMAIN_NAME ]; then
  384. echo "WIKI_DOMAIN_NAME=$WIKI_DOMAIN_NAME" >> freedombone.cfg
  385. fi
  386. if [ $WIKI_FREEDNS_SUBDOMAIN_CODE ]; then
  387. echo "WIKI_FREEDNS_SUBDOMAIN_CODE=$WIKI_FREEDNS_SUBDOMAIN_CODE" >> freedombone.cfg
  388. fi
  389. if [ $FREEDNS_SUBDOMAIN_CODE ]; then
  390. echo "FREEDNS_SUBDOMAIN_CODE=$FREEDNS_SUBDOMAIN_CODE" >> freedombone.cfg
  391. fi
  392. if [ $MY_BLOG_TITLE ]; then
  393. echo "MY_BLOG_TITLE=$MY_BLOG_TITLE" >> freedombone.cfg
  394. fi
  395. if [ $FULLBLOG_DOMAIN_NAME ]; then
  396. echo "FULLBLOG_DOMAIN_NAME=$FULLBLOG_DOMAIN_NAME" >> freedombone.cfg
  397. fi
  398. if [ $FULLBLOG_FREEDNS_SUBDOMAIN_CODE ]; then
  399. echo "FULLBLOG_FREEDNS_SUBDOMAIN_CODE=$FULLBLOG_FREEDNS_SUBDOMAIN_CODE" >> freedombone.cfg
  400. fi
  401. if [ $OWNCLOUD_DOMAIN_NAME ]; then
  402. echo "OWNCLOUD_DOMAIN_NAME=$OWNCLOUD_DOMAIN_NAME" >> freedombone.cfg
  403. fi
  404. if [ $OWNCLOUD_FREEDNS_SUBDOMAIN_CODE ]; then
  405. echo "OWNCLOUD_FREEDNS_SUBDOMAIN_CODE=$OWNCLOUD_FREEDNS_SUBDOMAIN_CODE" >> freedombone.cfg
  406. fi
  407. if [ $REDMATRIX_DOMAIN_NAME ]; then
  408. echo "REDMATRIX_DOMAIN_NAME=$REDMATRIX_DOMAIN_NAME" >> freedombone.cfg
  409. fi
  410. if [ $REDMATRIX_FREEDNS_SUBDOMAIN_CODE ]; then
  411. echo "REDMATRIX_FREEDNS_SUBDOMAIN_CODE=$REDMATRIX_FREEDNS_SUBDOMAIN_CODE" >> freedombone.cfg
  412. fi
  413. if [ $MICROBLOG_DOMAIN_NAME ]; then
  414. echo "MICROBLOG_DOMAIN_NAME=$MICROBLOG_DOMAIN_NAME" >> freedombone.cfg
  415. fi
  416. if [ $MICROBLOG_FREEDNS_SUBDOMAIN_CODE ]; then
  417. echo "MICROBLOG_FREEDNS_SUBDOMAIN_CODE=$MICROBLOG_FREEDNS_SUBDOMAIN_CODE" >> freedombone.cfg
  418. fi
  419. }
  420. function interactive_configuration {
  421. data=$(tempfile 2>/dev/null)
  422. trap "rm -f $data" 0 1 2 5 15
  423. dialog --backtitle "Freedombone Configuration" \
  424. --radiolist "Type of Installation:" 15 40 8 \
  425. 1 Full on \
  426. 2 Writer off \
  427. 3 Cloud off \
  428. 4 Chat off \
  429. 5 Mailbox off \
  430. 6 Non-Mailbox off \
  431. 7 Social off \
  432. 8 Media off 2> $data
  433. sel=$?
  434. case $sel in
  435. 1) exit 0;;
  436. 255) exit 0;;
  437. esac
  438. case $(cat $data) in
  439. 1) SYSTEM_TYPE=$VARIANT_FULL;;
  440. 2) SYSTEM_TYPE=$VARIANT_WRITER;;
  441. 3) SYSTEM_TYPE=$VARIANT_CLOUD;;
  442. 4) SYSTEM_TYPE=$VARIANT_CHAT;;
  443. 5) SYSTEM_TYPE=$VARIANT_MAILBOX;;
  444. 6) SYSTEM_TYPE=$VARIANT_NONMAILBOX;;
  445. 7) SYSTEM_TYPE=$VARIANT_SOCIAL;;
  446. 8) SYSTEM_TYPE=$VARIANT_MEDIA;;
  447. esac
  448. data=$(tempfile 2>/dev/null)
  449. trap "rm -f $data" 0 1 2 5 15
  450. dialog --title "Select the user account to install as" \
  451. --backtitle "Freedombone Configuration" \
  452. --dselect /home/ 14 40 2> $data
  453. sel=$?
  454. case $sel in
  455. 0) MY_USERNAME=$(cat $data | awk -F '/' '{print $3}');;
  456. 1) exit 0;;
  457. 255) exit 0;;
  458. esac
  459. if [ ! $MY_USERNAME ]; then
  460. echo 'No user account was selected'
  461. exit 0
  462. fi
  463. if [ ! -d /home/$MY_USERNAME ]; then
  464. echo "The directory /home/$MY_USERNAME does not exist"
  465. exit 6437
  466. fi
  467. dialog --title "Install Target" \
  468. --backtitle "Freedombone Configuration" \
  469. --defaultno \
  470. --yesno "\nAre you installing onto a Beaglebone Black?" 7 60
  471. sel=$?
  472. case $sel in
  473. 0) INSTALLING_ON_BBB="yes";;
  474. 1) INSTALLING_ON_BBB="no";;
  475. 255) exit 0;;
  476. esac
  477. data=$(tempfile 2>/dev/null)
  478. trap "rm -f $data" 0 1 2 5 15
  479. dialog --backtitle "Freedombone Configuration" \
  480. --radiolist "Choose Dynamic DNS provider:" 15 40 14 \
  481. 1 dyndns off \
  482. 2 freedns on \
  483. 3 zoneedit off \
  484. 4 no-ip off \
  485. 5 easydns off \
  486. 6 tzo off \
  487. 7 3322 off \
  488. 8 dnsomatic off \
  489. 9 tunnelbroker off \
  490. 10 dns.he.net off \
  491. 11 dynsip off \
  492. 12 sitelutions off \
  493. 13 dnsexit off \
  494. 14 changeip off 2> $data
  495. sel=$?
  496. case $sel in
  497. 1) exit 0;;
  498. 255) exit 0;;
  499. esac
  500. case $(cat $data) in
  501. 1) DDNS_PROVIDER="default@dyndns.org";;
  502. 2) DDNS_PROVIDER="default@freedns.afraid.org";;
  503. 3) DDNS_PROVIDER="default@zoneedit.com";;
  504. 4) DDNS_PROVIDER="default@no-ip.com";;
  505. 5) DDNS_PROVIDER="default@easydns.com";;
  506. 6) DDNS_PROVIDER="default@tzo.com";;
  507. 7) DDNS_PROVIDER="dyndns@3322.org";;
  508. 8) DDNS_PROVIDER="default@dnsomatic.com";;
  509. 9) DDNS_PROVIDER="ipv6tb@he.net";;
  510. 10) DDNS_PROVIDER="dyndns@he.net";;
  511. 11) DDNS_PROVIDER="default@dynsip.org";;
  512. 12) DDNS_PROVIDER="default@sitelutions.com";;
  513. 13) DDNS_PROVIDER="default@dnsexit.com";;
  514. 14) DDNS_PROVIDER="default@changeip.com";;
  515. 255) exit 0;;
  516. esac
  517. while [ ! $DDNS_USERNAME ]
  518. do
  519. data=$(tempfile 2>/dev/null)
  520. trap "rm -f $data" 0 1 2 5 15
  521. dialog --backtitle "Freedombone Configuration" \
  522. --inputbox "Dynamic DNS provider username" 10 30 2> $data
  523. sel=$?
  524. case $sel in
  525. 0) DDNS_USERNAME=$(cat $data);;
  526. 1) exit 0;;
  527. 255) exit 0;;
  528. esac
  529. done
  530. while [ ! $DDNS_PASSWORD ]
  531. do
  532. data=$(tempfile 2>/dev/null)
  533. trap "rm -f $data" 0 1 2 5 15
  534. dialog --backtitle "Freedombone Configuration" \
  535. --clear \
  536. --insecure \
  537. --passwordbox "Dynamic DNS provider password" 10 30 2> $data
  538. sel=$?
  539. case $sel in
  540. 0) DDNS_PASSWORD=$(cat $data);;
  541. 1) exit 0;;
  542. 255) exit 0;;
  543. esac
  544. if [ ${#DDNS_PASSWORD} -lt $MINIMUM_PASSWORD_LENGTH ]; then
  545. dialog --title "Password quality check" --msgbox "The password given was too short. It must be at least $MINIMUM_PASSWORD_LENGTH characters. You may need to change your password on the dynamic DNS provider's web site." 10 40
  546. DDNS_PASSWORD=""
  547. fi
  548. done
  549. while [ ! $MY_NAME ]
  550. do
  551. data=$(tempfile 2>/dev/null)
  552. trap "rm -f $data" 0 1 2 5 15
  553. dialog --backtitle "Freedombone Configuration" \
  554. --inputbox "Your full name (or nick)" 10 30 2> $data
  555. sel=$?
  556. case $sel in
  557. 0) MY_NAME=$(cat $data);;
  558. 1) exit 0;;
  559. 255) exit 0;;
  560. esac
  561. done
  562. data=$(tempfile 2>/dev/null)
  563. trap "rm -f $data" 0 1 2 5 15
  564. dialog --backtitle "Freedombone Configuration" \
  565. --title "Local Network Configuration" \
  566. --form "\nPlease enter the IP addresses:" 11 55 3 \
  567. "This system:" 1 1 "192.168.1.60" 1 16 16 15 \
  568. "Internet router:" 2 1 "192.168.1.254" 2 16 16 15 \
  569. 2> $data
  570. sel=$?
  571. case $sel in
  572. 1) exit 0;;
  573. 255) exit 0;;
  574. esac
  575. LOCAL_NETWORK_STATIC_IP_ADDRESS=$(cat $data | sed -n 1p)
  576. ROUTER_IP_ADDRESS=$(cat $data | sed -n 2p)
  577. data=$(tempfile 2>/dev/null)
  578. trap "rm -f $data" 0 1 2 5 15
  579. dialog --title "Mesh Networking" \
  580. --backtitle "Freedombone Configuration" \
  581. --defaultno \
  582. --yesno "\nDo you want to enable CJDNS?" 7 60
  583. sel=$?
  584. case $sel in
  585. 0) ENABLE_CJDNS="yes";;
  586. 1) ENABLE_CJDNS="no";;
  587. 255) exit 0;;
  588. esac
  589. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_FULL" ]]; then
  590. while [ ! $WIKI_DOMAIN_NAME ]
  591. do
  592. data=$(tempfile 2>/dev/null)
  593. trap "rm -f $data" 0 1 2 5 15
  594. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  595. dialog --backtitle "Freedombone Configuration" \
  596. --title "Wiki Configuration" \
  597. --form "\nPlease enter your wiki details:" 11 55 4 \
  598. "Title:" 1 1 "My Wiki" 1 16 16 15 \
  599. "Domain:" 2 1 "" 2 16 16 15 \
  600. "FreeDNS code:" 3 1 "" 3 16 16 15 \
  601. 2> $data
  602. else
  603. dialog --backtitle "Freedombone Configuration" \
  604. --title "Wiki Configuration" \
  605. --form "\nPlease enter your wiki details:" 11 55 3 \
  606. "Title:" 1 1 "My Wiki" 1 16 16 15 \
  607. "Domain:" 2 1 "" 2 16 16 15 \
  608. 2> $data
  609. fi
  610. sel=$?
  611. case $sel in
  612. 1) exit 0;;
  613. 255) exit 0;;
  614. esac
  615. WIKI_TITLE=$(cat $data | sed -n 1p)
  616. WIKI_DOMAIN_NAME=$(cat $data | sed -n 2p)
  617. if [ $WIKI_DOMAIN_NAME ]; then
  618. if [ ! $DOMAIN_NAME ]; then
  619. DOMAIN_NAME=$WIKI_DOMAIN_NAME
  620. fi
  621. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  622. WIKI_FREEDNS_SUBDOMAIN_CODE=$(cat $data | sed -n 3p)
  623. if [ ! $WIKI_FREEDNS_SUBDOMAIN_CODE ]; then
  624. WIKI_DOMAIN_NAME=""
  625. else
  626. if [[ $DOMAIN_NAME == "$WIKI_DOMAIN_NAME" ]]; then
  627. FREEDNS_SUBDOMAIN_CODE=$WIKI_FREEDNS_SUBDOMAIN_CODE
  628. fi
  629. fi
  630. fi
  631. fi
  632. done
  633. fi
  634. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_FULL" ]]; then
  635. while [ ! $FULLBLOG_DOMAIN_NAME ]
  636. do
  637. data=$(tempfile 2>/dev/null)
  638. trap "rm -f $data" 0 1 2 5 15
  639. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  640. dialog --backtitle "Freedombone Configuration" \
  641. --title "Blog Configuration" \
  642. --form "\nPlease enter your blog details:" 11 55 4 \
  643. "Title:" 1 1 "My Blog" 1 16 16 15 \
  644. "Domain:" 2 1 "" 2 16 16 15 \
  645. "FreeDNS code:" 3 1 "" 3 16 16 15 \
  646. 2> $data
  647. else
  648. dialog --backtitle "Freedombone Configuration" \
  649. --title "Blog Configuration" \
  650. --form "\nPlease enter your blog details:" 11 55 3 \
  651. "Title:" 1 1 "My Blog" 1 16 16 15 \
  652. "Domain:" 2 1 "" 2 16 16 15 \
  653. 2> $data
  654. fi
  655. sel=$?
  656. case $sel in
  657. 1) exit 0;;
  658. 255) exit 0;;
  659. esac
  660. MY_BLOG_TITLE=$(cat $data | sed -n 1p)
  661. FULLBLOG_DOMAIN_NAME=$(cat $data | sed -n 2p)
  662. if [ $FULLBLOG_DOMAIN_NAME ]; then
  663. if [[ $FULLBLOG_DOMAIN_NAME == "$WIKI_DOMAIN_NAME" ]]; then
  664. FULLBLOG_DOMAIN_NAME=""
  665. fi
  666. if [ ! $DOMAIN_NAME ]; then
  667. DOMAIN_NAME=$FULLBLOG_DOMAIN_NAME
  668. fi
  669. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  670. FULLBLOG_FREEDNS_SUBDOMAIN_CODE=$(cat $data | sed -n 3p)
  671. if [ ! $FULLBLOG_FREEDNS_SUBDOMAIN_CODE ]; then
  672. FULLBLOG_DOMAIN_NAME=""
  673. else
  674. if [[ $DOMAIN_NAME == "$FULLBLOG_DOMAIN_NAME" ]]; then
  675. FREEDNS_SUBDOMAIN_CODE=$FULLBLOG_FREEDNS_SUBDOMAIN_CODE
  676. fi
  677. fi
  678. fi
  679. fi
  680. done
  681. fi
  682. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_FULL" ]]; then
  683. while [ ! $OWNCLOUD_DOMAIN_NAME ]
  684. do
  685. data=$(tempfile 2>/dev/null)
  686. trap "rm -f $data" 0 1 2 5 15
  687. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  688. dialog --backtitle "Freedombone Configuration" \
  689. --title "Owncloud Configuration" \
  690. --form "\nPlease enter your Owncloud details:" 11 55 3 \
  691. "Domain:" 1 1 "" 1 16 16 15 \
  692. "FreeDNS code:" 2 1 "" 2 16 16 15 \
  693. 2> $data
  694. else
  695. dialog --backtitle "Freedombone Configuration" \
  696. --title "Owncloud Configuration" \
  697. --form "\nPlease enter your Owncloud details:" 11 55 3 \
  698. "Domain:" 1 1 "" 1 16 16 15 \
  699. 2> $data
  700. fi
  701. sel=$?
  702. case $sel in
  703. 1) exit 0;;
  704. 255) exit 0;;
  705. esac
  706. OWNCLOUD_DOMAIN_NAME=$(cat $data | sed -n 1p)
  707. if [ $OWNCLOUD_DOMAIN_NAME ]; then
  708. if [ ! $DOMAIN_NAME ]; then
  709. DOMAIN_NAME=$OWNCLOUD_DOMAIN_NAME
  710. fi
  711. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  712. OWNCLOUD_FREEDNS_SUBDOMAIN_CODE=$(cat $data | sed -n 2p)
  713. if [ ! $OWNCLOUD_FREEDNS_SUBDOMAIN_CODE ]; then
  714. OWNCLOUD_DOMAIN_NAME=""
  715. else
  716. if [[ $DOMAIN_NAME == "$OWNCLOUD_DOMAIN_NAME" ]]; then
  717. FREEDNS_SUBDOMAIN_CODE=$OWNCLOUD_FREEDNS_SUBDOMAIN_CODE
  718. fi
  719. fi
  720. fi
  721. fi
  722. done
  723. fi
  724. if [[ $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_FULL" ]]; then
  725. while [ ! $REDMATRIX_DOMAIN_NAME ]
  726. do
  727. data=$(tempfile 2>/dev/null)
  728. trap "rm -f $data" 0 1 2 5 15
  729. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  730. dialog --backtitle "Freedombone Configuration" \
  731. --title "RedMatrix Configuration" \
  732. --form "\nPlease enter your RedMatrix details:" 11 55 3 \
  733. "Domain:" 1 1 "" 1 16 16 15 \
  734. "FreeDNS code:" 2 1 "" 2 16 16 15 \
  735. 2> $data
  736. else
  737. dialog --backtitle "Freedombone Configuration" \
  738. --title "RedMatrix Configuration" \
  739. --form "\nPlease enter your RedMatrix details:" 11 55 3 \
  740. "Domain:" 1 1 "" 1 16 16 15 \
  741. 2> $data
  742. fi
  743. sel=$?
  744. case $sel in
  745. 1) exit 0;;
  746. 255) exit 0;;
  747. esac
  748. REDMATRIX_DOMAIN_NAME=$(cat $data | sed -n 1p)
  749. if [ $REDMATRIX_DOMAIN_NAME ]; then
  750. if [ ! $DOMAIN_NAME ]; then
  751. DOMAIN_NAME=$REDMATRIX_DOMAIN_NAME
  752. fi
  753. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  754. REDMATRIX_FREEDNS_SUBDOMAIN_CODE=$(cat $data | sed -n 2p)
  755. if [ ! $REDMATRIX_FREEDNS_SUBDOMAIN_CODE ]; then
  756. REDMATRIX_DOMAIN_NAME=""
  757. else
  758. if [[ $DOMAIN_NAME == "$REDMATRIX_DOMAIN_NAME" ]]; then
  759. FREEDNS_SUBDOMAIN_CODE=$REDMATRIX_FREEDNS_SUBDOMAIN_CODE
  760. fi
  761. fi
  762. fi
  763. fi
  764. done
  765. fi
  766. if [[ $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_FULL" ]]; then
  767. while [ ! $MICROBLOG_DOMAIN_NAME ]
  768. do
  769. data=$(tempfile 2>/dev/null)
  770. trap "rm -f $data" 0 1 2 5 15
  771. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  772. dialog --backtitle "Freedombone Configuration" \
  773. --title "Microblog Configuration" \
  774. --form "\nPlease enter your Microblog details:" 11 55 3 \
  775. "Domain:" 1 1 "" 1 16 16 15 \
  776. "FreeDNS code:" 2 1 "" 2 16 16 15 \
  777. 2> $data
  778. else
  779. dialog --backtitle "Freedombone Configuration" \
  780. --title "Microblog Configuration" \
  781. --form "\nPlease enter your Microblog details:" 11 55 3 \
  782. "Domain:" 1 1 "" 1 16 16 15 \
  783. 2> $data
  784. fi
  785. sel=$?
  786. case $sel in
  787. 1) exit 0;;
  788. 255) exit 0;;
  789. esac
  790. MICROBLOG_DOMAIN_NAME=$(cat $data | sed -n 1p)
  791. if [ $MICROBLOG_DOMAIN_NAME ]; then
  792. if [[ $MICROBLOG_DOMAIN_NAME == "$REDMATRIX_DOMAIN_NAME" ]]; then
  793. MICROBLOG_DOMAIN_NAME=""
  794. fi
  795. if [ ! $DOMAIN_NAME ]; then
  796. DOMAIN_NAME=$MICROBLOG_DOMAIN_NAME
  797. fi
  798. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  799. MICROBLOG_FREEDNS_SUBDOMAIN_CODE=$(cat $data | sed -n 2p)
  800. if [ ! $MICROBLOG_FREEDNS_SUBDOMAIN_CODE ]; then
  801. MICROBLOG_DOMAIN_NAME=""
  802. else
  803. if [[ $DOMAIN_NAME == "$MICROBLOG_DOMAIN_NAME" ]]; then
  804. FREEDNS_SUBDOMAIN_CODE=$MICROBLOG_FREEDNS_SUBDOMAIN_CODE
  805. fi
  806. fi
  807. fi
  808. fi
  809. done
  810. fi
  811. if [ ! $DOMAIN_NAME ]; then
  812. while [ ! $DOMAIN_NAME ]
  813. do
  814. data=$(tempfile 2>/dev/null)
  815. trap "rm -f $data" 0 1 2 5 15
  816. dialog --backtitle "Freedombone Configuration" \
  817. --inputbox "Domain name" 10 30 2> $data
  818. sel=$?
  819. case $sel in
  820. 0) DOMAIN_NAME=$(cat $data);;
  821. 1) exit 0;;
  822. 255) exit 0;;
  823. esac
  824. done
  825. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  826. while [ ! $FREEDNS_SUBDOMAIN_CODE ]
  827. do
  828. data=$(tempfile 2>/dev/null)
  829. trap "rm -f $data" 0 1 2 5 15
  830. dialog --backtitle "Freedombone Configuration" \
  831. --inputbox "FreeDNS subdomain code" 10 30 2> $data
  832. sel=$?
  833. case $sel in
  834. 0) FREEDNS_SUBDOMAIN_CODE=$(cat $data);;
  835. 1) exit 0;;
  836. 255) exit 0;;
  837. esac
  838. done
  839. fi
  840. fi
  841. while [ ! $MY_EMAIL_ADDRESS ]
  842. do
  843. data=$(tempfile 2>/dev/null)
  844. trap "rm -f $data" 0 1 2 5 15
  845. dialog --backtitle "Freedombone Configuration" \
  846. --inputbox "Your email address" 10 30 "$MY_USERNAME@$DOMAIN_NAME" 2> $data
  847. sel=$?
  848. case $sel in
  849. 0) MY_EMAIL_ADDRESS=$(cat $data);;
  850. 1) exit 0;;
  851. 255) exit 0;;
  852. esac
  853. done
  854. save_configuration_file
  855. FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
  856. dialog --title "Encrypted backup to other servers" \
  857. --backtitle "Freedombone Configuration" \
  858. --defaultno \
  859. --yesno "\nDo you wish to configure some remote backup locations?" 7 60
  860. sel=$?
  861. case $sel in
  862. 0) interactive_configuration_remote_backups;;
  863. esac
  864. }
  865. if [[ $1 == "menuconfig" ]]; then
  866. interactive_configuration
  867. else
  868. # Oddly it appears that command line parsing cannot be done inside of a function
  869. while [[ $# > 1 ]]
  870. do
  871. key="$1"
  872. case $key in
  873. -h|--help)
  874. show_help
  875. ;;
  876. # username within /home
  877. -u|--user)
  878. shift
  879. MY_USERNAME="$1"
  880. ;;
  881. # microblog domain name
  882. --microblogdomain)
  883. shift
  884. MICROBLOG_DOMAIN_NAME="$1"
  885. ;;
  886. # microblog domain code (freedns)
  887. --microblogcode)
  888. shift
  889. MICROBLOG_FREEDNS_SUBDOMAIN_CODE="$1"
  890. ;;
  891. # wiki domain name
  892. --wikidomain)
  893. shift
  894. WIKI_DOMAIN_NAME="$1"
  895. ;;
  896. # wiki domain code (freedns)
  897. --wikicode)
  898. shift
  899. WIKI_FREEDNS_SUBDOMAIN_CODE="$1"
  900. ;;
  901. # blog domain name
  902. --blogdomain)
  903. shift
  904. FULLBLOG_DOMAIN_NAME="$1"
  905. ;;
  906. # blog domain code (freedns)
  907. --blogcode)
  908. shift
  909. FULLBLOG_FREEDNS_SUBDOMAIN_CODE="$1"
  910. ;;
  911. # owncloud domain name
  912. --ownclouddomain)
  913. shift
  914. OWNCLOUD_DOMAIN_NAME="$1"
  915. ;;
  916. # owncloud domain code (freedns)
  917. --owncloudcode)
  918. shift
  919. OWNCLOUD_FREEDNS_SUBDOMAIN_CODE="$1"
  920. ;;
  921. # redmatrix domain name
  922. --redmatrixdomain)
  923. shift
  924. REDMATRIX_DOMAIN_NAME="$1"
  925. ;;
  926. # redmatrix domain code (freedns)
  927. --redmatrixcode)
  928. shift
  929. REDMATRIX_FREEDNS_SUBDOMAIN_CODE="$1"
  930. ;;
  931. # default domain name
  932. -d|--domain)
  933. shift
  934. DOMAIN_NAME="$1"
  935. ;;
  936. # default domain code (freedns)
  937. -c|--code)
  938. shift
  939. FREEDNS_SUBDOMAIN_CODE="$1"
  940. ;;
  941. # The type of system
  942. -s|--system)
  943. shift
  944. SYSTEM_TYPE="$1"
  945. ;;
  946. # The dynamic DNS provider
  947. --ddns)
  948. shift
  949. DDNS_PROVIDER="$1"
  950. ;;
  951. # Username for the synamic DNS provider
  952. --ddnsuser)
  953. shift
  954. DDNS_USERNAME="$1"
  955. ;;
  956. # Password for the synamic DNS provider
  957. --ddnspass)
  958. shift
  959. DDNS_PASSWORD="$1"
  960. ;;
  961. # Whether this installation is on a Beaglebone Black
  962. --bbb)
  963. INSTALLING_ON_BBB="yes"
  964. ;;
  965. # Domain name to use as a TLS time source
  966. -t|--time)
  967. shift
  968. TLS_TIME_SOURCE1="$1"
  969. ;;
  970. # Static IP address for the system
  971. --ip)
  972. shift
  973. LOCAL_NETWORK_STATIC_IP_ADDRESS=$1
  974. ;;
  975. # IP address for the internet router
  976. --iprouter)
  977. shift
  978. ROUTER_IP_ADDRESS=$1
  979. ;;
  980. # ssh port
  981. --ssh)
  982. shift
  983. SSH_PORT=$1
  984. ;;
  985. # public mailing list name
  986. --list)
  987. shift
  988. PUBLIC_MAILING_LIST="$1"
  989. ;;
  990. # Number of CPU cores
  991. --cores)
  992. shift
  993. CPU_CORES=$1
  994. ;;
  995. # my name
  996. --name)
  997. shift
  998. MY_NAME="$1"
  999. ;;
  1000. # my email address
  1001. --email)
  1002. shift
  1003. MY_EMAIL_ADDRESS="$1"
  1004. ;;
  1005. # USB drive
  1006. --usb)
  1007. shift
  1008. USB_DRIVE=$1
  1009. ;;
  1010. # Enable CJDNS
  1011. --cjdns)
  1012. shift
  1013. ENABLE_CJDNS="yes"
  1014. ;;
  1015. *)
  1016. # unknown option
  1017. ;;
  1018. esac
  1019. shift
  1020. done
  1021. fi
  1022. function parse_args {
  1023. if [[ $NO_OF_ARGS == 0 ]]; then
  1024. show_help
  1025. exit 0
  1026. fi
  1027. if [ ! -d /home/$MY_USERNAME ]; then
  1028. echo "There is no user '$MY_USERNAME' on the system. Use 'adduser $MY_USERNAME' to create the user."
  1029. exit 1
  1030. fi
  1031. if [ ! $DOMAIN_NAME ]; then
  1032. show_help
  1033. exit 2
  1034. fi
  1035. if [ ! $MY_USERNAME ]; then
  1036. show_help
  1037. exit 3
  1038. fi
  1039. if [ ! $DDNS_USERNAME ]; then
  1040. echo 'Please provide the username for your dynamic DNS provider with the --ddnsuser option'
  1041. exit 7823
  1042. fi
  1043. if [ ! $DDNS_PASSWORD ]; then
  1044. echo 'Please provide the password for your dynamic DNS provider with the --ddnspass option'
  1045. exit 6382
  1046. fi
  1047. if [[ $DDNS_PROVIDER == "default@freedns.afraid.org" ]]; then
  1048. if [ ! $FREEDNS_SUBDOMAIN_CODE ]; then
  1049. show_help
  1050. exit 4
  1051. fi
  1052. fi
  1053. if [ ! $SYSTEM_TYPE ]; then
  1054. SYSTEM_TYPE=$VARIANT_FULL
  1055. fi
  1056. if [[ $SYSTEM_TYPE != $VARIANT_WRITER && $SYSTEM_TYPE != $VARIANT_CLOUD && $SYSTEM_TYPE != $VARIANT_CHAT && $SYSTEM_TYPE != $VARIANT_MAILBOX && $SYSTEM_TYPE != $VARIANT_NONMAILBOX && $SYSTEM_TYPE != $VARIANT_SOCIAL && $SYSTEM_TYPE != $VARIANT_MEDIA && $SYSTEM_TYPE != $VARIANT_TOR_DONGLE && $SYSTEM_TYPE != $VARIANT_FULL ]]; then
  1057. echo "'$SYSTEM_TYPE' is an unrecognised Freedombone variant."
  1058. exit 30
  1059. fi
  1060. }
  1061. function read_configuration {
  1062. # if not installing on a Beaglebone then use sdb as the USB drive by default
  1063. if [ ! $INSTALLING_ON_BBB ]; then
  1064. if [[ $USB_DRIVE == /dev/sda1 ]]; then
  1065. USB_DRIVE=/dev/sdb1
  1066. fi
  1067. fi
  1068. if [ -f $CONFIGURATION_FILE ]; then
  1069. if grep -q "DDNS_PROVIDER" $CONFIGURATION_FILE; then
  1070. DDNS_PROVIDER=$(grep "DDNS_PROVIDER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1071. fi
  1072. if grep -q "DDNS_USERNAME" $CONFIGURATION_FILE; then
  1073. DDNS_USERNAME=$(grep "DDNS_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1074. fi
  1075. if grep -q "DDNS_PASSWORD" $CONFIGURATION_FILE; then
  1076. DDNS_PASSWORD=$(grep "DDNS_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1077. fi
  1078. if grep -q "LOCAL_NETWORK_STATIC_IP_ADDRESS" $CONFIGURATION_FILE; then
  1079. LOCAL_NETWORK_STATIC_IP_ADDRESS=$(grep "LOCAL_NETWORK_STATIC_IP_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1080. fi
  1081. if grep -q "ENABLE_CJDNS" $CONFIGURATION_FILE; then
  1082. ENABLE_CJDNS=$(grep "ENABLE_CJDNS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1083. fi
  1084. if grep -q "CJDNS_IPV6" $CONFIGURATION_FILE; then
  1085. CJDNS_IPV6=$(grep "CJDNS_IPV6" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1086. fi
  1087. if grep -q "CJDNS_PUBLIC_KEY" $CONFIGURATION_FILE; then
  1088. CJDNS_PUBLIC_KEY=$(grep "CJDNS_PUBLIC_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1089. fi
  1090. if grep -q "CJDNS_PRIVATE_KEY" $CONFIGURATION_FILE; then
  1091. CJDNS_PRIVATE_KEY=$(grep "CJDNS_PRIVATE_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1092. fi
  1093. if grep -q "BACKUP_CERTIFICATE" $CONFIGURATION_FILE; then
  1094. BACKUP_CERTIFICATE=$(grep "BACKUP_CERTIFICATE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1095. fi
  1096. if grep -q "ROUTER_IP_ADDRESS" $CONFIGURATION_FILE; then
  1097. ROUTER_IP_ADDRESS=$(grep "ROUTER_IP_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1098. fi
  1099. if grep -q "GITHUB_USERNAME" $CONFIGURATION_FILE; then
  1100. GITHUB_USERNAME=$(grep "GITHUB_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1101. fi
  1102. if grep -q "GITHUB_BACKUP_DIRECTORY" $CONFIGURATION_FILE; then
  1103. GITHUB_BACKUP_DIRECTORY=$(grep "GITHUB_BACKUP_DIRECTORY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1104. fi
  1105. if grep -q "CPU_CORES" $CONFIGURATION_FILE; then
  1106. CPU_CORES=$(grep "CPU_CORES" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1107. fi
  1108. if grep -q "WEBSERVER_LOG_LEVEL" $CONFIGURATION_FILE; then
  1109. WEBSERVER_LOG_LEVEL=$(grep "WEBSERVER_LOG_LEVEL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1110. fi
  1111. if grep -q "ROUTE_THROUGH_TOR" $CONFIGURATION_FILE; then
  1112. ROUTE_THROUGH_TOR=$(grep "ROUTE_THROUGH_TOR" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1113. fi
  1114. if grep -q "WIKI_TITLE" $CONFIGURATION_FILE; then
  1115. WIKI_TITLE=$(grep "WIKI_TITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1116. fi
  1117. if grep -q "MY_NAME" $CONFIGURATION_FILE; then
  1118. MY_NAME=$(grep "MY_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1119. fi
  1120. if grep -q "MY_EMAIL_ADDRESS" $CONFIGURATION_FILE; then
  1121. MY_EMAIL_ADDRESS=$(grep "MY_EMAIL_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1122. fi
  1123. if grep -q "INSTALLING_ON_BBB" $CONFIGURATION_FILE; then
  1124. INSTALLING_ON_BBB=$(grep "INSTALLING_ON_BBB" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1125. fi
  1126. if grep -q "SSH_PORT" $CONFIGURATION_FILE; then
  1127. SSH_PORT=$(grep "SSH_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1128. fi
  1129. if grep -q "INSTALLED_WITHIN_DOCKER" $CONFIGURATION_FILE; then
  1130. INSTALLED_WITHIN_DOCKER=$(grep "INSTALLED_WITHIN_DOCKER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1131. fi
  1132. if grep -q "PUBLIC_MAILING_LIST" $CONFIGURATION_FILE; then
  1133. PUBLIC_MAILING_LIST=$(grep "PUBLIC_MAILING_LIST" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1134. fi
  1135. if grep -q "MICROBLOG_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1136. MICROBLOG_DOMAIN_NAME=$(grep "MICROBLOG_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1137. fi
  1138. if grep -q "MICROBLOG_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE; then
  1139. MICROBLOG_FREEDNS_SUBDOMAIN_CODE=$(grep "MICROBLOG_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1140. fi
  1141. if grep -q "REDMATRIX_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1142. REDMATRIX_DOMAIN_NAME=$(grep "REDMATRIX_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1143. fi
  1144. if grep -q "REDMATRIX_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE; then
  1145. REDMATRIX_FREEDNS_SUBDOMAIN_CODE=$(grep "REDMATRIX_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1146. fi
  1147. if grep -q "OWNCLOUD_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1148. OWNCLOUD_DOMAIN_NAME=$(grep "OWNCLOUD_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1149. fi
  1150. if grep -q "OWNCLOUD_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE; then
  1151. OWNCLOUD_FREEDNS_SUBDOMAIN_CODE=$(grep "OWNCLOUD_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1152. fi
  1153. if grep -q "WIKI_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1154. WIKI_DOMAIN_NAME=$(grep "WIKI_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1155. fi
  1156. if grep -q "WIKI_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE; then
  1157. WIKI_FREEDNS_SUBDOMAIN_CODE=$(grep "WIKI_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1158. fi
  1159. if grep -q "FULLBLOG_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1160. FULLBLOG_DOMAIN_NAME=$(grep "FULLBLOG_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1161. fi
  1162. if grep -q "FULLBLOG_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE; then
  1163. FULLBLOG_FREEDNS_SUBDOMAIN_CODE=$(grep "FULLBLOG_FREEDNS_SUBDOMAIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1164. fi
  1165. if grep -q "MY_BLOG_TITLE" $CONFIGURATION_FILE; then
  1166. MY_BLOG_TITLE=$(grep "MY_BLOG_TITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1167. fi
  1168. if grep -q "MY_BLOG_SUBTITLE" $CONFIGURATION_FILE; then
  1169. MY_BLOG_SUBTITLE=$(grep "MY_BLOG_SUBTITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1170. fi
  1171. if grep -q "GPG_ENCRYPT_STORED_EMAIL" $CONFIGURATION_FILE; then
  1172. GPG_ENCRYPT_STORED_EMAIL=$(grep "GPG_ENCRYPT_STORED_EMAIL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1173. fi
  1174. if grep -q "MY_GPG_PUBLIC_KEY" $CONFIGURATION_FILE; then
  1175. MY_GPG_PUBLIC_KEY=$(grep "MY_GPG_PUBLIC_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1176. fi
  1177. if grep -q "MY_GPG_PRIVATE_KEY" $CONFIGURATION_FILE; then
  1178. MY_GPG_PRIVATE_KEY=$(grep "MY_GPG_PRIVATE_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1179. fi
  1180. if grep -q "MY_GPG_PUBLIC_KEY_ID" $CONFIGURATION_FILE; then
  1181. MY_GPG_PUBLIC_KEY_ID=$(grep "MY_GPG_PUBLIC_KEY_ID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1182. fi
  1183. if grep -q "USB_DRIVE" $CONFIGURATION_FILE; then
  1184. USB_DRIVE=$(grep "USB_DRIVE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1185. fi
  1186. if grep -q "MAX_PHP_MEMORY" $CONFIGURATION_FILE; then
  1187. MAX_PHP_MEMORY=$(grep "MAX_PHP_MEMORY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1188. fi
  1189. if grep -q "TLS_TIME_SOURCE1" $CONFIGURATION_FILE; then
  1190. TLS_TIME_SOURCE1=$(grep "TLS_TIME_SOURCE1" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1191. fi
  1192. if grep -q "TLS_TIME_SOURCE2" $CONFIGURATION_FILE; then
  1193. TLS_TIME_SOURCE2=$(grep "TLS_TIME_SOURCE2" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1194. fi
  1195. fi
  1196. }
  1197. function install_not_on_BBB {
  1198. if grep -Fxq "install_not_on_BBB" $COMPLETION_FILE; then
  1199. return
  1200. fi
  1201. if [[ INSTALLING_ON_BBB == "yes" ]]; then
  1202. return
  1203. fi
  1204. echo '# This file describes the network interfaces available on your system' > /etc/network/interfaces
  1205. echo '# and how to activate them. For more information, see interfaces(5).' >> /etc/network/interfaces
  1206. echo '' >> /etc/network/interfaces
  1207. echo '# The loopback network interface' >> /etc/network/interfaces
  1208. echo 'auto lo' >> /etc/network/interfaces
  1209. echo 'iface lo inet loopback' >> /etc/network/interfaces
  1210. echo '' >> /etc/network/interfaces
  1211. echo '# The primary network interface' >> /etc/network/interfaces
  1212. echo 'auto eth0' >> /etc/network/interfaces
  1213. echo 'iface eth0 inet static' >> /etc/network/interfaces
  1214. echo " address $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/network/interfaces
  1215. echo ' netmask 255.255.255.0' >> /etc/network/interfaces
  1216. echo " gateway $ROUTER_IP_ADDRESS" >> /etc/network/interfaces
  1217. echo ' dns-nameservers 213.73.91.35 85.214.20.141' >> /etc/network/interfaces
  1218. echo '# Example to keep MAC address between reboots' >> /etc/network/interfaces
  1219. echo '#hwaddress ether DE:AD:BE:EF:CA:FE' >> /etc/network/interfaces
  1220. echo '' >> /etc/network/interfaces
  1221. echo '# The secondary network interface' >> /etc/network/interfaces
  1222. echo '#auto eth1' >> /etc/network/interfaces
  1223. echo '#iface eth1 inet dhcp' >> /etc/network/interfaces
  1224. echo '' >> /etc/network/interfaces
  1225. echo '# WiFi Example' >> /etc/network/interfaces
  1226. echo '#auto wlan0' >> /etc/network/interfaces
  1227. echo '#iface wlan0 inet dhcp' >> /etc/network/interfaces
  1228. echo '# wpa-ssid "essid"' >> /etc/network/interfaces
  1229. echo '# wpa-psk "password"' >> /etc/network/interfaces
  1230. echo '' >> /etc/network/interfaces
  1231. echo '# Ethernet/RNDIS gadget (g_ether)' >> /etc/network/interfaces
  1232. echo '# ... or on host side, usbnet and random hwaddr' >> /etc/network/interfaces
  1233. echo '# Note on some boards, usb0 is automaticly setup with an init script' >> /etc/network/interfaces
  1234. echo '#iface usb0 inet static' >> /etc/network/interfaces
  1235. echo '# address 192.168.7.2' >> /etc/network/interfaces
  1236. echo '# netmask 255.255.255.0' >> /etc/network/interfaces
  1237. echo '# network 192.168.7.0' >> /etc/network/interfaces
  1238. echo '# gateway 192.168.7.1' >> /etc/network/interfaces
  1239. echo 'install_not_on_BBB' >> $COMPLETION_FILE
  1240. }
  1241. function get_cjdns_public_key {
  1242. if [ -f /home/$MY_USERNAME/README ]; then
  1243. if grep -q "cjdns public key" /home/$MY_USERNAME/README; then
  1244. if [ ! $CJDNS_PUBLIC_KEY ]; then
  1245. CJDNS_PUBLIC_KEY=$(cat /home/$MY_USERNAME/README | grep "cjdns public key" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1246. fi
  1247. fi
  1248. fi
  1249. }
  1250. function get_cjdns_private_key {
  1251. if [ -f /home/$MY_USERNAME/README ]; then
  1252. if grep -q "cjdns private key" /home/$MY_USERNAME/README; then
  1253. if [ ! $CJDNS_PRIVATE_KEY ]; then
  1254. CJDNS_PRIVATE_KEY=$(cat /home/$MY_USERNAME/README | grep "cjdns private key" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1255. fi
  1256. fi
  1257. fi
  1258. }
  1259. function get_cjdns_ipv6_address {
  1260. if [ -f /home/$MY_USERNAME/README ]; then
  1261. if grep -q "cjdns IPv6 address" /home/$MY_USERNAME/README; then
  1262. if [ ! $CJDNS_IPV6 ]; then
  1263. CJDNS_IPV6=$(cat /home/$MY_USERNAME/README | grep "cjdns IPv6 address" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1264. fi
  1265. fi
  1266. fi
  1267. }
  1268. function get_cjdns_port {
  1269. if [ -f /home/$MY_USERNAME/README ]; then
  1270. if grep -q "cjdns port" /home/$MY_USERNAME/README; then
  1271. if [ ! $CJDNS_PORT ]; then
  1272. CJDNS_PORT=$(cat /home/$MY_USERNAME/README | grep "cjdns port" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1273. fi
  1274. fi
  1275. fi
  1276. }
  1277. function get_cjdns_password {
  1278. if [ -f /home/$MY_USERNAME/README ]; then
  1279. if grep -q "cjdns password" /home/$MY_USERNAME/README; then
  1280. if [ ! $CJDNS_PASSWORD ]; then
  1281. CJDNS_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "cjdns password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1282. fi
  1283. fi
  1284. fi
  1285. }
  1286. function install_cjdns {
  1287. if grep -Fxq "install_cjdns" $COMPLETION_FILE; then
  1288. return
  1289. fi
  1290. if [[ $ENABLE_CJDNS != "yes" ]]; then
  1291. return
  1292. fi
  1293. apt-get -y install nodejs git build-essential nmap
  1294. # if a README exists then obtain the cjdns parameters
  1295. get_cjdns_ipv6_address
  1296. get_cjdns_public_key
  1297. get_cjdns_private_key
  1298. get_cjdns_port
  1299. get_cjdns_password
  1300. # special compile settings for running ./do on the Beaglebone Black
  1301. if [[ $INSTALLING_ON_BBB == "yes" ]]; then
  1302. CFLAGS="-O2 -march=armv7-a -mtune=cortex-a8 -mfpu=neon -ftree-vectorize -ffast-math -mfloat-abi=hard -marm -Wno-error=maybe-uninitialized"
  1303. export LDFLAGS="$CFLAGS"
  1304. fi
  1305. if [ ! -d /etc/cjdns ]; then
  1306. git clone https://github.com/cjdelisle/cjdns.git /etc/cjdns
  1307. cd /etc/cjdns
  1308. ./do
  1309. if [ ! "$?" = "0" ]; then
  1310. exit 7439
  1311. fi
  1312. # create a configuration
  1313. if [ ! -f /etc/cjdns/cjdroute.conf ]; then
  1314. ./cjdroute --genconf > /etc/cjdns/cjdroute.conf
  1315. if [ ! "$?" = "0" ]; then
  1316. exit 5922
  1317. fi
  1318. fi
  1319. # create a user to run as
  1320. useradd cjdns
  1321. else
  1322. cd /etc/cjdns
  1323. git pull
  1324. ./do
  1325. if [ ! "$?" = "0" ]; then
  1326. exit 9926
  1327. fi
  1328. fi
  1329. # set permissions
  1330. chown -R cjdns:cjdns /etc/cjdns
  1331. chmod 600 /etc/cjdns/cjdroute.conf
  1332. /sbin/ip tuntap add mode tun user cjdns dev cjdroute0
  1333. # insert values into the configuration file
  1334. if [ $CJDNS_PRIVATE_KEY ]; then
  1335. sed -i "s/\"privateKey\":.*/\"privateKey\": \"$CJDNS_PRIVATE_KEY\",/g" /etc/cjdns/cjdroute.conf
  1336. else
  1337. CJDNS_PRIVATE_KEY=$(cat /etc/cjdns/cjdroute.conf | grep '"privateKey"' | awk -F '"' '{print $4}' | sed -n 1p)
  1338. fi
  1339. if [ $CJDNS_PUBLIC_KEY ]; then
  1340. sed -i "s/\"publicKey\":.*/\"publicKey\": \"$CJDNS_PUBLIC_KEY\",/g" /etc/cjdns/cjdroute.conf
  1341. else
  1342. CJDNS_PUBLIC_KEY=$(cat /etc/cjdns/cjdroute.conf | grep '"publicKey"' | awk -F '"' '{print $4}' | sed -n 1p)
  1343. fi
  1344. if [ $CJDNS_IPV6 ]; then
  1345. sed -i "s/\"ipv6\":.*/\"ipv6\": \"$CJDNS_IPV6\",/g" /etc/cjdns/cjdroute.conf
  1346. else
  1347. CJDNS_IPV6=$(cat /etc/cjdns/cjdroute.conf | grep '"ipv6"' | awk -F '"' '{print $4}' | sed -n 1p)
  1348. fi
  1349. if [ $CJDNS_PASSWORD ]; then
  1350. sed -i "0,/{\"password\":.*/s//{\"password\": \"$CJDNS_PASSWORD\"}/g" /etc/cjdns/cjdroute.conf
  1351. else
  1352. CJDNS_PASSWORD=$(cat /etc/cjdns/cjdroute.conf | grep '"password"' | awk -F '"' '{print $4}' | sed -n 1p)
  1353. fi
  1354. if [ $CJDNS_PORT ]; then
  1355. sed -i "s/\"bind\": \"0.0.0.0:.*/\"bind\": \"0.0.0.0:$CJDNS_PORT\",/g" /etc/cjdns/cjdroute.conf
  1356. else
  1357. CJDNS_PORT=$(cat /etc/cjdns/cjdroute.conf | grep '"bind": "0.0.0.0:' | awk -F '"' '{print $4}' | awk -F ':' '{print $2}' | sed -n 1p)
  1358. fi
  1359. # endure that ipv6 is enabled and can route
  1360. sed -i 's/net.ipv6.conf.all.disable_ipv6.*/net.ipv6.conf.all.disable_ipv6 = 0/g' /etc/sysctl.conf
  1361. #sed -i "s/net.ipv6.conf.all.accept_redirects.*/net.ipv6.conf.all.accept_redirects = 1/g" /etc/sysctl.conf
  1362. #sed -i "s/net.ipv6.conf.all.accept_source_route.*/net.ipv6.conf.all.accept_source_route = 1/g" /etc/sysctl.conf
  1363. sed -i "s/net.ipv6.conf.all.forwarding.*/net.ipv6.conf.all.forwarding=1/g" /etc/sysctl.conf
  1364. echo 1 > /proc/sys/net/ipv6/conf/all/forwarding
  1365. echo '#!/bin/sh -e' > /etc/init.d/cjdns
  1366. echo '### BEGIN INIT INFO' >> /etc/init.d/cjdns
  1367. echo '# hyperboria.sh - An init script (/etc/init.d/) for cjdns' >> /etc/init.d/cjdns
  1368. echo '# Provides: cjdroute' >> /etc/init.d/cjdns
  1369. echo '# Required-Start: $remote_fs $network' >> /etc/init.d/cjdns
  1370. echo '# Required-Stop: $remote_fs $network' >> /etc/init.d/cjdns
  1371. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/cjdns
  1372. echo '# Default-Stop: 0 1 6' >> /etc/init.d/cjdns
  1373. echo '# Short-Description: Cjdns router' >> /etc/init.d/cjdns
  1374. echo '# Description: A routing engine designed for security, scalability, speed and ease of use.' >> /etc/init.d/cjdns
  1375. echo '# cjdns git repo: https://github.com/cjdelisle/cjdns/' >> /etc/init.d/cjdns
  1376. echo '### END INIT INFO' >> /etc/init.d/cjdns
  1377. echo '' >> /etc/init.d/cjdns
  1378. echo 'PROG="cjdroute"' >> /etc/init.d/cjdns
  1379. echo 'GIT_PATH="/etc/cjdns"' >> /etc/init.d/cjdns
  1380. echo 'PROG_PATH="/etc/cjdns"' >> /etc/init.d/cjdns
  1381. echo 'CJDNS_CONFIG="cjdroute.conf"' >> /etc/init.d/cjdns
  1382. echo 'CJDNS_USER="cjdns"' >> /etc/init.d/cjdns
  1383. echo "CJDNS_IP='$CJDNS_IPV6'" >> /etc/init.d/cjdns
  1384. echo '' >> /etc/init.d/cjdns
  1385. echo 'start() {' >> /etc/init.d/cjdns
  1386. echo ' # Start it up with the user cjdns' >> /etc/init.d/cjdns
  1387. echo ' if [ $(pgrep cjdroute | wc -l) != 0 ];' >> /etc/init.d/cjdns
  1388. echo ' then' >> /etc/init.d/cjdns
  1389. echo ' echo "cjdroute is already running. Doing nothing..."' >> /etc/init.d/cjdns
  1390. echo ' else' >> /etc/init.d/cjdns
  1391. echo ' echo " * Starting cjdroute"' >> /etc/init.d/cjdns
  1392. echo ' su -c "$PROG_PATH/$PROG < $PROG_PATH/$CJDNS_CONFIG" - $CJDNS_USER' >> /etc/init.d/cjdns
  1393. echo ' /sbin/ip addr add $CJDNS_IP/8 dev tun0' >> /etc/init.d/cjdns
  1394. echo ' /sbin/ip link set mtu 1312 dev tun0' >> /etc/init.d/cjdns
  1395. echo ' /sbin/ip link set tun0 up' >> /etc/init.d/cjdns
  1396. echo ' /sbin/ip tuntap add mode tun user cjdns dev tun0' >> /etc/init.d/cjdns
  1397. echo ' fi' >> /etc/init.d/cjdns
  1398. echo '}' >> /etc/init.d/cjdns
  1399. echo '' >> /etc/init.d/cjdns
  1400. echo 'stop() {' >> /etc/init.d/cjdns
  1401. echo '' >> /etc/init.d/cjdns
  1402. echo ' if [ $(pgrep cjdroute | wc -l) != 2 ];' >> /etc/init.d/cjdns
  1403. echo ' then' >> /etc/init.d/cjdns
  1404. echo ' echo "cjdns isnt running."' >> /etc/init.d/cjdns
  1405. echo ' else' >> /etc/init.d/cjdns
  1406. echo ' echo "Killing cjdroute"' >> /etc/init.d/cjdns
  1407. echo ' killall cjdroute' >> /etc/init.d/cjdns
  1408. echo ' fi' >> /etc/init.d/cjdns
  1409. echo '}' >> /etc/init.d/cjdns
  1410. echo '' >> /etc/init.d/cjdns
  1411. echo 'status() {' >> /etc/init.d/cjdns
  1412. echo ' if [ $(pgrep cjdroute | wc -l) != 0 ];' >> /etc/init.d/cjdns
  1413. echo ' then' >> /etc/init.d/cjdns
  1414. echo ' echo "Cjdns is running"' >> /etc/init.d/cjdns
  1415. echo ' else' >> /etc/init.d/cjdns
  1416. echo ' echo "Cjdns is not running"' >> /etc/init.d/cjdns
  1417. echo ' fi' >> /etc/init.d/cjdns
  1418. echo '}' >> /etc/init.d/cjdns
  1419. echo '' >> /etc/init.d/cjdns
  1420. echo ' update() {' >> /etc/init.d/cjdns
  1421. echo ' cd $GIT_PATH' >> /etc/init.d/cjdns
  1422. echo ' echo "Updating..."' >> /etc/init.d/cjdns
  1423. echo ' git pull' >> /etc/init.d/cjdns
  1424. echo ' ./do' >> /etc/init.d/cjdns
  1425. echo '}' >> /etc/init.d/cjdns
  1426. echo '' >> /etc/init.d/cjdns
  1427. echo '## Check to see if we are running as root first.' >> /etc/init.d/cjdns
  1428. echo 'if [ "$(id -u)" != "0" ]; then' >> /etc/init.d/cjdns
  1429. echo ' echo "This script must be run as root" 1>&2' >> /etc/init.d/cjdns
  1430. echo ' exit 1' >> /etc/init.d/cjdns
  1431. echo 'fi' >> /etc/init.d/cjdns
  1432. echo '' >> /etc/init.d/cjdns
  1433. echo 'case $1 in' >> /etc/init.d/cjdns
  1434. echo ' start)' >> /etc/init.d/cjdns
  1435. echo ' start' >> /etc/init.d/cjdns
  1436. echo ' exit 0' >> /etc/init.d/cjdns
  1437. echo ' ;;' >> /etc/init.d/cjdns
  1438. echo ' stop)' >> /etc/init.d/cjdns
  1439. echo ' stop' >> /etc/init.d/cjdns
  1440. echo ' exit 0' >> /etc/init.d/cjdns
  1441. echo ' ;;' >> /etc/init.d/cjdns
  1442. echo ' reload|restart|force-reload)' >> /etc/init.d/cjdns
  1443. echo ' stop' >> /etc/init.d/cjdns
  1444. echo ' sleep 1' >> /etc/init.d/cjdns
  1445. echo ' start' >> /etc/init.d/cjdns
  1446. echo ' exit 0' >> /etc/init.d/cjdns
  1447. echo ' ;;' >> /etc/init.d/cjdns
  1448. echo ' status)' >> /etc/init.d/cjdns
  1449. echo ' status' >> /etc/init.d/cjdns
  1450. echo ' exit 0' >> /etc/init.d/cjdns
  1451. echo ' ;;' >> /etc/init.d/cjdns
  1452. echo ' update|upgrade)' >> /etc/init.d/cjdns
  1453. echo ' update' >> /etc/init.d/cjdns
  1454. echo ' stop' >> /etc/init.d/cjdns
  1455. echo ' sleep 2' >> /etc/init.d/cjdns
  1456. echo ' start' >> /etc/init.d/cjdns
  1457. echo ' exit 0' >> /etc/init.d/cjdns
  1458. echo ' ;;' >> /etc/init.d/cjdns
  1459. echo ' **)' >> /etc/init.d/cjdns
  1460. echo ' echo "Usage: $0 (start|stop|restart|status|update)" 1>&2' >> /etc/init.d/cjdns
  1461. echo ' exit 1' >> /etc/init.d/cjdns
  1462. echo ' ;;' >> /etc/init.d/cjdns
  1463. echo 'esac' >> /etc/init.d/cjdns
  1464. chmod +x /etc/init.d/cjdns
  1465. update-rc.d cjdns defaults
  1466. service cjdns start
  1467. if [ ! "$?" = "0" ]; then
  1468. systemctl status cjdns.service
  1469. exit 8260
  1470. fi
  1471. apt-get -y install radvd
  1472. echo 'interface eth0' > /etc/radvd.conf
  1473. echo '{' >> /etc/radvd.conf
  1474. echo ' AdvSendAdvert on;' >> /etc/radvd.conf
  1475. echo ' prefix fdfc::1/64' >> /etc/radvd.conf
  1476. echo ' {' >> /etc/radvd.conf
  1477. echo ' AdvRouterAddr on;' >> /etc/radvd.conf
  1478. echo ' };' >> /etc/radvd.conf
  1479. echo '};' >> /etc/radvd.conf
  1480. service radvd restart
  1481. if [ ! "$?" = "0" ]; then
  1482. systemctl status radvd.service
  1483. exit 4395
  1484. fi
  1485. if ! grep -q "# Mesh network" /etc/network/interfaces; then
  1486. echo '' >> /etc/network/interfaces
  1487. echo '# Mesh network' >> /etc/network/interfaces
  1488. echo 'iface eth0 inet6 static' >> /etc/network/interfaces
  1489. echo ' pre-up modprobe ipv6' >> /etc/network/interfaces
  1490. echo ' address fdfc:0000:0000:0000:0000:0000:0000:0001' >> /etc/network/interfaces
  1491. echo ' netmask 64' >> /etc/network/interfaces
  1492. service networking restart
  1493. if [ ! "$?" = "0" ]; then
  1494. systemctl status networking.service
  1495. exit 6949
  1496. fi
  1497. fi
  1498. ip6tables -A INPUT -i eth0 -p udp --dport $CJDNS_PORT -j ACCEPT
  1499. ip6tables -A INPUT -i eth0 -p tcp --dport $CJDNS_PORT -j ACCEPT
  1500. save_firewall_settings
  1501. if ! grep -q "Mesh Networking" /home/$MY_USERNAME/README; then
  1502. CURRENT_IP_ADDRESS=$(ip addr show | grep "inet " | sed -n 2p | awk -F ' ' '{print $2}' | awk -F '/' '{print $1}')
  1503. echo '' >> /home/$MY_USERNAME/README
  1504. echo '' >> /home/$MY_USERNAME/README
  1505. echo 'Mesh Networking' >> /home/$MY_USERNAME/README
  1506. echo '===============' >> /home/$MY_USERNAME/README
  1507. echo "cjdns IPv6 address: $CJDNS_IPV6" >> /home/$MY_USERNAME/README
  1508. echo "cjdns public key: $CJDNS_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  1509. echo "cjdns private key: $CJDNS_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  1510. echo "cjdns password: $CJDNS_PASSWORD" >> /home/$MY_USERNAME/README
  1511. echo "cjdns port: $CJDNS_PORT" >> /home/$MY_USERNAME/README
  1512. echo '' >> /home/$MY_USERNAME/README
  1513. echo "Forward port $CJDNS_PORT from your internet router to the Freedombone" >> /home/$MY_USERNAME/README
  1514. echo '' >> /home/$MY_USERNAME/README
  1515. echo 'Below is an example of your connection credentials' >> /home/$MY_USERNAME/README
  1516. echo 'that you can give to other people so they can connect' >> /home/$MY_USERNAME/README
  1517. echo 'to you using your default password' >> /home/$MY_USERNAME/README
  1518. echo 'Adding a unique password for each user is advisable' >> /home/$MY_USERNAME/README
  1519. echo 'so that leaks can be isolated.' >> /home/$MY_USERNAME/README
  1520. echo '' >> /home/$MY_USERNAME/README
  1521. echo "\"$CURRENT_IP_ADDRESS:$CJDNS_PORT\":{\"password\":\"$CJDNS_PASSWORD\",\"publicKey\":\"$CJDNS_PUBLIC_KEY\"}" >> /home/$MY_USERNAME/README
  1522. echo '' >> /home/$MY_USERNAME/README
  1523. echo 'More is not better. 3-5 cjdns peers is good. 30 peers is bad.' >> /home/$MY_USERNAME/README
  1524. echo '' >> /home/$MY_USERNAME/README
  1525. echo 'NEVER USE A PUBLIC PEER. These degrade the network and make it centralized.' >> /home/$MY_USERNAME/README
  1526. echo 'Each node can handle many peers, but no node can handle the entire internet.' >> /home/$MY_USERNAME/README
  1527. echo 'As this network grows any public peer will simply become saturated and' >> /home/$MY_USERNAME/README
  1528. echo 'useless causing issues for the entire network.' >> /home/$MY_USERNAME/README
  1529. echo 'Please report anyone offering you a public peer as they are promoting shared' >> /home/$MY_USERNAME/README
  1530. echo 'passwords which could lead to people pretending to be you. A peering pass' >> /home/$MY_USERNAME/README
  1531. echo 'should not contain someone elses nickname or info but should contain yours' >> /home/$MY_USERNAME/README
  1532. echo 'to ensure it is not shared. It also helps when editing the conf to know who' >> /home/$MY_USERNAME/README
  1533. echo 'each password is for.' >> /home/$MY_USERNAME/README
  1534. echo '' >> /home/$MY_USERNAME/README
  1535. echo 'Possible cjdns destinations of interest:' >> /home/$MY_USERNAME/README
  1536. echo ' http://transitiontech.ca/faq' >> /home/$MY_USERNAME/README
  1537. echo ' http://cjdns.ca/hypeirc.txt' >> /home/$MY_USERNAME/README
  1538. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  1539. fi
  1540. echo 'install_cjdns' >> $COMPLETION_FILE
  1541. }
  1542. function install_cjdns_tools {
  1543. if grep -Fxq "install_cjdns_tools" $COMPLETION_FILE; then
  1544. return
  1545. fi
  1546. if [[ $ENABLE_CJDNS != "yes" ]]; then
  1547. return
  1548. fi
  1549. if [ ! -d /etc/cjdns ]; then
  1550. install_cjdns
  1551. fi
  1552. apt-get -y install golang mercurial
  1553. if [ ! -f ~/.bashrc ]; then
  1554. touch ~/.bashrc
  1555. fi
  1556. if ! grep -q "export GOPATH=" ~/.bashrc; then
  1557. echo 'export GOPATH=$HOME/projects/go' >> ~/.bashrc
  1558. fi
  1559. if ! grep -q "export PATH=$PATH:$HOME/projects/go/bin" ~/.bashrc; then
  1560. echo 'export PATH=$PATH:$HOME/projects/go/bin' >> ~/.bashrc
  1561. fi
  1562. . ~/.bashrc
  1563. export GOPATH=$HOME/projects/go
  1564. export PATH=$PATH:$HOME/projects/go/bin
  1565. go get github.com/inhies/cjdcmd
  1566. if [ ! -f $HOME/projects/go/bin/cjdcmd ]; then
  1567. echo 'cjdcmd was not compiled. Check your golang installation'
  1568. exit 7439
  1569. fi
  1570. cp $HOME/projects/go/bin/cjdcmd /usr/bin
  1571. # initialise from the cjdns config
  1572. /usr/bin/cjdcmd cjdnsadmin -file /etc/cjdns/cjdroute.conf
  1573. echo 'install_cjdns_tools' >> $COMPLETION_FILE
  1574. }
  1575. function check_hwrng {
  1576. # If hardware random number generation was enabled then make sure that the device exists.
  1577. # if /dev/hwrng is not found then any subsequent cryptographic key generation would
  1578. # suffer from low entropy and might be insecure
  1579. if [ ! -f /etc/default/rng-tools ]; then
  1580. return
  1581. fi
  1582. if [ ! -e /dev/hwrng ]; then
  1583. ls /dev/hw*
  1584. echo 'The hardware random number generator is enabled but could not be detected on'
  1585. echo '/dev/hwrng. There may be a problem with the installation or the Beaglebone hardware.'
  1586. exit 75
  1587. fi
  1588. }
  1589. function get_mariadb_password {
  1590. if [ -f /home/$MY_USERNAME/README ]; then
  1591. if grep -q "MariaDB password" /home/$MY_USERNAME/README; then
  1592. if [ -f $DATABASE_PASSWORD_FILE ]; then
  1593. MARIADB_PASSWORD=$(cat $DATABASE_PASSWORD_FILE)
  1594. else
  1595. MARIADB_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1596. echo "$MARIADB_PASSWORD" > $DATABASE_PASSWORD_FILE
  1597. chmod 600 $DATABASE_PASSWORD_FILE
  1598. fi
  1599. fi
  1600. fi
  1601. }
  1602. function get_mariadb_gnusocial_admin_password {
  1603. if [ -f /home/$MY_USERNAME/README ]; then
  1604. if grep -q "MariaDB gnusocial admin password" /home/$MY_USERNAME/README; then
  1605. MICROBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB gnusocial admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1606. fi
  1607. fi
  1608. }
  1609. function get_mariadb_redmatrix_admin_password {
  1610. if [ -f /home/$MY_USERNAME/README ]; then
  1611. if grep -q "MariaDB Red Matrix admin password" /home/$MY_USERNAME/README; then
  1612. REDMATRIX_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB Red Matrix admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1613. fi
  1614. fi
  1615. }
  1616. function get_mariadb_owncloud_admin_password {
  1617. if [ -f /home/$MY_USERNAME/README ]; then
  1618. if grep -q "Owncloud database password" /home/$MY_USERNAME/README; then
  1619. OWNCLOUD_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Owncloud database password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1620. fi
  1621. fi
  1622. }
  1623. # For rsyncrypto usage see http://archive09.linux.com/feature/125322
  1624. function create_backup_script {
  1625. if grep -Fxq "create_backup_script" $COMPLETION_FILE; then
  1626. return
  1627. fi
  1628. apt-get -y --force-yes install rsyncrypto
  1629. get_mariadb_password
  1630. get_mariadb_gnusocial_admin_password
  1631. get_mariadb_redmatrix_admin_password
  1632. get_mariadb_owncloud_admin_password
  1633. echo '#!/bin/bash' > /usr/bin/$BACKUP_SCRIPT_NAME
  1634. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1635. echo "if [ ! -b $USB_DRIVE ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1636. echo ' echo "Please attach a USB drive"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1637. echo ' exit 1' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1638. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1639. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1640. echo "if [ ! -d $USB_MOUNT ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1641. echo " mkdir $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1642. echo " mount $USB_DRIVE $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1643. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1644. echo "if [ ! -d $USB_MOUNT/backup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1645. echo " mkdir $USB_MOUNT/backup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1646. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1647. echo "if [ ! -d $USB_MOUNT/backup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1648. echo " echo 'There was a problem making the directory $USB_MOUNT/backup.'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1649. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1650. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1651. echo ' exit 27' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1652. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1653. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1654. echo "if [ ! -f $BACKUP_CERTIFICATE ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1655. echo ' echo "Creating backup key"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1656. echo ' makecert backup' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1657. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1658. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1659. echo "if [ ! -f $BACKUP_CERTIFICATE.gpg ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1660. echo ' echo "GPG encrypt the backup key"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1661. echo " gpg -c $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1662. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1663. echo "cp $BACKUP_CERTIFICATE.gpg $USB_MOUNT/backup/key.gpg" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1664. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1665. echo '# MariaDB password' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1666. echo -n 'DATABASE_PASSWORD=$(cat ' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1667. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1668. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1669. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  1670. BACKUP_INCLUDES_DATABASES="yes"
  1671. echo "if [ ! -d $USB_MOUNT/backup/gnusocial ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1672. echo " mkdir -p $USB_MOUNT/backup/gnusocial" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1673. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1674. echo "if [ ! -d $USB_MOUNT/backup/gnusocialdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1675. echo " mkdir -p $USB_MOUNT/backup/gnusocialdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1676. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1677. echo "if [ ! -d /root/tempgnusocialdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1678. echo " mkdir -p /root/tempgnusocialdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1679. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1680. echo 'echo "Obtaining GNU Social database backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1681. echo 'mysqldump --password=$DATABASE_PASSWORD gnusocial > /root/tempgnusocialdata/gnusocial.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1682. echo "if [ ! -s /root/tempgnusocialdata/gnusocial.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1683. echo ' echo "GNU social database could not be saved"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1684. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1685. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1686. echo " fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1687. echo ' shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1688. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1689. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1690. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1691. echo ' exit 296' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1692. echo "fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1693. echo "rsyncrypto -v -r /root/tempgnusocialdata $USB_MOUNT/backup/gnusocialdata $USB_MOUNT/backup/gnusocialdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1694. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1695. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1696. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1697. echo ' exit 853' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1698. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1699. echo 'shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1700. echo 'rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1701. echo 'echo "Backing up GNU social installation"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1702. echo "rsyncrypto -v -r /var/www/$MICROBLOG_DOMAIN_NAME/htdocs $USB_MOUNT/backup/gnusocial $USB_MOUNT/backup/gnusocial.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1703. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1704. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1705. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1706. echo ' exit 846' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1707. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1708. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1709. fi
  1710. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  1711. BACKUP_INCLUDES_DATABASES="yes"
  1712. echo "if [ ! -d $USB_MOUNT/backup/redmatrix ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1713. echo " mkdir -p $USB_MOUNT/backup/redmatrix" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1714. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1715. echo "if [ ! -d $USB_MOUNT/backup/redmatrixdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1716. echo " mkdir -p $USB_MOUNT/backup/redmatrixdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1717. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1718. echo "if [ ! -d /root/tempredmatrixdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1719. echo " mkdir -p /root/tempredmatrixdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1720. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1721. echo 'echo "Obtaining Red Matrix database backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1722. echo 'mysqldump --password=$DATABASE_PASSWORD redmatrix > /root/tempredmatrixdata/redmatrix.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1723. echo "if [ ! -s /root/tempredmatrixdata/redmatrix.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1724. echo ' echo "Red Matrix database could not be saved"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1725. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1726. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1727. echo " fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1728. echo ' shred -zu /root/tempredmatrixdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1729. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1730. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1731. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1732. echo ' exit 378' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1733. echo "fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1734. echo "rsyncrypto -v -r /root/tempredmatrixdata $USB_MOUNT/backup/redmatrixdata $USB_MOUNT/backup/redmatrixdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1735. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1736. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1737. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1738. echo ' exit 285' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1739. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1740. echo 'shred -zu /root/tempredmatrixdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1741. echo 'rm -rf /root/tempredmatrixdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1742. echo 'echo "Backing up Red Matrix installation"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1743. echo "rsyncrypto -v -r /var/www/$REDMATRIX_DOMAIN_NAME/htdocs $USB_MOUNT/backup/redmatrix $USB_MOUNT/backup/redmatrix.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1744. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1745. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1746. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1747. echo ' exit 593' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1748. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1749. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1750. fi
  1751. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  1752. BACKUP_INCLUDES_DATABASES="yes"
  1753. echo "if [ ! -d $USB_MOUNT/backup/owncloud ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1754. echo " mkdir -p $USB_MOUNT/backup/owncloud" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1755. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1756. echo "if [ ! -d $USB_MOUNT/backup/owncloud2 ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1757. echo " mkdir -p $USB_MOUNT/backup/owncloud2" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1758. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1759. echo "if [ ! -d $USB_MOUNT/backup/ownclouddata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1760. echo " mkdir -p $USB_MOUNT/backup/ownclouddata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1761. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1762. echo "if [ ! -d /root/tempownclouddata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1763. echo " mkdir -p /root/tempownclouddata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1764. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1765. echo 'mysqldump --password=$DATABASE_PASSWORD owncloud > /root/tempownclouddata/owncloud.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1766. echo "if [ ! -s /root/tempownclouddata/owncloud.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1767. echo ' echo "Owncloud database could not be saved"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1768. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1769. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1770. echo " fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1771. echo ' shred -zu /root/tempownclouddata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1772. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1773. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1774. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1775. echo ' exit 377' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1776. echo "fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1777. echo "rsyncrypto -v -r /root/tempownclouddata $USB_MOUNT/backup/ownclouddata $USB_MOUNT/backup/ownclouddata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1778. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1779. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1780. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1781. echo ' exit 188' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1782. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1783. echo 'shred -zu /root/tempownclouddata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1784. echo 'rm -rf /root/tempownclouddata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1785. echo 'echo "Obtaining Owncloud data backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1786. echo "rsyncrypto -v -r /var/lib/owncloud $USB_MOUNT/backup/owncloud $USB_MOUNT/backup/owncloud.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1787. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1788. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1789. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1790. echo ' exit 632' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1791. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1792. echo "rsyncrypto -v -r /etc/owncloud $USB_MOUNT/backup/owncloud2 $USB_MOUNT/backup/owncloud2.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1793. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1794. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1795. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1796. echo ' exit 632' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1797. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1798. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1799. fi
  1800. if grep -Fxq "install_wiki" $COMPLETION_FILE; then
  1801. echo "if [ ! -d $USB_MOUNT/backup/wiki ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1802. echo " mkdir -p $USB_MOUNT/backup/wiki" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1803. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1804. echo "if [ ! -d $USB_MOUNT/backup/wiki2 ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1805. echo " mkdir -p $USB_MOUNT/backup/wiki2" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1806. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1807. echo 'echo "Obtaining wiki data backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1808. echo "rsyncrypto -v -r /var/lib/dokuwiki $USB_MOUNT/backup/wiki $USB_MOUNT/backup/wiki.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1809. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1810. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1811. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1812. echo ' exit 964' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1813. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1814. echo "rsyncrypto -v -r /etc/dokuwiki $USB_MOUNT/backup/wiki2 $USB_MOUNT/backup/wiki2.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1815. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1816. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1817. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1818. echo ' exit 964' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1819. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1820. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1821. fi
  1822. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  1823. echo "if [ ! -d $USB_MOUNT/backup/blog ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1824. echo " mkdir -p $USB_MOUNT/backup/blog" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1825. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1826. echo 'echo "Obtaining blog backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1827. echo "rsyncrypto -v -r /var/www/$FULLBLOG_DOMAIN_NAME/htdocs $USB_MOUNT/backup/blog $USB_MOUNT/backup/blog.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1828. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1829. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1830. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1831. echo ' exit 854' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1832. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1833. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1834. fi
  1835. if grep -Fxq "install_cjdns" $COMPLETION_FILE; then
  1836. echo "if [ ! -d $USB_MOUNT/backup/cjdns ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1837. echo " mkdir -p $USB_MOUNT/backup/cjdns" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1838. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1839. echo 'echo "Obtaining cjdns backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1840. echo "rsyncrypto -v -r /etc/cjdns $USB_MOUNT/backup/blog $USB_MOUNT/backup/cjdns.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1841. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1842. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1843. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1844. echo ' exit 7438' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1845. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1846. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1847. fi
  1848. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1849. echo '# Backup certificates' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1850. echo "if [ -d /etc/ssl ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1851. echo ' echo "Backing up certificates"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1852. echo " if [ ! -d $USB_MOUNT/backup/ssl ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1853. echo " mkdir -p $USB_MOUNT/backup/ssl" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1854. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1855. echo " rsyncrypto -v -r /etc/ssl $USB_MOUNT/backup/ssl $USB_MOUNT/backup/ssl.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1856. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1857. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1858. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1859. echo ' exit 343' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1860. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1861. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1862. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1863. echo '# Backup projects' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1864. echo "if [ -d /home/$MY_USERNAME/projects ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1865. echo ' echo "Backing up projects"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1866. echo " if [ ! -d $USB_MOUNT/backup/projects ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1867. echo " mkdir -p $USB_MOUNT/backup/projects" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1868. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1869. echo " rsyncrypto -v -r /home/$MY_USERNAME/projects $USB_MOUNT/backup/projects $USB_MOUNT/backup/projects.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1870. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1871. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1872. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1873. echo ' exit 873' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1874. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1875. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1876. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1877. echo '# Backup personal settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1878. echo "if [ -d /home/$MY_USERNAME/personal ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1879. echo ' echo "Backing up personal settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1880. echo " if [ ! -d $USB_MOUNT/backup/personal ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1881. echo " mkdir -p $USB_MOUNT/backup/personal" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1882. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1883. echo " rsyncrypto -v -r /home/$MY_USERNAME/personal $USB_MOUNT/backup/personal $USB_MOUNT/backup/personal.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1884. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1885. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1886. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1887. echo ' exit 649' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1888. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1889. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1890. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1891. echo '# Backup the public mailing list' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1892. echo "if [ -d $PUBLIC_MAILING_LIST_DIRECTORY ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1893. echo ' echo "Backing up the public mailing list"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1894. echo " if [ ! -d $USB_MOUNT/backup/mailinglist ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1895. echo " mkdir -p $USB_MOUNT/backup/mailinglist" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1896. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1897. echo " rsyncrypto -v -r $PUBLIC_MAILING_LIST_DIRECTORY $USB_MOUNT/backup/mailinglist $USB_MOUNT/backup/mailinglist.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1898. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1899. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1900. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1901. echo ' exit 938' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1902. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1903. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1904. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1905. echo '# Backup xmpp settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1906. echo "if [ -d $XMPP_DIRECTORY ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1907. echo ' echo "Backing up the XMPP settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1908. echo " if [ ! -d $USB_MOUNT/backup/xmpp ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1909. echo " mkdir -p $USB_MOUNT/backup/xmpp" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1910. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1911. echo " rsyncrypto -v -r $XMPP_DIRECTORY $USB_MOUNT/backup/xmpp $USB_MOUNT/backup/xmpp.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1912. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1913. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1914. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1915. echo ' exit 593' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1916. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1917. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1918. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1919. echo '# Backup gpg keys' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1920. echo "if [ -d /home/$MY_USERNAME/.gnupg ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1921. echo ' echo "Backing up gpg keys"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1922. echo " if [ ! -d $USB_MOUNT/backup/gnupg ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1923. echo " mkdir -p $USB_MOUNT/backup/gnupg" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1924. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1925. echo " rsyncrypto -v -r /home/$MY_USERNAME/.gnupg $USB_MOUNT/backup/gnupg $USB_MOUNT/backup/gnupg.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1926. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1927. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1928. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1929. echo ' exit 491' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1930. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1931. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1932. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1933. echo '# Backup ssh keys' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1934. echo "if [ -d /home/$MY_USERNAME/.ssh ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1935. echo ' echo "Backing up ssh keys"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1936. echo " if [ ! -d $USB_MOUNT/backup/ssh ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1937. echo " mkdir -p $USB_MOUNT/backup/ssh" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1938. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1939. echo " rsyncrypto -v -r /home/$MY_USERNAME/.ssh $USB_MOUNT/backup/ssh $USB_MOUNT/backup/ssh.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1940. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1941. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1942. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1943. echo ' exit 731' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1944. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1945. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1946. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1947. echo '# Backup web sites' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1948. echo "if [ -d /etc/nginx ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1949. echo ' echo "Backing up web settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1950. echo " if [ ! -d $USB_MOUNT/backup/web ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1951. echo " mkdir -p $USB_MOUNT/backup/web" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1952. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1953. echo " rsyncrypto -v -r /etc/nginx/sites-available $USB_MOUNT/backup/web $USB_MOUNT/backup/web.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1954. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1955. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1956. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1957. echo ' exit 848' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1958. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1959. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1960. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1961. echo '# Backup README file' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1962. echo "if [ -f /home/$MY_USERNAME/README ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1963. echo ' echo "Backing up README"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1964. echo " if [ ! -d $USB_MOUNT/backup/readme ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1965. echo " mkdir -p $USB_MOUNT/backup/readme" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1966. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1967. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1968. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1969. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1970. echo " cp -f /home/$MY_USERNAME/README /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1971. echo " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup $USB_MOUNT/backup/readme $USB_MOUNT/backup/readme.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1972. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1973. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1974. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1975. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1976. echo ' exit 848' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1977. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1978. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1979. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1980. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1981. echo '# Backup Mutt settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1982. echo "if [ -f /home/$MY_USERNAME/.muttrc ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1983. echo ' echo "Backing up Mutt settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1984. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1985. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1986. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1987. echo " cp /home/$MY_USERNAME/.muttrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1988. echo ' if [ -f /etc/Muttrc ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1989. echo " cp /etc/Muttrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1990. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1991. echo " if [ ! -d $USB_MOUNT/backup/mutt ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1992. echo " mkdir -p $USB_MOUNT/backup/mutt" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1993. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1994. echo " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup $USB_MOUNT/backup/mutt $USB_MOUNT/backup/mutt.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1995. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1996. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1997. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1998. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1999. echo ' exit 492' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2000. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2001. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2002. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2003. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2004. echo '# Backup procmail settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2005. echo "if [ -f /home/$MY_USERNAME/.procmailrc ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2006. echo ' echo "Backing up procmail settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2007. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2008. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2009. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2010. echo " cp /home/$MY_USERNAME/.procmailrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2011. echo " if [ ! -d $USB_MOUNT/backup/procmail ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2012. echo " mkdir -p $USB_MOUNT/backup/procmail" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2013. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2014. echo " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup $USB_MOUNT/backup/procmail $USB_MOUNT/backup/procmail.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2015. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2016. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2017. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2018. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2019. echo ' exit 492' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2020. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2021. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2022. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2023. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2024. echo '# Backup email' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2025. echo "if [ -d /home/$MY_USERNAME/Maildir ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2026. echo ' echo "Backing up emails"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2027. echo " if [ ! -d $USB_MOUNT/backup/mail ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2028. echo " mkdir -p $USB_MOUNT/backup/mail" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2029. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2030. echo " rsyncrypto -v -r /home/$MY_USERNAME/Maildir $USB_MOUNT/backup/mail $USB_MOUNT/backup/mail.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2031. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2032. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2033. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2034. echo ' exit 396' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2035. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2036. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2037. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2038. echo '# Backup DLNA cache' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2039. echo "if [ -d /var/cache/minidlna ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2040. echo ' echo "Backing up DLNA cache"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2041. echo " if [ ! -d $USB_MOUNT/backup/dlna ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2042. echo " mkdir -p $USB_MOUNT/backup/dlna" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2043. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2044. echo " rsyncrypto -v -r /var/cache/minidlna $USB_MOUNT/backup/dlna $USB_MOUNT/backup/dlna.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2045. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2046. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2047. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2048. echo ' exit 498' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2049. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2050. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2051. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2052. if [[ $BACKUP_INCLUDES_DATABASES == "yes" ]]; then
  2053. echo '# Mysql settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2054. echo "if [ ! -d $USB_MOUNT/backup/mariadb ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2055. echo " mkdir -p $USB_MOUNT/backup/mariadb" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2056. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2057. echo 'if [ ! -d /root/tempmariadb ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2058. echo ' mkdir /root/tempmariadb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2059. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2060. echo 'mysqldump --password=$DATABASE_PASSWORD mysql user > /root/tempmariadb/mysql.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2061. echo "if [ ! -s /root/tempmariadb/mysql.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2062. echo ' echo "Unable to backup mysql settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2063. echo ' rm -rf /root/tempmariadb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2064. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2065. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2066. echo ' exit 653' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2067. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2068. echo 'echo "$DATABASE_PASSWORD" > /root/tempmariadb/db' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2069. echo 'chmod 400 /root/tempmariadb/db' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2070. echo "rsyncrypto -v -r /root/tempmariadb $USB_MOUNT/backup/mariadb $USB_MOUNT/backup/mariadb.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2071. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2072. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2073. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2074. echo ' exit 794' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2075. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2076. echo 'shred -zu /root/tempmariadb/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2077. echo 'rm -rf /root/tempmariadb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2078. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2079. fi
  2080. echo 'sync' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2081. echo "umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2082. echo "rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2083. echo 'echo "Backup to USB drive is complete. You can now unplug it."' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2084. echo 'exit 0' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2085. chmod 400 /usr/bin/$BACKUP_SCRIPT_NAME
  2086. chmod +x /usr/bin/$BACKUP_SCRIPT_NAME
  2087. echo 'create_backup_script' >> $COMPLETION_FILE
  2088. }
  2089. function create_restore_script {
  2090. if grep -Fxq "create_restore_script" $COMPLETION_FILE; then
  2091. return
  2092. fi
  2093. apt-get -y --force-yes install rsyncrypto
  2094. get_mariadb_password
  2095. get_mariadb_gnusocial_admin_password
  2096. get_mariadb_redmatrix_admin_password
  2097. get_mariadb_owncloud_admin_password
  2098. echo '#!/bin/bash' > /usr/bin/$RESTORE_SCRIPT_NAME
  2099. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2100. echo "if [ ! -b $USB_DRIVE ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2101. echo ' echo "Please attach a USB drive"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2102. echo ' exit 1' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2103. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2104. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2105. echo "if [ ! -d $USB_MOUNT ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2106. echo " mkdir $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2107. echo " mount $USB_DRIVE $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2108. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2109. echo "if [ ! -d $USB_MOUNT/backup ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2110. echo ' echo "No backup directory found on the USB drive."' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2111. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2112. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2113. echo ' exit 2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2114. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2115. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2116. echo 'echo "Checking that user exists"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2117. echo "if [ ! -d /home/$MY_USERNAME ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2118. echo " echo 'Username $MY_USERNAME not found. Reinstall Freedombone with this username.'" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2119. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2120. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2121. echo ' exit 295' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2122. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2123. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2124. echo 'echo "Copying GPG keys to root"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2125. echo "cp -r /home/$MY_USERNAME/.gnupg /root" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2126. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2127. echo "if [ -f $USB_MOUNT/backup/key.gpg ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2128. echo " if [ -f $BACKUP_CERTIFICATE.new ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2129. echo " rm $BACKUP_CERTIFICATE.new" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2130. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2131. echo " cp $USB_MOUNT/backup/key.gpg /root/tempbackupkey.gpg" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2132. echo " gpg /root/tempbackupkey.gpg" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2133. echo " if [ -f /root/tempbackupkey ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2134. echo ' echo "Backup key decrypted"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2135. echo " cp /root/tempbackupkey $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2136. echo " shred -zu /root/tempbackupkey" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2137. echo " chmod 400 $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2138. echo ' echo "Backup certificate installed"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2139. echo ' else' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2140. echo ' echo "Unable to decrypt the backup key"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2141. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2142. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2143. echo ' exit 735' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2144. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2145. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2146. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2147. echo "if [ ! -f $BACKUP_CERTIFICATE ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2148. echo " echo 'No backup key was found. Copy your backup key to $BACKUP_CERTIFICATE'" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2149. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2150. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2151. echo ' exit 563' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2152. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2153. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2154. echo '# MariaDB password' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2155. echo -n 'DATABASE_PASSWORD=$(cat ' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2156. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2157. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2158. echo '# Make a backup of the original README file' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2159. echo '# incase old passwords need to be used' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2160. echo "if [ -f /home/$MY_USERNAME/README ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2161. echo " if [ ! -f /home/$MY_USERNAME/README_original ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2162. echo " cp /home/$MY_USERNAME/README /home/$MY_USERNAME/README_original" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2163. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2164. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2165. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2166. if [[ $BACKUP_INCLUDES_DATABASES == "yes" ]]; then
  2167. echo "if [ -d $USB_MOUNT/backup/mariadb ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2168. echo ' echo "Restoring mysql settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2169. echo ' if [ ! -d /root/tempmariadb ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2170. echo ' mkdir /root/tempmariadb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2171. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2172. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/mariadb /root/tempmariadb $USB_MOUNT/backup/mariadb.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2173. echo ' echo "Get the MariaDB password from the backup"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2174. echo ' if [ ! -f /root/tempmariadb/usb/backup/mariadb/tempmariadb/db ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2175. echo ' echo "MariaDB password file not found"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2176. echo ' exit 495' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2177. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2178. echo ' BACKUP_MARIADB_PASSWORD=$(cat /root/tempmariadb/usb/backup/mariadb/tempmariadb/db)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2179. echo ' if [[ $BACKUP_MARIADB_PASSWORD != $DATABASE_PASSWORD ]]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2180. echo ' echo "Restore the MariaDB user table"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2181. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD mysql -o < /root/tempmariadb/usb/backup/mariadb/tempmariadb/mysql.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2182. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2183. echo ' echo "Try again using the password obtained from backup"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2184. echo ' mysqlsuccess=$(mysql -u root --password=$BACKUP_MARIADB_PASSWORD mysql -o < /root/tempmariadb/usb/backup/mariadb/tempmariadb/mysql.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2185. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2186. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2187. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2188. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2189. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2190. echo ' exit 962' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2191. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2192. echo ' echo "Restarting database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2193. echo ' service mysql restart' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2194. echo ' echo "Change the MariaDB password to the backup version"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2195. echo ' DATABASE_PASSWORD=$BACKUP_MARIADB_PASSWORD' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2196. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2197. echo ' shred -zu /root/tempmariadb/usb/backup/mariadb/tempmariadb/db' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2198. echo ' rm -rf /root/tempmariadb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2199. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2200. echo ' # Change database password file' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2201. echo -n ' echo "$DATABASE_PASSWORD" > ' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2202. echo "$DATABASE_PASSWORD_FILE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2203. echo " chmod 600 $DATABASE_PASSWORD_FILE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2204. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2205. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2206. fi
  2207. echo "if [ -d $USB_MOUNT/backup/mutt ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2208. echo ' echo "Restoring Mutt settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2209. echo ' mkdir /root/tempmutt' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2210. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/mutt /root/tempmutt $USB_MOUNT/backup/mutt.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2211. echo " if [ -f /root/tempmutt/usb/backup/mutt/$MY_USERNAME/tempbackup/.muttrc ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2212. echo " cp -f /root/tempmutt/usb/backup/mutt/$MY_USERNAME/tempbackup/.muttrc /home/$MY_USERNAME/.muttrc" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2213. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2214. echo " if [ -f /root/tempmutt/usb/backup/mutt/$MY_USERNAME/tempbackup/Muttrc ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2215. echo " cp -f /root/tempmutt/usb/backup/mutt/$MY_USERNAME/tempbackup/Muttrc /etc/Muttrc" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2216. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2217. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2218. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2219. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2220. echo ' rm -rf /root/tempmutt' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2221. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2222. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2223. echo ' rm -rf /root/tempmutt' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2224. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2225. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2226. echo "if [ -d $USB_MOUNT/backup/gnupg ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2227. echo ' echo "Restoring gnupg settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2228. echo ' mkdir /root/tempgnupg' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2229. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gnupg /root/tempgnupg $USB_MOUNT/backup/gnupg.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2230. echo " cp -r /root/tempgnupg/usb/backup/gnupg/$MY_USERNAME/.gnupg /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2231. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2232. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2233. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2234. echo ' rm -rf /root/tempgnupg' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2235. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2236. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2237. echo ' rm -rf /root/tempgnupg' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2238. echo " cp -r /home/$MY_USERNAME/.gnupg /root" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2239. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2240. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2241. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2242. echo ' exit 283' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2243. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2244. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2245. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2246. echo "if [ -d $USB_MOUNT/backup/procmail ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2247. echo ' echo "Restoring procmail settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2248. echo ' mkdir /root/tempprocmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2249. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/procmail /root/tempprocmail $USB_MOUNT/backup/procmail.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2250. echo " cp -f /root/tempprocmail/usb/backup/procmail/$MY_USERNAME/tempbackup/.procmailrc /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2251. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2252. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2253. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2254. echo ' rm -rf /root/tempprocmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2255. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2256. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2257. echo ' rm -rf /root/tempprocmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2258. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2259. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2260. echo "if [ -d $USB_MOUNT/backup/readme ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2261. echo ' echo "Restoring README"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2262. echo ' mkdir /root/tempreadme' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2263. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/readme /root/tempreadme $USB_MOUNT/backup/readme.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2264. echo " cp -f /root/tempreadme/usb/backup/readme/$MY_USERNAME/tempbackup/README /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2265. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2266. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2267. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2268. echo ' rm -rf /root/tempreadme' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2269. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2270. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2271. echo ' rm -rf /root/tempreadme' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2272. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2273. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2274. echo "if [ -d $USB_MOUNT/backup/ssh ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2275. echo ' echo "Restoring ssh keys"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2276. echo ' mkdir /root/tempssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2277. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/ssh /root/tempssh $USB_MOUNT/backup/ssh.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2278. echo " cp -r /root/tempssh/usb/backup/ssh/$MY_USERNAME/.ssh /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2279. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2280. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2281. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2282. echo ' rm -rf /root/tempssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2283. echo ' exit 664' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2284. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2285. echo ' rm -rf /root/tempssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2286. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2287. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2288. echo "if [ -d $USB_MOUNT/backup/ssl ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2289. echo ' echo "Restoring certificates"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2290. echo ' mkdir /root/tempssl' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2291. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/ssl /root/tempssl $USB_MOUNT/backup/ssl.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2292. echo ' cp -r /root/tempssl/usb/backup/ssl/ssl/* /etc/ssl' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2293. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2294. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2295. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2296. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2297. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2298. echo ' rm -rf /root/tempssl' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2299. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2300. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2301. echo "if [ -d $USB_MOUNT/backup/projects ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2302. echo ' echo "Restoring projects"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2303. echo ' mkdir /root/tempprojects' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2304. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/projects /root/tempprojects $USB_MOUNT/backup/projects.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2305. echo " if [ -d /home/$MY_USERNAME/projects ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2306. echo ' rm -rf /home/$MY_USERNAME/projects' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2307. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2308. echo " mv /root/tempprojects/usb/backup/projects/$MY_USERNAME/projects /home/$MY_USERNAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2309. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2310. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2311. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2312. echo ' exit 166' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2313. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2314. echo ' rm -rf /root/tempprojects' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2315. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2316. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2317. echo "if [ -d $USB_MOUNT/backup/personal ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2318. echo ' echo "Restoring personal settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2319. echo ' mkdir /root/temppersonal' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2320. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/personal /root/temppersonal $USB_MOUNT/backup/personal.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2321. echo " if [ -d /home/$MY_USERNAME/personal ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2322. echo ' rm -rf /home/$MY_USERNAME/personal' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2323. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2324. echo " mv /root/temppersonal/usb/backup/personal/$MY_USERNAME/personal /home/$MY_USERNAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2325. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2326. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2327. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2328. echo ' exit 184' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2329. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2330. echo ' rm -rf /root/temppersonal' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2331. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2332. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2333. echo "if [ -d $PUBLIC_MAILING_LIST_DIRECTORY ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2334. echo ' echo "Restoring public mailing list"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2335. echo ' mkdir /root/tempmailinglist' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2336. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/mailinglist /root/tempmailinglist $USB_MOUNT/backup/mailinglist.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2337. echo " cp -r /root/tempmailinglist/usb/backup/mailinglist/spool/mlmmj/* $PUBLIC_MAILING_LIST_DIRECTORY" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2338. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2339. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2340. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2341. echo ' exit 526' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2342. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2343. echo ' rm -rf /root/tempmailinglist' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2344. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2345. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2346. echo "if [ -d $XMPP_DIRECTORY ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2347. echo ' echo "Restoring XMPP settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2348. echo ' mkdir /root/tempxmpp' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2349. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/xmpp /root/tempxmpp $USB_MOUNT/backup/xmpp.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2350. echo " cp -r /root/tempxmpp/usb/backup/xmpp/lib/prosody/* $XMPP_DIRECTORY" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2351. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2352. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2353. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2354. echo ' exit 725' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2355. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2356. echo ' rm -rf /root/tempxmpp' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2357. echo ' service prosody restart' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2358. echo ' chown -R prosody:prosody /var/lib/prosody/*' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2359. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2360. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2361. BACKUP_INCLUDES_WEBSITES="no"
  2362. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  2363. BACKUP_INCLUDES_WEBSITES="yes"
  2364. echo "if [ -d $USB_MOUNT/backup/gnusocial ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2365. echo ' echo "Restoring microblog database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2366. echo ' if [ ! -d /root/tempgnusocialdata ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2367. echo ' mkdir /root/tempgnusocialdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2368. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2369. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gnusocialdata /root/tempgnusocialdata $USB_MOUNT/backup/gnusocialdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2370. echo ' if [ ! -f /root/tempgnusocialdata/usb/backup/gnusocialdata/tempgnusocialdata/gnusocial.sql ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2371. echo ' echo "Unable to restore microblog database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2372. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2373. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2374. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2375. echo ' exit 503' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2376. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2377. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD gnusocial -o < /root/tempgnusocialdata/usb/backup/gnusocialdata/tempgnusocialdata/gnusocial.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2378. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2379. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2380. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2381. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2382. echo ' exit 964' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2383. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2384. echo ' shred -zu /root/tempgnusocialdata/usb/backup/gnusocialdata/tempgnusocialdata/*' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2385. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2386. echo ' echo "Restoring microblog installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2387. echo ' if [ ! -d /root/tempgnusocial ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2388. echo ' mkdir /root/tempgnusocial' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2389. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2390. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gnusocial /root/tempgnusocial $USB_MOUNT/backup/gnusocial.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2391. echo " rm -rf /var/www/$MICROBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2392. echo " mv /root/tempgnusocial/usb/backup/gnusocial/www/$MICROBLOG_DOMAIN_NAME/htdocs /var/www/$MICROBLOG_DOMAIN_NAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2393. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2394. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2395. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2396. echo ' exit 683' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2397. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2398. echo ' rm -rf /root/tempgnusocial' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2399. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2400. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2401. fi
  2402. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  2403. BACKUP_INCLUDES_WEBSITES="yes"
  2404. echo "if [ -d $USB_MOUNT/backup/redmatrix ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2405. echo ' echo "Restoring Red Matrix database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2406. echo ' if [ ! -d /root/tempredmatrixdata ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2407. echo ' mkdir /root/tempredmatrixdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2408. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2409. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/redmatrixdata /root/tempredmatrixdata $USB_MOUNT/backup/redmatrixdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2410. echo ' if [ ! -f /root/tempredmatrixdata/usb/backup/redmatrixdata/tempredmatrixdata/redmatrix.sql ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2411. echo ' echo "Unable to restore Red Matrix database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2412. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2413. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2414. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2415. echo ' exit 504' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2416. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2417. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD redmatrix -o < /root/tempredmatrixdata/usb/backup/redmatrixdata/tempredmatrixdata/redmatrix.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2418. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2419. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2420. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2421. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2422. echo ' exit 965' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2423. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2424. echo ' shred -zu /root/tempredmatrixdata/usb/backup/redmatrixdata/tempredmatrixdata/*' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2425. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2426. echo ' echo "Restoring Red Matrix installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2427. echo ' if [ ! -d /root/tempredmatrix ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2428. echo ' mkdir /root/tempredmatrix' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2429. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2430. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/redmatrix /root/tempredmatrix $USB_MOUNT/backup/redmatrix.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2431. echo " rm -rf /var/www/$REDMATRIX_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2432. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2433. echo " cp -r /root/tempredmatrix/usb/backup/redmatrix/www/$REDMATRIX_DOMAIN_NAME/htdocs/* /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2434. echo ' else' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2435. echo " mv /root/tempredmatrix/usb/backup/redmatrix/www/$REDMATRIX_DOMAIN_NAME/htdocs /var/www/$REDMATRIX_DOMAIN_NAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2436. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2437. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2438. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2439. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2440. echo ' exit 759' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2441. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2442. echo ' rm -rf /root/tempredmatrix' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2443. echo " chmod 777 /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2444. echo " chown -R www-data:www-data /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/*" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2445. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2446. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2447. fi
  2448. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  2449. BACKUP_INCLUDES_WEBSITES="yes"
  2450. echo "if [ -d $USB_MOUNT/backup/owncloud ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2451. echo ' echo "Restoring owncloud database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2452. echo ' if [ ! -d /root/tempownclouddata ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2453. echo ' mkdir /root/tempownclouddata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2454. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2455. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/ownclouddata /root/tempownclouddata $USB_MOUNT/backup/ownclouddata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2456. echo ' if [ ! -f /root/tempownclouddata/usb/backup/ownclouddata/tempownclouddata/owncloud.sql ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2457. echo ' echo "Unable to restore Owncloud database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2458. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2459. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2460. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2461. echo ' exit 505' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2462. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2463. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD owncloud -o < /root/tempownclouddata/usb/backup/ownclouddata/tempownclouddata/owncloud.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2464. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2465. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2466. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2467. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2468. echo ' exit 965' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2469. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2470. echo ' echo "Restoring Owncloud installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2471. echo ' if [ ! -d /root/tempowncloud ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2472. echo ' mkdir /root/tempowncloud' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2473. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2474. echo ' if [ ! -d /root/tempowncloud2 ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2475. echo ' mkdir /root/tempowncloud2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2476. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2477. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/owncloud /root/tempowncloud $USB_MOUNT/backup/owncloud.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2478. echo " cp -r /root/tempowncloud/usb/backup/owncloud/lib/owncloud/* /var/lib/owncloud/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2479. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2480. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2481. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2482. echo ' exit 981' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2483. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2484. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/owncloud2 /root/tempowncloud2 $USB_MOUNT/backup/owncloud2.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2485. echo " cp -r /root/tempowncloud2/usb/backup/owncloud2/owncloud/* /etc/owncloud/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2486. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2487. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2488. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2489. echo ' exit 982' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2490. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2491. echo ' rm -rf /root/tempowncloud' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2492. echo ' rm -rf /root/tempowncloud2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2493. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2494. echo ' chown -R www-data:www-data /var/lib/owncloud/data' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2495. echo ' chown -R www-data:www-data /var/lib/owncloud/backup' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2496. echo ' chown -R www-data:www-data /var/lib/owncloud/assets' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2497. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2498. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2499. fi
  2500. echo "if [ -d $USB_MOUNT/backup/wiki ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2501. echo ' echo "Restoring Wiki installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2502. echo ' mkdir /root/tempwiki' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2503. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/wiki /root/tempwiki $USB_MOUNT/backup/wiki.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2504. echo " cp -r /root/tempwiki/usb/backup/wiki/lib/dokuwiki/* /var/lib/dokuwiki/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2505. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2506. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2507. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2508. echo ' exit 868' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2509. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2510. echo ' mkdir /root/tempwiki2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2511. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/wiki2 /root/tempwiki2 $USB_MOUNT/backup/wiki2.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2512. echo " cp -r /root/tempwiki2/usb/backup/wiki2/dokuwiki/* /etc/dokuwiki/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2513. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2514. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2515. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2516. echo ' exit 869' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2517. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2518. echo ' rm -rf /root/tempwiki' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2519. echo ' rm -rf /root/tempwiki2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2520. echo ' chown -R www-data:www-data /var/lib/dokuwiki/*' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2521. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2522. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2523. echo "if [ -d $USB_MOUNT/backup/blog ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2524. echo ' echo "Restoring blog installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2525. echo ' mkdir /root/tempblog' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2526. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/blog /root/tempblog $USB_MOUNT/backup/blog.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2527. echo " rm -rf /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2528. echo " cp -r /root/tempblog/usb/backup/blog/www/$FULLBLOG_DOMAIN_NAME/htdocs /var/www/$FULLBLOG_DOMAIN_NAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2529. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2530. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2531. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2532. echo ' exit 593' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2533. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2534. echo ' rm -rf /root/tempblog' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2535. echo " if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/content ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2536. echo ' echo "No content directory found after restoring blog"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2537. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2538. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2539. echo ' exit 287' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2540. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2541. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2542. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2543. echo "if [ -d $USB_MOUNT/backup/cjdns ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2544. echo ' echo "Restoring cjdns installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2545. echo ' mkdir /root/tempcjdns' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2546. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/cjdns /root/tempcjdns $USB_MOUNT/backup/cjdns.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2547. echo " rm -rf /etc/cjdns" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2548. echo " cp -r /root/tempcjdns/usb/backup/cjdns/cjdns /etc/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2549. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2550. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2551. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2552. echo ' exit 8472' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2553. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2554. echo ' rm -rf /root/tempcjdns' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2555. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2556. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2557. echo "if [ -d $USB_MOUNT/backup/mail ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2558. echo ' echo "Restoring emails"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2559. echo ' mkdir /root/tempmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2560. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/mail /root/tempmail $USB_MOUNT/backup/mail.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2561. echo " if [ ! -d /home/$MY_USERNAME/Maildir ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2562. echo " mkdir /home/$MY_USERNAME/Maildir" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2563. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2564. echo " cp -r /root/tempmail/usb/backup/mail/$MY_USERNAME/Maildir/* /home/$MY_USERNAME/Maildir/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2565. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2566. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2567. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2568. echo ' exit 927' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2569. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2570. echo ' rm -rf /root/tempmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2571. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2572. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2573. echo "if [ -d /var/cache/minidlna ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2574. echo " if [ -d $USB_MOUNT/backup/dlna ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2575. echo ' echo "Restoring DLNA cache"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2576. echo ' mkdir /root/tempdlna' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2577. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/dlna /root/tempdlna $USB_MOUNT/backup/dlna.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2578. echo " cp -r /root/tempdlna/usb/backup/dlna/cache/minidlna/* /var/cache/minidlna/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2579. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2580. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2581. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2582. echo ' exit 982' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2583. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2584. echo ' rm -rf /root/tempdlna' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2585. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2586. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2587. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2588. echo 'sync' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2589. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2590. echo "# Unmount the USB drive" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2591. echo "umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2592. echo "rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2593. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2594. if [[ $BACKUP_INCLUDES_WEBSITES == "yes" ]]; then
  2595. echo "# Restart the web server" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2596. echo "service nginx restart" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2597. echo "service php5-fpm restart" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2598. fi
  2599. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2600. echo 'echo "Setting permissions"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2601. echo "chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2602. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2603. echo 'echo "Restore from USB drive is complete. You can now remove it."' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2604. echo 'exit 0' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2605. chmod 400 /usr/bin/$RESTORE_SCRIPT_NAME
  2606. chmod +x /usr/bin/$RESTORE_SCRIPT_NAME
  2607. echo 'create_restore_script' >> $COMPLETION_FILE
  2608. }
  2609. function backup_to_friends_servers {
  2610. if grep -Fxq "backup_to_friends_servers" $COMPLETION_FILE; then
  2611. return
  2612. fi
  2613. if [ ! $FRIENDS_SERVERS_LIST ]; then
  2614. return
  2615. fi
  2616. apt-get -y --force-yes install rsyncrypto sshpass
  2617. get_mariadb_password
  2618. get_mariadb_gnusocial_admin_password
  2619. get_mariadb_redmatrix_admin_password
  2620. get_mariadb_owncloud_admin_password
  2621. if ! grep -q "backups on friends servers" /home/$MY_USERNAME/README; then
  2622. echo '' >> /home/$MY_USERNAME/README
  2623. echo '' >> /home/$MY_USERNAME/README
  2624. echo 'Backups' >> /home/$MY_USERNAME/README
  2625. echo '=======' >> /home/$MY_USERNAME/README
  2626. echo 'Key file: /root/backupkey' >> /home/$MY_USERNAME/README
  2627. echo "To add friends servers create a file called $FRIENDS_SERVERS_LIST" >> /home/$MY_USERNAME/README
  2628. echo 'and add entries like this:' >> /home/$MY_USERNAME/README
  2629. echo '' >> /home/$MY_USERNAME/README
  2630. echo "username1@domain1:$SSH_PORT//home/username1 ssh_password1" >> /home/$MY_USERNAME/README
  2631. echo "username2@domain2:$SSH_PORT//home/username2 ssh_password2" >> /home/$MY_USERNAME/README
  2632. echo '...' >> /home/$MY_USERNAME/README
  2633. echo '' >> /home/$MY_USERNAME/README
  2634. echo 'The system will try to backup to these remote locations once per day.' >> /home/$MY_USERNAME/README
  2635. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  2636. fi
  2637. echo '#!/bin/bash' > /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2638. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2639. echo '# Temporary location for data to be backed up to other servers' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2640. echo 'SERVER_DIRECTORY=/root/remotebackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2641. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2642. echo "if [ ! -f $BACKUP_CERTIFICATE ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2643. echo ' echo "Creating backup key"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2644. echo ' makecert backup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2645. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2646. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2647. echo "if [ ! -f $FRIENDS_SERVERS_LIST ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2648. echo ' exit 1' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2649. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2650. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2651. echo '# MariaDB password' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2652. echo -n 'DATABASE_PASSWORD=$(cat ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2653. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2654. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2655. echo '# local directory where the backup will be made' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2656. echo 'if [ ! -d $SERVER_DIRECTORY ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2657. echo ' mkdir $SERVER_DIRECTORY' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2658. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2659. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2660. echo 'if [ ! -d $SERVER_DIRECTORY/backup ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2661. echo ' mkdir -p $SERVER_DIRECTORY/backup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2662. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2663. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2664. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  2665. BACKUP_INCLUDES_DATABASES="yes"
  2666. echo 'if [ ! -d $SERVER_DIRECTORY/backup/gnusocial ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2667. echo ' mkdir -p $SERVER_DIRECTORY/backup/gnusocial' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2668. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2669. echo 'if [ ! -d $SERVER_DIRECTORY/backup/gnusocialdata ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2670. echo ' mkdir -p $SERVER_DIRECTORY/backup/gnusocialdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2671. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2672. echo "if [ ! -d /root/tempgnusocialdata ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2673. echo " mkdir -p /root/tempgnusocialdata" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2674. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2675. echo 'echo "Obtaining GNU Social database backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2676. echo 'mysqldump --password=$DATABASE_PASSWORD gnusocial > /root/tempgnusocialdata/gnusocial.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2677. echo "if [ ! -s /root/tempgnusocialdata/gnusocial.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2678. echo ' echo "GNU social database could not be saved"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2679. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2680. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2681. echo " fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2682. echo ' shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2683. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2684. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2685. echo -n ' echo "Unable to export gnusocial database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2686. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2687. echo ' exit 296' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2688. echo "fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2689. echo -n 'rsyncrypto -v -r /root/tempgnusocialdata $SERVER_DIRECTORY/backup/gnusocialdata $SERVER_DIRECTORY/backup/gnusocialdata.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2690. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2691. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2692. echo ' shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2693. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2694. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2695. echo -n ' echo "Unable to encrypt gnusocial database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2696. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2697. echo ' exit 853' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2698. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2699. echo 'shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2700. echo 'rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2701. echo 'echo "Backing up GNU social installation"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2702. echo -n "rsyncrypto -v -r /var/www/$MICROBLOG_DOMAIN_NAME/htdocs " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2703. echo -n '$SERVER_DIRECTORY/backup/gnusocial $SERVER_DIRECTORY/backup/gnusocial.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2704. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2705. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2706. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2707. echo -n ' echo "Unable to encrypt gnusocial installation" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2708. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2709. echo ' exit 846' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2710. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2711. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2712. fi
  2713. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  2714. BACKUP_INCLUDES_DATABASES="yes"
  2715. echo 'if [ ! -d $SERVER_DIRECTORY/backup/redmatrix ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2716. echo ' mkdir -p $SERVER_DIRECTORY/backup/redmatrix' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2717. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2718. echo 'if [ ! -d $SERVER_DIRECTORY/backup/redmatrixdata ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2719. echo ' mkdir -p $SERVER_DIRECTORY/backup/redmatrixdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2720. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2721. echo "if [ ! -d /root/tempredmatrixdata ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2722. echo " mkdir -p /root/tempredmatrixdata" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2723. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2724. echo 'echo "Obtaining Red Matrix database backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2725. echo 'mysqldump --password=$DATABASE_PASSWORD redmatrix > /root/tempredmatrixdata/redmatrix.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2726. echo "if [ ! -s /root/tempredmatrixdata/redmatrix.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2727. echo ' echo "Red Matrix database could not be saved"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2728. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2729. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2730. echo " fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2731. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2732. echo -n ' echo "Unable to export redmatrix database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2733. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2734. echo ' exit 378' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2735. echo "fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2736. echo -n 'rsyncrypto -v -r /root/tempredmatrixdata $SERVER_DIRECTORY/backup/redmatrixdata $SERVER_DIRECTORY/backup/redmatrixdata.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2737. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2738. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2739. echo ' shred -zu /root/tempredmatrixdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2740. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2741. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2742. echo -n ' echo "Unable to encrypt redmatrix database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2743. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2744. echo ' exit 285' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2745. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2746. echo 'shred -zu /root/tempredmatrixdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2747. echo 'rm -rf /root/tempredmatrixdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2748. echo 'echo "Backing up Red Matrix installation"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2749. echo -n "rsyncrypto -v -r /var/www/$REDMATRIX_DOMAIN_NAME/htdocs " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2750. echo -n '$SERVER_DIRECTORY/backup/redmatrix $SERVER_DIRECTORY/backup/redmatrix.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2751. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2752. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2753. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2754. echo -n ' echo "Unable to encrypt redmatrix installation" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2755. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2756. echo ' exit 593' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2757. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2758. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2759. fi
  2760. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  2761. BACKUP_INCLUDES_DATABASES="yes"
  2762. echo 'if [ ! -d $SERVER_DIRECTORY/backup/owncloud ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2763. echo ' mkdir -p $SERVER_DIRECTORY/backup/owncloud' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2764. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2765. echo 'if [ ! -d $SERVER_DIRECTORY/backup/owncloud2 ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2766. echo ' mkdir -p $SERVER_DIRECTORY/backup/owncloud2' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2767. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2768. echo 'if [ ! -d $SERVER_DIRECTORY/backup/ownclouddata ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2769. echo ' mkdir -p $SERVER_DIRECTORY/backup/ownclouddata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2770. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2771. echo "if [ ! -d /root/tempownclouddata ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2772. echo " mkdir -p /root/tempownclouddata" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2773. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2774. echo 'mysqldump --password=$DATABASE_PASSWORD owncloud > /root/tempownclouddata/owncloud.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2775. echo "if [ ! -s /root/tempownclouddata/owncloud.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2776. echo ' echo "Owncloud database could not be saved"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2777. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2778. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2779. echo " fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2780. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2781. echo -n ' echo "Unable to export owncloud database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2782. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2783. echo ' exit 377' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2784. echo "fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2785. echo -n 'rsyncrypto -v -r /root/tempownclouddata $SERVER_DIRECTORY/backup/ownclouddata $SERVER_DIRECTORY/backup/ownclouddata.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2786. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2787. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2788. echo ' shred -zu /root/tempownclouddata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2789. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2790. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2791. echo -n ' echo "Unable to encrypt owncloud database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2792. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2793. echo ' exit 188' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2794. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2795. echo 'shred -zu /root/tempownclouddata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2796. echo 'rm -rf /root/tempownclouddata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2797. echo 'echo "Obtaining Owncloud data backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2798. echo -n 'rsyncrypto -v -r /var/lib/owncloud $SERVER_DIRECTORY/backup/owncloud $SERVER_DIRECTORY/backup/owncloud.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2799. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2800. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2801. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2802. echo -n ' echo "Unable to encrypt owncloud installation (/var/lib/owncloud)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2803. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2804. echo ' exit 632' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2805. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2806. echo -n 'rsyncrypto -v -r /etc/owncloud $SERVER_DIRECTORY/backup/owncloud2 $SERVER_DIRECTORY/backup/owncloud2.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2807. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2808. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2809. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2810. echo -n ' echo "Unable to encrypt owncloud installation (/etc/owncloud)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2811. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2812. echo ' exit 632' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2813. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2814. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2815. fi
  2816. if grep -Fxq "install_wiki" $COMPLETION_FILE; then
  2817. echo 'if [ ! -d $SERVER_DIRECTORY/backup/wiki ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2818. echo ' mkdir -p $SERVER_DIRECTORY/backup/wiki' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2819. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2820. echo 'if [ ! -d $SERVER_DIRECTORY/backup/wiki2 ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2821. echo ' mkdir -p $SERVER_DIRECTORY/backup/wiki2' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2822. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2823. echo 'echo "Obtaining wiki data backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2824. echo -n 'rsyncrypto -v -r /var/lib/dokuwiki $SERVER_DIRECTORY/backup/wiki $SERVER_DIRECTORY/backup/wiki.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2825. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2826. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2827. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2828. echo -n ' echo "Unable to encrypt wiki installation (/var/lib/dokuwiki)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2829. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2830. echo ' exit 964' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2831. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2832. echo -n 'rsyncrypto -v -r /etc/dokuwiki $SERVER_DIRECTORY/backup/wiki2 $SERVER_DIRECTORY/backup/wiki2.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2833. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2834. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2835. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2836. echo -n ' echo "Unable to encrypt wiki installation (/etc/dokuwiki)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2837. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2838. echo ' exit 964' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2839. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2840. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2841. fi
  2842. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  2843. echo 'if [ ! -d $SERVER_DIRECTORY/backup/blog ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2844. echo ' mkdir -p $SERVER_DIRECTORY/backup/blog' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2845. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2846. echo 'echo "Obtaining blog backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2847. echo -n "rsyncrypto -v -r /var/www/$FULLBLOG_DOMAIN_NAME/htdocs " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2848. echo -n '$SERVER_DIRECTORY/backup/blog $SERVER_DIRECTORY/backup/blog.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2849. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2850. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2851. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2852. echo -n ' echo "Unable to encrypt blog installation" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2853. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2854. echo ' exit 854' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2855. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2856. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2857. fi
  2858. if grep -Fxq "install_cjdns" $COMPLETION_FILE; then
  2859. echo 'if [ ! -d $SERVER_DIRECTORY/backup/cjdns ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2860. echo ' mkdir -p $SERVER_DIRECTORY/backup/cjdns' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2861. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2862. echo 'echo "Obtaining cjdns backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2863. echo -n "rsyncrypto -v -r /etc/cjdns " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2864. echo -n '$SERVER_DIRECTORY/backup/cjdns $SERVER_DIRECTORY/backup/cjdns.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2865. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2866. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2867. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2868. echo -n ' echo "Unable to encrypt cjdns installation" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2869. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2870. echo ' exit 854' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2871. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2872. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2873. fi
  2874. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2875. echo '# Backup certificates' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2876. echo "if [ -d /etc/ssl ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2877. echo ' echo "Backing up certificates"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2878. echo ' if [ ! -d $SERVER_DIRECTORY/backup/ssl ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2879. echo ' mkdir -p $SERVER_DIRECTORY/backup/ssl' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2880. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2881. echo -n ' rsyncrypto -v -r /etc/ssl $SERVER_DIRECTORY/backup/ssl $SERVER_DIRECTORY/backup/ssl.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2882. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2883. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2884. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2885. echo -n ' echo "Unable to encrypt ssl certificates" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2886. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2887. echo ' exit 343' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2888. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2889. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2890. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2891. echo '# Backup projects' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2892. echo "if [ -d /home/$MY_USERNAME/projects ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2893. echo ' echo "Backing up projects"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2894. echo ' if [ ! -d $SERVER_DIRECTORY/backup/projects ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2895. echo ' mkdir -p $SERVER_DIRECTORY/backup/projects' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2896. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2897. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/projects " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2898. echo -n '$SERVER_DIRECTORY/backup/projects $SERVER_DIRECTORY/backup/projects.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2899. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2900. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2901. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2902. echo -n ' echo "Unable to encrypt git projects" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2903. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2904. echo ' exit 873' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2905. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2906. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2907. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2908. echo '# Backup personal settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2909. echo "if [ -d /home/$MY_USERNAME/personal ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2910. echo ' echo "Backing up personal settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2911. echo ' if [ ! -d $SERVER_DIRECTORY/backup/personal ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2912. echo ' mkdir -p $SERVER_DIRECTORY/backup/personal' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2913. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2914. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/personal " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2915. echo -n '$SERVER_DIRECTORY/backup/personal $SERVER_DIRECTORY/backup/personal.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2916. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2917. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2918. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2919. echo -n ' echo "Unable to encrypt personal settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2920. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2921. echo ' exit 649' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2922. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2923. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2924. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2925. echo '# Backup the public mailing list' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2926. echo "if [ -d $PUBLIC_MAILING_LIST_DIRECTORY ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2927. echo ' echo "Backing up the public mailing list"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2928. echo ' if [ ! -d $SERVER_DIRECTORY/backup/mailinglist ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2929. echo ' mkdir -p $SERVER_DIRECTORY/backup/mailinglist' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2930. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2931. echo -n " rsyncrypto -v -r $PUBLIC_MAILING_LIST_DIRECTORY " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2932. echo -n '$SERVER_DIRECTORY/backup/mailinglist $SERVER_DIRECTORY/backup/mailinglist.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2933. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2934. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2935. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2936. echo -n ' echo "Unable to encrypt public mailing list" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2937. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2938. echo ' exit 938' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2939. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2940. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2941. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2942. echo '# Backup xmpp settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2943. echo "if [ -d $XMPP_DIRECTORY ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2944. echo ' echo "Backing up the XMPP settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2945. echo ' if [ ! -d $SERVER_DIRECTORY/backup/xmpp ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2946. echo ' mkdir -p $SERVER_DIRECTORY/backup/xmpp' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2947. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2948. echo -n " rsyncrypto -v -r $XMPP_DIRECTORY " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2949. echo -n '$SERVER_DIRECTORY/backup/xmpp $SERVER_DIRECTORY/backup/xmpp.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2950. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2951. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2952. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2953. echo -n ' echo "Unable to encrypt XMPP settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2954. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2955. echo ' exit 593' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2956. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2957. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2958. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2959. echo '# Backup gpg keys' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2960. echo "if [ -d /home/$MY_USERNAME/.gnupg ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2961. echo ' echo "Backing up gpg keys"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2962. echo ' if [ ! -d $SERVER_DIRECTORY/backup/gnupg ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2963. echo ' mkdir -p $SERVER_DIRECTORY/backup/gnupg' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2964. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2965. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/.gnupg " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2966. echo -n '$SERVER_DIRECTORY/backup/gnupg $SERVER_DIRECTORY/backup/gnupg.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2967. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2968. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2969. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2970. echo -n ' echo "Unable to encrypt gpg keys" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2971. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2972. echo ' exit 491' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2973. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2974. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2975. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2976. echo '# Backup ssh keys' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2977. echo "if [ -d /home/$MY_USERNAME/.ssh ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2978. echo ' echo "Backing up ssh keys"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2979. echo ' if [ ! -d $SERVER_DIRECTORY/backup/ssh ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2980. echo ' mkdir -p $SERVER_DIRECTORY/backup/ssh' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2981. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2982. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/.ssh " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2983. echo -n '$SERVER_DIRECTORY/backup/ssh $SERVER_DIRECTORY/backup/ssh.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2984. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2985. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2986. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2987. echo -n ' echo "Unable to encrypt ssh keys" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2988. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2989. echo ' exit 731' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2990. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2991. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2992. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2993. echo '# Backup web sites' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2994. echo "if [ -d /etc/nginx ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2995. echo ' echo "Backing up web settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2996. echo ' if [ ! -d $SERVER_DIRECTORY/backup/web ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2997. echo ' mkdir -p $SERVER_DIRECTORY/backup/web' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2998. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2999. echo -n ' rsyncrypto -v -r /etc/nginx/sites-available $SERVER_DIRECTORY/backup/web $SERVER_DIRECTORY/backup/web.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3000. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3001. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3002. echo ' exit 848' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3003. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3004. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3005. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3006. echo '# Backup README file' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3007. echo "if [ -f /home/$MY_USERNAME/README ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3008. echo ' echo "Backing up README"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3009. echo ' if [ ! -d $SERVER_DIRECTORY/backup/readme ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3010. echo ' mkdir -p $SERVER_DIRECTORY/backup/readme' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3011. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3012. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3013. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3014. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3015. echo " cp -f /home/$MY_USERNAME/README /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3016. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3017. echo -n '$SERVER_DIRECTORY/backup/readme $SERVER_DIRECTORY/backup/readme.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3018. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3019. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3020. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3021. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3022. echo -n ' echo "Unable to encrypt README file" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3023. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3024. echo ' exit 848' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3025. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3026. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3027. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3028. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3029. echo '# Backup Mutt settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3030. echo "if [ -f /home/$MY_USERNAME/.muttrc ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3031. echo ' echo "Backing up Mutt settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3032. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3033. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3034. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3035. echo " cp /home/$MY_USERNAME/.muttrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3036. echo ' if [ -f /etc/Muttrc ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3037. echo " cp /etc/Muttrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3038. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3039. echo ' if [ ! -d $SERVER_DIRECTORY/backup/mutt ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3040. echo ' mkdir -p $SERVER_DIRECTORY/backup/mutt' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3041. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3042. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3043. echo -n '$SERVER_DIRECTORY/backup/mutt $SERVER_DIRECTORY/backup/mutt.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3044. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3045. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3046. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3047. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3048. echo -n ' echo "Unable to encrypt Mutt settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3049. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3050. echo ' exit 492' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3051. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3052. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3053. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3054. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3055. echo '# Backup procmail settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3056. echo "if [ -f /home/$MY_USERNAME/.procmailrc ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3057. echo ' echo "Backing up procmail settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3058. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3059. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3060. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3061. echo " cp /home/$MY_USERNAME/.procmailrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3062. echo ' if [ ! -d $SERVER_DIRECTORY/backup/procmail ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3063. echo ' mkdir -p $SERVER_DIRECTORY/backup/procmail' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3064. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3065. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3066. echo -n '$SERVER_DIRECTORY/backup/procmail $SERVER_DIRECTORY/backup/procmail.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3067. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3068. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3069. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3070. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3071. echo -n ' echo "Unable to encrypt procmail settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3072. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3073. echo ' exit 492' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3074. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3075. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3076. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3077. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3078. echo '# Backup email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3079. echo "if [ -d /home/$MY_USERNAME/Maildir ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3080. echo ' echo "Backing up emails"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3081. echo ' if [ ! -d $SERVER_DIRECTORY/backup/mail ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3082. echo ' mkdir -p $SERVER_DIRECTORY/backup/mail' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3083. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3084. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/Maildir " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3085. echo -n '$SERVER_DIRECTORY/backup/mail $SERVER_DIRECTORY/backup/mail.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3086. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3087. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3088. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3089. echo -n ' echo "Unable to encrypt emails" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3090. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3091. echo ' exit 396' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3092. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3093. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3094. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3095. echo '# Backup DLNA cache' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3096. echo "if [ -d /var/cache/minidlna ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3097. echo ' echo "Backing up DLNA cache"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3098. echo ' if [ ! -d $SERVER_DIRECTORY/backup/dlna ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3099. echo ' mkdir -p $SERVER_DIRECTORY/backup/dlna' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3100. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3101. echo -n ' rsyncrypto -v -r /var/cache/minidlna $SERVER_DIRECTORY/backup/dlna $SERVER_DIRECTORY/backup/dlna.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3102. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3103. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3104. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3105. echo -n ' echo "Unable to encrypt DLNA settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3106. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3107. echo ' exit 498' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3108. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3109. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3110. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3111. if [[ $BACKUP_INCLUDES_DATABASES == "yes" ]]; then
  3112. echo '# Mysql settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3113. echo 'if [ ! -d $SERVER_DIRECTORY/backup/mariadb ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3114. echo ' mkdir -p $SERVER_DIRECTORY/backup/mariadb' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3115. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3116. echo 'if [ ! -d /root/tempmariadb ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3117. echo ' mkdir /root/tempmariadb' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3118. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3119. echo 'mysqldump --password=$DATABASE_PASSWORD mysql user > /root/tempmariadb/mysql.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3120. echo "if [ ! -s /root/tempmariadb/mysql.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3121. echo ' echo "Unable to backup mysql settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3122. echo ' rm -rf /root/tempmariadb' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3123. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3124. echo -n ' echo "Unable to export database settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3125. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3126. echo ' exit 653' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3127. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3128. echo 'echo "$DATABASE_PASSWORD" > /root/tempmariadb/db' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3129. echo 'chmod 400 /root/tempmariadb/db' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3130. echo -n 'rsyncrypto -v -r /root/tempmariadb $SERVER_DIRECTORY/backup/mariadb $SERVER_DIRECTORY/backup/mariadb.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3131. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3132. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3133. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3134. echo -n ' echo "Unable to encrypt database settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3135. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3136. echo ' exit 794' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3137. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3138. echo 'rm -rf /root/tempmariadb' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3139. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3140. fi
  3141. # Now that we have the server directory updated with the encrypted backup
  3142. # we just need to rsync it to each friend
  3143. echo '# For each remote server' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3144. echo 'while read remote_server' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3145. echo 'do' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3146. echo ' # Get the server and its password' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3147. echo ' # Format is:' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3148. echo ' # username@domain:/home/username <port number> <ssh password>' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3149. echo -n ' REMOTE_SERVER=$(echo "${remote_server}" | ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3150. echo -n "awk -F ' ' '{print " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3151. echo -n '$1' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3152. echo "}')" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3153. echo ' if [ $REMOTE_SERVER ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3154. echo -n ' REMOTE_SSH_PORT=$(echo "${remote_server}" | ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3155. echo -n "awk -F ' ' '{print " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3156. echo -n '$2' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3157. echo "}')" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3158. echo -n ' REMOTE_PASSWORD=$(echo "${remote_server}" | ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3159. echo -n "awk -F ' ' '{print " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3160. echo -n '$3' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3161. echo "}')" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3162. echo ' NOW=$(date +"%Y-%m-%d %H:%M:%S")' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3163. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3164. echo -n ' echo "$NOW Starting backup to $REMOTE_SERVER" >> ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3165. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3166. echo -n ' rsync -ratlzv --rsh="/usr/bin/sshpass -p $REMOTE_PASSWORD ssh -p $REMOTE_SSH_PORT -o StrictHostKeyChecking=no" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3167. echo '$SERVER_DIRECTORY/backup $REMOTE_SERVER' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3168. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3169. echo -n ' echo "$NOW Backup to $REMOTE_SERVER failed" >> ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3170. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3171. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3172. echo -n ' echo "Backup to $REMOTE_SERVER failed" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3173. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3174. echo ' else' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3175. echo -n ' echo "$NOW Backed up to $REMOTE_SERVER" >> ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3176. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3177. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3178. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3179. # End of the loop
  3180. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3181. echo "done < $FRIENDS_SERVERS_LIST" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3182. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3183. echo 'exit 0' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3184. chown root:root /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3185. chmod 400 /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3186. chmod +x /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3187. # update crontab
  3188. echo '#!/bin/bash' > /etc/cron.daily/backuptofriends
  3189. echo "/usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME" >> /etc/cron.daily/backuptofriends
  3190. chmod +x /etc/cron.daily/backuptofriends
  3191. echo 'backup_to_friends_servers' >> $COMPLETION_FILE
  3192. }
  3193. function restore_from_friend {
  3194. if grep -Fxq "restore_from_friend" $COMPLETION_FILE; then
  3195. return
  3196. fi
  3197. apt-get -y --force-yes install rsyncrypto sshpass
  3198. get_mariadb_password
  3199. get_mariadb_gnusocial_admin_password
  3200. get_mariadb_redmatrix_admin_password
  3201. get_mariadb_owncloud_admin_password
  3202. if ! grep -q "restore from a friend's server" /home/$MY_USERNAME/README; then
  3203. echo '' >> /home/$MY_USERNAME/README
  3204. echo '' >> /home/$MY_USERNAME/README
  3205. echo 'Restoring from backups to friends servers' >> /home/$MY_USERNAME/README
  3206. echo '=========================================' >> /home/$MY_USERNAME/README
  3207. echo "To restore from a friend's server use the command:" >> /home/$MY_USERNAME/README
  3208. echo '' >> /home/$MY_USERNAME/README
  3209. echo " $RESTORE_FROM_FRIEND_SCRIPT_NAME [server]" >> /home/$MY_USERNAME/README
  3210. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  3211. fi
  3212. echo '#!/bin/bash' > /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3213. echo 'SERVER_NAME=$1' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3214. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3215. echo '# Temporary location for data to be backed up to other servers' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3216. echo 'SERVER_DIRECTORY=/root/remoterestore' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3217. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3218. echo 'if [ ! $SERVER_NAME ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3219. echo " echo '$RESTORE_FROM_FRIEND_SCRIPT_NAME [server]'" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3220. echo ' exit 1' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3221. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3222. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3223. echo "if [ ! -f $FRIENDS_SERVERS_LIST ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3224. echo " echo 'No friends list found at $FRIENDS_SERVERS_LIST'" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3225. echo ' exit 2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3226. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3227. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3228. echo -n 'if ! grep -q "$SERVER_NAME" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3229. echo "$FRIENDS_SERVERS_LIST; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3230. echo ' echo "Server not found within the friends list"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3231. echo ' exit 3' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3232. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3233. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3234. echo -n 'REMOTE_SERVER=$(grep -i "$SERVER_NAME" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3235. echo -n "$FRIENDS_SERVERS_LIST | awk -F ' ' '{print " >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3236. echo -n '$1' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3237. echo "}')" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3238. echo -n 'REMOTE_SSH_PORT=$(grep -i "$SERVER_NAME" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3239. echo -n "$FRIENDS_SERVERS_LIST | awk -F ' ' '{print " >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3240. echo -n '$2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3241. echo "}')" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3242. echo -n 'REMOTE_PASSWORD=$(grep -i "$SERVER_NAME" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3243. echo -n "$FRIENDS_SERVERS_LIST | awk -F ' ' '{print " >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3244. echo -n '$3' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3245. echo "}')" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3246. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3247. echo '# Check that a backup key exists' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3248. echo "if [ ! -f $BACKUP_CERTIFICATE ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3249. echo " echo 'No backup key was found in $BACKUP_CERTIFICATE'" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3250. echo ' exit 84' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3251. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3252. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3253. # Rsync from the remote server back to this server
  3254. echo 'NOW=$(date +"%Y-%m-%d %H:%M:%S")' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3255. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3256. echo -n 'echo "$NOW Starting restore from $REMOTE_SERVER" >> ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3257. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3258. echo -n 'rsync -ratlzv --rsh="/usr/bin/sshpass -p $REMOTE_PASSWORD ssh -p $REMOTE_SSH_PORT -o StrictHostKeyChecking=no" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3259. echo '$REMOTE_SERVER/backup $SERVER_DIRECTORY' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3260. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3261. echo -n ' echo "$NOW Restore from $REMOTE_SERVER failed" >> ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3262. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3263. echo ' # Send a warning email' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3264. echo -n ' echo "Restore from $REMOTE_SERVER failed" | mail -s "Freedombone restore from friend" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3265. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3266. echo ' exit 790' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3267. echo 'else' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3268. echo -n ' echo "$NOW Restored encrypted data from $REMOTE_SERVER" >> ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3269. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3270. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3271. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3272. echo '# MariaDB password' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3273. echo -n 'DATABASE_PASSWORD=$(cat ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3274. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3275. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3276. echo 'if [ -d $SERVER_DIRECTORY/backup/mariadb ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3277. echo ' echo "Restoring mysql settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3278. echo ' if [ ! -d /root/tempmariadb ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3279. echo ' mkdir /root/tempmariadb' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3280. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3281. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/mariadb /root/tempmariadb $SERVER_DIRECTORY/backup/mariadb.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3282. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3283. echo ' echo "Get the MariaDB password from the backup"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3284. echo ' if [ ! -f /root/tempmariadb/remoterestore/backup/mariadb/tempmariadb/db ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3285. echo ' echo "MariaDB password file not found"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3286. echo ' exit 495' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3287. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3288. echo ' BACKUP_MARIADB_PASSWORD=$(cat /root/tempmariadb/remoterestore/backup/mariadb/tempmariadb/db)' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3289. echo ' if [[ $BACKUP_MARIADB_PASSWORD != $DATABASE_PASSWORD ]]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3290. echo ' echo "Restore the MariaDB user table"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3291. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD mysql -o < /root/tempmariadb/remoterestore/backup/mariadb/tempmariadb/mysql.sql)' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3292. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3293. echo ' echo "Try again using the password obtained from backup"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3294. echo ' mysqlsuccess=$(mysql -u root --password=$BACKUP_MARIADB_PASSWORD mysql -o < /root/tempmariadb/remoterestore/backup/mariadb/tempmariadb/mysql.sql)' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3295. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3296. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3297. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3298. echo ' exit 962' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3299. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3300. echo ' echo "Restarting database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3301. echo ' service mysql restart' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3302. echo ' echo "Change the MariaDB password to the backup version"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3303. echo ' DATABASE_PASSWORD=$BACKUP_MARIADB_PASSWORD' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3304. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3305. echo ' shred -zu /root/tempmariadb/remoterestore/backup/mariadb/tempmariadb/db' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3306. echo ' rm -rf /root/tempmariadb' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3307. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3308. echo ' # Change database password file' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3309. echo -n ' echo "$DATABASE_PASSWORD" > ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3310. echo "$DATABASE_PASSWORD_FILE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3311. echo " chmod 600 $DATABASE_PASSWORD_FILE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3312. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3313. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3314. echo 'if [ -d $SERVER_DIRECTORY/backup/mutt ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3315. echo ' echo "Restoring Mutt settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3316. echo ' mkdir /root/tempmutt' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3317. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/mutt /root/tempmutt $SERVER_DIRECTORY/backup/mutt.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3318. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3319. echo " if [ -f /root/tempmutt/remoterestore/backup/mutt/$MY_USERNAME/tempbackup/.muttrc ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3320. echo " cp -f /root/tempmutt/remoterestore/backup/mutt/$MY_USERNAME/tempbackup/.muttrc /home/$MY_USERNAME/.muttrc" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3321. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3322. echo " if [ -f /root/tempmutt/remoterestore/backup/mutt/$MY_USERNAME/tempbackup/Muttrc ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3323. echo " cp -f /root/tempmutt/remoterestore/backup/mutt/$MY_USERNAME/tempbackup/Muttrc /etc/Muttrc" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3324. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3325. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3326. echo ' rm -rf /root/tempmutt' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3327. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3328. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3329. echo ' rm -rf /root/tempmutt' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3330. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3331. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3332. echo 'if [ -d $SERVER_DIRECTORY/backup/gnupg ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3333. echo ' echo "Restoring gnupg settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3334. echo ' mkdir /root/tempgnupg' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3335. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gnupg /root/tempgnupg $SERVER_DIRECTORY/backup/gnupg.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3336. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3337. echo " cp -r /root/tempgnupg/remoterestore/backup/gnupg/$MY_USERNAME/.gnupg /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3338. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3339. echo ' rm -rf /root/tempgnupg' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3340. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3341. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3342. echo ' rm -rf /root/tempgnupg' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3343. echo " cp -r /home/$MY_USERNAME/.gnupg /root" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3344. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3345. echo ' exit 283' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3346. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3347. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3348. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3349. echo 'if [ -d $SERVER_DIRECTORY/backup/procmail ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3350. echo ' echo "Restoring procmail settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3351. echo ' mkdir /root/tempprocmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3352. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/procmail /root/tempprocmail $SERVER_DIRECTORY/backup/procmail.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3353. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3354. echo " cp -f /root/tempprocmail/remoterestore/backup/procmail/$MY_USERNAME/tempbackup/.procmailrc /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3355. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3356. echo ' rm -rf /root/tempprocmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3357. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3358. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3359. echo ' rm -rf /root/tempprocmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3360. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3361. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3362. echo 'if [ -d $SERVER_DIRECTORY/backup/readme ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3363. echo ' echo "Restoring README"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3364. echo ' mkdir /root/tempreadme' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3365. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/readme /root/tempreadme $SERVER_DIRECTORY/backup/readme.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3366. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3367. echo " cp -f /root/tempreadme/remoterestore/backup/readme/$MY_USERNAME/tempbackup/README /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3368. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3369. echo ' rm -rf /root/tempreadme' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3370. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3371. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3372. echo ' rm -rf /root/tempreadme' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3373. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3374. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3375. echo 'if [ -d $SERVER_DIRECTORY/backup/ssh ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3376. echo ' echo "Restoring ssh keys"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3377. echo ' mkdir /root/tempssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3378. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/ssh /root/tempssh $SERVER_DIRECTORY/backup/ssh.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3379. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3380. echo " cp -r /root/tempssh/remoterestore/backup/ssh/$MY_USERNAME/.ssh /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3381. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3382. echo ' rm -rf /root/tempssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3383. echo ' exit 664' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3384. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3385. echo ' rm -rf /root/tempssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3386. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3387. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3388. echo 'if [ -d $SERVER_DIRECTORY/backup/ssl ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3389. echo ' echo "Restoring certificates"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3390. echo ' mkdir /root/tempssl' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3391. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/ssl /root/tempssl $SERVER_DIRECTORY/backup/ssl.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3392. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3393. echo ' cp -r /root/tempssl/remoterestore/backup/ssl/ssl/* /etc/ssl' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3394. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3395. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3396. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3397. echo ' rm -rf /root/tempssl' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3398. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3399. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3400. echo 'if [ -d $SERVER_DIRECTORY/backup/projects ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3401. echo ' echo "Restoring projects"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3402. echo ' mkdir /root/tempprojects' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3403. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/projects /root/tempprojects $SERVER_DIRECTORY/backup/projects.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3404. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3405. echo " if [ -d /home/$MY_USERNAME/projects ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3406. echo " rm -rf /home/$MY_USERNAME/projects" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3407. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3408. echo " mv /root/tempprojects/remoterestore/backup/projects/$MY_USERNAME/projects /home/$MY_USERNAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3409. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3410. echo ' exit 166' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3411. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3412. echo ' rm -rf /root/tempprojects' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3413. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3414. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3415. echo 'if [ -d $SERVER_DIRECTORY/backup/personal ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3416. echo ' echo "Restoring personal settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3417. echo ' mkdir /root/temppersonal' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3418. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/personal /root/temppersonal $SERVER_DIRECTORY/backup/personal.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3419. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3420. echo " if [ -d /home/$MY_USERNAME/personal ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3421. echo " rm -rf /home/$MY_USERNAME/personal" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3422. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3423. echo " mv /root/temppersonal/remoterestore/backup/personal/$MY_USERNAME/personal /home/$MY_USERNAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3424. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3425. echo ' exit 184' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3426. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3427. echo ' rm -rf /root/temppersonal' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3428. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3429. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3430. echo "if [ -d $PUBLIC_MAILING_LIST_DIRECTORY ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3431. echo ' echo "Restoring public mailing list"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3432. echo ' mkdir /root/tempmailinglist' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3433. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/mailinglist /root/tempmailinglist $SERVER_DIRECTORY/backup/mailinglist.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3434. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3435. echo " cp -r /root/tempmailinglist/remoterestore/backup/mailinglist/spool/mlmmj/* $PUBLIC_MAILING_LIST_DIRECTORY" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3436. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3437. echo ' exit 526' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3438. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3439. echo ' rm -rf /root/tempmailinglist' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3440. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3441. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3442. echo "if [ -d $XMPP_DIRECTORY ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3443. echo ' echo "Restoring XMPP settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3444. echo ' mkdir /root/tempxmpp' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3445. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/xmpp /root/tempxmpp $SERVER_DIRECTORY/backup/xmpp.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3446. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3447. echo " cp -r /root/tempxmpp/remoterestore/backup/xmpp/lib/prosody/* $XMPP_DIRECTORY" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3448. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3449. echo ' exit 725' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3450. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3451. echo ' rm -rf /root/tempxmpp' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3452. echo ' service prosody restart' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3453. echo ' chown -R prosody:prosody /var/lib/prosody/*' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3454. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3455. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3456. BACKUP_INCLUDES_WEBSITES="no"
  3457. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  3458. BACKUP_INCLUDES_WEBSITES="yes"
  3459. echo 'if [ -d $SERVER_DIRECTORY/backup/gnusocial ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3460. echo ' echo "Restoring microblog database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3461. echo ' if [ ! -d /root/tempgnusocialdata ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3462. echo ' mkdir /root/tempgnusocialdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3463. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3464. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gnusocialdata /root/tempgnusocialdata $SERVER_DIRECTORY/backup/gnusocialdata.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3465. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3466. echo ' if [ ! -f /root/tempgnusocialdata/remoterestore/backup/gnusocialdata/tempgnusocialdata/gnusocial.sql ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3467. echo ' echo "Unable to restore microblog database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3468. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3469. echo ' exit 503' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3470. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3471. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD gnusocial -o < /root/tempgnusocialdata/remoterestore/backup/gnusocialdata/tempgnusocialdata/gnusocial.sql)' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3472. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3473. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3474. echo ' exit 964' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3475. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3476. echo ' shred -zu /root/tempgnusocialdata/remoterestore/backup/gnusocialdata/tempgnusocialdata/*' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3477. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3478. echo ' echo "Restoring microblog installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3479. echo ' if [ ! -d /root/tempgnusocial ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3480. echo ' mkdir /root/tempgnusocial' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3481. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3482. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gnusocial /root/tempgnusocial $SERVER_DIRECTORY/backup/gnusocial.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3483. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3484. echo " rm -rf /var/www/$MICROBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3485. echo " mv /root/tempgnusocial/remoterestore/backup/gnusocial/www/$MICROBLOG_DOMAIN_NAME/htdocs /var/www/$MICROBLOG_DOMAIN_NAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3486. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3487. echo ' exit 683' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3488. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3489. echo ' rm -rf /root/tempgnusocial' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3490. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3491. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3492. fi
  3493. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  3494. BACKUP_INCLUDES_WEBSITES="yes"
  3495. echo 'if [ -d $SERVER_DIRECTORY/backup/redmatrix ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3496. echo ' echo "Restoring Red Matrix database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3497. echo ' if [ ! -d /root/tempredmatrixdata ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3498. echo ' mkdir /root/tempredmatrixdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3499. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3500. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/redmatrixdata /root/tempredmatrixdata $SERVER_DIRECTORY/backup/redmatrixdata.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3501. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3502. echo ' if [ ! -f /root/tempredmatrixdata/remoterestore/backup/redmatrixdata/tempredmatrixdata/redmatrix.sql ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3503. echo ' echo "Unable to restore Red Matrix database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3504. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3505. echo ' exit 504' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3506. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3507. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD redmatrix -o < /root/tempredmatrixdata/remoterestore/backup/redmatrixdata/tempredmatrixdata/redmatrix.sql)' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3508. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3509. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3510. echo ' exit 965' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3511. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3512. echo ' shred -zu /root/tempredmatrixdata/remoterestore/backup/redmatrixdata/tempredmatrixdata/*' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3513. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3514. echo ' echo "Restoring Red Matrix installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3515. echo ' if [ ! -d /root/tempredmatrix ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3516. echo ' mkdir /root/tempredmatrix' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3517. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3518. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/redmatrix /root/tempredmatrix $SERVER_DIRECTORY/backup/redmatrix.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3519. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3520. echo " rm -rf /var/www/$REDMATRIX_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3521. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3522. echo " cp -r /root/tempredmatrix/remoterestore/backup/redmatrix/www/$REDMATRIX_DOMAIN_NAME/htdocs/* /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3523. echo ' else' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3524. echo " mv /root/tempredmatrix/remoterestore/backup/redmatrix/www/$REDMATRIX_DOMAIN_NAME/htdocs /var/www/$REDMATRIX_DOMAIN_NAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3525. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3526. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3527. echo ' exit 759' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3528. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3529. echo ' rm -rf /root/tempredmatrix' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3530. echo " chmod 777 /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3531. echo " chown -R www-data:www-data /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/*" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3532. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3533. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3534. fi
  3535. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  3536. BACKUP_INCLUDES_WEBSITES="yes"
  3537. echo 'if [ -d $SERVER_DIRECTORY/backup/owncloud ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3538. echo ' echo "Restoring owncloud database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3539. echo ' if [ ! -d /root/tempownclouddata ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3540. echo ' mkdir /root/tempownclouddata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3541. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3542. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/ownclouddata /root/tempownclouddata $SERVER_DIRECTORY/backup/ownclouddata.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3543. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3544. echo ' if [ ! -f /root/tempownclouddata/remoterestore/backup/ownclouddata/tempownclouddata/owncloud.sql ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3545. echo ' echo "Unable to restore Owncloud database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3546. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3547. echo ' exit 505' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3548. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3549. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD owncloud -o < /root/tempownclouddata/remoterestore/backup/ownclouddata/tempownclouddata/owncloud.sql)' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3550. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3551. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3552. echo ' exit 965' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3553. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3554. echo ' echo "Restoring Owncloud installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3555. echo ' if [ ! -d /root/tempowncloud ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3556. echo ' mkdir /root/tempowncloud' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3557. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3558. echo ' if [ ! -d /root/tempowncloud2 ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3559. echo ' mkdir /root/tempowncloud2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3560. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3561. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/owncloud /root/tempowncloud $SERVER_DIRECTORY/backup/owncloud.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3562. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3563. echo " cp -r /root/tempowncloud/remoterestore/backup/owncloud/lib/owncloud/* /var/lib/owncloud/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3564. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3565. echo ' exit 981' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3566. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3567. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/owncloud2 /root/tempowncloud2 $SERVER_DIRECTORY/backup/owncloud2.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3568. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3569. echo " cp -r /root/tempowncloud2/remoterestore/backup/owncloud2/owncloud/* /etc/owncloud/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3570. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3571. echo ' exit 982' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3572. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3573. echo ' rm -rf /root/tempowncloud' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3574. echo ' rm -rf /root/tempowncloud2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3575. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3576. echo ' chown -R www-data:www-data /var/lib/owncloud/data' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3577. echo ' chown -R www-data:www-data /var/lib/owncloud/backup' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3578. echo ' chown -R www-data:www-data /var/lib/owncloud/assets' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3579. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3580. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3581. fi
  3582. echo 'if [ -d $SERVER_DIRECTORY/backup/wiki ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3583. echo ' echo "Restoring Wiki installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3584. echo ' mkdir /root/tempwiki' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3585. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/wiki /root/tempwiki $SERVER_DIRECTORY/backup/wiki.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3586. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3587. echo " cp -r /root/tempwiki/remoterestore/backup/wiki/lib/dokuwiki/* /var/lib/dokuwiki/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3588. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3589. echo ' exit 868' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3590. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3591. echo ' mkdir /root/tempwiki2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3592. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/wiki2 /root/tempwiki2 $SERVER_DIRECTORY/backup/wiki2.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3593. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3594. echo " cp -r /root/tempwiki2/remoterestore/backup/wiki2/dokuwiki/* /etc/dokuwiki/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3595. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3596. echo ' exit 869' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3597. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3598. echo ' rm -rf /root/tempwiki' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3599. echo ' rm -rf /root/tempwiki2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3600. echo ' chown -R www-data:www-data /var/lib/dokuwiki/*' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3601. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3602. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3603. echo 'if [ -d $SERVER_DIRECTORY/backup/blog ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3604. echo ' echo "Restoring blog installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3605. echo ' mkdir /root/tempblog' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3606. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/blog /root/tempblog $SERVER_DIRECTORY/backup/blog.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3607. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3608. echo " rm -rf /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3609. echo " cp -r /root/tempblog/remoterestore/backup/blog/www/$FULLBLOG_DOMAIN_NAME/htdocs /var/www/$FULLBLOG_DOMAIN_NAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3610. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3611. echo ' exit 593' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3612. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3613. echo ' rm -rf /root/tempblog' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3614. echo " if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/content ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3615. echo ' echo "No content directory found after restoring blog"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3616. echo ' exit 287' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3617. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3618. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3619. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3620. echo 'if [ -d $SERVER_DIRECTORY/backup/cjdns ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3621. echo ' echo "Restoring cjdns installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3622. echo ' mkdir /root/tempcjdns' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3623. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/cjdns /root/tempcjdns $SERVER_DIRECTORY/backup/cjdns.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3624. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3625. echo " rm -rf /etc/cjdns" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3626. echo " cp -r /root/tempcjdns/remoterestore/backup/cjdns/cjdns /etc/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3627. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3628. echo ' exit 7438' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3629. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3630. echo ' rm -rf /root/tempcjdns' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3631. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3632. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3633. echo 'if [ -d $SERVER_DIRECTORY/backup/mail ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3634. echo ' echo "Restoring emails"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3635. echo ' mkdir /root/tempmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3636. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/mail /root/tempmail $SERVER_DIRECTORY/backup/mail.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3637. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3638. echo " if [ ! -d /home/$MY_USERNAME/Maildir ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3639. echo " mkdir /home/$MY_USERNAME/Maildir" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3640. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3641. echo " cp -r /root/tempmail/remoterestore/backup/mail/$MY_USERNAME/Maildir/* /home/$MY_USERNAME/Maildir/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3642. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3643. echo ' exit 927' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3644. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3645. echo ' rm -rf /root/tempmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3646. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3647. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3648. echo "if [ -d /var/cache/minidlna ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3649. echo ' if [ -d $SERVER_DIRECTORY/backup/dlna ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3650. echo ' echo "Restoring DLNA cache"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3651. echo ' mkdir /root/tempdlna' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3652. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/dlna /root/tempdlna $SERVER_DIRECTORY/backup/dlna.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3653. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3654. echo " cp -r /root/tempdlna/remoterestore/backup/dlna/cache/minidlna/* /var/cache/minidlna/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3655. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3656. echo ' exit 982' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3657. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3658. echo ' rm -rf /root/tempdlna' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3659. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3660. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3661. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3662. echo 'echo "*** Remote restore was successful ***"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3663. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3664. echo 'exit 0' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3665. chmod 400 /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3666. chmod +x /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3667. echo 'restore_from_friend' >> $COMPLETION_FILE
  3668. }
  3669. function remove_default_user {
  3670. # make sure you don't use the default user account
  3671. if [[ $MY_USERNAME == "debian" ]]; then
  3672. echo 'Do not use the default debian user account. Create a different user with: adduser [username]'
  3673. exit 68
  3674. fi
  3675. # remove the default debian user to prevent it from becoming an attack vector
  3676. if [ -d /home/debian ]; then
  3677. userdel -r debian
  3678. echo 'Default debian user account removed'
  3679. fi
  3680. }
  3681. function enforce_good_passwords {
  3682. # because humans are generally bad at choosing passwords
  3683. if grep -Fxq "enforce_good_passwords" $COMPLETION_FILE; then
  3684. return
  3685. fi
  3686. apt-get -y --force-yes install libpam-cracklib
  3687. sed -i 's/password.*requisite.*pam_cracklib.so.*/password required pam_cracklib.so retry=2 dcredit=-4 ucredit=-1 ocredit=-1 lcredit=0 minlen=10 reject_username/g' /etc/pam.d/common-password
  3688. echo 'enforce_good_passwords' >> $COMPLETION_FILE
  3689. }
  3690. function change_login_message {
  3691. if grep -Fxq "change_login_message" $COMPLETION_FILE; then
  3692. return
  3693. fi
  3694. echo '' > /etc/motd
  3695. echo ".---. . . " >> /etc/motd
  3696. echo "| | | " >> /etc/motd
  3697. echo "|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-. " >> /etc/motd
  3698. echo "| | (.-' (.-' ( | ( )| | | | )( )| | (.-' " >> /etc/motd
  3699. echo "' ' --' --' -' - -' ' ' -' -' -' ' - --'" >> /etc/motd
  3700. if [[ $SYSTEM_TYPE == "$VARIANT_MEDIA" ]]; then
  3701. echo ' . . . ' >> /etc/motd
  3702. echo ' |\ /| | o ' >> /etc/motd
  3703. echo " | \/ | .-. .-.| . .-. " >> /etc/motd
  3704. echo " | |(.-'( | | ( ) " >> /etc/motd
  3705. echo " ' ' --' -' --' - -' - " >> /etc/motd
  3706. fi
  3707. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" ]]; then
  3708. echo ' . . . . . ' >> /etc/motd
  3709. echo ' \ \ / / o _|_ ' >> /etc/motd
  3710. echo ' \ \ /.--.. | .-. .--.' >> /etc/motd
  3711. echo " \/ \/ | | | (.-' | " >> /etc/motd
  3712. echo " ' ' ' -' - -' --'' " >> /etc/motd
  3713. fi
  3714. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  3715. echo ' .--.. . ' >> /etc/motd
  3716. echo ' : | | ' >> /etc/motd
  3717. echo ' | | .-. . . .-.| ' >> /etc/motd
  3718. echo ' : |( )| |( | ' >> /etc/motd
  3719. echo " --' - -' -- - -' -" >> /etc/motd
  3720. fi
  3721. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  3722. echo ' .--.. . ' >> /etc/motd
  3723. echo ' : | _|_ ' >> /etc/motd
  3724. echo ' | |--. .-. | ' >> /etc/motd
  3725. echo ' : | |( ) | ' >> /etc/motd
  3726. echo " --'' - -' - -' " >> /etc/motd
  3727. fi
  3728. if [[ $SYSTEM_TYPE == "$VARIANT_SOCIAL" ]]; then
  3729. echo ' .-. . ' >> /etc/motd
  3730. echo ' ( ) o | ' >> /etc/motd
  3731. echo ' -. .-. .-. . .-. | ' >> /etc/motd
  3732. echo ' ( )( )( | ( ) | ' >> /etc/motd
  3733. echo " -' -' -'-' - -' - - " >> /etc/motd
  3734. fi
  3735. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  3736. echo ' . . . . ' >> /etc/motd
  3737. echo ' |\ /| o | | ' >> /etc/motd
  3738. echo ' | \/ | .-. . | |.-. .-.-. ,- ' >> /etc/motd
  3739. echo ' | |( ) | | | )( ) : ' >> /etc/motd
  3740. echo " ' ' -' --' - -' -' -'-' - " >> /etc/motd
  3741. fi
  3742. if [[ $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  3743. echo ' .---. .--. . ' >> /etc/motd
  3744. echo ' | | : | ' >> /etc/motd
  3745. echo ' | .-. .--. | | .-. .--. .-..| .-. ' >> /etc/motd
  3746. echo " |( )| | ;( )| |( ||(.-' " >> /etc/motd
  3747. echo " ' -' ' '--' -' ' - - | - --'" >> /etc/motd
  3748. echo " ._.' " >> /etc/motd
  3749. fi
  3750. echo '' >> /etc/motd
  3751. echo ' Freedom in the Cloud' >> /etc/motd
  3752. echo '' >> /etc/motd
  3753. echo 'change_login_message' >> $COMPLETION_FILE
  3754. }
  3755. function search_for_attached_usb_drive {
  3756. # If a USB drive is attached then search for email,
  3757. # gpg, ssh keys and emacs configuration
  3758. if grep -Fxq "search_for_attached_usb_drive" $COMPLETION_FILE; then
  3759. return
  3760. fi
  3761. if [[ $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  3762. return
  3763. fi
  3764. if [ -b $USB_DRIVE ]; then
  3765. if [ ! -d $USB_MOUNT ]; then
  3766. echo 'Mounting USB drive'
  3767. mkdir $USB_MOUNT
  3768. mount $USB_DRIVE $USB_MOUNT
  3769. fi
  3770. if ! [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  3771. if [ -d $USB_MOUNT/Maildir ]; then
  3772. echo 'Maildir found on USB drive'
  3773. IMPORT_MAILDIR=$USB_MOUNT/Maildir
  3774. fi
  3775. if [ -d $USB_MOUNT/.gnupg ]; then
  3776. echo 'Importing GPG keyring'
  3777. cp -r $USB_MOUNT/.gnupg /home/$MY_USERNAME
  3778. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.gnupg
  3779. GPG_KEYS_IMPORTED="yes"
  3780. if [ -f /home/$MY_USERNAME/.gnupg/secring.gpg ]; then
  3781. shred -zu $USB_MOUNT/.gnupg/secring.gpg
  3782. shred -zu $USB_MOUNT/.gnupg/random_seed
  3783. shred -zu $USB_MOUNT/.gnupg/trustdb.gpg
  3784. rm -rf $USB_MOUNT/.gnupg
  3785. else
  3786. echo 'GPG files did not copy'
  3787. exit 7
  3788. fi
  3789. fi
  3790. if [ -f $USB_MOUNT/.procmailrc ]; then
  3791. echo 'Importing procmail settings'
  3792. cp $USB_MOUNT/.procmailrc /home/$MY_USERNAME
  3793. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  3794. fi
  3795. if [ -f $USB_MOUNT/private_key.gpg ]; then
  3796. echo 'GPG private key found on USB drive'
  3797. MY_GPG_PRIVATE_KEY=$USB_MOUNT/private_key.gpg
  3798. fi
  3799. if [ -f $USB_MOUNT/public_key.gpg ]; then
  3800. echo 'GPG public key found on USB drive'
  3801. MY_GPG_PUBLIC_KEY=$USB_MOUNT/public_key.gpg
  3802. fi
  3803. fi
  3804. if [ -d $USB_MOUNT/prosody ]; then
  3805. if [ ! -d $XMPP_DIRECTORY ]; then
  3806. mkdir $XMPP_DIRECTORY
  3807. fi
  3808. cp -r $USB_MOUNT/prosody/* $XMPP_DIRECTORY
  3809. chown -R prosody:prosody $XMPP_DIRECTORY
  3810. fi
  3811. if [ -d $USB_MOUNT/.ssh ]; then
  3812. echo 'Importing ssh keys'
  3813. cp -r $USB_MOUNT/.ssh /home/$MY_USERNAME
  3814. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.ssh
  3815. # for security delete the ssh keys from the usb drive
  3816. if [ -f /home/$MY_USERNAME/.ssh/id_rsa ]; then
  3817. shred -zu $USB_MOUNT/.ssh/id_rsa
  3818. shred -zu $USB_MOUNT/.ssh/id_rsa.pub
  3819. shred -zu $USB_MOUNT/.ssh/known_hosts
  3820. rm -rf $USB_MOUNT/.ssh
  3821. else
  3822. echo 'ssh files did not copy'
  3823. exit 8
  3824. fi
  3825. fi
  3826. if [ -f $USB_MOUNT/.emacs ]; then
  3827. echo 'Importing .emacs file'
  3828. cp -f $USB_MOUNT/.emacs /home/$MY_USERNAME/.emacs
  3829. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs
  3830. fi
  3831. if [ -d $USB_MOUNT/.emacs.d ]; then
  3832. echo 'Importing .emacs.d directory'
  3833. cp -r $USB_MOUNT/.emacs.d /home/$MY_USERNAME
  3834. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs.d
  3835. fi
  3836. if [ -d $USB_MOUNT/ssl ]; then
  3837. echo 'Importing SSL certificates'
  3838. cp -r $USB_MOUNT/ssl/* /etc/ssl
  3839. chmod 640 /etc/ssl/certs/*
  3840. chmod 400 /etc/ssl/private/*
  3841. # change ownership of some certificates
  3842. if [ -d /etc/prosody ]; then
  3843. chown prosody:prosody /etc/ssl/private/xmpp.*
  3844. chown prosody:prosody /etc/ssl/certs/xmpp.*
  3845. fi
  3846. if [ -d /etc/dovecot ]; then
  3847. chown root:dovecot /etc/ssl/certs/dovecot.*
  3848. chown root:dovecot /etc/ssl/private/dovecot.*
  3849. fi
  3850. if [ -f /etc/ssl/private/exim.key ]; then
  3851. chown root:Debian-exim /etc/ssl/private/exim.key /etc/ssl/certs/exim.crt /etc/ssl/certs/exim.dhparam
  3852. fi
  3853. fi
  3854. if [ -d $USB_MOUNT/personal ]; then
  3855. echo 'Importing personal directory'
  3856. cp -r $USB_MOUNT/personal /home/$MY_USERNAME
  3857. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/personal
  3858. fi
  3859. else
  3860. if [ -d $USB_MOUNT ]; then
  3861. umount $USB_MOUNT
  3862. rm -rf $USB_MOUNT
  3863. fi
  3864. echo 'No USB drive attached'
  3865. fi
  3866. echo 'search_for_attached_usb_drive' >> $COMPLETION_FILE
  3867. }
  3868. function remove_proprietary_repos {
  3869. if grep -Fxq "remove_proprietary_repos" $COMPLETION_FILE; then
  3870. return
  3871. fi
  3872. sed -i 's/ non-free//g' /etc/apt/sources.list
  3873. echo 'remove_proprietary_repos' >> $COMPLETION_FILE
  3874. }
  3875. function change_debian_repos {
  3876. if grep -Fxq "change_debian_repos" $COMPLETION_FILE; then
  3877. return
  3878. fi
  3879. rm -rf /var/lib/apt/lists/*
  3880. apt-get clean
  3881. sed -i "s/ftp.us.debian.org/$DEBIAN_REPO/g" /etc/apt/sources.list
  3882. # ensure that there is a security repo
  3883. if ! grep -q "security" /etc/apt/sources.list; then
  3884. echo "deb http://security.debian.org/ $DEBIAN_VERSION/updates main contrib" >> /etc/apt/sources.list
  3885. echo "#deb-src http://security.debian.org/ $DEBIAN_VERSION/updates main contrib" >> /etc/apt/sources.list
  3886. fi
  3887. apt-get update
  3888. apt-get -y --force-yes install apt-transport-https
  3889. echo 'change_debian_repos' >> $COMPLETION_FILE
  3890. }
  3891. function initial_setup {
  3892. if grep -Fxq "initial_setup" $COMPLETION_FILE; then
  3893. return
  3894. fi
  3895. apt-get -y remove --purge apache*
  3896. apt-get -y dist-upgrade
  3897. apt-get -y install ca-certificates emacs24 cpulimit
  3898. echo 'initial_setup' >> $COMPLETION_FILE
  3899. }
  3900. function install_editor {
  3901. if grep -Fxq "install_editor" $COMPLETION_FILE; then
  3902. return
  3903. fi
  3904. update-alternatives --set editor /usr/bin/emacs24
  3905. # A minimal emacs configuration
  3906. #echo -n "(add-to-list 'load-path " > /home/$MY_USERNAME/.emacs
  3907. #echo '"~/.emacs.d/")' >> /home/$MY_USERNAME/.emacs
  3908. #echo '' >> /home/$MY_USERNAME/.emacs
  3909. echo ';; ===== Remove trailing whitepace ======================================' >> /home/$MY_USERNAME/.emacs
  3910. echo '' >> /home/$MY_USERNAME/.emacs
  3911. echo ";;(add-hook 'before-save-hook 'delete-trailing-whitespace)" >> /home/$MY_USERNAME/.emacs
  3912. echo '' >> /home/$MY_USERNAME/.emacs
  3913. echo ';; Goto a line number with CTRL-l' >> /home/$MY_USERNAME/.emacs
  3914. echo -n '(global-set-key "\C-l" ' >> /home/$MY_USERNAME/.emacs
  3915. echo "'goto-line)" >> /home/$MY_USERNAME/.emacs
  3916. echo '' >> /home/$MY_USERNAME/.emacs
  3917. echo ';; ===== Show line numbers ==============================================' >> /home/$MY_USERNAME/.emacs
  3918. echo '' >> /home/$MY_USERNAME/.emacs
  3919. echo "(add-hook 'find-file-hook (lambda () (linum-mode 1)))" >> /home/$MY_USERNAME/.emacs
  3920. echo '' >> /home/$MY_USERNAME/.emacs
  3921. echo ';; ===== Enable line wrapping in org-mode ===============================' >> /home/$MY_USERNAME/.emacs
  3922. echo '' >> /home/$MY_USERNAME/.emacs
  3923. echo " (add-hook 'org-mode-hook" >> /home/$MY_USERNAME/.emacs
  3924. echo " '(lambda ()" >> /home/$MY_USERNAME/.emacs
  3925. echo " (visual-line-mode 1)))" >> /home/$MY_USERNAME/.emacs
  3926. echo '' >> /home/$MY_USERNAME/.emacs
  3927. echo ';; ===== Enable shift select in org mode ================================' >> /home/$MY_USERNAME/.emacs
  3928. echo '' >> /home/$MY_USERNAME/.emacs
  3929. echo '(setq org-support-shift-select t)' >> /home/$MY_USERNAME/.emacs
  3930. echo '' >> /home/$MY_USERNAME/.emacs
  3931. echo ';; ===== Set standard indent to 4 rather that 4 =========================' >> /home/$MY_USERNAME/.emacs
  3932. echo '' >> /home/$MY_USERNAME/.emacs
  3933. echo '(setq standard-indent 4)' >> /home/$MY_USERNAME/.emacs
  3934. echo '(setq-default tab-width 4)' >> /home/$MY_USERNAME/.emacs
  3935. echo '(setq c-basic-offset 4)' >> /home/$MY_USERNAME/.emacs
  3936. echo '' >> /home/$MY_USERNAME/.emacs
  3937. echo ';; ===== Support Wheel Mouse Scrolling ==================================' >> /home/$MY_USERNAME/.emacs
  3938. echo '' >> /home/$MY_USERNAME/.emacs
  3939. echo '(mouse-wheel-mode t)' >> /home/$MY_USERNAME/.emacs
  3940. echo '' >> /home/$MY_USERNAME/.emacs
  3941. echo ';; ===== Place Backup Files in Specific Directory =======================' >> /home/$MY_USERNAME/.emacs
  3942. echo '' >> /home/$MY_USERNAME/.emacs
  3943. echo '(setq make-backup-files t)' >> /home/$MY_USERNAME/.emacs
  3944. echo '(setq version-control t)' >> /home/$MY_USERNAME/.emacs
  3945. echo '(setq backup-directory-alist (quote ((".*" . "~/.emacs_backups/"))))' >> /home/$MY_USERNAME/.emacs
  3946. echo '' >> /home/$MY_USERNAME/.emacs
  3947. echo ';; ===== Make Text mode the default mode for new buffers ================' >> /home/$MY_USERNAME/.emacs
  3948. echo '' >> /home/$MY_USERNAME/.emacs
  3949. echo "(setq default-major-mode 'text-mode)" >> /home/$MY_USERNAME/.emacs
  3950. echo '' >> /home/$MY_USERNAME/.emacs
  3951. echo ';; ===== Line length ====================================================' >> /home/$MY_USERNAME/.emacs
  3952. echo '' >> /home/$MY_USERNAME/.emacs
  3953. echo '(setq-default fill-column 72)' >> /home/$MY_USERNAME/.emacs
  3954. echo '' >> /home/$MY_USERNAME/.emacs
  3955. echo ';; ===== Enable Line and Column Numbering ===============================' >> /home/$MY_USERNAME/.emacs
  3956. echo '' >> /home/$MY_USERNAME/.emacs
  3957. echo '(line-number-mode 1)' >> /home/$MY_USERNAME/.emacs
  3958. echo '(column-number-mode 1)' >> /home/$MY_USERNAME/.emacs
  3959. echo '' >> /home/$MY_USERNAME/.emacs
  3960. echo ';; ===== Turn on Auto Fill mode automatically in all modes ==============' >> /home/$MY_USERNAME/.emacs
  3961. echo '' >> /home/$MY_USERNAME/.emacs
  3962. echo ';; Auto-fill-mode the the automatic wrapping of lines and insertion of' >> /home/$MY_USERNAME/.emacs
  3963. echo ';; newlines when the cursor goes over the column limit.' >> /home/$MY_USERNAME/.emacs
  3964. echo '' >> /home/$MY_USERNAME/.emacs
  3965. echo ';; This should actually turn on auto-fill-mode by default in all major' >> /home/$MY_USERNAME/.emacs
  3966. echo ';; modes. The other way to do this is to turn on the fill for specific modes' >> /home/$MY_USERNAME/.emacs
  3967. echo ';; via hooks.' >> /home/$MY_USERNAME/.emacs
  3968. echo '' >> /home/$MY_USERNAME/.emacs
  3969. echo '(setq auto-fill-mode 1)' >> /home/$MY_USERNAME/.emacs
  3970. echo '' >> /home/$MY_USERNAME/.emacs
  3971. echo ';; ===== Enable GPG encryption =========================================' >> /home/$MY_USERNAME/.emacs
  3972. echo '' >> /home/$MY_USERNAME/.emacs
  3973. echo "(require 'epa)" >> /home/$MY_USERNAME/.emacs
  3974. echo '(epa-file-enable)' >> /home/$MY_USERNAME/.emacs
  3975. cp /home/$MY_USERNAME/.emacs /root/.emacs
  3976. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs
  3977. echo 'install_editor' >> $COMPLETION_FILE
  3978. }
  3979. function enable_backports {
  3980. if grep -Fxq "enable_backports" $COMPLETION_FILE; then
  3981. return
  3982. fi
  3983. if ! grep -Fxq "deb http://$DEBIAN_REPO/debian $DEBIAN_VERSION-backports main" /etc/apt/sources.list; then
  3984. echo "deb http://$DEBIAN_REPO/debian $DEBIAN_VERSION-backports main" >> /etc/apt/sources.list
  3985. fi
  3986. echo 'enable_backports' >> $COMPLETION_FILE
  3987. }
  3988. function update_the_kernel {
  3989. if grep -Fxq "update_the_kernel" $COMPLETION_FILE; then
  3990. return
  3991. fi
  3992. # if this is not a beaglebone or is a docker container
  3993. # then just use the standard kernel
  3994. if [[ $INSTALLED_WITHIN_DOCKER == "yes" || $INSTALLING_ON_BBB != "yes" ]]; then
  3995. return
  3996. fi
  3997. cd /opt/scripts/tools
  3998. ./update_kernel.sh --kernel $KERNEL_VERSION
  3999. echo 'update_the_kernel' >> $COMPLETION_FILE
  4000. }
  4001. function enable_zram {
  4002. if grep -Fxq "enable_zram" $COMPLETION_FILE; then
  4003. return
  4004. fi
  4005. if [[ $INSTALLED_WITHIN_DOCKER == "yes" || $INSTALLING_ON_BBB != "yes" ]]; then
  4006. return
  4007. fi
  4008. if ! grep -q "options zram num_devices=1" /etc/modprobe.d/zram.conf; then
  4009. echo 'options zram num_devices=1' >> /etc/modprobe.d/zram.conf
  4010. fi
  4011. echo '#!/bin/bash' > /etc/init.d/zram
  4012. echo '### BEGIN INIT INFO' >> /etc/init.d/zram
  4013. echo '# Provides: zram' >> /etc/init.d/zram
  4014. echo '# Required-Start:' >> /etc/init.d/zram
  4015. echo '# Required-Stop:' >> /etc/init.d/zram
  4016. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/zram
  4017. echo '# Default-Stop: 0 1 6' >> /etc/init.d/zram
  4018. echo '# Short-Description: Increased Performance In Linux With zRam (Virtual Swap Compressed in RAM)' >> /etc/init.d/zram
  4019. echo '# Description: Adapted from systemd scripts at https://github.com/mystilleef/FedoraZram' >> /etc/init.d/zram
  4020. echo '### END INIT INFO' >> /etc/init.d/zram
  4021. echo 'start() {' >> /etc/init.d/zram
  4022. echo ' # get the number of CPUs' >> /etc/init.d/zram
  4023. echo ' num_cpus=$(grep -c processor /proc/cpuinfo)' >> /etc/init.d/zram
  4024. echo ' # if something goes wrong, assume we have 1' >> /etc/init.d/zram
  4025. echo ' [ "$num_cpus" != 0 ] || num_cpus=1' >> /etc/init.d/zram
  4026. echo ' # set decremented number of CPUs' >> /etc/init.d/zram
  4027. echo ' decr_num_cpus=$((num_cpus - 1))' >> /etc/init.d/zram
  4028. echo ' # get the amount of memory in the machine' >> /etc/init.d/zram
  4029. echo ' mem_total_kb=$(grep MemTotal /proc/meminfo | grep -E --only-matching "[[:digit:]]+")' >> /etc/init.d/zram
  4030. echo ' mem_total=$((mem_total_kb * 1024))' >> /etc/init.d/zram
  4031. echo ' # load dependency modules' >> /etc/init.d/zram
  4032. echo ' modprobe zram num_devices=$num_cpus' >> /etc/init.d/zram
  4033. echo ' # initialize the devices' >> /etc/init.d/zram
  4034. echo ' for i in $(seq 0 $decr_num_cpus); do' >> /etc/init.d/zram
  4035. echo ' echo $((mem_total / num_cpus)) > /sys/block/zram$i/disksize' >> /etc/init.d/zram
  4036. echo ' done' >> /etc/init.d/zram
  4037. echo ' # Creating swap filesystems' >> /etc/init.d/zram
  4038. echo ' for i in $(seq 0 $decr_num_cpus); do' >> /etc/init.d/zram
  4039. echo ' mkswap /dev/zram$i' >> /etc/init.d/zram
  4040. echo ' done' >> /etc/init.d/zram
  4041. echo ' # Switch the swaps on' >> /etc/init.d/zram
  4042. echo ' for i in $(seq 0 $decr_num_cpus); do' >> /etc/init.d/zram
  4043. echo ' swapon -p 100 /dev/zram$i' >> /etc/init.d/zram
  4044. echo ' done' >> /etc/init.d/zram
  4045. echo '}' >> /etc/init.d/zram
  4046. echo 'stop() {' >> /etc/init.d/zram
  4047. echo ' # get the number of CPUs' >> /etc/init.d/zram
  4048. echo ' num_cpus=$(grep -c processor /proc/cpuinfo)' >> /etc/init.d/zram
  4049. echo ' # set decremented number of CPUs' >> /etc/init.d/zram
  4050. echo ' decr_num_cpus=$((num_cpus - 1))' >> /etc/init.d/zram
  4051. echo ' # Switching off swap' >> /etc/init.d/zram
  4052. echo ' for i in $(seq 0 $decr_num_cpus); do' >> /etc/init.d/zram
  4053. echo ' if [ "$(grep /dev/zram$i /proc/swaps)" != "" ]; then' >> /etc/init.d/zram
  4054. echo ' swapoff /dev/zram$i' >> /etc/init.d/zram
  4055. echo ' sleep 1' >> /etc/init.d/zram
  4056. echo ' fi' >> /etc/init.d/zram
  4057. echo ' done' >> /etc/init.d/zram
  4058. echo ' sleep 1' >> /etc/init.d/zram
  4059. echo ' rmmod zram' >> /etc/init.d/zram
  4060. echo '}' >> /etc/init.d/zram
  4061. echo 'case "$1" in' >> /etc/init.d/zram
  4062. echo ' start)' >> /etc/init.d/zram
  4063. echo ' start' >> /etc/init.d/zram
  4064. echo ' ;;' >> /etc/init.d/zram
  4065. echo ' stop)' >> /etc/init.d/zram
  4066. echo ' stop' >> /etc/init.d/zram
  4067. echo ' ;;' >> /etc/init.d/zram
  4068. echo ' restart)' >> /etc/init.d/zram
  4069. echo ' stop' >> /etc/init.d/zram
  4070. echo ' sleep 3' >> /etc/init.d/zram
  4071. echo ' start' >> /etc/init.d/zram
  4072. echo ' ;;' >> /etc/init.d/zram
  4073. echo ' *)' >> /etc/init.d/zram
  4074. echo ' echo "Usage: $0 {start|stop|restart}"' >> /etc/init.d/zram
  4075. echo ' RETVAL=1' >> /etc/init.d/zram
  4076. echo 'esac' >> /etc/init.d/zram
  4077. echo 'exit $RETVAL' >> /etc/init.d/zram
  4078. chmod +x /etc/init.d/zram
  4079. update-rc.d zram defaults
  4080. echo 'enable_zram' >> $COMPLETION_FILE
  4081. }
  4082. function random_number_generator {
  4083. if grep -Fxq "random_number_generator" $COMPLETION_FILE; then
  4084. return
  4085. fi
  4086. if [[ $INSTALLING_ON_BBB != "yes" ]]; then
  4087. # On systems which are not beaglebones assume that
  4088. # no hardware random number generator is available
  4089. # and use the second best option
  4090. apt-get -y --force-yes install haveged
  4091. return
  4092. fi
  4093. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4094. # it is assumed that docker uses the random number
  4095. # generator of the host system
  4096. return
  4097. fi
  4098. if [[ $USE_HWRNG == "yes" ]]; then
  4099. apt-get -y --force-yes install rng-tools
  4100. sed -i 's|#HRNGDEVICE=/dev/hwrng|HRNGDEVICE=/dev/hwrng|g' /etc/default/rng-tools
  4101. else
  4102. apt-get -y --force-yes install haveged
  4103. fi
  4104. echo 'random_number_generator' >> $COMPLETION_FILE
  4105. }
  4106. function configure_ssh {
  4107. if grep -Fxq "configure_ssh" $COMPLETION_FILE; then
  4108. return
  4109. fi
  4110. sed -i "s/Port .*/Port $SSH_PORT/g" /etc/ssh/sshd_config
  4111. sed -i 's/PermitRootLogin.*/PermitRootLogin no/g' /etc/ssh/sshd_config
  4112. sed -i 's/X11Forwarding.*/X11Forwarding no/g' /etc/ssh/sshd_config
  4113. sed -i 's/ServerKeyBits.*/ServerKeyBits 4096/g' /etc/ssh/sshd_config
  4114. sed -i 's/TCPKeepAlive.*/TCPKeepAlive no/g' /etc/ssh/sshd_config
  4115. sed -i 's|HostKey /etc/ssh/ssh_host_dsa_key|#HostKey /etc/ssh/ssh_host_dsa_key|g' /etc/ssh/sshd_config
  4116. sed -i 's|HostKey /etc/ssh/ssh_host_ecdsa_key|#HostKey /etc/ssh/ssh_host_ecdsa_key|g' /etc/ssh/sshd_config
  4117. if grep -q 'ClientAliveInterval' /etc/ssh/sshd_config; then
  4118. sed -i 's/ClientAliveInterval.*/ClientAliveInterval 60/g' /etc/ssh/sshd_config
  4119. else
  4120. echo 'ClientAliveInterval 60' >> /etc/ssh/sshd_config
  4121. fi
  4122. if grep -q 'ClientAliveCountMax' /etc/ssh/sshd_config; then
  4123. sed -i 's/ClientAliveCountMax.*/ClientAliveCountMax 3/g' /etc/ssh/sshd_config
  4124. else
  4125. echo 'ClientAliveCountMax 3' >> /etc/ssh/sshd_config
  4126. fi
  4127. if grep -q 'Ciphers' /etc/ssh/sshd_config; then
  4128. sed -i "s|Ciphers.*|Ciphers $SSH_CIPHERS|g" /etc/ssh/sshd_config
  4129. else
  4130. echo "Ciphers $SSH_CIPHERS" >> /etc/ssh/sshd_config
  4131. fi
  4132. if grep -q 'MACs' /etc/ssh/sshd_config; then
  4133. sed -i "s|MACs.*|MACs $SSH_MACS|g" /etc/ssh/sshd_config
  4134. else
  4135. echo "MACs $SSH_MACS" >> /etc/ssh/sshd_config
  4136. fi
  4137. if grep -q 'KexAlgorithms' /etc/ssh/sshd_config; then
  4138. sed -i "s|KexAlgorithms.*|KexAlgorithms $SSH_KEX|g" /etc/ssh/sshd_config
  4139. else
  4140. echo "KexAlgorithms $SSH_KEX" >> /etc/ssh/sshd_config
  4141. fi
  4142. apt-get -y --force-yes install fail2ban
  4143. echo 'configure_ssh' >> $COMPLETION_FILE
  4144. # Don't reboot if installing within docker
  4145. # random numbers will come from the host system
  4146. if [[ $INSTALLED_WITHIN_DOCKER == "yes" || $INSTALLING_ON_BBB != "yes" ]]; then
  4147. return
  4148. fi
  4149. echo ''
  4150. echo ''
  4151. echo ' *** Rebooting to initialise ssh settings and random number generator ***'
  4152. echo ''
  4153. echo " *** Reconnect via ssh on port $SSH_PORT, then run this script again ***"
  4154. echo ''
  4155. reboot
  4156. }
  4157. function regenerate_ssh_keys {
  4158. if grep -Fxq "regenerate_ssh_keys" $COMPLETION_FILE; then
  4159. return
  4160. fi
  4161. rm -f /etc/ssh/ssh_host_*
  4162. dpkg-reconfigure openssh-server
  4163. service ssh restart
  4164. echo 'regenerate_ssh_keys' >> $COMPLETION_FILE
  4165. }
  4166. function configure_dns {
  4167. if grep -Fxq "configure_dns" $COMPLETION_FILE; then
  4168. return
  4169. fi
  4170. echo 'domain localdomain' > /etc/resolv.conf
  4171. echo 'search localdomain' >> /etc/resolv.conf
  4172. echo 'nameserver 213.73.91.35' >> /etc/resolv.conf
  4173. echo 'nameserver 85.214.20.141' >> /etc/resolv.conf
  4174. echo 'configure_dns' >> $COMPLETION_FILE
  4175. }
  4176. function set_your_domain_name {
  4177. if grep -Fxq "set_your_domain_name" $COMPLETION_FILE; then
  4178. return
  4179. fi
  4180. echo "$DOMAIN_NAME" > /etc/hostname
  4181. hostname $DOMAIN_NAME
  4182. sed -i "s/127.0.1.1 arm/127.0.1.1 $DOMAIN_NAME/g" /etc/hosts
  4183. echo "127.0.1.1 $DOMAIN_NAME" >> /etc/hosts
  4184. echo 'set_your_domain_name' >> $COMPLETION_FILE
  4185. }
  4186. function time_synchronisation {
  4187. if grep -Fxq "time_synchronisation" $COMPLETION_FILE; then
  4188. return
  4189. fi
  4190. #apt-get -y --force-yes install tlsdate
  4191. # building tlsdate from source is a workaround because of
  4192. # this bug https://github.com/ioerror/tlsdate/issues/130
  4193. apt-get -y --force-yes install build-essential automake git pkg-config autoconf libtool libssl-dev libevent-dev
  4194. if [ ! -d $INSTALL_DIR ]; then
  4195. mkdir $INSTALL_DIR
  4196. fi
  4197. cd $INSTALL_DIR
  4198. git clone https://github.com/ioerror/tlsdate.git
  4199. cd $INSTALL_DIR/tlsdate
  4200. ./autogen.sh
  4201. ./configure
  4202. make
  4203. make install
  4204. cp /usr/local/bin/tlsdate* /usr/bin
  4205. cp /usr/local/sbin/tlsdate* /usr/bin
  4206. apt-get -y remove ntpdate
  4207. echo '#!/bin/bash' > /usr/bin/updatedate
  4208. echo "TIMESOURCE='TLS_TIME_SOURCE1'" >> /usr/bin/updatedate
  4209. echo "TIMESOURCE2='TLS_TIME_SOURCE2'" >> /usr/bin/updatedate
  4210. echo 'LOGFILE=/var/log/tlsdate.log' >> /usr/bin/updatedate
  4211. echo 'TIMEOUT=5' >> /usr/bin/updatedate
  4212. echo "EMAIL=$MY_EMAIL_ADDRESS" >> /usr/bin/updatedate
  4213. echo '# File which contains the previous date as a number' >> /usr/bin/updatedate
  4214. echo 'BEFORE_DATE_FILE=/var/log/tlsdateprevious.txt' >> /usr/bin/updatedate
  4215. echo '# File which contains the previous date as a string' >> /usr/bin/updatedate
  4216. echo 'BEFORE_FULLDATE_FILE=/var/log/tlsdate.txt' >> /usr/bin/updatedate
  4217. echo 'DATE_BEFORE=$(date)' >> /usr/bin/updatedate
  4218. echo 'BEFORE=$(date -d "$Y-$M-$D" "+%s")' >> /usr/bin/updatedate
  4219. echo 'BACKWARDS_BETWEEN=0' >> /usr/bin/updatedate
  4220. echo '# If the date was previously set' >> /usr/bin/updatedate
  4221. echo 'if [ -f "$BEFORE_DATE_FILE" ]; then' >> /usr/bin/updatedate
  4222. echo ' BEFORE_FILE=$(cat $BEFORE_DATE_FILE)' >> /usr/bin/updatedate
  4223. echo ' BEFORE_FULLDATE=$(cat $BEFORE_FULLDATE_FILE)' >> /usr/bin/updatedate
  4224. echo ' # is the date going backwards?' >> /usr/bin/updatedate
  4225. echo ' if (( $BEFORE_FILE > $BEFORE )); then' >> /usr/bin/updatedate
  4226. echo ' echo -n "Date went backwards between tlsdate updates. " >> $LOGFILE' >> /usr/bin/updatedate
  4227. echo ' echo -n "$BEFORE_FILE > $BEFORE, " >> $LOGFILE' >> /usr/bin/updatedate
  4228. echo ' echo "$BEFORE_FULLDATE > $DATE_BEFORE" >> $LOGFILE' >> /usr/bin/updatedate
  4229. echo ' # Send a warning email' >> /usr/bin/updatedate
  4230. echo ' echo $(tail $LOGFILE -n 2) | mail -s "tlsdate anomaly" $EMAIL' >> /usr/bin/updatedate
  4231. echo ' # Try another time source' >> /usr/bin/updatedate
  4232. echo ' TIMESOURCE=$TIMESOURCE2' >> /usr/bin/updatedate
  4233. echo ' # try running without any parameters' >> /usr/bin/updatedate
  4234. echo ' tlsdate >> $LOGFILE' >> /usr/bin/updatedate
  4235. echo ' BACKWARDS_BETWEEN=1' >> /usr/bin/updatedate
  4236. echo ' fi' >> /usr/bin/updatedate
  4237. echo 'fi' >> /usr/bin/updatedate
  4238. echo '# Set the date' >> /usr/bin/updatedate
  4239. echo '/usr/bin/timeout $TIMEOUT tlsdate -l -t -H $TIMESOURCE -p 443 >> $LOGFILE' >> /usr/bin/updatedate
  4240. echo 'DATE_AFTER=$(date)' >> /usr/bin/updatedate
  4241. echo 'AFTER=$(date -d "$Y-$M-$D" '+%s')' >> /usr/bin/updatedate
  4242. echo '# After setting the date did it go backwards?' >> /usr/bin/updatedate
  4243. echo 'if (( $AFTER < $BEFORE )); then' >> /usr/bin/updatedate
  4244. echo ' echo "Incorrect date: $DATE_BEFORE -> $DATE_AFTER" >> $LOGFILE' >> /usr/bin/updatedate
  4245. echo ' # Send a warning email' >> /usr/bin/updatedate
  4246. echo ' echo $(tail $LOGFILE -n 2) | mail -s "tlsdate anomaly" $EMAIL' >> /usr/bin/updatedate
  4247. echo ' # Try resetting the date from another time source' >> /usr/bin/updatedate
  4248. echo ' /usr/bin/timeout $TIMEOUT tlsdate -l -t -H $TIMESOURCE2 -p 443 >> $LOGFILE' >> /usr/bin/updatedate
  4249. echo ' DATE_AFTER=$(date)' >> /usr/bin/updatedate
  4250. echo ' AFTER=$(date -d "$Y-$M-$D" "+%s")' >> /usr/bin/updatedate
  4251. echo 'else' >> /usr/bin/updatedate
  4252. echo ' echo -n $TIMESOURCE >> $LOGFILE' >> /usr/bin/updatedate
  4253. echo ' if [ -f "$BEFORE_DATE_FILE" ]; then' >> /usr/bin/updatedate
  4254. echo ' echo -n " " >> $LOGFILE' >> /usr/bin/updatedate
  4255. echo ' echo -n $BEFORE_FILE >> $LOGFILE' >> /usr/bin/updatedate
  4256. echo ' fi' >> /usr/bin/updatedate
  4257. echo ' echo -n " " >> $LOGFILE' >> /usr/bin/updatedate
  4258. echo ' echo -n $BEFORE >> $LOGFILE' >> /usr/bin/updatedate
  4259. echo ' echo -n " " >> $LOGFILE' >> /usr/bin/updatedate
  4260. echo ' echo -n $AFTER >> $LOGFILE' >> /usr/bin/updatedate
  4261. echo ' echo -n " " >> $LOGFILE' >> /usr/bin/updatedate
  4262. echo ' echo $DATE_AFTER >> $LOGFILE' >> /usr/bin/updatedate
  4263. echo 'fi' >> /usr/bin/updatedate
  4264. echo '# Log the last date' >> /usr/bin/updatedate
  4265. echo 'if [[ $BACKWARDS_BETWEEN == 0 ]]; then' >> /usr/bin/updatedate
  4266. echo ' echo "$AFTER" > $BEFORE_DATE_FILE' >> /usr/bin/updatedate
  4267. echo ' echo "$DATE_AFTER" > $BEFORE_FULLDATE_FILE' >> /usr/bin/updatedate
  4268. echo ' exit 0' >> /usr/bin/updatedate
  4269. echo 'else' >> /usr/bin/updatedate
  4270. echo ' exit 1' >> /usr/bin/updatedate
  4271. echo 'fi' >> /usr/bin/updatedate
  4272. chmod +x /usr/bin/updatedate
  4273. echo '*/15 * * * * root /usr/bin/updatedate' >> /etc/crontab
  4274. service cron restart
  4275. echo '#!/bin/bash' > /etc/init.d/tlsdate
  4276. echo '# /etc/init.d/tlsdate' >> /etc/init.d/tlsdate
  4277. echo '### BEGIN INIT INFO' >> /etc/init.d/tlsdate
  4278. echo '# Provides: tlsdate' >> /etc/init.d/tlsdate
  4279. echo '# Required-Start: $remote_fs $syslog' >> /etc/init.d/tlsdate
  4280. echo '# Required-Stop: $remote_fs $syslog' >> /etc/init.d/tlsdate
  4281. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/tlsdate
  4282. echo '# Default-Stop: 0 1 6' >> /etc/init.d/tlsdate
  4283. echo '# Short-Description: Initially calls tlsdate with the timewarp option' >> /etc/init.d/tlsdate
  4284. echo '# Description: Initially calls tlsdate with the timewarp option' >> /etc/init.d/tlsdate
  4285. echo '### END INIT INFO' >> /etc/init.d/tlsdate
  4286. echo '# Author: Bob Mottram <bob@robotics.uk.to>' >> /etc/init.d/tlsdate
  4287. echo 'PATH="/usr/local/sbin:/usr/local/bin:/usr/bin:/sbin:/usr/sbin:/bin"' >> /etc/init.d/tlsdate
  4288. echo 'LOGFILE="/var/log/tlsdate.log"' >> /etc/init.d/tlsdate
  4289. echo 'TLSDATECOMMAND="tlsdate --timewarp -l -H www.ptb.de -p 443 >> $LOGFILE"' >> /etc/init.d/tlsdate
  4290. echo '#Start-Stop here' >> /etc/init.d/tlsdate
  4291. echo 'case "$1" in' >> /etc/init.d/tlsdate
  4292. echo ' start)' >> /etc/init.d/tlsdate
  4293. echo ' echo "tlsdate started"' >> /etc/init.d/tlsdate
  4294. echo ' $TLSDATECOMMAND' >> /etc/init.d/tlsdate
  4295. echo ' ;;' >> /etc/init.d/tlsdate
  4296. echo ' stop)' >> /etc/init.d/tlsdate
  4297. echo ' echo "tlsdate stopped"' >> /etc/init.d/tlsdate
  4298. echo ' ;;' >> /etc/init.d/tlsdate
  4299. echo ' restart)' >> /etc/init.d/tlsdate
  4300. echo ' echo "tlsdate restarted"' >> /etc/init.d/tlsdate
  4301. echo ' $TLSDATECOMMAND' >> /etc/init.d/tlsdate
  4302. echo ' ;;' >> /etc/init.d/tlsdate
  4303. echo ' *)' >> /etc/init.d/tlsdate
  4304. echo ' echo "Usage: $0 {start|stop|restart}"' >> /etc/init.d/tlsdate
  4305. echo ' exit 1' >> /etc/init.d/tlsdate
  4306. echo ' ;;' >> /etc/init.d/tlsdate
  4307. echo 'esac' >> /etc/init.d/tlsdate
  4308. echo 'exit 0' >> /etc/init.d/tlsdate
  4309. chmod +x /etc/init.d/tlsdate
  4310. update-rc.d tlsdate defaults
  4311. echo 'time_synchronisation' >> $COMPLETION_FILE
  4312. }
  4313. function configure_firewall {
  4314. if grep -Fxq "configure_firewall" $COMPLETION_FILE; then
  4315. return
  4316. fi
  4317. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4318. # docker does its own firewalling
  4319. return
  4320. fi
  4321. iptables -P INPUT ACCEPT
  4322. ip6tables -P INPUT ACCEPT
  4323. iptables -F
  4324. ip6tables -F
  4325. iptables -t nat -F
  4326. ip6tables -t nat -F
  4327. iptables -X
  4328. ip6tables -X
  4329. iptables -P INPUT DROP
  4330. ip6tables -P INPUT DROP
  4331. iptables -A INPUT -i lo -j ACCEPT
  4332. iptables -A INPUT -i eth0 -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT
  4333. # Make sure incoming tcp connections are SYN packets
  4334. iptables -A INPUT -p tcp ! --syn -m state --state NEW -j DROP
  4335. # Drop packets with incoming fragments
  4336. iptables -A INPUT -f -j DROP
  4337. # Drop bogons
  4338. iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP
  4339. iptables -A INPUT -p tcp --tcp-flags ALL FIN,PSH,URG -j DROP
  4340. iptables -A INPUT -p tcp --tcp-flags ALL SYN,RST,ACK,FIN,URG -j DROP
  4341. # Incoming malformed NULL packets:
  4342. iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP
  4343. echo 'configure_firewall' >> $COMPLETION_FILE
  4344. }
  4345. function save_firewall_settings {
  4346. iptables-save > /etc/firewall.conf
  4347. ip6tables-save > /etc/firewall6.conf
  4348. printf '#!/bin/sh\n' > /etc/network/if-up.d/iptables
  4349. printf 'iptables-restore < /etc/firewall.conf\n' >> /etc/network/if-up.d/iptables
  4350. printf 'ip6tables-restore < /etc/firewall6.conf\n' >> /etc/network/if-up.d/iptables
  4351. chmod +x /etc/network/if-up.d/iptables
  4352. }
  4353. function configure_firewall_for_cjdns {
  4354. if grep -Fxq "configure_firewall_for_cjdns" $COMPLETION_FILE; then
  4355. return
  4356. fi
  4357. if [[ $ENABLE_CJDNS != "yes" ]]; then
  4358. return
  4359. fi
  4360. ip6tables -t nat -A POSTROUTING -o tun0 -j MASQUERADE
  4361. ip6tables -A FORWARD -i tun0 -o eth0 -m state --state RELATED,ESTABLISHED -j ACCEPT
  4362. save_firewall_settings
  4363. echo 'configure_firewall_for_cjdns' >> $COMPLETION_FILE
  4364. }
  4365. function configure_firewall_for_dlna {
  4366. if grep -Fxq "configure_firewall_for_dlna" $COMPLETION_FILE; then
  4367. return
  4368. fi
  4369. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4370. # docker does its own firewalling
  4371. return
  4372. fi
  4373. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4374. return
  4375. fi
  4376. iptables -A INPUT -i eth0 -p udp --dport 1900 -j ACCEPT
  4377. iptables -A INPUT -i eth0 -p tcp --dport 8200 -j ACCEPT
  4378. save_firewall_settings
  4379. echo 'configure_firewall_for_dlna' >> $COMPLETION_FILE
  4380. }
  4381. function configure_firewall_for_dns {
  4382. if grep -Fxq "configure_firewall_for_dns" $COMPLETION_FILE; then
  4383. return
  4384. fi
  4385. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4386. # docker does its own firewalling
  4387. return
  4388. fi
  4389. iptables -A INPUT -i eth0 -p udp -m udp --dport 1024:65535 --sport 53 -j ACCEPT
  4390. save_firewall_settings
  4391. echo 'configure_firewall_for_dns' >> $COMPLETION_FILE
  4392. }
  4393. function configure_firewall_for_xmpp {
  4394. if [ ! -d /etc/prosody ]; then
  4395. return
  4396. fi
  4397. if grep -Fxq "configure_firewall_for_xmpp" $COMPLETION_FILE; then
  4398. return
  4399. fi
  4400. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4401. # docker does its own firewalling
  4402. return
  4403. fi
  4404. iptables -A INPUT -i eth0 -p tcp --dport 5222:5223 -j ACCEPT
  4405. iptables -A INPUT -i eth0 -p tcp --dport 5269 -j ACCEPT
  4406. iptables -A INPUT -i eth0 -p tcp --dport 5280:5281 -j ACCEPT
  4407. save_firewall_settings
  4408. echo 'configure_firewall_for_xmpp' >> $COMPLETION_FILE
  4409. }
  4410. function configure_firewall_for_irc {
  4411. if [ ! -d /etc/ngircd ]; then
  4412. return
  4413. fi
  4414. if grep -Fxq "configure_firewall_for_irc" $COMPLETION_FILE; then
  4415. return
  4416. fi
  4417. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4418. # docker does its own firewalling
  4419. return
  4420. fi
  4421. iptables -A INPUT -i eth0 -p tcp --dport 6697 -j ACCEPT
  4422. iptables -I INPUT -i eth0 -p tcp --dport 1024:65535 --sport 6697 -j ACCEPT
  4423. iptables -A INPUT -i eth0 -p tcp --dport 9999 -j ACCEPT
  4424. save_firewall_settings
  4425. echo 'configure_firewall_for_irc' >> $COMPLETION_FILE
  4426. }
  4427. function configure_firewall_for_ftp {
  4428. if grep -Fxq "configure_firewall_for_ftp" $COMPLETION_FILE; then
  4429. return
  4430. fi
  4431. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4432. # docker does its own firewalling
  4433. return
  4434. fi
  4435. iptables -I INPUT -i eth0 -p tcp --dport 1024:65535 --sport 20:21 -j ACCEPT
  4436. save_firewall_settings
  4437. echo 'configure_firewall_for_ftp' >> $COMPLETION_FILE
  4438. }
  4439. function configure_firewall_for_web_access {
  4440. if grep -Fxq "configure_firewall_for_web_access" $COMPLETION_FILE; then
  4441. return
  4442. fi
  4443. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4444. # docker does its own firewalling
  4445. return
  4446. fi
  4447. iptables -A INPUT -i eth0 -p tcp --dport 32768:61000 --sport 80 -j ACCEPT
  4448. iptables -A INPUT -i eth0 -p tcp --dport 32768:61000 --sport 443 -j ACCEPT
  4449. save_firewall_settings
  4450. echo 'configure_firewall_for_web_access' >> $COMPLETION_FILE
  4451. }
  4452. function configure_firewall_for_web_server {
  4453. if grep -Fxq "configure_firewall_for_web_server" $COMPLETION_FILE; then
  4454. return
  4455. fi
  4456. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4457. # docker does its own firewalling
  4458. return
  4459. fi
  4460. iptables -A INPUT -i eth0 -p tcp --dport 80 -j ACCEPT
  4461. iptables -A INPUT -i eth0 -p tcp --dport 443 -j ACCEPT
  4462. save_firewall_settings
  4463. echo 'configure_firewall_for_web_server' >> $COMPLETION_FILE
  4464. }
  4465. function configure_firewall_for_ssh {
  4466. if grep -Fxq "configure_firewall_for_ssh" $COMPLETION_FILE; then
  4467. return
  4468. fi
  4469. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4470. # docker does its own firewalling
  4471. return
  4472. fi
  4473. iptables -A INPUT -i eth0 -p tcp --dport 22 -j ACCEPT
  4474. iptables -A INPUT -i eth0 -p tcp --dport $SSH_PORT -j ACCEPT
  4475. save_firewall_settings
  4476. echo 'configure_firewall_for_ssh' >> $COMPLETION_FILE
  4477. }
  4478. function configure_firewall_for_git {
  4479. if grep -Fxq "configure_firewall_for_git" $COMPLETION_FILE; then
  4480. return
  4481. fi
  4482. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4483. # docker does its own firewalling
  4484. return
  4485. fi
  4486. iptables -A INPUT -i eth0 -p tcp --dport 9418 -j ACCEPT
  4487. save_firewall_settings
  4488. echo 'configure_firewall_for_git' >> $COMPLETION_FILE
  4489. }
  4490. function configure_firewall_for_email {
  4491. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4492. return
  4493. fi
  4494. if grep -Fxq "configure_firewall_for_email" $COMPLETION_FILE; then
  4495. return
  4496. fi
  4497. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4498. # docker does its own firewalling
  4499. return
  4500. fi
  4501. iptables -A INPUT -i eth0 -p tcp --dport 25 -j ACCEPT
  4502. iptables -A INPUT -i eth0 -p tcp --dport 587 -j ACCEPT
  4503. iptables -A INPUT -i eth0 -p tcp --dport 465 -j ACCEPT
  4504. iptables -A INPUT -i eth0 -p tcp --dport 993 -j ACCEPT
  4505. save_firewall_settings
  4506. echo 'configure_firewall_for_email' >> $COMPLETION_FILE
  4507. }
  4508. function configure_internet_protocol {
  4509. if grep -Fxq "configure_internet_protocol" $COMPLETION_FILE; then
  4510. return
  4511. fi
  4512. sed -i "s/#net.ipv4.tcp_syncookies=1/net.ipv4.tcp_syncookies=1/g" /etc/sysctl.conf
  4513. sed -i "s/#net.ipv4.conf.all.accept_redirects = 0/net.ipv4.conf.all.accept_redirects = 0/g" /etc/sysctl.conf
  4514. sed -i "s/#net.ipv6.conf.all.accept_redirects = 0/net.ipv6.conf.all.accept_redirects = 0/g" /etc/sysctl.conf
  4515. sed -i "s/#net.ipv4.conf.all.send_redirects = 0/net.ipv4.conf.all.send_redirects = 0/g" /etc/sysctl.conf
  4516. sed -i "s/#net.ipv4.conf.all.accept_source_route = 0/net.ipv4.conf.all.accept_source_route = 0/g" /etc/sysctl.conf
  4517. sed -i "s/#net.ipv6.conf.all.accept_source_route = 0/net.ipv6.conf.all.accept_source_route = 0/g" /etc/sysctl.conf
  4518. sed -i "s/#net.ipv4.conf.default.rp_filter=1/net.ipv4.conf.default.rp_filter=1/g" /etc/sysctl.conf
  4519. sed -i "s/#net.ipv4.conf.all.rp_filter=1/net.ipv4.conf.all.rp_filter=1/g" /etc/sysctl.conf
  4520. sed -i "s/#net.ipv4.ip_forward=1/net.ipv4.ip_forward=0/g" /etc/sysctl.conf
  4521. sed -i "s/#net.ipv6.conf.all.forwarding=1/net.ipv6.conf.all.forwarding=0/g" /etc/sysctl.conf
  4522. echo '# ignore pings' >> /etc/sysctl.conf
  4523. echo 'net.ipv4.icmp_echo_ignore_all = 1' >> /etc/sysctl.conf
  4524. echo 'net.ipv6.icmp_echo_ignore_all = 1' >> /etc/sysctl.conf
  4525. echo '# disable ipv6' >> /etc/sysctl.conf
  4526. echo 'net.ipv6.conf.all.disable_ipv6 = 1' >> /etc/sysctl.conf
  4527. echo 'net.ipv4.tcp_synack_retries = 2' >> /etc/sysctl.conf
  4528. echo 'net.ipv4.tcp_syn_retries = 1' >> /etc/sysctl.conf
  4529. echo '# keepalive' >> /etc/sysctl.conf
  4530. echo 'net.ipv4.tcp_keepalive_probes = 9' >> /etc/sysctl.conf
  4531. echo 'net.ipv4.tcp_keepalive_intvl = 75' >> /etc/sysctl.conf
  4532. echo 'net.ipv4.tcp_keepalive_time = 7200' >> /etc/sysctl.conf
  4533. echo 'configure_internet_protocol' >> $COMPLETION_FILE
  4534. }
  4535. function script_to_make_self_signed_certificates {
  4536. if grep -Fxq "script_to_make_self_signed_certificates" $COMPLETION_FILE; then
  4537. return
  4538. fi
  4539. echo '#!/bin/bash' > /usr/bin/makecert
  4540. echo 'HOSTNAME=$1' >> /usr/bin/makecert
  4541. echo 'COUNTRY_CODE="US"' >> /usr/bin/makecert
  4542. echo 'AREA="Free Speech Zone"' >> /usr/bin/makecert
  4543. echo 'LOCATION="Freedomville"' >> /usr/bin/makecert
  4544. echo 'ORGANISATION="Freedombone"' >> /usr/bin/makecert
  4545. echo 'UNIT="Freedombone Unit"' >> /usr/bin/makecert
  4546. echo 'if ! which openssl > /dev/null ;then' >> /usr/bin/makecert
  4547. echo ' echo "$0: openssl is not installed, exiting" 1>&2' >> /usr/bin/makecert
  4548. echo ' exit 1' >> /usr/bin/makecert
  4549. echo 'fi' >> /usr/bin/makecert
  4550. echo 'openssl req -x509 -nodes -days 3650 -sha256 -subj "/O=$ORGANISATION/OU=$UNIT/C=$COUNTRY_CODE/ST=$AREA/L=$LOCATION/CN=$HOSTNAME" -newkey rsa:4096 -keyout /etc/ssl/private/$HOSTNAME.key -out /etc/ssl/certs/$HOSTNAME.crt' >> /usr/bin/makecert
  4551. echo 'openssl dhparam -check -text -5 1024 -out /etc/ssl/certs/$HOSTNAME.dhparam' >> /usr/bin/makecert
  4552. echo 'chmod 400 /etc/ssl/private/$HOSTNAME.key' >> /usr/bin/makecert
  4553. echo 'chmod 640 /etc/ssl/certs/$HOSTNAME.crt' >> /usr/bin/makecert
  4554. echo 'chmod 640 /etc/ssl/certs/$HOSTNAME.dhparam' >> /usr/bin/makecert
  4555. echo 'if [ -f /etc/init.d/nginx ]; then' >> /usr/bin/makecert
  4556. echo ' /etc/init.d/nginx reload' >> /usr/bin/makecert
  4557. echo 'fi' >> /usr/bin/makecert
  4558. echo '# add the public certificate to a separate directory' >> /usr/bin/makecert
  4559. echo '# so that we can redistribute it easily' >> /usr/bin/makecert
  4560. echo 'if [ ! -d /etc/ssl/mycerts ]; then' >> /usr/bin/makecert
  4561. echo ' mkdir /etc/ssl/mycerts' >> /usr/bin/makecert
  4562. echo 'fi' >> /usr/bin/makecert
  4563. echo 'cp /etc/ssl/certs/$HOSTNAME.crt /etc/ssl/mycerts' >> /usr/bin/makecert
  4564. echo '# Create a bundle of your certificates' >> /usr/bin/makecert
  4565. echo 'cat /etc/ssl/mycerts/*.crt > /etc/ssl/freedombone-bundle.crt' >> /usr/bin/makecert
  4566. echo 'tar -czvf /etc/ssl/freedombone-certs.tar.gz /etc/ssl/mycerts/*.crt' >> /usr/bin/makecert
  4567. chmod +x /usr/bin/makecert
  4568. echo 'script_to_make_self_signed_certificates' >> $COMPLETION_FILE
  4569. }
  4570. function configure_email {
  4571. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4572. return
  4573. fi
  4574. if grep -Fxq "configure_email" $COMPLETION_FILE; then
  4575. return
  4576. fi
  4577. apt-get -y remove postfix
  4578. apt-get -y --force-yes install exim4 sasl2-bin swaks libnet-ssleay-perl procmail
  4579. if [ ! -d /etc/exim4 ]; then
  4580. echo "ERROR: Exim does not appear to have installed. $CHECK_MESSAGE"
  4581. exit 48
  4582. fi
  4583. # configure for Maildir format
  4584. sed -i 's/MAIL_DIR/#MAIL_DIR/g' /etc/login.defs
  4585. sed -i 's|#MAIL_FILE.*|MAIL_FILE Maildir/|g' /etc/login.defs
  4586. if ! grep -q "export MAIL" /etc/profile; then
  4587. echo 'export MAIL=~/Maildir' >> /etc/profile
  4588. fi
  4589. sed -i 's|pam_mail.so standard|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/login
  4590. sed -i 's|pam_mail.so standard noenv|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/sshd
  4591. sed -i 's|pam_mail.so nopen|pam_mail.so dir=~/Maildir nopen|g' /etc/pam.d/su
  4592. echo 'dc_eximconfig_configtype="internet"' > /etc/exim4/update-exim4.conf.conf
  4593. echo "dc_other_hostnames='$DOMAIN_NAME'" >> /etc/exim4/update-exim4.conf.conf
  4594. echo "dc_local_interfaces=''" >> /etc/exim4/update-exim4.conf.conf
  4595. echo "dc_readhost=''" >> /etc/exim4/update-exim4.conf.conf
  4596. echo "dc_relay_domains=''" >> /etc/exim4/update-exim4.conf.conf
  4597. echo "dc_minimaldns='false'" >> /etc/exim4/update-exim4.conf.conf
  4598. echo "dc_relay_nets='192.168.1.0/24'" >> /etc/exim4/update-exim4.conf.conf
  4599. echo "dc_smarthost=''" >> /etc/exim4/update-exim4.conf.conf
  4600. echo "CFILEMODE='644'" >> /etc/exim4/update-exim4.conf.conf
  4601. echo "dc_use_split_config='false'" >> /etc/exim4/update-exim4.conf.conf
  4602. echo "dc_hide_mailname=''" >> /etc/exim4/update-exim4.conf.conf
  4603. echo "dc_mailname_in_oh='true'" >> /etc/exim4/update-exim4.conf.conf
  4604. echo "dc_localdelivery='maildir_home'" >> /etc/exim4/update-exim4.conf.conf
  4605. update-exim4.conf
  4606. sed -i "s/START=no/START=yes/g" /etc/default/saslauthd
  4607. /etc/init.d/saslauthd start
  4608. # make a tls certificate for email
  4609. if [ ! -f /etc/ssl/private/exim.key ]; then
  4610. makecert exim
  4611. fi
  4612. cp /etc/ssl/private/exim.key /etc/exim4
  4613. cp /etc/ssl/certs/exim.crt /etc/exim4
  4614. cp /etc/ssl/certs/exim.dhparam /etc/exim4
  4615. chown root:Debian-exim /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  4616. chmod 640 /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  4617. sed -i '/login_saslauthd_server/,/.endif/ s/# *//' /etc/exim4/exim4.conf.template
  4618. sed -i "/.ifdef MAIN_HARDCODE_PRIMARY_HOSTNAME/i\MAIN_HARDCODE_PRIMARY_HOSTNAME = $DOMAIN_NAME\nMAIN_TLS_ENABLE = true" /etc/exim4/exim4.conf.template
  4619. sed -i "s|SMTPLISTENEROPTIONS=''|SMTPLISTENEROPTIONS='-oX 465:25:587 -oP /var/run/exim4/exim.pid'|g" /etc/default/exim4
  4620. if ! grep -q "tls_on_connect_ports=465" /etc/exim4/exim4.conf.template; then
  4621. sed -i '/SSL configuration for exim/i\tls_on_connect_ports=465' /etc/exim4/exim4.conf.template
  4622. fi
  4623. adduser $MY_USERNAME sasl
  4624. addgroup Debian-exim sasl
  4625. /etc/init.d/exim4 restart
  4626. if [ ! -d /etc/skel/Maildir ]; then
  4627. mkdir -m 700 /etc/skel/Maildir
  4628. mkdir -m 700 /etc/skel/Maildir/Sent
  4629. mkdir -m 700 /etc/skel/Maildir/Sent/tmp
  4630. mkdir -m 700 /etc/skel/Maildir/Sent/cur
  4631. mkdir -m 700 /etc/skel/Maildir/Sent/new
  4632. mkdir -m 700 /etc/skel/Maildir/.learn-spam
  4633. mkdir -m 700 /etc/skel/Maildir/.learn-spam/cur
  4634. mkdir -m 700 /etc/skel/Maildir/.learn-spam/new
  4635. mkdir -m 700 /etc/skel/Maildir/.learn-spam/tmp
  4636. mkdir -m 700 /etc/skel/Maildir/.learn-ham
  4637. mkdir -m 700 /etc/skel/Maildir/.learn-ham/cur
  4638. mkdir -m 700 /etc/skel/Maildir/.learn-ham/new
  4639. mkdir -m 700 /etc/skel/Maildir/.learn-ham/tmp
  4640. ln -s /etc/skel/Maildir/.learn-spam /etc/skel/Maildir/spam
  4641. ln -s /etc/skel/Maildir/.learn-ham /etc/skel/Maildir/ham
  4642. fi
  4643. if [ ! -d /home/$MY_USERNAME/Maildir ]; then
  4644. mkdir -m 700 /home/$MY_USERNAME/Maildir
  4645. mkdir -m 700 /home/$MY_USERNAME/Maildir/cur
  4646. mkdir -m 700 /home/$MY_USERNAME/Maildir/tmp
  4647. mkdir -m 700 /home/$MY_USERNAME/Maildir/new
  4648. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent
  4649. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/cur
  4650. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/tmp
  4651. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/new
  4652. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam
  4653. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/cur
  4654. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/new
  4655. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/tmp
  4656. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham
  4657. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/cur
  4658. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/new
  4659. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/tmp
  4660. ln -s /home/$MY_USERNAME/Maildir/.learn-spam /home/$MY_USERNAME/Maildir/spam
  4661. ln -s /home/$MY_USERNAME/Maildir/.learn-ham /home/$MY_USERNAME/Maildir/ham
  4662. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  4663. fi
  4664. echo 'configure_email' >> $COMPLETION_FILE
  4665. }
  4666. function create_procmail {
  4667. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4668. return
  4669. fi
  4670. if grep -Fxq "create_procmail" $COMPLETION_FILE; then
  4671. return
  4672. fi
  4673. if [ ! -f /home/$MY_USERNAME/.procmailrc ]; then
  4674. echo 'MAILDIR=$HOME/Maildir' > /home/$MY_USERNAME/.procmailrc
  4675. echo 'DEFAULT=$MAILDIR/' >> /home/$MY_USERNAME/.procmailrc
  4676. echo 'LOGFILE=$HOME/log/procmail.log' >> /home/$MY_USERNAME/.procmailrc
  4677. echo 'LOGABSTRACT=all' >> /home/$MY_USERNAME/.procmailrc
  4678. fi
  4679. echo 'create_procmail' >> $COMPLETION_FILE
  4680. }
  4681. function spam_filtering {
  4682. # NOTE: spamassassin installation currently doesn't work, sa-compile fails with a make error 23/09/2014
  4683. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4684. return
  4685. fi
  4686. if grep -Fxq "spam_filtering" $COMPLETION_FILE; then
  4687. return
  4688. fi
  4689. apt-get -y --force-yes install exim4-daemon-heavy
  4690. apt-get -y --force-yes install spamassassin
  4691. sa-update -v
  4692. sed -i 's/ENABLED=0/ENABLED=1/g' /etc/default/spamassassin
  4693. sed -i 's/# spamd_address = 127.0.0.1 783/spamd_address = 127.0.0.1 783/g' /etc/exim4/exim4.conf.template
  4694. # This configuration is based on https://wiki.debian.org/DebianSpamAssassin
  4695. sed -i 's/local_parts = postmaster/local_parts = postmaster:abuse/g' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  4696. sed -i '/domains = +local_domains : +relay_to_domains/a\ set acl_m0 = rfcnames' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  4697. sed -i 's/accept/accept condition = ${if eq{$acl_m0}{rfcnames} {1}{0}}/g' /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4698. echo 'warn message = X-Spam-Score: $spam_score ($spam_bar)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4699. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4700. echo 'warn message = X-Spam-Flag: YES' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4701. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4702. echo 'warn message = X-Spam-Report: $spam_report' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4703. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4704. echo '# reject spam at high scores (> 12)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4705. echo 'deny message = This message scored $spam_score spam points.' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4706. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4707. echo ' condition = ${if >{$spam_score_int}{120}{1}{0}}' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4708. # procmail configuration
  4709. echo '# get spamassassin to check emails' >> /home/$MY_USERNAME/.procmailrc
  4710. echo ':0fw: .spamassassin.lock' >> /home/$MY_USERNAME/.procmailrc
  4711. echo ' * < 256000' >> /home/$MY_USERNAME/.procmailrc
  4712. echo '| spamc' >> /home/$MY_USERNAME/.procmailrc
  4713. echo '# strong spam are discarded' >> /home/$MY_USERNAME/.procmailrc
  4714. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4715. echo ' * ^X-Spam-Level: \*\*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  4716. echo '/dev/null' >> /home/$MY_USERNAME/.procmailrc
  4717. echo '# weak spam are kept just in case - clear this out every now and then' >> /home/$MY_USERNAME/.procmailrc
  4718. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4719. echo ' * ^X-Spam-Level: \*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  4720. echo '.0-spam/' >> /home/$MY_USERNAME/.procmailrc
  4721. echo '# otherwise, marginal spam goes here for revision' >> /home/$MY_USERNAME/.procmailrc
  4722. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4723. echo ' * ^X-Spam-Level: \*\*' >> /home/$MY_USERNAME/.procmailrc
  4724. echo '.spam/' >> /home/$MY_USERNAME/.procmailrc
  4725. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  4726. # filtering scripts
  4727. echo '#!/bin/bash' > /usr/bin/filterspam
  4728. echo 'USERNAME=$1' >> /usr/bin/filterspam
  4729. echo 'MAILDIR=/home/$USERNAME/Maildir/.learn-spam' >> /usr/bin/filterspam
  4730. echo 'if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterspam
  4731. echo ' exit' >> /usr/bin/filterspam
  4732. echo 'fi' >> /usr/bin/filterspam
  4733. echo 'for f in `ls $MAILDIR/cur`' >> /usr/bin/filterspam
  4734. echo 'do' >> /usr/bin/filterspam
  4735. echo ' spamc -L spam < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterspam
  4736. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterspam
  4737. echo 'done' >> /usr/bin/filterspam
  4738. echo 'for f in `ls $MAILDIR/new`' >> /usr/bin/filterspam
  4739. echo 'do' >> /usr/bin/filterspam
  4740. echo ' spamc -L spam < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterspam
  4741. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterspam
  4742. echo 'done' >> /usr/bin/filterspam
  4743. echo '#!/bin/bash' > /usr/bin/filterham
  4744. echo 'USERNAME=$1' >> /usr/bin/filterham
  4745. echo 'MAILDIR=/home/$USERNAME/Maildir/.learn-ham' >> /usr/bin/filterham
  4746. echo 'if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterham
  4747. echo ' exit' >> /usr/bin/filterham
  4748. echo 'fi' >> /usr/bin/filterham
  4749. echo 'for f in `ls $MAILDIR/cur`' >> /usr/bin/filterham
  4750. echo 'do' >> /usr/bin/filterham
  4751. echo ' spamc -L ham < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterham
  4752. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterham
  4753. echo 'done' >> /usr/bin/filterham
  4754. echo 'for f in `ls $MAILDIR/new`' >> /usr/bin/filterham
  4755. echo 'do' >> /usr/bin/filterham
  4756. echo ' spamc -L ham < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterham
  4757. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterham
  4758. echo 'done' >> /usr/bin/filterham
  4759. if ! grep -q "filterspam" /etc/crontab; then
  4760. echo "*/3 * * * * root /usr/bin/timeout 120 /usr/bin/filterspam $MY_USERNAME" >> /etc/crontab
  4761. fi
  4762. if ! grep -q "filterham" /etc/crontab; then
  4763. echo "*/3 * * * * root /usr/bin/timeout 120 /usr/bin/filterham $MY_USERNAME" >> /etc/crontab
  4764. fi
  4765. chmod 655 /usr/bin/filterspam /usr/bin/filterham
  4766. sed -i 's/# use_bayes 1/use_bayes 1/g' /etc/mail/spamassassin/local.cf
  4767. sed -i 's/# bayes_auto_learn 1/bayes_auto_learn 1/g' /etc/mail/spamassassin/local.cf
  4768. service spamassassin restart
  4769. service exim4 restart
  4770. service cron restart
  4771. echo 'spam_filtering' >> $COMPLETION_FILE
  4772. }
  4773. function configure_imap {
  4774. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4775. return
  4776. fi
  4777. if grep -Fxq "configure_imap" $COMPLETION_FILE; then
  4778. return
  4779. fi
  4780. apt-get -y --force-yes install dovecot-common dovecot-imapd
  4781. if [ ! -d /etc/dovecot ]; then
  4782. echo "ERROR: Dovecot does not appear to have installed. $CHECK_MESSAGE"
  4783. exit 48
  4784. fi
  4785. if [ ! -f /etc/ssl/private/dovecot.key ]; then
  4786. makecert dovecot
  4787. fi
  4788. chown root:dovecot /etc/ssl/certs/dovecot.*
  4789. chown root:dovecot /etc/ssl/private/dovecot.*
  4790. sed -i 's|#ssl =.*|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  4791. sed -i 's|ssl_cert =.*|ssl_cert = </etc/ssl/certs/dovecot.crt|g' /etc/dovecot/conf.d/10-ssl.conf
  4792. sed -i 's|ssl_key =.*|ssl_key = </etc/ssl/private/dovecot.key|g' /etc/dovecot/conf.d/10-ssl.conf
  4793. sed -i 's|#ssl_dh_parameters_length.*|ssl_dh_parameters_length = 1024|g' /etc/dovecot/conf.d/10-ssl.conf
  4794. sed -i 's/#ssl_prefer_server_ciphers.*/ssl_prefer_server_ciphers = yes/g' /etc/dovecot/conf.d/10-ssl.conf
  4795. echo "ssl_cipher_list = '$SSL_CIPHERS'" >> /etc/dovecot/conf.d/10-ssl.conf
  4796. sed -i 's/#process_limit =.*/process_limit = 5/g' /etc/dovecot/conf.d/10-master.conf
  4797. sed -i 's/#default_client_limit.*/default_client_limit = 5/g' /etc/dovecot/conf.d/10-master.conf
  4798. sed -i 's/#auth_verbose.*/auth_verbose = yes/g' /etc/dovecot/conf.d/10-logging.conf
  4799. sed -i 's/#listen =.*/listen = */g' /etc/dovecot/dovecot.conf
  4800. sed -i 's/#disable_plaintext_auth =.*/disable_plaintext_auth = no/g' /etc/dovecot/conf.d/10-auth.conf
  4801. sed -i 's/auth_mechanisms =.*/auth_mechanisms = plain login/g' /etc/dovecot/conf.d/10-auth.conf
  4802. sed -i 's|mail_location =.*|mail_location = maildir:~/Maildir:LAYOUT=fs|g' /etc/dovecot/conf.d/10-mail.conf
  4803. service dovecot restart
  4804. echo 'configure_imap' >> $COMPLETION_FILE
  4805. }
  4806. function configure_gpg {
  4807. if grep -Fxq "configure_gpg" $COMPLETION_FILE; then
  4808. return
  4809. fi
  4810. apt-get -y --force-yes install gnupg
  4811. # if gpg keys directory was previously imported from usb
  4812. if [[ $GPG_KEYS_IMPORTED == "yes" && -d /home/$MY_USERNAME/.gnupg ]]; then
  4813. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" /home/$MY_USERNAME/.gnupg/gpg.conf
  4814. MY_GPG_PUBLIC_KEY_ID=$(su -c "gpg --list-keys $MY_EMAIL_ADDRESS | grep 'pub '" - $MY_USERNAME | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4815. echo 'configure_gpg' >> $COMPLETION_FILE
  4816. return
  4817. fi
  4818. if [ ! -d /home/$MY_USERNAME/.gnupg ]; then
  4819. mkdir /home/$MY_USERNAME/.gnupg
  4820. echo 'keyserver hkp://keys.gnupg.net' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  4821. echo 'keyserver-options auto-key-retrieve' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  4822. fi
  4823. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" /home/$MY_USERNAME/.gnupg/gpg.conf
  4824. if ! grep -q "# default preferences" /home/$MY_USERNAME/.gnupg/gpg.conf; then
  4825. echo '' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  4826. echo '# default preferences' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  4827. echo 'personal-digest-preferences SHA256' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  4828. echo 'cert-digest-algo SHA256' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  4829. echo 'default-preference-list SHA512 SHA384 SHA256 SHA224 AES256 AES192 AES CAST5 ZLIB BZIP2 ZIP Uncompressed' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  4830. fi
  4831. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.gnupg
  4832. if [[ $MY_GPG_PUBLIC_KEY && $MY_GPG_PRIVATE_KEY ]]; then
  4833. # use your existing GPG keys which were exported
  4834. if [ ! -f $MY_GPG_PUBLIC_KEY ]; then
  4835. echo "GPG public key file $MY_GPG_PUBLIC_KEY was not found"
  4836. exit 5
  4837. fi
  4838. if [ ! -f $MY_GPG_PRIVATE_KEY ]; then
  4839. echo "GPG private key file $MY_GPG_PRIVATE_KEY was not found"
  4840. exit 6
  4841. fi
  4842. su -c "gpg --import $MY_GPG_PUBLIC_KEY" - $MY_USERNAME
  4843. su -c "gpg --allow-secret-key-import --import $MY_GPG_PRIVATE_KEY" - $MY_USERNAME
  4844. # for security ensure that the private key file doesn't linger around
  4845. shred -zu $MY_GPG_PRIVATE_KEY
  4846. MY_GPG_PUBLIC_KEY_ID=$(su -c "gpg --list-keys $MY_EMAIL_ADDRESS | grep 'pub '" - $MY_USERNAME | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4847. else
  4848. # Generate a GPG key
  4849. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  4850. echo 'Key-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4851. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  4852. echo 'Subkey-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4853. echo "Name-Real: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  4854. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  4855. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  4856. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  4857. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  4858. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  4859. MY_GPG_PUBLIC_KEY_ID=$(su -c "gpg --list-keys $MY_EMAIL_ADDRESS | grep 'pub '" - $MY_USERNAME | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4860. MY_GPG_PUBLIC_KEY=/tmp/public_key.gpg
  4861. su -c "gpg --output $MY_GPG_PUBLIC_KEY --armor --export $MY_GPG_PUBLIC_KEY_ID" - $MY_USERNAME
  4862. if grep -q "configure_email" $COMPLETION_FILE; then
  4863. if ! grep -q "Change your GPG password" /home/$MY_USERNAME/README; then
  4864. echo '' >> /home/$MY_USERNAME/README
  4865. echo '' >> /home/$MY_USERNAME/README
  4866. echo 'Change your GPG password' >> /home/$MY_USERNAME/README
  4867. echo '========================' >> /home/$MY_USERNAME/README
  4868. echo "It's very important to add a password to your GPG key so that" >> /home/$MY_USERNAME/README
  4869. echo "if anyone does get access to your email they still won't be able" >> /home/$MY_USERNAME/README
  4870. echo 'to read them without knowning the GPG password.' >> /home/$MY_USERNAME/README
  4871. echo 'You can change the it with:' >> /home/$MY_USERNAME/README
  4872. echo '' >> /home/$MY_USERNAME/README
  4873. echo " gpg --edit-key $MY_GPG_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  4874. echo ' passwd' >> /home/$MY_USERNAME/README
  4875. echo ' save' >> /home/$MY_USERNAME/README
  4876. echo ' quit' >> /home/$MY_USERNAME/README
  4877. fi
  4878. if ! grep -q "Publish your GPG public key" /home/$MY_USERNAME/README; then
  4879. echo '' >> /home/$MY_USERNAME/README
  4880. echo '' >> /home/$MY_USERNAME/README
  4881. echo 'Publish your GPG public key' >> /home/$MY_USERNAME/README
  4882. echo '===========================' >> /home/$MY_USERNAME/README
  4883. echo 'So that others can send emails to you securely you should' >> /home/$MY_USERNAME/README
  4884. echo 'publish your GPG public key with the command:' >> /home/$MY_USERNAME/README
  4885. echo '' >> /home/$MY_USERNAME/README
  4886. echo " gpg --send-keys $MY_GPG_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  4887. fi
  4888. fi
  4889. fi
  4890. echo 'configure_gpg' >> $COMPLETION_FILE
  4891. }
  4892. function encrypt_incoming_email {
  4893. # encrypts incoming mail using your GPG public key
  4894. # so even if an attacker gains access to the data at rest they still need
  4895. # to know your GPG key password to be able to read anything
  4896. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4897. return
  4898. fi
  4899. if grep -Fxq "encrypt_incoming_email" $COMPLETION_FILE; then
  4900. return
  4901. fi
  4902. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  4903. return
  4904. fi
  4905. if [ ! -f /usr/bin/gpgit.pl ]; then
  4906. apt-get -y --force-yes install git libmail-gnupg-perl
  4907. cd $INSTALL_DIR
  4908. git clone https://github.com/mikecardwell/gpgit
  4909. cd gpgit
  4910. cp gpgit.pl /usr/bin
  4911. fi
  4912. # add a procmail rule
  4913. if ! grep -q "/usr/bin/gpgit.pl" /home/$MY_USERNAME/.procmailrc; then
  4914. echo '' >> /home/$MY_USERNAME/.procmailrc
  4915. echo ':0 f' >> /home/$MY_USERNAME/.procmailrc
  4916. echo "| /usr/bin/gpgit.pl $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/.procmailrc
  4917. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  4918. fi
  4919. echo 'encrypt_incoming_email' >> $COMPLETION_FILE
  4920. }
  4921. function encrypt_outgoing_email {
  4922. # encrypts outgoing mail using your GPG public key
  4923. # so even if an attacker gains access to the data at rest they still need
  4924. # to know your GPG key password to be able to read sent mail
  4925. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4926. return
  4927. fi
  4928. if grep -Fxq "encrypt_outgoing_email" $COMPLETION_FILE; then
  4929. return
  4930. fi
  4931. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  4932. return
  4933. fi
  4934. if [ ! -d /home/$MY_USERNAME/.gnupg ]; then
  4935. return
  4936. fi
  4937. if [ ! $MY_GPG_PUBLIC_KEY_ID ]; then
  4938. MY_GPG_PUBLIC_KEY_ID=$(su -c "gpg --list-keys $MY_EMAIL_ADDRESS | grep 'pub '" - $MY_USERNAME | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4939. if [ ! $MY_GPG_PUBLIC_KEY_ID ]; then
  4940. return
  4941. fi
  4942. fi
  4943. sed -i "s|#encrypt-to .*|hidden-encrypt-to $MY_GPG_PUBLIC_KEY_ID|g" /home/$MY_USERNAME/.gnupg/gpg.conf
  4944. echo 'encrypt_outgoing_email' >> $COMPLETION_FILE
  4945. }
  4946. function encrypt_all_email {
  4947. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  4948. return
  4949. fi
  4950. if grep -Fxq "encrypt_all_email" $COMPLETION_FILE; then
  4951. return
  4952. fi
  4953. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  4954. return
  4955. fi
  4956. echo '#!/bin/bash' > /usr/bin/encmaildir
  4957. echo '#' >> /usr/bin/encmaildir
  4958. echo '# GPLv2' >> /usr/bin/encmaildir
  4959. echo '# GPG Encrypt a Maildir using gpgit.pl' >> /usr/bin/encmaildir
  4960. echo '# Oct 03, 2014' >> /usr/bin/encmaildir
  4961. echo '#' >> /usr/bin/encmaildir
  4962. echo '# Change log:' >> /usr/bin/encmaildir
  4963. echo '# Sep 03, 2011' >> /usr/bin/encmaildir
  4964. echo '# - Temporary file is based on file_owner to avoid' >> /usr/bin/encmaildir
  4965. echo '# issues with permission differences.' >> /usr/bin/encmaildir
  4966. echo '# - Temporary file is removed after run.' >> /usr/bin/encmaildir
  4967. echo '# - Optional arguments passed to "find".' >> /usr/bin/encmaildir
  4968. echo '# - Full paths to binaries.' >> /usr/bin/encmaildir
  4969. echo '# - Removed unneccessary need of "cat", "grep", etc.' >> /usr/bin/encmaildir
  4970. echo '# Sep 04, 2011' >> /usr/bin/encmaildir
  4971. echo '# - Dont remove Dovecot index/uid unless messages' >> /usr/bin/encmaildir
  4972. echo '# have been GPG encrypted.' >> /usr/bin/encmaildir
  4973. echo '# - Adjust file tests to not just use -e' >> /usr/bin/encmaildir
  4974. echo '# - Quote all file operations' >> /usr/bin/encmaildir
  4975. echo '# Sep 05, 2011' >> /usr/bin/encmaildir
  4976. echo '# - Dont arbitrarily copy files, only overwrite the file' >> /usr/bin/encmaildir
  4977. echo '# in ~/Maildir if it differs after calling gpgencmail.pl' >> /usr/bin/encmaildir
  4978. echo '# - Only rebuild the index if we have modified ~/Maildir' >> /usr/bin/encmaildir
  4979. echo '# Oct 03, 2014' >> /usr/bin/encmaildir
  4980. echo '# - Minor modifications for use with Freedombone' >> /usr/bin/encmaildir
  4981. echo '' >> /usr/bin/encmaildir
  4982. echo 'if [[ -z "$1" || -z "$2" || -z "$3" ]]; then' >> /usr/bin/encmaildir
  4983. echo ' echo "Usage is ./encmaildir.sh {optional arguments passed to find for messages such as -mtime 0}"' >> /usr/bin/encmaildir
  4984. echo ' exit 0' >> /usr/bin/encmaildir
  4985. echo 'fi' >> /usr/bin/encmaildir
  4986. echo '' >> /usr/bin/encmaildir
  4987. echo 'MAIL_DIR=$1' >> /usr/bin/encmaildir
  4988. echo 'EMAIL_ADDRESS=$2' >> /usr/bin/encmaildir
  4989. echo 'USERNAME=$3' >> /usr/bin/encmaildir
  4990. echo 'if [ ! -d "$MAIL_DIR" ]; then' >> /usr/bin/encmaildir
  4991. echo " MAIL_DIR='/home/$MY_USERNAME/Maildir'" >> /usr/bin/encmaildir
  4992. echo 'fi' >> /usr/bin/encmaildir
  4993. echo '' >> /usr/bin/encmaildir
  4994. echo 'if [ ! $EMAIL_ADDRESS ]; then' >> /usr/bin/encmaildir
  4995. echo " EMAIL_ADDRESS='$MY_EMAIL_ADDRESS'" >> /usr/bin/encmaildir
  4996. echo 'fi' >> /usr/bin/encmaildir
  4997. echo '' >> /usr/bin/encmaildir
  4998. echo 'if [ ! $USERNAME ]; then' >> /usr/bin/encmaildir
  4999. echo " USERNAME='$MY_USERNAME'" >> /usr/bin/encmaildir
  5000. echo 'fi' >> /usr/bin/encmaildir
  5001. echo '' >> /usr/bin/encmaildir
  5002. echo '# Does this key exist?' >> /usr/bin/encmaildir
  5003. echo 'gpg --list-keys "$EMAIL_ADDRESS" > /dev/null 2>&1' >> /usr/bin/encmaildir
  5004. echo 'if [ $? -gt 0 ]; then' >> /usr/bin/encmaildir
  5005. echo ' echo "A GPG key for $EMAIL_ADDRESS could not be found!"' >> /usr/bin/encmaildir
  5006. echo ' exit 0' >> /usr/bin/encmaildir
  5007. echo 'fi' >> /usr/bin/encmaildir
  5008. echo '' >> /usr/bin/encmaildir
  5009. echo '# Find all files in the Maildir specified.' >> /usr/bin/encmaildir
  5010. echo 'echo "Calling find"' >> /usr/bin/encmaildir
  5011. echo -n 'find "$MAIL_DIR" -type f -regex ' >> /usr/bin/encmaildir
  5012. echo -n "'.*/\(cur\|new\)/.*' " >> /usr/bin/encmaildir
  5013. echo '$4|while read line; do' >> /usr/bin/encmaildir
  5014. echo ' gpgit.pl --encrypt-mode prefer-inline "$EMAIL_ADDRESS" "/tmp/msg_$USERNAME"' >> /usr/bin/encmaildir
  5015. echo '' >> /usr/bin/encmaildir
  5016. echo ' # Check to see if there are differences between the existing' >> /usr/bin/encmaildir
  5017. echo ' # Maildir file and what was created by gpgit.pl' >> /usr/bin/encmaildir
  5018. echo ' diff -qa "$line" "/tmp/msg_$USERNAME" > /dev/null 2>&1;' >> /usr/bin/encmaildir
  5019. echo ' if [ $? -gt 0 ]; then' >> /usr/bin/encmaildir
  5020. echo ' # Preserve timestamps, set ownership.' >> /usr/bin/encmaildir
  5021. echo ' chown $USERNAME:$USERNAME "/tmp/msg_$USERNAME"' >> /usr/bin/encmaildir
  5022. echo ' chmod 600 "/tmp/msg_$USERNAME"' >> /usr/bin/encmaildir
  5023. echo ' touch "/tmp/msg_$USERNAME" --reference="$line"' >> /usr/bin/encmaildir
  5024. echo '' >> /usr/bin/encmaildir
  5025. echo ' # Unlink the original Maildir message' >> /usr/bin/encmaildir
  5026. echo ' unlink "$line"' >> /usr/bin/encmaildir
  5027. echo '' >> /usr/bin/encmaildir
  5028. echo ' # Strip message sizes, retain experimental flags' >> /usr/bin/encmaildir
  5029. echo ' # and status flags, and copy the file over.' >> /usr/bin/encmaildir
  5030. echo ' STRIPSIZES=$(/bin/echo "$line"|/bin/sed -e "s/W=[[:digit:]]*//" -e "s/S=[[:digit:]]*//" -e "s/,,//" -e "s/,:2/:2/")' >> /usr/bin/encmaildir
  5031. echo ' cp -av "/tmp/msg_$USERNAME" "$STRIPSIZES"' >> /usr/bin/encmaildir
  5032. echo '' >> /usr/bin/encmaildir
  5033. echo ' #Indexes must be rebuilt, weve modified Maildir.' >> /usr/bin/encmaildir
  5034. echo ' touch "/tmp/rebuild_index_$USERNAME"' >> /usr/bin/encmaildir
  5035. echo ' else' >> /usr/bin/encmaildir
  5036. echo ' echo "Not copying, no differences between /tmp/msg_$USERNAME and $line"' >> /usr/bin/encmaildir
  5037. echo ' fi' >> /usr/bin/encmaildir
  5038. echo '' >> /usr/bin/encmaildir
  5039. echo ' # Remove the temporary file' >> /usr/bin/encmaildir
  5040. echo ' unlink "/tmp/msg_$USERNAME"' >> /usr/bin/encmaildir
  5041. echo 'done' >> /usr/bin/encmaildir
  5042. echo '' >> /usr/bin/encmaildir
  5043. echo '# Remove Dovecot index and uids for regeneration.' >> /usr/bin/encmaildir
  5044. echo 'if [ -f "/tmp/rebuild_index_$USERNAME" ]; then' >> /usr/bin/encmaildir
  5045. echo ' echo "Removing Dovecot indexes and uids"' >> /usr/bin/encmaildir
  5046. echo -n ' find "$MAIL_DIR" -type f -regex ' >> /usr/bin/encmaildir
  5047. echo "'.*\(dovecot-\|dovecot\.\|\.uidvalidity\).*' -delete" >> /usr/bin/encmaildir
  5048. echo '' >> /usr/bin/encmaildir
  5049. echo ' # Remove the temporary file' >> /usr/bin/encmaildir
  5050. echo ' unlink "/tmp/rebuild_index_$USERNAME"' >> /usr/bin/encmaildir
  5051. echo 'else' >> /usr/bin/encmaildir
  5052. echo ' echo "No messages found needing GPG encryption, not' >> /usr/bin/encmaildir
  5053. echo ' echo "removing Dovecot indexes and UIDs."' >> /usr/bin/encmaildir
  5054. echo 'fi' >> /usr/bin/encmaildir
  5055. echo 'exit 0' >> /usr/bin/encmaildir
  5056. chmod +x /usr/bin/encmaildir
  5057. if [ ! /home/$MY_USERNAME/README ]; then
  5058. touch /home/$MY_USERNAME/README
  5059. fi
  5060. if ! grep -q "If you have imported legacy email" /home/$MY_USERNAME/README; then
  5061. echo '' >> /home/$MY_USERNAME/README
  5062. echo '' >> /home/$MY_USERNAME/README
  5063. echo 'Encrypting legacy email' >> /home/$MY_USERNAME/README
  5064. echo '=======================' >> /home/$MY_USERNAME/README
  5065. echo 'If you have imported legacy email which is not encrypted' >> /home/$MY_USERNAME/README
  5066. echo 'then it can be encrypted with the command:' >> /home/$MY_USERNAME/README
  5067. echo '' >> /home/$MY_USERNAME/README
  5068. echo ' encmaildir' >> /home/$MY_USERNAME/README
  5069. echo '' >> /home/$MY_USERNAME/README
  5070. echo 'But be warned that depending upon how much email you have' >> /home/$MY_USERNAME/README
  5071. echo 'this could take a seriously LONG time on the Beaglebone' >> /home/$MY_USERNAME/README
  5072. echo 'and may be better done on a faster machine.' >> /home/$MY_USERNAME/README
  5073. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5074. fi
  5075. echo 'encrypt_all_email' >> $COMPLETION_FILE
  5076. }
  5077. function email_client {
  5078. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5079. return
  5080. fi
  5081. if grep -Fxq "email_client" $COMPLETION_FILE; then
  5082. return
  5083. fi
  5084. apt-get -y --force-yes install mutt-patched lynx abook
  5085. if [ ! -f /etc/Muttrc ]; then
  5086. echo "ERROR: Mutt does not appear to have installed. $CHECK_MESSAGE"
  5087. exit 49
  5088. fi
  5089. if [ ! -d /home/$MY_USERNAME/.mutt ]; then
  5090. mkdir /home/$MY_USERNAME/.mutt
  5091. fi
  5092. echo "text/html; lynx -dump -width=78 -nolist %s | sed ‘s/^ //’; copiousoutput; needsterminal; nametemplate=%s.html" > /home/$MY_USERNAME/.mutt/mailcap
  5093. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt
  5094. echo 'set mbox_type=Maildir' >> /etc/Muttrc
  5095. echo 'set folder="~/Maildir"' >> /etc/Muttrc
  5096. echo 'set mask="!^\\.[^.]"' >> /etc/Muttrc
  5097. echo 'set mbox="~/Maildir"' >> /etc/Muttrc
  5098. echo 'set record="+Sent"' >> /etc/Muttrc
  5099. echo 'set postponed="+Drafts"' >> /etc/Muttrc
  5100. echo 'set trash="+Trash"' >> /etc/Muttrc
  5101. echo 'set spoolfile="~/Maildir"' >> /etc/Muttrc
  5102. echo 'auto_view text/x-vcard text/html text/enriched' >> /etc/Muttrc
  5103. echo 'set editor="emacs"' >> /etc/Muttrc
  5104. echo 'set header_cache="+.cache"' >> /etc/Muttrc
  5105. echo '' >> /etc/Muttrc
  5106. echo 'macro index S "<tag-prefix><save-message>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  5107. echo 'macro pager S "<save-message>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  5108. echo 'macro index H "<tag-prefix><copy-message>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  5109. echo 'macro pager H "<copy-message>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  5110. echo '' >> /etc/Muttrc
  5111. echo '# set up the sidebar' >> /etc/Muttrc
  5112. echo 'set sidebar_width=22' >> /etc/Muttrc
  5113. echo 'set sidebar_visible=yes' >> /etc/Muttrc
  5114. echo "set sidebar_delim='|'" >> /etc/Muttrc
  5115. echo 'set sidebar_sort=yes' >> /etc/Muttrc
  5116. echo '' >> /etc/Muttrc
  5117. echo 'set rfc2047_parameters' >> /etc/Muttrc
  5118. echo '' >> /etc/Muttrc
  5119. echo '# Show inbox and sent items' >> /etc/Muttrc
  5120. echo 'mailboxes = =Sent' >> /etc/Muttrc
  5121. echo '' >> /etc/Muttrc
  5122. echo '# Alter these colours as needed for maximum bling' >> /etc/Muttrc
  5123. echo 'color sidebar_new yellow default' >> /etc/Muttrc
  5124. echo 'color normal white default' >> /etc/Muttrc
  5125. echo 'color hdrdefault brightcyan default' >> /etc/Muttrc
  5126. echo 'color signature green default' >> /etc/Muttrc
  5127. echo 'color attachment brightyellow default' >> /etc/Muttrc
  5128. echo 'color quoted green default' >> /etc/Muttrc
  5129. echo 'color quoted1 white default' >> /etc/Muttrc
  5130. echo 'color tilde blue default' >> /etc/Muttrc
  5131. echo '' >> /etc/Muttrc
  5132. echo '# ctrl-n, ctrl-p to select next, prev folder' >> /etc/Muttrc
  5133. echo '# ctrl-o to open selected folder' >> /etc/Muttrc
  5134. echo 'bind index \Cp sidebar-prev' >> /etc/Muttrc
  5135. echo 'bind index \Cn sidebar-next' >> /etc/Muttrc
  5136. echo 'bind index \Co sidebar-open' >> /etc/Muttrc
  5137. echo 'bind pager \Cp sidebar-prev' >> /etc/Muttrc
  5138. echo 'bind pager \Cn sidebar-next' >> /etc/Muttrc
  5139. echo 'bind pager \Co sidebar-open' >> /etc/Muttrc
  5140. echo '' >> /etc/Muttrc
  5141. echo '# ctrl-b toggles sidebar visibility' >> /etc/Muttrc
  5142. echo "macro index,pager \Cb '<enter-command>toggle sidebar_visible<enter><redraw-screen>' 'toggle sidebar'" >> /etc/Muttrc
  5143. echo '' >> /etc/Muttrc
  5144. echo '# esc-m Mark new messages as read' >> /etc/Muttrc
  5145. echo 'macro index <esc>m "T~N<enter>;WNT~O<enter>;WO\CT~T<enter>" "mark all messages read"' >> /etc/Muttrc
  5146. echo '' >> /etc/Muttrc
  5147. echo '# Collapsing threads' >> /etc/Muttrc
  5148. echo 'macro index [ "<collapse-thread>" "collapse/uncollapse thread"' >> /etc/Muttrc
  5149. echo 'macro index ] "<collapse-all>" "collapse/uncollapse all threads"' >> /etc/Muttrc
  5150. echo '' >> /etc/Muttrc
  5151. echo '# threads containing new messages' >> /etc/Muttrc
  5152. echo 'uncolor index "~(~N)"' >> /etc/Muttrc
  5153. echo 'color index brightblue default "~(~N)"' >> /etc/Muttrc
  5154. echo '' >> /etc/Muttrc
  5155. echo '# new messages themselves' >> /etc/Muttrc
  5156. echo 'uncolor index "~N"' >> /etc/Muttrc
  5157. echo 'color index brightyellow default "~N"' >> /etc/Muttrc
  5158. echo '' >> /etc/Muttrc
  5159. echo '# GPG/PGP integration' >> /etc/Muttrc
  5160. echo '# this set the number of seconds to keep in memory the passphrase used to encrypt/sign' >> /etc/Muttrc
  5161. echo 'set pgp_timeout=1800' >> /etc/Muttrc
  5162. echo '' >> /etc/Muttrc
  5163. echo '# automatically sign and encrypt with PGP/MIME' >> /etc/Muttrc
  5164. echo 'set pgp_autosign # autosign all outgoing mails' >> /etc/Muttrc
  5165. echo 'set pgp_autoencrypt # Try to encrypt automatically' >> /etc/Muttrc
  5166. echo 'set pgp_replyencrypt # autocrypt replies to crypted' >> /etc/Muttrc
  5167. echo 'set pgp_replysign # autosign replies to signed' >> /etc/Muttrc
  5168. echo 'set pgp_auto_decode=yes # decode attachments' >> /etc/Muttrc
  5169. echo 'set fcc_clear # Keep cleartext copy of sent encrypted mail' >> /etc/Muttrc
  5170. echo 'unset smime_is_default' >> /etc/Muttrc
  5171. echo '' >> /etc/Muttrc
  5172. echo 'set alias_file=~/.mutt-alias' >> /etc/Muttrc
  5173. echo 'source ~/.mutt-alias' >> /etc/Muttrc
  5174. echo 'set query_command= "abook --mutt-query \"%s\""' >> /etc/Muttrc
  5175. echo 'macro index,pager A "<pipe-message>abook --add-email-quiet<return>" "add the sender address to abook"' >> /etc/Muttrc
  5176. cp -f /etc/Muttrc /home/$MY_USERNAME/.muttrc
  5177. touch /home/$MY_USERNAME/.mutt-alias
  5178. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.muttrc
  5179. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt-alias
  5180. echo 'email_client' >> $COMPLETION_FILE
  5181. }
  5182. function email_archiving {
  5183. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5184. return
  5185. fi
  5186. if grep -Fxq "email_archiving" $COMPLETION_FILE; then
  5187. return
  5188. fi
  5189. if [ ! -d $INSTALL_DIR ]; then
  5190. mkdir $INSTALL_DIR
  5191. fi
  5192. cd $INSTALL_DIR
  5193. git clone https://github.com/bashrc/cleanup-maildir
  5194. cp $INSTALL_DIR/cleanup-maildir/cleanup-maildir /usr/bin
  5195. echo '#!/bin/bash' > /etc/cron.daily/archivemail
  5196. echo "MUTTRC=/home/$MY_USERNAME/.muttrc" >> /etc/cron.daily/archivemail
  5197. echo "python /usr/bin/cleanup-maildir --archive-folder='archive' --maildir-root='/home/$MY_USERNAME/Maildir' archive ''" >> /etc/cron.daily/archivemail
  5198. echo "chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir/archive-*" >> /etc/cron.daily/archivemail
  5199. echo 'if [ -f $MUTTRC ]; then' >> /etc/cron.daily/archivemail
  5200. echo ' MUTT_MAILBOXES=$(grep "mailboxes =" $MUTTRC)' >> /etc/cron.daily/archivemail
  5201. echo ' BACKUP_DIRECTORY=archive-$(date +"%Y")' >> /etc/cron.daily/archivemail
  5202. echo ' if [[ $MUTT_MAILBOXES != *$BACKUP_DIRECTORY* ]]; then' >> /etc/cron.daily/archivemail
  5203. echo ' sed -i "s|$MUTT_MAILBOXES|$MUTT_MAILBOXES =$BACKUP_DIRECTORY|g" $MUTTRC' >> /etc/cron.daily/archivemail
  5204. echo ' chown $MYUSERNAME:$MYUSERNAME $MUTTRC' >> /etc/cron.daily/archivemail
  5205. echo ' fi' >> /etc/cron.daily/archivemail
  5206. echo 'fi' >> /etc/cron.daily/archivemail
  5207. echo 'exit 0' >> /etc/cron.daily/archivemail
  5208. chmod +x /etc/cron.daily/archivemail
  5209. echo 'email_archiving' >> $COMPLETION_FILE
  5210. }
  5211. function folders_for_mailing_lists {
  5212. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5213. return
  5214. fi
  5215. if grep -Fxq "folders_for_mailing_lists" $COMPLETION_FILE; then
  5216. return
  5217. fi
  5218. echo '#!/bin/bash' > /usr/bin/addmailinglist
  5219. echo 'MYUSERNAME=$1' >> /usr/bin/addmailinglist
  5220. echo 'MAILINGLIST=$2' >> /usr/bin/addmailinglist
  5221. echo 'SUBJECTTAG=$3' >> /usr/bin/addmailinglist
  5222. echo 'MUTTRC=/home/$MYUSERNAME/.muttrc' >> /usr/bin/addmailinglist
  5223. echo 'PM=/home/$MYUSERNAME/.procmailrc' >> /usr/bin/addmailinglist
  5224. echo 'LISTDIR=/home/$MYUSERNAME/Maildir/$MAILINGLIST' >> /usr/bin/addmailinglist
  5225. echo '' >> /usr/bin/addmailinglist
  5226. echo '# Exit if the list was already added' >> /usr/bin/addmailinglist
  5227. echo 'if grep -q "=$MAILINGLIST" $MUTTRC; then' >> /usr/bin/addmailinglist
  5228. echo ' exit 1' >> /usr/bin/addmailinglist
  5229. echo 'fi' >> /usr/bin/addmailinglist
  5230. echo '' >> /usr/bin/addmailinglist
  5231. echo 'if ! [[ $MYUSERNAME && $MAILINGLIST && $SUBJECTTAG ]]; then' >> /usr/bin/addmailinglist
  5232. echo ' echo "addmailinglist [user name] [mailing list name] [subject tag]"' >> /usr/bin/addmailinglist
  5233. echo ' exit 1' >> /usr/bin/addmailinglist
  5234. echo 'fi' >> /usr/bin/addmailinglist
  5235. echo '' >> /usr/bin/addmailinglist
  5236. echo 'if [ ! -d "$LISTDIR" ]; then' >> /usr/bin/addmailinglist
  5237. echo ' mkdir -m 700 $LISTDIR' >> /usr/bin/addmailinglist
  5238. echo ' mkdir -m 700 $LISTDIR/tmp' >> /usr/bin/addmailinglist
  5239. echo ' mkdir -m 700 $LISTDIR/new' >> /usr/bin/addmailinglist
  5240. echo ' mkdir -m 700 $LISTDIR/cur' >> /usr/bin/addmailinglist
  5241. echo 'fi' >> /usr/bin/addmailinglist
  5242. echo '' >> /usr/bin/addmailinglist
  5243. echo 'chown -R $MYUSERNAME:$MYUSERNAME $LISTDIR' >> /usr/bin/addmailinglist
  5244. echo 'echo "" >> $PM' >> /usr/bin/addmailinglist
  5245. echo 'echo ":0" >> $PM' >> /usr/bin/addmailinglist
  5246. echo 'echo " * ^Subject:.*()\[$SUBJECTTAG\]" >> $PM' >> /usr/bin/addmailinglist
  5247. echo 'echo "$LISTDIR/new" >> $PM' >> /usr/bin/addmailinglist
  5248. echo 'chown $MYUSERNAME:$MYUSERNAME $PM' >> /usr/bin/addmailinglist
  5249. echo '' >> /usr/bin/addmailinglist
  5250. echo 'if [ ! -f "$MUTTRC" ]; then' >> /usr/bin/addmailinglist
  5251. echo ' cp /etc/Muttrc $MUTTRC' >> /usr/bin/addmailinglist
  5252. echo ' chown $MYUSERNAME:$MYUSERNAME $MUTTRC' >> /usr/bin/addmailinglist
  5253. echo 'fi' >> /usr/bin/addmailinglist
  5254. echo '' >> /usr/bin/addmailinglist
  5255. echo 'PROCMAILLOG=/home/$MYUSERNAME/log' >> /usr/bin/addmailinglist
  5256. echo 'if [ ! -d $PROCMAILLOG ]; then' >> /usr/bin/addmailinglist
  5257. echo ' mkdir $PROCMAILLOG' >> /usr/bin/addmailinglist
  5258. echo ' chown -R $MYUSERNAME:$MYUSERNAME $PROCMAILLOG' >> /usr/bin/addmailinglist
  5259. echo 'fi' >> /usr/bin/addmailinglist
  5260. echo '' >> /usr/bin/addmailinglist
  5261. echo 'MUTT_MAILBOXES=$(grep "mailboxes =" $MUTTRC)' >> /usr/bin/addmailinglist
  5262. echo 'if [[ $MUTT_MAILBOXES != *$MAILINGLIST* ]]; then' >> /usr/bin/addmailinglist
  5263. echo ' sed -i "s|$MUTT_MAILBOXES|$MUTT_MAILBOXES =$MAILINGLIST|g" $MUTTRC' >> /usr/bin/addmailinglist
  5264. echo ' chown $MYUSERNAME:$MYUSERNAME $MUTTRC' >> /usr/bin/addmailinglist
  5265. echo 'fi' >> /usr/bin/addmailinglist
  5266. echo 'exit 0' >> /usr/bin/addmailinglist
  5267. chmod +x /usr/bin/addmailinglist
  5268. echo 'folders_for_mailing_lists' >> $COMPLETION_FILE
  5269. }
  5270. # Ensure that the from field is correct when sending email from Mutt
  5271. function email_from_address {
  5272. if grep -Fxq "email_from_address" $COMPLETION_FILE; then
  5273. return
  5274. fi
  5275. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  5276. return
  5277. fi
  5278. if grep -q "set from=" /home/$MY_USERNAME/.muttrc; then
  5279. sed -i "s|set from=.*|set from='$MY_NAME <$MY_EMAIL_ADDRESS>'|g" /home/$MY_USERNAME/.muttrc
  5280. else
  5281. echo "set from='$MY_NAME <$MY_EMAIL_ADDRESS>'" >> /home/$MY_USERNAME/.muttrc
  5282. fi
  5283. echo 'email_from_address' >> $COMPLETION_FILE
  5284. }
  5285. function folders_for_email_addresses {
  5286. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5287. return
  5288. fi
  5289. if grep -Fxq "folders_for_email_addresses" $COMPLETION_FILE; then
  5290. return
  5291. fi
  5292. echo '#!/bin/bash' > /usr/bin/addemailtofolder
  5293. echo 'MYUSERNAME=$1' >> /usr/bin/addemailtofolder
  5294. echo 'EMAILADDRESS=$2' >> /usr/bin/addemailtofolder
  5295. echo 'MAILINGLIST=$3' >> /usr/bin/addemailtofolder
  5296. echo 'MUTTRC=/home/$MYUSERNAME/.muttrc' >> /usr/bin/addemailtofolder
  5297. echo 'PM=/home/$MYUSERNAME/.procmailrc' >> /usr/bin/addemailtofolder
  5298. echo 'LISTDIR=/home/$MYUSERNAME/Maildir/$MAILINGLIST' >> /usr/bin/addemailtofolder
  5299. echo '' >> /usr/bin/addemailtofolder
  5300. echo 'if ! [[ $MYUSERNAME && $EMAILADDRESS && $MAILINGLIST ]]; then' >> /usr/bin/addemailtofolder
  5301. echo ' echo "addemailtofolder [user name] [email address] [mailing list name]"' >> /usr/bin/addemailtofolder
  5302. echo ' exit 1' >> /usr/bin/addemailtofolder
  5303. echo 'fi' >> /usr/bin/addemailtofolder
  5304. echo '' >> /usr/bin/addemailtofolder
  5305. echo 'if [ ! -d "$LISTDIR" ]; then' >> /usr/bin/addemailtofolder
  5306. echo ' mkdir -m 700 $LISTDIR' >> /usr/bin/addemailtofolder
  5307. echo ' mkdir -m 700 $LISTDIR/tmp' >> /usr/bin/addemailtofolder
  5308. echo ' mkdir -m 700 $LISTDIR/new' >> /usr/bin/addemailtofolder
  5309. echo ' mkdir -m 700 $LISTDIR/cur' >> /usr/bin/addemailtofolder
  5310. echo 'fi' >> /usr/bin/addemailtofolder
  5311. echo 'chown -R $MYUSERNAME:$MYUSERNAME $LISTDIR' >> /usr/bin/addemailtofolder
  5312. echo 'echo "" >> $PM' >> /usr/bin/addemailtofolder
  5313. echo 'echo ":0" >> $PM' >> /usr/bin/addemailtofolder
  5314. echo 'echo " * ^From: $EMAILADDRESS" >> $PM' >> /usr/bin/addemailtofolder
  5315. echo 'echo "$LISTDIR/new" >> $PM' >> /usr/bin/addemailtofolder
  5316. echo 'chown $MYUSERNAME:$MYUSERNAME $PM' >> /usr/bin/addemailtofolder
  5317. echo 'if [ ! -f "$MUTTRC" ]; then' >> /usr/bin/addemailtofolder
  5318. echo ' cp /etc/Muttrc $MUTTRC' >> /usr/bin/addemailtofolder
  5319. echo ' chown $MYUSERNAME:$MYUSERNAME $MUTTRC' >> /usr/bin/addemailtofolder
  5320. echo 'fi' >> /usr/bin/addemailtofolder
  5321. echo 'PROCMAILLOG=/home/$MYUSERNAME/log' >> /usr/bin/addemailtofolder
  5322. echo 'if [ ! -d $PROCMAILLOG ]; then' >> /usr/bin/addemailtofolder
  5323. echo ' mkdir $PROCMAILLOG' >> /usr/bin/addemailtofolder
  5324. echo ' chown -R $MYUSERNAME:$MYUSERNAME $PROCMAILLOG' >> /usr/bin/addemailtofolder
  5325. echo 'fi' >> /usr/bin/addemailtofolder
  5326. echo 'MUTT_MAILBOXES=$(grep "mailboxes =" $MUTTRC)' >> /usr/bin/addemailtofolder
  5327. echo 'if [[ $MUTT_MAILBOXES != *$MAILINGLIST* ]]; then' >> /usr/bin/addemailtofolder
  5328. echo ' if ! grep -q "=$MAILINGLIST" $MUTTRC; then' >> /usr/bin/addemailtofolder
  5329. echo ' sed -i "s|$MUTT_MAILBOXES|$MUTT_MAILBOXES =$MAILINGLIST|g" $MUTTRC' >> /usr/bin/addemailtofolder
  5330. echo ' chown $MYUSERNAME:$MYUSERNAME $MUTTRC' >> /usr/bin/addemailtofolder
  5331. echo ' fi' >> /usr/bin/addemailtofolder
  5332. echo 'fi' >> /usr/bin/addemailtofolder
  5333. echo 'exit 0' >> /usr/bin/addemailtofolder
  5334. chmod +x /usr/bin/addemailtofolder
  5335. echo 'folders_for_email_addresses' >> $COMPLETION_FILE
  5336. }
  5337. function create_public_mailing_list {
  5338. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5339. return
  5340. fi
  5341. if grep -Fxq "create_public_mailing_list" $COMPLETION_FILE; then
  5342. return
  5343. fi
  5344. if [ ! $PUBLIC_MAILING_LIST ]; then
  5345. return
  5346. fi
  5347. # does the mailing list have a separate domain name?
  5348. if [ ! $PUBLIC_MAILING_LIST_DOMAIN_NAME ]; then
  5349. PUBLIC_MAILING_LIST_DOMAIN_NAME=$DOMAIN_NAME
  5350. fi
  5351. PUBLIC_MAILING_LIST_USER="mlmmj"
  5352. apt-get -y --force-yes install mlmmj
  5353. adduser --system $PUBLIC_MAILING_LIST_USER
  5354. addgroup $PUBLIC_MAILING_LIST_USER
  5355. adduser $PUBLIC_MAILING_LIST_USER $PUBLIC_MAILING_LIST_USER
  5356. echo ''
  5357. echo "Creating the $PUBLIC_MAILING_LIST mailing list"
  5358. echo ''
  5359. # create the list
  5360. mlmmj-make-ml -a -L "$PUBLIC_MAILING_LIST" -c $PUBLIC_MAILING_LIST_USER
  5361. echo 'SYSTEM_ALIASES_PIPE_TRANSPORT = address_pipe' > /etc/exim4/conf.d/main/000_localmacros
  5362. echo "SYSTEM_ALIASES_USER = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  5363. echo "SYSTEM_ALIASES_GROUP = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  5364. # router
  5365. echo 'mlmmj_router:' > /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5366. echo ' debug_print = "R: mlmmj_router for $local_part@$domain"' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5367. echo ' driver = accept' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5368. echo ' domains = +mlmmj_domains' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5369. echo ' #require_files = MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5370. echo ' # Use this instead, if you dont want to give Exim rx rights to mlmmj spool.' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5371. echo ' # Exim will then spawn a new process running under the UID of "mlmmj".' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5372. echo ' require_files = mlmmj:MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5373. echo ' local_part_suffix = +*' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5374. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5375. echo ' headers_remove = Delivered-To' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5376. echo ' headers_add = Delivered-To: $local_part$local_part_suffix@$domain' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5377. echo ' transport = mlmmj_transport' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5378. # transport
  5379. echo 'mlmmj_transport:' > /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5380. echo ' debug_print = "T: mlmmj_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5381. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5382. echo ' return_path_add' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5383. echo ' user = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5384. echo ' group = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5385. echo ' home_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5386. echo ' current_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5387. echo ' command = /usr/bin/mlmmj-receive -F -L MLMMJ_HOME/${lc:$local_part}' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5388. if ! grep -q "MLMMJ_HOME=/var/spool/mlmmj" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5389. sed -i '/MAIN CONFIGURATION SETTINGS/a\MLMMJ_HOME=/var/spool/mlmmj' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5390. fi
  5391. if ! grep -q "domainlist mlmmj_domains =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5392. sed -i "/MLMMJ_HOME/a\domainlist mlmmj_domains = $PUBLIC_MAILING_LIST_DOMAIN_NAME" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5393. fi
  5394. if ! grep -q "delay_warning_condition =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5395. sed -i '/domainlist mlmmj_domains =/a\delay_warning_condition = ${if match_domain{$domain}{+mlmmj_domains}{no}{yes}}' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5396. fi
  5397. if ! grep -q ": +mlmmj_domains" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5398. sed -i 's/domainlist relay_to_domains = MAIN_RELAY_TO_DOMAINS/domainlist relay_to_domains = MAIN_RELAY_TO_DOMAINS : +mlmmj_domains/g' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5399. fi
  5400. if ! grep -q "! +mlmmj_domains" /etc/exim4/conf.d/router/200_exim4-config_primary; then
  5401. sed -i 's/domains = ! +local_domains/domains = ! +mlmmj_domains : ! +local_domains/g' /etc/exim4/conf.d/router/200_exim4-config_primary
  5402. fi
  5403. newaliases
  5404. update-exim4.conf.template -r
  5405. update-exim4.conf
  5406. service exim4 restart
  5407. if ! grep -q "$PUBLIC_MAILING_LIST mailing list" /home/$MY_USERNAME/README; then
  5408. echo '' >> /home/$MY_USERNAME/README
  5409. echo '' >> /home/$MY_USERNAME/README
  5410. echo 'Public mailing list' >> /home/$MY_USERNAME/README
  5411. echo '===================' >> /home/$MY_USERNAME/README
  5412. echo "To subscribe to the $PUBLIC_MAILING_LIST mailing list send a" >> /home/$MY_USERNAME/README
  5413. echo "cleartext email to $PUBLIC_MAILING_LIST+subscribe@$DOMAIN_NAME" >> /home/$MY_USERNAME/README
  5414. fi
  5415. addmailinglist $MY_USERNAME "$PUBLIC_MAILING_LIST" "$PUBLIC_MAILING_LIST"
  5416. echo 'create_public_mailing_list' >> $COMPLETION_FILE
  5417. }
  5418. function create_private_mailing_list {
  5419. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5420. return
  5421. fi
  5422. # This installation doesn't work, results in ruby errors
  5423. # There is currently no schleuder package for Debian jessie
  5424. if grep -Fxq "create_private_mailing_list" $COMPLETION_FILE; then
  5425. return
  5426. fi
  5427. if [ ! $PRIVATE_MAILING_LIST ]; then
  5428. return
  5429. fi
  5430. if [[ $PRIVATE_MAILING_LIST == $MY_USERNAME ]]; then
  5431. echo 'The name of the private mailing list should not be the'
  5432. echo 'same as your username'
  5433. exit 10
  5434. fi
  5435. if [ ! $MY_GPG_PUBLIC_KEY ]; then
  5436. echo 'To create a private mailing list you need to specify a file'
  5437. echo 'containing your exported GPG key within MY_GPG_PUBLIC_KEY at'
  5438. echo 'the top of the script'
  5439. exit 11
  5440. fi
  5441. apt-get -y --force-yes install ruby ruby-dev ruby-gpgme libgpgme11-dev libmagic-dev
  5442. gem install schleuder
  5443. schleuder-fix-gem-dependencies
  5444. schleuder-init-setup --gem
  5445. # NOTE: this is version number sensitive and so might need changing
  5446. ln -s /var/lib/gems/2.1.0/gems/schleuder-2.2.4 /var/lib/schleuder
  5447. sed -i 's/#smtp_port: 25/smtp_port: 465/g' /etc/schleuder/schleuder.conf
  5448. sed -i 's/#superadminaddr: root@localhost/superadminaddr: root@localhost' /etc/schleuder/schleuder.conf
  5449. schleuder-newlist $PRIVATE_MAILING_LIST@$DOMAIN_NAME -realname "$PRIVATE_MAILING_LIST" -adminaddress $MY_EMAIL_ADDRESS -initmember $MY_EMAIL_ADDRESS -initmemberkey $MY_GPG_PUBLIC_KEY -nointeractive
  5450. addemailtofolder $MY_USERNAME $PRIVATE_MAILING_LIST@$DOMAIN_NAME $PRIVATE_MAILING_LIST
  5451. echo 'schleuder:' > /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5452. echo ' debug_print = "R: schleuder for $local_part@$domain"' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5453. echo ' driver = accept' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5454. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5455. echo ' local_part_suffix = +* : -bounce : -sendkey' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5456. echo ' domains = +local_domains' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5457. echo ' user = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5458. echo ' group = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5459. echo ' require_files = schleuder:+/var/lib/schleuder/$domain/${local_part}' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5460. echo ' transport = schleuder_transport' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5461. echo 'schleuder_transport:' > /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5462. echo ' debug_print = "T: schleuder_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5463. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5464. echo ' home_directory = "/var/lib/schleuder/$domain/$local_part"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5465. echo ' command = "/usr/bin/schleuder $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5466. chown -R schleuder:schleuder /var/lib/schleuder
  5467. update-exim4.conf.template -r
  5468. update-exim4.conf
  5469. service exim4 restart
  5470. useradd -d /var/schleuderlists -s /bin/false schleuder
  5471. adduser Debian-exim schleuder
  5472. usermod -a -G mail schleuder
  5473. #exim -d -bt $PRIVATE_MAILING_LIST@$DOMAIN_NAME
  5474. echo 'create_private_mailing_list' >> $COMPLETION_FILE
  5475. }
  5476. function import_email {
  5477. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5478. return
  5479. fi
  5480. EMAIL_COMPLETE_MSG=' *** Freedombone mailbox installation is complete ***'
  5481. if grep -Fxq "import_email" $COMPLETION_FILE; then
  5482. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  5483. create_backup_script
  5484. create_restore_script
  5485. backup_to_friends_servers
  5486. intrusion_detection
  5487. echo ''
  5488. echo "$EMAIL_COMPLETE_MSG"
  5489. if [ -d $USB_MOUNT ]; then
  5490. umount $USB_MOUNT
  5491. rm -rf $USB_MOUNT
  5492. echo ' You can now remove the USB drive'
  5493. fi
  5494. exit 0
  5495. fi
  5496. return
  5497. fi
  5498. if [ $IMPORT_MAILDIR ]; then
  5499. if [ -d $IMPORT_MAILDIR ]; then
  5500. echo 'Transfering email files'
  5501. cp -r $IMPORT_MAILDIR /home/$MY_USERNAME
  5502. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  5503. else
  5504. echo "Email import directory $IMPORT_MAILDIR not found"
  5505. exit 9
  5506. fi
  5507. fi
  5508. echo 'import_email' >> $COMPLETION_FILE
  5509. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  5510. create_backup_script
  5511. create_restore_script
  5512. backup_to_friends_servers
  5513. intrusion_detection
  5514. # unmount any attached usb drive
  5515. echo ''
  5516. echo "$EMAIL_COMPLETE_MSG"
  5517. echo ''
  5518. if [ -d $USB_MOUNT ]; then
  5519. umount $USB_MOUNT
  5520. rm -rf $USB_MOUNT
  5521. echo ' You can now remove the USB drive'
  5522. fi
  5523. exit 0
  5524. fi
  5525. }
  5526. function install_web_server {
  5527. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5528. return
  5529. fi
  5530. if grep -Fxq "install_web_server" $COMPLETION_FILE; then
  5531. return
  5532. fi
  5533. # remove apache
  5534. apt-get -y remove --purge apache2
  5535. if [ -d /etc/apache2 ]; then
  5536. rm -rf /etc/apache2
  5537. fi
  5538. # install nginx
  5539. apt-get -y --force-yes install nginx php5-fpm git
  5540. # limit the number of php processes
  5541. sed -i 's/; process.max = 128/process.max = 32/g' /etc/php5/fpm/php-fpm.conf
  5542. sed -i 's/;process_control_timeout = 0/process_control_timeout = 300/g' /etc/php5/fpm/php-fpm.conf
  5543. if ! grep -q "pm.max_children" /etc/php5/fpm/php-fpm.conf; then
  5544. echo 'pm.max_children = 10' >> /etc/php5/fpm/php-fpm.conf
  5545. echo 'pm.start_servers = 2' >> /etc/php5/fpm/php-fpm.conf
  5546. echo 'pm.min_spare_servers = 2' >> /etc/php5/fpm/php-fpm.conf
  5547. echo 'pm.max_spare_servers = 5' >> /etc/php5/fpm/php-fpm.conf
  5548. echo 'pm.max_requests = 50' >> /etc/php5/fpm/php-fpm.conf
  5549. fi
  5550. if [ ! -d /etc/nginx ]; then
  5551. echo "ERROR: nginx does not appear to have installed. $CHECK_MESSAGE"
  5552. exit 51
  5553. fi
  5554. # Nginx settings
  5555. echo 'user www-data;' > /etc/nginx/nginx.conf
  5556. #echo "worker_processes; $CPU_CORES" >> /etc/nginx/nginx.conf
  5557. echo 'pid /run/nginx.pid;' >> /etc/nginx/nginx.conf
  5558. echo '' >> /etc/nginx/nginx.conf
  5559. echo 'events {' >> /etc/nginx/nginx.conf
  5560. echo ' worker_connections 50;' >> /etc/nginx/nginx.conf
  5561. echo ' # multi_accept on;' >> /etc/nginx/nginx.conf
  5562. echo '}' >> /etc/nginx/nginx.conf
  5563. echo '' >> /etc/nginx/nginx.conf
  5564. echo 'http {' >> /etc/nginx/nginx.conf
  5565. echo ' # limit the number of connections per single IP' >> /etc/nginx/nginx.conf
  5566. echo ' limit_conn_zone $binary_remote_addr zone=conn_limit_per_ip:10m;' >> /etc/nginx/nginx.conf
  5567. echo '' >> /etc/nginx/nginx.conf
  5568. echo ' # limit the number of requests for a given session' >> /etc/nginx/nginx.conf
  5569. echo ' # Note that the Owncloud web interface seems to require a rate of around 140r/s' >> /etc/nginx/nginx.conf
  5570. echo ' limit_req_zone $binary_remote_addr zone=req_limit_per_ip:10m rate=140r/s;' >> /etc/nginx/nginx.conf
  5571. echo '' >> /etc/nginx/nginx.conf
  5572. echo ' # if the request body size is more than the buffer size, then the entire (or partial) request body is written into a temporary file' >> /etc/nginx/nginx.conf
  5573. echo ' client_body_buffer_size 128k;' >> /etc/nginx/nginx.conf
  5574. echo '' >> /etc/nginx/nginx.conf
  5575. echo ' # headerbuffer size for the request header from client, its set for testing purpose' >> /etc/nginx/nginx.conf
  5576. echo ' client_header_buffer_size 3m;' >> /etc/nginx/nginx.conf
  5577. echo '' >> /etc/nginx/nginx.conf
  5578. echo ' # maximum number and size of buffers for large headers to read from client request' >> /etc/nginx/nginx.conf
  5579. echo ' large_client_header_buffers 4 256k;' >> /etc/nginx/nginx.conf
  5580. echo '' >> /etc/nginx/nginx.conf
  5581. echo ' # read timeout for the request body from client, its set for testing purpose' >> /etc/nginx/nginx.conf
  5582. echo ' client_body_timeout 3m;' >> /etc/nginx/nginx.conf
  5583. echo '' >> /etc/nginx/nginx.conf
  5584. echo ' # how long to wait for the client to send a request header, its set for testing purpose' >> /etc/nginx/nginx.conf
  5585. echo ' client_header_timeout 3m;' >> /etc/nginx/nginx.conf
  5586. echo '' >> /etc/nginx/nginx.conf
  5587. echo ' ##' >> /etc/nginx/nginx.conf
  5588. echo ' # Basic Settings' >> /etc/nginx/nginx.conf
  5589. echo ' ##' >> /etc/nginx/nginx.conf
  5590. echo '' >> /etc/nginx/nginx.conf
  5591. echo ' sendfile on;' >> /etc/nginx/nginx.conf
  5592. echo ' tcp_nopush on;' >> /etc/nginx/nginx.conf
  5593. echo ' tcp_nodelay on;' >> /etc/nginx/nginx.conf
  5594. echo ' keepalive_timeout 65;' >> /etc/nginx/nginx.conf
  5595. echo ' types_hash_max_size 2048;' >> /etc/nginx/nginx.conf
  5596. echo ' server_tokens off;' >> /etc/nginx/nginx.conf
  5597. echo '' >> /etc/nginx/nginx.conf
  5598. echo ' # server_names_hash_bucket_size 64;' >> /etc/nginx/nginx.conf
  5599. echo ' # server_name_in_redirect off;' >> /etc/nginx/nginx.conf
  5600. echo '' >> /etc/nginx/nginx.conf
  5601. echo ' include /etc/nginx/mime.types;' >> /etc/nginx/nginx.conf
  5602. echo ' default_type application/octet-stream;' >> /etc/nginx/nginx.conf
  5603. echo '' >> /etc/nginx/nginx.conf
  5604. echo ' ##' >> /etc/nginx/nginx.conf
  5605. echo ' # Logging Settings' >> /etc/nginx/nginx.conf
  5606. echo ' ##' >> /etc/nginx/nginx.conf
  5607. echo '' >> /etc/nginx/nginx.conf
  5608. echo ' access_log /var/log/nginx/access.log;' >> /etc/nginx/nginx.conf
  5609. echo ' error_log /var/log/nginx/error.log;' >> /etc/nginx/nginx.conf
  5610. echo '' >> /etc/nginx/nginx.conf
  5611. echo ' ###' >> /etc/nginx/nginx.conf
  5612. echo ' # Gzip Settings' >> /etc/nginx/nginx.conf
  5613. echo ' ##' >> /etc/nginx/nginx.conf
  5614. echo ' gzip on;' >> /etc/nginx/nginx.conf
  5615. echo ' gzip_disable "msie6";' >> /etc/nginx/nginx.conf
  5616. echo '' >> /etc/nginx/nginx.conf
  5617. echo ' # gzip_vary on;' >> /etc/nginx/nginx.conf
  5618. echo ' # gzip_proxied any;' >> /etc/nginx/nginx.conf
  5619. echo ' # gzip_comp_level 6;' >> /etc/nginx/nginx.conf
  5620. echo ' # gzip_buffers 16 8k;' >> /etc/nginx/nginx.conf
  5621. echo ' # gzip_http_version 1.1;' >> /etc/nginx/nginx.conf
  5622. echo ' # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;' >> /etc/nginx/nginx.conf
  5623. echo '' >> /etc/nginx/nginx.conf
  5624. echo ' ##' >> /etc/nginx/nginx.conf
  5625. echo ' # Virtual Host Configs' >> /etc/nginx/nginx.conf
  5626. echo ' ##' >> /etc/nginx/nginx.conf
  5627. echo '' >> /etc/nginx/nginx.conf
  5628. echo ' include /etc/nginx/conf.d/*.conf;' >> /etc/nginx/nginx.conf
  5629. echo ' include /etc/nginx/sites-enabled/*;' >> /etc/nginx/nginx.conf
  5630. echo '}' >> /etc/nginx/nginx.conf
  5631. # install a script to easily enable and disable nginx virtual hosts
  5632. if [ ! -d $INSTALL_DIR ]; then
  5633. mkdir $INSTALL_DIR
  5634. fi
  5635. cd $INSTALL_DIR
  5636. git clone https://github.com/perusio/nginx_ensite
  5637. cd $INSTALL_DIR/nginx_ensite
  5638. cp nginx_* /usr/sbin
  5639. nginx_dissite default
  5640. echo 'install_web_server' >> $COMPLETION_FILE
  5641. }
  5642. function configure_php {
  5643. sed -i "s/memory_limit = 128M/memory_limit = ${MAX_PHP_MEMORY}M/g" /etc/php5/fpm/php.ini
  5644. sed -i 's/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/g' /etc/php5/fpm/php.ini
  5645. sed -i "s/memory_limit = -1/memory_limit = ${MAX_PHP_MEMORY}M/g" /etc/php5/cli/php.ini
  5646. sed -i "s/upload_max_filesize = 2M/upload_max_filesize = 50M/g" /etc/php5/fpm/php.ini
  5647. sed -i "s/post_max_size = 8M/post_max_size = 50M/g" /etc/php5/fpm/php.ini
  5648. }
  5649. function install_mariadb {
  5650. if grep -Fxq "install_mariadb" $COMPLETION_FILE; then
  5651. return
  5652. fi
  5653. apt-get -y --force-yes install python-software-properties debconf-utils
  5654. apt-key adv --recv-keys --keyserver keyserver.ubuntu.com 0xcbcb082a1bb943db
  5655. add-apt-repository 'deb http://mariadb.biz.net.id//repo/10.1/debian sid main'
  5656. apt-get -y --force-yes install software-properties-common
  5657. apt-get -y update
  5658. get_mariadb_password
  5659. if [ ! $MARIADB_PASSWORD ]; then
  5660. MARIADB_PASSWORD=$(openssl rand -base64 32)
  5661. echo "$MARIADB_PASSWORD" > $DATABASE_PASSWORD_FILE
  5662. chmod 600 $DATABASE_PASSWORD_FILE
  5663. echo '' >> /home/$MY_USERNAME/README
  5664. echo '' >> /home/$MY_USERNAME/README
  5665. echo 'MariaDB / MySql' >> /home/$MY_USERNAME/README
  5666. echo '===============' >> /home/$MY_USERNAME/README
  5667. echo "Your MariaDB password is: $MARIADB_PASSWORD" >> /home/$MY_USERNAME/README
  5668. echo '' >> /home/$MY_USERNAME/README
  5669. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5670. fi
  5671. debconf-set-selections <<< "mariadb-server mariadb-server/root_password password $MARIADB_PASSWORD"
  5672. debconf-set-selections <<< "mariadb-server mariadb-server/root_password_again password $MARIADB_PASSWORD"
  5673. apt-get -y --force-yes install mariadb-server
  5674. if [ ! -d /etc/mysql ]; then
  5675. echo "ERROR: mariadb-server does not appear to have installed. $CHECK_MESSAGE"
  5676. exit 54
  5677. fi
  5678. mysqladmin -u root password "$MARIADB_PASSWORD"
  5679. echo 'install_mariadb' >> $COMPLETION_FILE
  5680. }
  5681. function backup_databases_script_header {
  5682. if [ ! -f /usr/bin/backupdatabases ]; then
  5683. # daily
  5684. echo '#!/bin/sh' > /usr/bin/backupdatabases
  5685. echo '' >> /usr/bin/backupdatabases
  5686. echo "EMAIL='$MY_EMAIL_ADDRESS'" >> /usr/bin/backupdatabases
  5687. echo '' >> /usr/bin/backupdatabases
  5688. echo -n 'MYSQL_PASSWORD=$(cat ' >> /usr/bin/backupdatabases
  5689. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/backupdatabases
  5690. echo 'umask 0077' >> /usr/bin/backupdatabases
  5691. echo '' >> /usr/bin/backupdatabases
  5692. echo '# exit if we are backing up to friends servers' >> /usr/bin/backupdatabases
  5693. echo "if [ -f $FRIENDS_SERVERS_LIST ]; then" >> /usr/bin/backupdatabases
  5694. echo ' exit 1' >> /usr/bin/backupdatabases
  5695. echo 'fi' >> /usr/bin/backupdatabases
  5696. chmod 600 /usr/bin/backupdatabases
  5697. chmod +x /usr/bin/backupdatabases
  5698. echo '#!/bin/sh' > /etc/cron.daily/backupdatabasesdaily
  5699. echo '/usr/bin/backupdatabases' >> /etc/cron.daily/backupdatabasesdaily
  5700. chmod 600 /etc/cron.daily/backupdatabasesdaily
  5701. chmod +x /etc/cron.daily/backupdatabasesdaily
  5702. # weekly
  5703. echo '#!/bin/sh' > /etc/cron.weekly/backupdatabasesweekly
  5704. echo '' >> /etc/cron.weekly/backupdatabasesweekly
  5705. echo 'umask 0077' >> /etc/cron.weekly/backupdatabasesweekly
  5706. chmod 600 /etc/cron.weekly/backupdatabasesweekly
  5707. chmod +x /etc/cron.weekly/backupdatabasesweekly
  5708. # monthly
  5709. echo '#!/bin/sh' > /etc/cron.monthly/backupdatabasesmonthly
  5710. echo '' >> /etc/cron.monthly/backupdatabasesmonthly
  5711. echo 'umask 0077' >> /etc/cron.monthly/backupdatabasesmonthly
  5712. chmod 600 /etc/cron.monthly/backupdatabasesmonthly
  5713. chmod +x /etc/cron.monthly/backupdatabasesmonthly
  5714. fi
  5715. }
  5716. function repair_databases_script {
  5717. if grep -Fxq "repair_databases_script" $COMPLETION_FILE; then
  5718. return
  5719. fi
  5720. if [ ! -f $DATABASE_PASSWORD_FILE ]; then
  5721. return
  5722. fi
  5723. echo '#!/bin/bash' > /usr/bin/repairdatabase
  5724. echo '' >> /usr/bin/repairdatabase
  5725. echo 'DATABASE=$1' >> /usr/bin/repairdatabase
  5726. echo "EMAIL=$MY_EMAIL_ADDRESS" >> /usr/bin/repairdatabase
  5727. echo '' >> /usr/bin/repairdatabase
  5728. echo -n 'MYSQL_ROOT_PASSWORD=$(cat ' >> /usr/bin/repairdatabase
  5729. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/repairdatabase
  5730. echo 'TEMPFILE=/root/repairdatabase_$DATABASE' >> /usr/bin/repairdatabase
  5731. echo '' >> /usr/bin/repairdatabase
  5732. echo 'umask 0077' >> /usr/bin/repairdatabase
  5733. echo '' >> /usr/bin/repairdatabase
  5734. echo '# check the database' >> /usr/bin/repairdatabase
  5735. echo 'mysqlcheck -c -u root --password=$MYSQL_ROOT_PASSWORD $DATABASE > $TEMPFILE' >> /usr/bin/repairdatabase
  5736. echo '' >> /usr/bin/repairdatabase
  5737. echo '# Attempt to repair the database if it contains errors' >> /usr/bin/repairdatabase
  5738. echo 'if grep -q "Error" "$TEMPFILE"; then' >> /usr/bin/repairdatabase
  5739. echo ' mysqlcheck -u root --password=$MYSQL_ROOT_PASSWORD --auto-repair $DATABASE' >> /usr/bin/repairdatabase
  5740. echo 'else' >> /usr/bin/repairdatabase
  5741. echo ' # No errors were found, so exit' >> /usr/bin/repairdatabase
  5742. echo ' rm -f $TEMPFILE' >> /usr/bin/repairdatabase
  5743. echo ' exit 0' >> /usr/bin/repairdatabase
  5744. echo 'fi' >> /usr/bin/repairdatabase
  5745. echo 'rm -f $TEMPFILE' >> /usr/bin/repairdatabase
  5746. echo '' >> /usr/bin/repairdatabase
  5747. echo '# Check the database again' >> /usr/bin/repairdatabase
  5748. echo 'mysqlcheck -c -u root --password=$MYSQL_ROOT_PASSWORD $DATABASE > $TEMPFILE' >> /usr/bin/repairdatabase
  5749. echo '' >> /usr/bin/repairdatabase
  5750. echo '# If it still contains errors then restore from backup' >> /usr/bin/repairdatabase
  5751. echo 'if grep -q "Error" "$TEMPFILE"; then' >> /usr/bin/repairdatabase
  5752. echo ' mysql -u root --password=$MYSQL_ROOT_PASSWORD $DATABASE -o < /var/backups/${DATABASE}_daily.sql' >> /usr/bin/repairdatabase
  5753. echo '' >> /usr/bin/repairdatabase
  5754. echo ' # Send a warning email' >> /usr/bin/repairdatabase
  5755. echo ' echo "$DATABASE database corruption could not be repaired. Restored from backup." | mail -s "Freedombone database maintenance" $EMAIL' >> /usr/bin/repairdatabase
  5756. echo ' rm -f $TEMPFILE' >> /usr/bin/repairdatabase
  5757. echo '' >> /usr/bin/repairdatabase
  5758. echo ' exit 1' >> /usr/bin/repairdatabase
  5759. echo 'fi' >> /usr/bin/repairdatabase
  5760. echo 'rm -f $TEMPFILE' >> /usr/bin/repairdatabase
  5761. echo '' >> /usr/bin/repairdatabase
  5762. echo 'exit 0' >> /usr/bin/repairdatabase
  5763. chmod 600 /usr/bin/repairdatabase
  5764. chmod +x /usr/bin/repairdatabase
  5765. echo '#!/bin/bash' > /etc/cron.hourly/repair
  5766. echo '' >> /etc/cron.hourly/repair
  5767. chmod 600 /etc/cron.hourly/repair
  5768. chmod +x /etc/cron.hourly/repair
  5769. echo 'repair_databases_script' >> $COMPLETION_FILE
  5770. }
  5771. function install_owncloud_music_app {
  5772. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5773. return
  5774. fi
  5775. if grep -Fxq "install_owncloud_music_app" $COMPLETION_FILE; then
  5776. return
  5777. fi
  5778. cd /usr/share/owncloud/apps
  5779. git clone https://github.com/owncloud/music music
  5780. if grep -q "Music player in Owncloud" /home/$MY_USERNAME/README; then
  5781. echo '' >> /home/$MY_USERNAME/README
  5782. echo '' >> /home/$MY_USERNAME/README
  5783. echo 'Music player in Owncloud' >> /home/$MY_USERNAME/README
  5784. echo '========================' >> /home/$MY_USERNAME/README
  5785. echo 'To enable the music app within ouwncloud log in to the Owncloud' >> /home/$MY_USERNAME/README
  5786. echo 'administrator account then go to Apps on the left hand dropdown' >> /home/$MY_USERNAME/README
  5787. echo 'menu and enable the music app. You can then log out and log back' >> /home/$MY_USERNAME/README
  5788. echo 'in as your Owncloud user and select music from the left hand' >> /home/$MY_USERNAME/README
  5789. echo 'dropdown menu.' >> /home/$MY_USERNAME/README
  5790. fi
  5791. echo 'install_owncloud_music_app' >> $COMPLETION_FILE
  5792. }
  5793. function add_ddns_domain {
  5794. if [ ! $CURRENT_DDNS_DOMAIN ]; then
  5795. echo 'ddns domain not specified'
  5796. exit 5638
  5797. fi
  5798. if [ ! -f /etc/inadyn.conf ]; then
  5799. echo 'Unable to find inadyn configuration file /etc/inadyn.conf'
  5800. exit 5745
  5801. fi
  5802. if ! grep -q "$DDNS_PROVIDER" /etc/inadyn.conf; then
  5803. echo '' >> /etc/inadyn.conf
  5804. echo "system $DDNS_PROVIDER" >> /etc/inadyn.conf
  5805. echo ' ssl' >> /etc/inadyn.conf
  5806. if [ $DDNS_USERNAME ]; then
  5807. echo " username $DDNS_USERNAME" >> /etc/inadyn.conf
  5808. fi
  5809. if [ $DDNS_PASSWORD ]; then
  5810. echo " password $DDNS_PASSWORD" >> /etc/inadyn.conf
  5811. fi
  5812. fi
  5813. if ! grep -q "$CURRENT_DDNS_DOMAIN" /etc/inadyn.conf; then
  5814. if [ $CURRENT_DDNS_CODE ]; then
  5815. echo " alias $CURRENT_DDNS_DOMAIN,$CURRENT_DDNS_CODE" >> /etc/inadyn.conf
  5816. else
  5817. echo " alias $CURRENT_DDNS_DOMAIN" >> /etc/inadyn.conf
  5818. fi
  5819. fi
  5820. chmod 600 /etc/inadyn.conf
  5821. service inadyn restart
  5822. systemctl daemon-reload
  5823. # clear the arguments
  5824. CURRENT_DDNS_DOMAIN=
  5825. CURRENT_DDNS_CODE=
  5826. }
  5827. function install_owncloud {
  5828. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  5829. return
  5830. fi
  5831. OWNCLOUD_COMPLETION_MSG1=" *** Freedombone $SYSTEM_TYPE is now installed ***"
  5832. OWNCLOUD_COMPLETION_MSG2="Open $OWNCLOUD_DOMAIN_NAME in a web browser to complete the setup"
  5833. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  5834. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  5835. install_owncloud_music_app
  5836. create_backup_script
  5837. create_restore_script
  5838. backup_to_friends_servers
  5839. intrusion_detection
  5840. # unmount any attached usb drive
  5841. if [ -d $USB_MOUNT ]; then
  5842. umount $USB_MOUNT
  5843. rm -rf $USB_MOUNT
  5844. fi
  5845. echo ''
  5846. echo "$OWNCLOUD_COMPLETION_MSG1"
  5847. echo "$OWNCLOUD_COMPLETION_MSG2"
  5848. exit 0
  5849. fi
  5850. return
  5851. fi
  5852. # if this is exclusively a cloud setup
  5853. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  5854. OWNCLOUD_DOMAIN_NAME=$DOMAIN_NAME
  5855. OWNCLOUD_FREEDNS_SUBDOMAIN_CODE=$FREEDNS_SUBDOMAIN_CODE
  5856. fi
  5857. if [ ! $OWNCLOUD_DOMAIN_NAME ]; then
  5858. return
  5859. fi
  5860. if ! [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  5861. if [ $SYSTEM_TYPE ]; then
  5862. return
  5863. fi
  5864. fi
  5865. apt-get -y --force-yes install owncloud
  5866. install_mariadb
  5867. get_mariadb_password
  5868. get_mariadb_owncloud_admin_password
  5869. if [ ! $OWNCLOUD_ADMIN_PASSWORD ]; then
  5870. OWNCLOUD_ADMIN_PASSWORD=$(openssl rand -base64 32)
  5871. fi
  5872. if ! grep -q "Owncloud database user" /home/$MY_USERNAME/README; then
  5873. echo '' >> /home/$MY_USERNAME/README
  5874. echo '' >> /home/$MY_USERNAME/README
  5875. echo 'Owncloud' >> /home/$MY_USERNAME/README
  5876. echo '========' >> /home/$MY_USERNAME/README
  5877. echo 'Owncloud database user: owncloudadmin' >> /home/$MY_USERNAME/README
  5878. echo "Owncloud database password: $OWNCLOUD_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  5879. echo 'Owncloud database name: owncloud' >> /home/$MY_USERNAME/README
  5880. echo '' >> /home/$MY_USERNAME/README
  5881. echo 'After creating an administrator account then create a user account via' >> /home/$MY_USERNAME/README
  5882. echo "the Users dropdown menu entry. The username should be '$MY_USERNAME'." >> /home/$MY_USERNAME/README
  5883. echo '' >> /home/$MY_USERNAME/README
  5884. echo 'On mobile devices you can download the Owncloud client via F-Droid.' >> /home/$MY_USERNAME/README
  5885. echo '' >> /home/$MY_USERNAME/README
  5886. echo 'To synchronise calendar entries with Android "install CalDAV Sync Adapter"' >> /home/$MY_USERNAME/README
  5887. echo 'using F-Droid then go to settings/accounts and add a CalDav account with' >> /home/$MY_USERNAME/README
  5888. echo "the URL https://$OWNCLOUD_DOMAIN_NAME/remote.php/caldav/principals/$MY_USERNAME" >> /home/$MY_USERNAME/README
  5889. echo 'and the username and password shown above.' >> /home/$MY_USERNAME/README
  5890. fi
  5891. echo "create database owncloud;
  5892. CREATE USER 'owncloudadmin'@'localhost' IDENTIFIED BY '$OWNCLOUD_ADMIN_PASSWORD';
  5893. GRANT ALL PRIVILEGES ON owncloud.* TO 'owncloudadmin'@'localhost';
  5894. quit" > $INSTALL_DIR/batch.sql
  5895. chmod 600 $INSTALL_DIR/batch.sql
  5896. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  5897. shred -zu $INSTALL_DIR/batch.sql
  5898. if [ ! -d /var/www/$OWNCLOUD_DOMAIN_NAME ]; then
  5899. mkdir /var/www/$OWNCLOUD_DOMAIN_NAME
  5900. fi
  5901. if [ -d /var/www/$OWNCLOUD_DOMAIN_NAME/htdocs ]; then
  5902. rm -rf /var/www/$OWNCLOUD_DOMAIN_NAME/htdocs
  5903. fi
  5904. ln -s /usr/share/owncloud /var/www/$OWNCLOUD_DOMAIN_NAME/htdocs
  5905. echo 'server {' > /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5906. echo ' listen 80;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5907. echo " server_name $OWNCLOUD_DOMAIN_NAME;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5908. echo ' access_log off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5909. echo " error_log /var/log/nginx/$OWNCLOUD_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5910. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5911. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5912. echo ' rewrite ^ https://$server_name$request_uri? permanent;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5913. echo '}' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5914. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5915. echo 'server {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5916. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5917. echo " root /var/www/$OWNCLOUD_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5918. echo " server_name $OWNCLOUD_DOMAIN_NAME;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5919. echo ' access_log off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5920. echo " error_log /var/log/nginx/$OWNCLOUD_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5921. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5922. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5923. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5924. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5925. echo ' ssl on;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5926. echo " ssl_certificate /etc/ssl/certs/$OWNCLOUD_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5927. echo " ssl_certificate_key /etc/ssl/private/$OWNCLOUD_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5928. echo " ssl_dhparam /etc/ssl/certs/$OWNCLOUD_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5929. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5930. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5931. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5932. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5933. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5934. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5935. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5936. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5937. echo ' # if you want to be able to access the site via HTTP' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5938. echo ' # then replace the above with the following:' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5939. echo ' # add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5940. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5941. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5942. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5943. echo ' allow all;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5944. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5945. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5946. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5947. echo ' client_max_body_size 10G; # set max upload size' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5948. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5949. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5950. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5951. echo ' rewrite ^/caldav(.*)$ /remote.php/caldav$1 redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5952. echo ' rewrite ^/carddav(.*)$ /remote.php/carddav$1 redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5953. echo ' rewrite ^/webdav(.*)$ /remote.php/webdav$1 redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5954. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5955. echo ' index index.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5956. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5957. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5958. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5959. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5960. echo ' allow all;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5961. echo ' log_not_found off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5962. echo ' access_log off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5963. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5964. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5965. echo ' location ~ ^/(data|config|\.ht|db_structure\.xml|README) {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5966. echo ' deny all;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5967. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5968. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5969. echo ' location / {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5970. echo ' # The following 2 rules are only needed with webfinger' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5971. echo ' rewrite ^/.well-known/host-meta /public.php?service=host-meta last;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5972. echo ' rewrite ^/.well-known/host-meta.json /public.php?service=host-meta-json last;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5973. echo ' rewrite ^/.well-known/carddav /remote.php/carddav/ redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5974. echo ' rewrite ^/.well-known/caldav /remote.php/caldav/ redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5975. echo ' rewrite ^(/core/doc/[^\/]+/)$ $1/index.html;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5976. echo ' try_files $uri $uri/ index.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5977. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5978. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5979. echo ' location ~ ^(.+?\.php)(/.*)?$ {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5980. echo ' try_files $1 =404;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5981. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5982. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5983. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5984. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5985. echo ' fastcgi_param SCRIPT_FILENAME $document_root$1;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5986. echo ' fastcgi_param PATH_INFO $2;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5987. echo ' fastcgi_param HTTPS on;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5988. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5989. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5990. echo ' # Optional: set long EXPIRES header on static assets' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5991. echo ' location ~* ^.+\.(jpg|jpeg|gif|bmp|ico|png|css|js|swf)$ {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5992. echo ' expires 30d;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5993. echo " # Optional: Don't log access to assets" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5994. echo ' access_log off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5995. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5996. echo '}' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  5997. configure_php
  5998. if [ ! -f /etc/ssl/private/$OWNCLOUD_DOMAIN_NAME.key ]; then
  5999. makecert $OWNCLOUD_DOMAIN_NAME
  6000. fi
  6001. # Ensure that the database gets backed up locally, if remote
  6002. # backups are not being used
  6003. backup_databases_script_header
  6004. echo '' >> /usr/bin/backupdatabases
  6005. echo '# Backup Owncloud database' >> /usr/bin/backupdatabases
  6006. echo 'TEMPFILE=/root/owncloud.sql' >> /usr/bin/backupdatabases
  6007. echo 'DAILYFILE=/var/backups/owncloud_daily.sql' >> /usr/bin/backupdatabases
  6008. echo 'mysqldump --password="$MYSQL_PASSWORD" owncloud > $TEMPFILE' >> /usr/bin/backupdatabases
  6009. echo 'FILESIZE=$(stat -c%s $TEMPFILE)' >> /usr/bin/backupdatabases
  6010. echo 'if [ "$FILESIZE" -eq "0" ]; then' >> /usr/bin/backupdatabases
  6011. echo ' if [ -f $DAILYFILE ]; then' >> /usr/bin/backupdatabases
  6012. echo ' cp $DAILYFILE $TEMPFILE' >> /usr/bin/backupdatabases
  6013. echo '' >> /usr/bin/backupdatabases
  6014. echo ' # try to restore yesterdays database' >> /usr/bin/backupdatabases
  6015. echo ' mysql -u root --password="$MYSQL_PASSWORD" owncloud -o < $DAILYFILE' >> /usr/bin/backupdatabases
  6016. echo '' >> /usr/bin/backupdatabases
  6017. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  6018. echo ' echo "Unable to create a backup of the Owncloud database. Attempted to restore from yesterdays backup" | mail -s "Owncloud backup" $EMAIL' >> /usr/bin/backupdatabases
  6019. echo ' else' >> /usr/bin/backupdatabases
  6020. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  6021. echo ' echo "Unable to create a backup of the Owncloud database." | mail -s "Owncloud backup" $EMAIL' >> /usr/bin/backupdatabases
  6022. echo ' fi' >> /usr/bin/backupdatabases
  6023. echo 'else' >> /usr/bin/backupdatabases
  6024. echo ' chmod 600 $TEMPFILE' >> /usr/bin/backupdatabases
  6025. echo ' mv $TEMPFILE $DAILYFILE' >> /usr/bin/backupdatabases
  6026. echo '' >> /usr/bin/backupdatabases
  6027. echo ' # Make the backup readable only by root' >> /usr/bin/backupdatabases
  6028. echo ' chmod 600 $DAILYFILE' >> /usr/bin/backupdatabases
  6029. echo 'fi' >> /usr/bin/backupdatabases
  6030. nginx_ensite $OWNCLOUD_DOMAIN_NAME
  6031. service php5-fpm restart
  6032. service nginx restart
  6033. # update the dynamic DNS
  6034. CURRENT_DDNS_DOMAIN=$OWNCLOUD_DOMAIN_NAME
  6035. CURRENT_DDNS_CODE=$OWNCLOUD_FREEDNS_SUBDOMAIN_CODE
  6036. add_ddns_domain
  6037. echo 'install_owncloud' >> $COMPLETION_FILE
  6038. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  6039. install_owncloud_music_app
  6040. create_backup_script
  6041. create_restore_script
  6042. backup_to_friends_servers
  6043. intrusion_detection
  6044. # unmount any attached usb drive
  6045. if [ -d $USB_MOUNT ]; then
  6046. umount $USB_MOUNT
  6047. rm -rf $USB_MOUNT
  6048. fi
  6049. echo ''
  6050. echo "$OWNCLOUD_COMPLETION_MSG1"
  6051. echo "$OWNCLOUD_COMPLETION_MSG2"
  6052. exit 0
  6053. fi
  6054. }
  6055. function install_xmpp {
  6056. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  6057. return
  6058. fi
  6059. if grep -Fxq "install_xmpp" $COMPLETION_FILE; then
  6060. return
  6061. fi
  6062. apt-get -y --force-yes install prosody
  6063. if [ ! -d /etc/prosody ]; then
  6064. echo "ERROR: prosody does not appear to have installed. $CHECK_MESSAGE"
  6065. exit 52
  6066. fi
  6067. if [ ! -f "/etc/ssl/private/xmpp.key" ]; then
  6068. makecert xmpp
  6069. fi
  6070. chown prosody:prosody /etc/ssl/private/xmpp.key
  6071. chown prosody:prosody /etc/ssl/certs/xmpp.*
  6072. cp -a /etc/prosody/conf.avail/example.com.cfg.lua /etc/prosody/conf.avail/xmpp.cfg.lua
  6073. sed -i 's|/etc/prosody/certs/example.com.key|/etc/ssl/private/xmpp.key|g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6074. sed -i 's|/etc/prosody/certs/example.com.crt|/etc/ssl/certs/xmpp.crt|g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6075. if ! grep -q "xmpp.dhparam" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6076. sed -i '/certificate =/a\ dhparam = "/etc/ssl/certs/xmpp.dhparam";' /etc/prosody/conf.avail/xmpp.cfg.lua
  6077. fi
  6078. if ! grep -q 'options = {"no_sslv2", "no_sslv3" }' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6079. sed -i '/certificate =/a\ options = {"no_sslv2", "no_sslv3" };' /etc/prosody/conf.avail/xmpp.cfg.lua
  6080. fi
  6081. if ! grep -q 'ciphers =' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6082. sed -i "/certificate =/a\ ciphers = $XMPP_CIPHERS;" /etc/prosody/conf.avail/xmpp.cfg.lua
  6083. fi
  6084. if ! grep -q 'depth = "1";' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6085. sed -i '/certificate =/a\ depth = "1";' /etc/prosody/conf.avail/xmpp.cfg.lua
  6086. fi
  6087. if ! grep -q 'curve =' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6088. sed -i "/certificate =/a\ curve = $XMPP_ECC_CURVE;" /etc/prosody/conf.avail/xmpp.cfg.lua
  6089. fi
  6090. sed -i "s/example.com/$DOMAIN_NAME/g" /etc/prosody/conf.avail/xmpp.cfg.lua
  6091. sed -i 's/enabled = false -- Remove this line to enable this host//g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6092. if ! grep -q "modules_enabled" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6093. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6094. echo 'modules_enabled = {' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6095. echo ' "bosh"; -- Enable mod_bosh' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6096. echo ' "tls"; -- Enable mod_tls' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6097. echo ' "saslauth"; -- Enable mod_saslauth' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6098. echo '}' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6099. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6100. echo 'c2s_require_encryption = true' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6101. echo 's2s_require_encryption = true' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6102. echo 'allow_unencrypted_plain_auth = false' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6103. fi
  6104. ln -sf /etc/prosody/conf.avail/xmpp.cfg.lua /etc/prosody/conf.d/xmpp.cfg.lua
  6105. sed -i 's|/etc/prosody/certs/localhost.key|/etc/ssl/private/xmpp.key|g' /etc/prosody/prosody.cfg.lua
  6106. sed -i 's|/etc/prosody/certs/localhost.crt|/etc/ssl/certs/xmpp.crt|g' /etc/prosody/prosody.cfg.lua
  6107. if ! grep -q "xmpp.dhparam" /etc/prosody/prosody.cfg.lua; then
  6108. sed -i '/certificate =/a\ dhparam = "/etc/ssl/certs/xmpp.dhparam";' /etc/prosody/prosody.cfg.lua
  6109. fi
  6110. if ! grep -q 'options = {"no_sslv2", "no_sslv3" }' /etc/prosody/prosody.cfg.lua; then
  6111. sed -i '/certificate =/a\ options = {"no_sslv2", "no_sslv3" };' /etc/prosody/prosody.cfg.lua
  6112. fi
  6113. if ! grep -q 'ciphers =' /etc/prosody/prosody.cfg.lua; then
  6114. sed -i "/certificate =/a\ ciphers = $XMPP_CIPHERS;" /etc/prosody/prosody.cfg.lua
  6115. fi
  6116. if ! grep -q 'depth = "1";' /etc/prosody/prosody.cfg.lua; then
  6117. sed -i '/certificate =/a\ depth = "1";' /etc/prosody/prosody.cfg.lua
  6118. fi
  6119. if ! grep -q 'curve =' /etc/prosody/prosody.cfg.lua; then
  6120. sed -i "/certificate =/a\ curve = $XMPP_ECC_CURVE;" /etc/prosody/prosody.cfg.lua
  6121. fi
  6122. sed -i 's/c2s_require_encryption = false/c2s_require_encryption = true/g' /etc/prosody/prosody.cfg.lua
  6123. if ! grep -q "s2s_require_encryption" /etc/prosody/prosody.cfg.lua; then
  6124. sed -i '/c2s_require_encryption/a\s2s_require_encryption = true' /etc/prosody/prosody.cfg.lua
  6125. fi
  6126. if ! grep -q "allow_unencrypted_plain_auth" /etc/prosody/prosody.cfg.lua; then
  6127. echo 'allow_unencrypted_plain_auth = false' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6128. fi
  6129. sed -i 's/--"bosh";/"bosh";/g' /etc/prosody/prosody.cfg.lua
  6130. sed -i 's/authentication = "internal_plain"/authentication = "internal_hashed"/g' /etc/prosody/prosody.cfg.lua
  6131. sed -i 's/enabled = false -- Remove this line to enable this host//g' /etc/prosody/prosody.cfg.lua
  6132. sed -i 's|key = "/etc/prosody/certs/example.com.key"|key = "/etc/ssl/private/xmpp.key"|g' /etc/prosody/prosody.cfg.lua
  6133. sed -i 's|certificate = "/etc/prosody/certs/example.com.crt"|certificate = "/etc/ssl/certs/xmpp.crt"|g' /etc/prosody/prosody.cfg.lua
  6134. sed -i "s/example.com/$DOMAIN_NAME/g" /etc/prosody/prosody.cfg.lua
  6135. service prosody restart
  6136. touch /home/$MY_USERNAME/README
  6137. if ! grep -q "Your XMPP password is" /home/$MY_USERNAME/README; then
  6138. XMPP_PASSWORD=$(openssl rand -base64 8)
  6139. prosodyctl register $MY_USERNAME $DOMAIN_NAME $XMPP_PASSWORD
  6140. echo '' >> /home/$MY_USERNAME/README
  6141. echo '' >> /home/$MY_USERNAME/README
  6142. echo 'XMPP' >> /home/$MY_USERNAME/README
  6143. echo '====' >> /home/$MY_USERNAME/README
  6144. echo "Your XMPP password is: $XMPP_PASSWORD" >> /home/$MY_USERNAME/README
  6145. echo 'You can change it with: ' >> /home/$MY_USERNAME/README
  6146. echo '' >> /home/$MY_USERNAME/README
  6147. echo " prosodyctl passwd $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/README
  6148. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6149. fi
  6150. echo 'install_xmpp' >> $COMPLETION_FILE
  6151. }
  6152. function install_watchdog_script {
  6153. if grep -Fxq "install_watchdog_script" $COMPLETION_FILE; then
  6154. return
  6155. fi
  6156. echo '#!/bin/bash' > /usr/bin/$WATCHDOG_SCRIPT_NAME
  6157. echo 'LOGFILE=/var/log/keepon.log' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6158. echo 'CURRENT_DATE=$(date)' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6159. # application specific stuff is added later
  6160. chmod +x /usr/bin/$WATCHDOG_SCRIPT_NAME
  6161. if ! grep -q "/usr/bin/$WATCHDOG_SCRIPT_NAME" /etc/crontab; then
  6162. echo "*/1 * * * * root /usr/bin/$WATCHDOG_SCRIPT_NAME" >> /etc/crontab
  6163. fi
  6164. echo 'install_watchdog_script' >> $COMPLETION_FILE
  6165. }
  6166. function install_irc_server {
  6167. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  6168. return
  6169. fi
  6170. if grep -Fxq "install_irc_server" $COMPLETION_FILE; then
  6171. return
  6172. fi
  6173. apt-get -y --force-yes install ngircd
  6174. if [ ! -d /etc/ngircd ]; then
  6175. echo "ERROR: ngircd does not appear to have installed. $CHECK_MESSAGE"
  6176. exit 53
  6177. fi
  6178. if [ ! -f /etc/ssl/private/ngircd.key ]; then
  6179. makecert ngircd
  6180. fi
  6181. echo '**************************************************' > /etc/ngircd/motd
  6182. echo '* F R E E D O M B O N E I R C *' >> /etc/ngircd/motd
  6183. echo '* *' >> /etc/ngircd/motd
  6184. echo '* Freedom in the Cloud *' >> /etc/ngircd/motd
  6185. echo '**************************************************' >> /etc/ngircd/motd
  6186. sed -i 's|MotdFile = /etc/ngircd/ngircd.motd|MotdFile = /etc/ngircd/motd|g' /etc/ngircd/ngircd.conf
  6187. sed -i "s/irc@irc.example.com/$MY_EMAIL_ADDRESS/g" /etc/ngircd/ngircd.conf
  6188. sed -i "s/irc.example.net/$DOMAIN_NAME/g" /etc/ngircd/ngircd.conf
  6189. sed -i "s|Yet another IRC Server running on Debian GNU/Linux|IRC Server of $DOMAIN_NAME|g" /etc/ngircd/ngircd.conf
  6190. sed -i 's/;Password = wealllikedebian/Password =/g' /etc/ngircd/ngircd.conf
  6191. sed -i 's|;CertFile = /etc/ssl/certs/server.crt|CertFile = /etc/ssl/certs/ngircd.crt|g' /etc/ngircd/ngircd.conf
  6192. sed -i 's|;DHFile = /etc/ngircd/dhparams.pem|DHFile = /etc/ssl/certs/ngircd.dhparam|g' /etc/ngircd/ngircd.conf
  6193. sed -i 's|;KeyFile = /etc/ssl/private/server.key|KeyFile = /etc/ssl/private/ngircd.key|g' /etc/ngircd/ngircd.conf
  6194. sed -i 's/;Ports = 6697, 9999/Ports = 6697, 9999/g' /etc/ngircd/ngircd.conf
  6195. sed -i 's/;Name = #ngircd/Name = #freedombone/g' /etc/ngircd/ngircd.conf
  6196. sed -i 's/;Topic = Our ngircd testing channel/Topic = Freedombone chat channel/g' /etc/ngircd/ngircd.conf
  6197. sed -i 's/;MaxUsers = 23/MaxUsers = 23/g' /etc/ngircd/ngircd.conf
  6198. sed -i 's|;KeyFile = /etc/ngircd/#chan.key|KeyFile = /etc/ngircd/#freedombone.key|g' /etc/ngircd/ngircd.conf
  6199. sed -i 's/;CloakHost = cloaked.host/CloakHost = freedombone/g' /etc/ngircd/ngircd.conf
  6200. IRC_SALT=$(openssl rand -base64 32)
  6201. IRC_OPERATOR_PASSWORD=$(openssl rand -base64 8)
  6202. sed -i "s|;CloakHostSalt = abcdefghijklmnopqrstuvwxyz|CloakHostSalt = $IRC_SALT|g" /etc/ngircd/ngircd.conf
  6203. sed -i 's/;ConnectIPv4 = yes/ConnectIPv4 = yes/g' /etc/ngircd/ngircd.conf
  6204. sed -i 's/;MorePrivacy = no/MorePrivacy = yes/g' /etc/ngircd/ngircd.conf
  6205. sed -i 's/;RequireAuthPing = no/RequireAuthPing = no/g' /etc/ngircd/ngircd.conf
  6206. sed -i "s/;Name = TheOper/Name = $MY_USERNAME/g" /etc/ngircd/ngircd.conf
  6207. sed -i "s/;Password = ThePwd/Password = $IRC_OPERATOR_PASSWORD/g" /etc/ngircd/ngircd.conf
  6208. service ngircd start
  6209. # keep the daemon running
  6210. echo '' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6211. echo '# keep irc daemon running' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6212. echo 'IRC_RUNNING=$(pgrep ngircd > /dev/null && echo Running)' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6213. echo 'if [ ! $IRC_RUNNING ]; then' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6214. echo ' service ngircd start' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6215. echo ' echo -n $CURRENT_DATE >> $LOGFILE' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6216. echo ' echo " IRC daemon restarted" >> $LOGFILE' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6217. echo 'fi' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6218. if ! grep -q "IRC Server" /home/$MY_USERNAME/README; then
  6219. echo '' >> /home/$MY_USERNAME/README
  6220. echo '' >> /home/$MY_USERNAME/README
  6221. echo 'IRC Server' >> /home/$MY_USERNAME/README
  6222. echo '==========' >> /home/$MY_USERNAME/README
  6223. echo 'To connect to your IRC server in irssi:' >> /home/$MY_USERNAME/README
  6224. echo '' >> /home/$MY_USERNAME/README
  6225. echo " /server add -auto -ssl $DOMAIN_NAME 6697" >> /home/$MY_USERNAME/README
  6226. echo " /connect $DOMAIN_NAME" >> /home/$MY_USERNAME/README
  6227. echo ' /join #freedombone' >> /home/$MY_USERNAME/README
  6228. fi
  6229. echo 'install_irc_server' >> $COMPLETION_FILE
  6230. }
  6231. function get_wiki_admin_password {
  6232. if [ -f /home/$MY_USERNAME/README ]; then
  6233. if grep -q "Wiki password" /home/$MY_USERNAME/README; then
  6234. WIKI_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Wiki password:" | awk -F ':' '{print $2}' | sed 's/^ *//')
  6235. fi
  6236. fi
  6237. }
  6238. function install_wiki {
  6239. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  6240. return
  6241. fi
  6242. if grep -Fxq "install_wiki" $COMPLETION_FILE; then
  6243. return
  6244. fi
  6245. # if everything is being installed or if this is exclusively a writer setup
  6246. if [[ $SYSTEM_TYPE == "$VARIANT_FULL" || $SYSTEM_TYPE == "$VARIANT_WRITER" ]]; then
  6247. WIKI_DOMAIN_NAME=$DOMAIN_NAME
  6248. WIKI_FREEDNS_SUBDOMAIN_CODE=$FREEDNS_SUBDOMAIN_CODE
  6249. fi
  6250. if [ ! $WIKI_DOMAIN_NAME ]; then
  6251. return
  6252. fi
  6253. apt-get -y --force-yes install dokuwiki
  6254. if [ ! -d /var/www/$WIKI_DOMAIN_NAME ]; then
  6255. mkdir /var/www/$WIKI_DOMAIN_NAME
  6256. fi
  6257. if [ -d /var/www/$WIKI_DOMAIN_NAME/htdocs ]; then
  6258. rm -rf /var/www/$WIKI_DOMAIN_NAME/htdocs
  6259. fi
  6260. if [ ! -f /etc/ssl/private/$WIKI_DOMAIN_NAME.key ]; then
  6261. makecert $WIKI_DOMAIN_NAME
  6262. fi
  6263. ln -s /usr/share/dokuwiki /var/www/$WIKI_DOMAIN_NAME/htdocs
  6264. mkdir /var/lib/dokuwiki/custom
  6265. cp /etc/dokuwiki/local.php.dist /var/lib/dokuwiki/custom/local.php
  6266. ln -s /var/lib/dokuwiki/custom/local.php /etc/dokuwiki/local.php
  6267. chown www-data /var/lib/dokuwiki/custom
  6268. chown www-data /var/lib/dokuwiki/custom/local.php
  6269. chmod 600 /var/lib/dokuwiki/custom/local.php
  6270. sed -i 's|//$conf|$conf|g' /var/lib/dokuwiki/custom/local.php
  6271. sed -i "s|joe|$MY_USERNAME|g" /var/lib/dokuwiki/custom/local.php
  6272. sed -i "s|Debian DokuWiki|$WIKI_TITLE|g" /etc/dokuwiki/local.php
  6273. # set the admin user
  6274. sed -i "s/@admin/$MY_USERNAME/g" /etc/dokuwiki/local.php
  6275. # disallow registration of new users
  6276. if ! grep -q "disableactions" /etc/dokuwiki/local.php; then
  6277. echo "$conf['disableactions'] = 'register'" >> /etc/dokuwiki/local.php
  6278. fi
  6279. if ! grep -q "disableactions" /var/lib/dokuwiki/custom/local.php; then
  6280. echo "$conf['disableactions'] = 'register';" >> /var/lib/dokuwiki/custom/local.php
  6281. fi
  6282. if ! grep -q "authtype" /var/lib/dokuwiki/custom/local.php; then
  6283. echo "$conf['authtype'] = 'authplain';" >> /var/lib/dokuwiki/custom/local.php
  6284. fi
  6285. if ! grep -q "authtype" /etc/dokuwiki/local.php; then
  6286. echo "$conf['authtype'] = 'authplain';" >> /etc/dokuwiki/local.php
  6287. fi
  6288. get_wiki_admin_password
  6289. if [ ! $WIKI_ADMIN_PASSWORD ]; then
  6290. WIKI_ADMIN_PASSWORD=$(openssl rand -base64 16)
  6291. fi
  6292. HASHED_WIKI_PASSWORD=$(echo -n "$WIKI_ADMIN_PASSWORD" | md5sum | awk -F ' ' '{print $1}')
  6293. echo -n "$MY_USERNAME:$HASHED_WIKI_PASSWORD:$MY_NAME:$MY_EMAIL:admin,user,upload" > /var/lib/dokuwiki/acl/users.auth.php
  6294. chmod 640 /var/lib/dokuwiki/acl/users.auth.php
  6295. if ! grep -q "video/ogg" /var/www/$WIKI_DOMAIN_NAME/htdocs/conf/mime.conf; then
  6296. echo 'ogv video/ogg' >> /var/www/$WIKI_DOMAIN_NAME/htdocs/conf/mime.conf
  6297. echo 'mp4 video/mp4' >> /var/www/$WIKI_DOMAIN_NAME/htdocs/conf/mime.conf
  6298. echo 'webm video/webm' >> /var/www/$WIKI_DOMAIN_NAME/htdocs/conf/mime.conf
  6299. fi
  6300. echo 'server {' > /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6301. echo ' listen 80;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6302. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6303. echo " server_name $WIKI_DOMAIN_NAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6304. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6305. echo " error_log /var/log/nginx/$WIKI_DOMAIN_NAME_error.log;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6306. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6307. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6308. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6309. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6310. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6311. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6312. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6313. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6314. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6315. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6316. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6317. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6318. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6319. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6320. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6321. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6322. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6323. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6324. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6325. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6326. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6327. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6328. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6329. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6330. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6331. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6332. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6333. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6334. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6335. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6336. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6337. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6338. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6339. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6340. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6341. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6342. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6343. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6344. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6345. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6346. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6347. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6348. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6349. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6350. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6351. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6352. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6353. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6354. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6355. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6356. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6357. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6358. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6359. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6360. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6361. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6362. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6363. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6364. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6365. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6366. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6367. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6368. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6369. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6370. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6371. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6372. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6373. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6374. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6375. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6376. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6377. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6378. echo 'server {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6379. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6380. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6381. echo " server_name $WIKI_DOMAIN_NAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6382. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6383. echo " error_log /var/log/nginx/$WIKI_DOMAIN_NAME_error_ssl.log;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6384. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6385. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6386. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6387. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6388. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6389. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6390. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6391. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6392. echo ' ssl on;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6393. echo " ssl_certificate /etc/ssl/certs/$WIKI_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6394. echo " ssl_certificate_key /etc/ssl/private/$WIKI_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6395. echo " ssl_dhparam /etc/ssl/certs/$WIKI_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6396. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6397. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6398. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6399. echo ' ssl_session_cache builtin:1000 shared:SSL:10m;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6400. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6401. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6402. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6403. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6404. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6405. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6406. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6407. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6408. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6409. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6410. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6411. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6412. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6413. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6414. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6415. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6416. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6417. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6418. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6419. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6420. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6421. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6422. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6423. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6424. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6425. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6426. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6427. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6428. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6429. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6430. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6431. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6432. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6433. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6434. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6435. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6436. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6437. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6438. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6439. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6440. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6441. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6442. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6443. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6444. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6445. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6446. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6447. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6448. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6449. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6450. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6451. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6452. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6453. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6454. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6455. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6456. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6457. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6458. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6459. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6460. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6461. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6462. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6463. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6464. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6465. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6466. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6467. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6468. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6469. configure_php
  6470. nginx_ensite $WIKI_DOMAIN_NAME
  6471. service php5-fpm restart
  6472. service nginx restart
  6473. # update the dynamic DNS
  6474. CURRENT_DDNS_DOMAIN=$WIKI_DOMAIN_NAME
  6475. CURRENT_DDNS_CODE=$WIKI_FREEDNS_SUBDOMAIN_CODE
  6476. add_ddns_domain
  6477. # add some post-install instructions
  6478. if ! grep -q "Wiki password" /home/$MY_USERNAME/README; then
  6479. echo '' >> /home/$MY_USERNAME/README
  6480. echo '' >> /home/$MY_USERNAME/README
  6481. echo 'Wiki' >> /home/$MY_USERNAME/README
  6482. echo '====' >> /home/$MY_USERNAME/README
  6483. echo "Wiki username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  6484. echo "Wiki password: $WIKI_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  6485. echo '' >> /home/$MY_USERNAME/README
  6486. echo 'Once you have set up the wiki then remove the install file:' >> /home/$MY_USERNAME/README
  6487. echo '' >> /home/$MY_USERNAME/README
  6488. echo " rm /var/www/$WIKI_DOMAIN_NAME/htdocs/install.php" >> /home/$MY_USERNAME/README
  6489. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6490. fi
  6491. echo 'install_wiki' >> $COMPLETION_FILE
  6492. }
  6493. function get_blog_admin_password {
  6494. if [ -f /home/$MY_USERNAME/README ]; then
  6495. if grep -q "Your blog password is" /home/$MY_USERNAME/README; then
  6496. FULLBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Your blog password is" | awk -F ':' '{print $2}' | sed 's/^ *//')
  6497. fi
  6498. fi
  6499. }
  6500. function install_blog {
  6501. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  6502. return
  6503. fi
  6504. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  6505. return
  6506. fi
  6507. if [ ! $FULLBLOG_DOMAIN_NAME ]; then
  6508. return
  6509. fi
  6510. if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME ]; then
  6511. mkdir /var/www/$FULLBLOG_DOMAIN_NAME
  6512. fi
  6513. cd /var/www/$FULLBLOG_DOMAIN_NAME
  6514. git clone https://github.com/danpros/htmly htdocs
  6515. chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs
  6516. if [ ! -f /etc/ssl/private/$FULLBLOG_DOMAIN_NAME.key ]; then
  6517. makecert $FULLBLOG_DOMAIN_NAME
  6518. fi
  6519. echo 'server {' > /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6520. echo ' listen 80;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6521. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6522. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6523. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6524. echo " error_log /var/log/nginx/$FULLBLOG_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6525. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6526. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6527. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6528. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6529. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6530. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6531. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6532. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6533. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6534. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6535. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6536. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6537. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6538. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6539. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6540. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6541. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6542. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6543. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6544. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6545. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6546. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6547. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6548. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6549. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6550. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6551. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6552. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6553. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6554. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6555. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6556. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6557. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6558. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6559. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6560. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6561. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6562. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6563. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6564. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6565. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6566. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6567. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6568. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6569. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6570. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6571. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6572. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6573. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6574. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6575. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6576. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6577. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6578. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6579. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6580. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6581. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6582. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6583. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6584. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6585. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6586. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6587. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6588. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6589. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6590. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6591. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6592. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6593. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6594. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6595. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6596. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6597. echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6598. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6599. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6600. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6601. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6602. echo " error_log /var/log/nginx/$FULLBLOG_DOMAIN_NAME_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6603. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6604. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6605. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6606. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6607. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6608. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6609. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6610. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6611. echo ' ssl on;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6612. echo " ssl_certificate /etc/ssl/certs/$FULLBLOG_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6613. echo " ssl_certificate_key /etc/ssl/private/$FULLBLOG_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6614. echo " ssl_dhparam /etc/ssl/certs/$FULLBLOG_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6615. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6616. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6617. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6618. echo ' ssl_session_cache builtin:1000 shared:SSL:10m;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6619. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6620. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6621. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6622. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6623. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6624. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6625. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6626. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6627. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6628. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6629. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6630. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6631. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6632. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6633. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6634. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6635. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6636. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6637. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6638. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6639. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6640. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6641. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6642. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6643. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6644. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6645. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6646. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6647. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6648. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6649. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6650. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6651. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6652. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6653. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6654. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6655. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6656. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6657. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6658. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6659. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6660. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6661. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6662. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6663. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6664. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6665. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6666. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6667. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6668. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6669. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6670. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6671. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6672. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6673. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6674. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6675. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6676. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6677. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6678. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6679. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6680. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6681. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6682. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6683. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6684. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6685. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6686. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6687. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6688. configure_php
  6689. # blog settings
  6690. cp /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini.example /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6691. sed -i "s|site.url.*|site.url = 'https://$FULLBLOG_DOMAIN_NAME'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6692. sed -i "s|blog.title.*|blog.title = '$MY_BLOG_TITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6693. sed -i "s|blog.tagline.*|blog.tagline = '$MY_BLOG_SUBTITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6694. sed -i 's|timezone.*|timezone = "Europe/London"|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6695. sed -i "s|Your name|$MY_NAME|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6696. # create a user password
  6697. get_blog_admin_password
  6698. if [ ! $FULLBLOG_ADMIN_PASSWORD ]; then
  6699. FULLBLOG_ADMIN_PASSWORD=$(openssl rand -base64 16)
  6700. echo '' >> /home/$MY_USERNAME/README
  6701. echo '' >> /home/$MY_USERNAME/README
  6702. echo 'HTMLy Blog' >> /home/$MY_USERNAME/README
  6703. echo '==========' >> /home/$MY_USERNAME/README
  6704. echo "Your blog username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  6705. echo "Your blog password is: $FULLBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  6706. echo "Log into your blog at https://$FULLBLOG_DOMAIN_NAME/login" >> /home/$MY_USERNAME/README
  6707. echo 'Edit your blog title and time zone at:' >> /home/$MY_USERNAME/README
  6708. echo " /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini" >> /home/$MY_USERNAME/README
  6709. echo '' >> /home/$MY_USERNAME/README
  6710. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6711. fi
  6712. # create a user
  6713. cp /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/username.ini.example /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  6714. HASHED_BLOG_PASSWORD="$(echo -n $FULLBLOG_ADMIN_PASSWORD | sha256sum | awk -F ' ' '{print $1}')"
  6715. sed -i "s|yourpassword|$HASHED_BLOG_PASSWORD|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  6716. sed -i 's/encryption = clear/encryption = "sha256"/g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  6717. nginx_ensite $FULLBLOG_DOMAIN_NAME
  6718. service php5-fpm restart
  6719. service nginx restart
  6720. # update the dynamic DNS
  6721. CURRENT_DDNS_DOMAIN=$FULLBLOG_DOMAIN_NAME
  6722. CURRENT_DDNS_CODE=$FULLBLOG_FREEDNS_SUBDOMAIN_CODE
  6723. add_ddns_domain
  6724. echo 'install_blog' >> $COMPLETION_FILE
  6725. }
  6726. function install_gnu_social {
  6727. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  6728. return
  6729. fi
  6730. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  6731. return
  6732. fi
  6733. if [ ! $MICROBLOG_DOMAIN_NAME ]; then
  6734. return
  6735. fi
  6736. install_mariadb
  6737. get_mariadb_password
  6738. repair_databases_script
  6739. apt-get -y --force-yes install php-gettext php5-curl php5-gd php5-mysql git curl php-xml-parser
  6740. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME ]; then
  6741. mkdir /var/www/$MICROBLOG_DOMAIN_NAME
  6742. fi
  6743. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs ]; then
  6744. mkdir /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  6745. fi
  6746. cd $INSTALL_DIR
  6747. git clone $MICROBLOG_REPO gnusocial
  6748. rm -rf /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  6749. mv gnusocial /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  6750. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  6751. chown www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  6752. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/avatar
  6753. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/background
  6754. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/file
  6755. chmod +x /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php
  6756. get_mariadb_gnusocial_admin_password
  6757. if [ ! $MICROBLOG_ADMIN_PASSWORD ]; then
  6758. MICROBLOG_ADMIN_PASSWORD=$(openssl rand -base64 32)
  6759. echo '' >> /home/$MY_USERNAME/README
  6760. echo '' >> /home/$MY_USERNAME/README
  6761. echo 'GNU Social' >> /home/$MY_USERNAME/README
  6762. echo '==========' >> /home/$MY_USERNAME/README
  6763. echo "Your MariaDB gnusocial admin password is: $MICROBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  6764. echo '' >> /home/$MY_USERNAME/README
  6765. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6766. fi
  6767. echo "create database gnusocial;
  6768. CREATE USER 'gnusocialadmin'@'localhost' IDENTIFIED BY '$MICROBLOG_ADMIN_PASSWORD';
  6769. GRANT ALL PRIVILEGES ON gnusocial.* TO 'gnusocialadmin'@'localhost';
  6770. quit" > $INSTALL_DIR/batch.sql
  6771. chmod 600 $INSTALL_DIR/batch.sql
  6772. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  6773. shred -zu $INSTALL_DIR/batch.sql
  6774. if [ ! -f "/etc/aliases" ]; then
  6775. touch /etc/aliases
  6776. fi
  6777. if grep -q "www-data: root" /etc/aliases; then
  6778. echo 'www-data: root' >> /etc/aliases
  6779. fi
  6780. if grep -q "/var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php" /etc/aliases; then
  6781. echo "*: /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php" >> /etc/aliases
  6782. fi
  6783. newaliases
  6784. # update the dynamic DNS
  6785. CURRENT_DDNS_DOMAIN=$MICROBLOG_DOMAIN_NAME
  6786. CURRENT_DDNS_CODE=$MICROBLOG_FREEDNS_SUBDOMAIN_CODE
  6787. add_ddns_domain
  6788. echo 'server {' > /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6789. echo ' listen 80;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6790. echo " server_name $MICROBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6791. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6792. echo ' access_log off;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6793. echo " error_log /var/log/nginx/$MICROBLOG_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6794. echo ' index index.php;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6795. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6796. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6797. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6798. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6799. echo ' rewrite ^ https://$server_name$request_uri? permanent;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6800. echo '}' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6801. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6802. echo 'server {' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6803. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6804. echo " server_name $MICROBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6805. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6806. echo ' index index.php index.html index.htm;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6807. echo ' access_log off;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6808. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6809. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6810. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6811. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6812. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6813. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6814. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6815. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6816. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6817. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6818. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6819. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6820. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6821. echo ' fastcgi_read_timeout 300;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6822. echo ' }' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6823. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6824. echo ' ssl on;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6825. echo " ssl_certificate /etc/ssl/certs/$MICROBLOG_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6826. echo " ssl_certificate_key /etc/ssl/private/$MICROBLOG_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6827. echo " ssl_dhparam /etc/ssl/certs/$MICROBLOG_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6828. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6829. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6830. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6831. echo ' ssl_session_cache builtin:1000 shared:SSL:10m;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6832. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6833. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6834. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6835. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6836. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6837. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6838. echo ' location / {' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6839. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6840. echo ' break;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6841. echo ' }' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6842. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6843. echo ' location ~* ^/(.*)\.(ico|css|js|gif|png|jpg|bmp|JPG|jpeg)$ {' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6844. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6845. echo ' rewrite ^/(.*)$ /$1 break;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6846. echo ' access_log off;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6847. echo ' expires max;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6848. echo ' }' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6849. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6850. echo ' client_max_body_size 15m;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6851. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6852. echo " error_log /var/log/nginx/$MICROBLOG_DOMAIN_NAME_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6853. echo '}' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  6854. configure_php
  6855. if [ ! -f /etc/ssl/private/$MICROBLOG_DOMAIN_NAME.key ]; then
  6856. makecert $MICROBLOG_DOMAIN_NAME
  6857. fi
  6858. # Ensure that the database gets backed up locally, if remote
  6859. # backups are not being used
  6860. backup_databases_script_header
  6861. echo '' >> /usr/bin/backupdatabases
  6862. echo '# Backup the GNU Social database' >> /usr/bin/backupdatabases
  6863. echo 'TEMPFILE=/root/gnusocial.sql' >> /usr/bin/backupdatabases
  6864. echo 'DAILYFILE=/var/backups/gnusocial_daily.sql' >> /usr/bin/backupdatabases
  6865. echo 'mysqldump --password="$MYSQL_PASSWORD" gnusocial > $TEMPFILE' >> /usr/bin/backupdatabases
  6866. echo 'FILESIZE=$(stat -c%s $TEMPFILE)' >> /usr/bin/backupdatabases
  6867. echo 'if [ "$FILESIZE" -eq "0" ]; then' >> /usr/bin/backupdatabases
  6868. echo ' if [ -f $DAILYFILE ]; then' >> /usr/bin/backupdatabases
  6869. echo ' cp $DAILYFILE $TEMPFILE' >> /usr/bin/backupdatabases
  6870. echo '' >> /usr/bin/backupdatabases
  6871. echo ' # try to restore yesterdays database' >> /usr/bin/backupdatabases
  6872. echo ' mysql -u root --password="$MYSQL_PASSWORD" gnusocial -o < $DAILYFILE' >> /usr/bin/backupdatabases
  6873. echo '' >> /usr/bin/backupdatabases
  6874. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  6875. echo ' echo "Unable to create a backup of the GNU Social database. Attempted to restore from yesterdays backup" | mail -s "GNU Social backup" $EMAIL' >> /usr/bin/backupdatabases
  6876. echo ' else' >> /usr/bin/backupdatabases
  6877. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  6878. echo ' echo "Unable to create a backup of the GNU Social database." | mail -s "GNU Social backup" $EMAIL' >> /usr/bin/backupdatabases
  6879. echo ' fi' >> /usr/bin/backupdatabases
  6880. echo 'else' >> /usr/bin/backupdatabases
  6881. echo ' chmod 600 $TEMPFILE' >> /usr/bin/backupdatabases
  6882. echo ' mv $TEMPFILE $DAILYFILE' >> /usr/bin/backupdatabases
  6883. echo '' >> /usr/bin/backupdatabases
  6884. echo ' # Make the backup readable only by root' >> /usr/bin/backupdatabases
  6885. echo ' chmod 600 $DAILYFILE' >> /usr/bin/backupdatabases
  6886. echo 'fi' >> /usr/bin/backupdatabases
  6887. echo '' >> /etc/cron.weekly/backupdatabasesweekly
  6888. echo '# GNU Social' >> /etc/cron.weekly/backupdatabasesweekly
  6889. echo 'if [ -f /var/backups/gnusocial_weekly.sql ]; then' >> /etc/cron.weekly/backupdatabasesweekly
  6890. echo ' cp -f /var/backups/gnusocial_weekly.sql /var/backups/gnusocial_2weekly.sql' >> /etc/cron.weekly/backupdatabasesweekly
  6891. echo 'fi' >> /etc/cron.weekly/backupdatabasesweekly
  6892. echo 'if [ -f /var/backups/gnusocial_daily.sql ]; then' >> /etc/cron.weekly/backupdatabasesweekly
  6893. echo ' cp -f /var/backups/gnusocial_daily.sql /var/backups/gnusocial_weekly.sql' >> /etc/cron.weekly/backupdatabasesweekly
  6894. echo 'fi' >> /etc/cron.weekly/backupdatabasesweekly
  6895. echo '' >> /etc/cron.monthly/backupdatabasesmonthly
  6896. echo '# GNU Social' >> /etc/cron.monthly/backupdatabasesmonthly
  6897. echo 'if [ -f /var/backups/gnusocial_monthly.sql ]; then' >> /etc/cron.monthly/backupdatabasesmonthly
  6898. echo ' cp -f /var/backups/gnusocial_monthly.sql /var/backups/gnusocial_2monthly.sql' >> /etc/cron.monthly/backupdatabasesmonthly
  6899. echo 'fi' >> /etc/cron.monthly/backupdatabasesmonthly
  6900. echo 'if [ -f /var/backups/gnusocial_weekly.sql ]; then' >> /etc/cron.monthly/backupdatabasesmonthly
  6901. echo ' cp -f /var/backups/gnusocial_weekly.sql /var/backups/gnusocial_monthly.sql' >> /etc/cron.monthly/backupdatabasesmonthly
  6902. echo 'fi' >> /etc/cron.monthly/backupdatabasesmonthly
  6903. echo '/usr/bin/repairdatabase gnusocial' >> /etc/cron.hourly/repair
  6904. nginx_ensite $MICROBLOG_DOMAIN_NAME
  6905. service php5-fpm restart
  6906. service nginx restart
  6907. # some post-install instructions for the user
  6908. if ! grep -q "To set up your microblog" /home/$MY_USERNAME/README; then
  6909. echo '' >> /home/$MY_USERNAME/README
  6910. echo '' >> /home/$MY_USERNAME/README
  6911. echo 'Microblog' >> /home/$MY_USERNAME/README
  6912. echo '=========' >> /home/$MY_USERNAME/README
  6913. echo "To set up your microblog go to" >> /home/$MY_USERNAME/README
  6914. echo "https://$MICROBLOG_DOMAIN_NAME/install.php" >> /home/$MY_USERNAME/README
  6915. echo 'and enter the following settings:' >> /home/$MY_USERNAME/README
  6916. echo ' - Set a name for the site' >> /home/$MY_USERNAME/README
  6917. echo ' - Server SSL: enable' >> /home/$MY_USERNAME/README
  6918. echo ' - Hostname: localhost' >> /home/$MY_USERNAME/README
  6919. echo ' - Type: MySql/MariaDB' >> /home/$MY_USERNAME/README
  6920. echo ' - Name: gnusocial' >> /home/$MY_USERNAME/README
  6921. echo ' - DB username: root' >> /home/$MY_USERNAME/README
  6922. echo " - DB Password; $MARIADB_PASSWORD" >> /home/$MY_USERNAME/README
  6923. echo " - Administrator nickname: $MY_USERNAME" >> /home/$MY_USERNAME/README
  6924. echo " - Administrator password: $MICROBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  6925. echo ' - Subscribe to announcements: ticked' >> /home/$MY_USERNAME/README
  6926. echo ' - Site profile: Community' >> /home/$MY_USERNAME/README
  6927. echo '' >> /home/$MY_USERNAME/README
  6928. echo 'When the install is complete you will see a lot of warnings' >> /home/$MY_USERNAME/README
  6929. echo 'but just ignore those and navigate to ' >> /home/$MY_USERNAME/README
  6930. echo "https://$MICROBLOG_DOMAIN_NAME and you can then " >> /home/$MY_USERNAME/README
  6931. echo 'complete the configuration via the *Admin* section on the header' >> /home/$MY_USERNAME/README
  6932. echo 'bar. Some recommended admin settings are:' >> /home/$MY_USERNAME/README
  6933. echo '' >> /home/$MY_USERNAME/README
  6934. echo 'Under the *Site* settings:' >> /home/$MY_USERNAME/README
  6935. echo ' Text limit: 140' >> /home/$MY_USERNAME/README
  6936. echo ' Dupe Limit: 60000' >> /home/$MY_USERNAME/README
  6937. echo '' >> /home/$MY_USERNAME/README
  6938. echo 'Under the *User* settings:' >> /home/$MY_USERNAME/README
  6939. echo ' Bio limit: 1000' >> /home/$MY_USERNAME/README
  6940. echo '' >> /home/$MY_USERNAME/README
  6941. echo 'Under the *Access* settings:' >> /home/$MY_USERNAME/README
  6942. echo ' /Invite only/ ticked' >> /home/$MY_USERNAME/README
  6943. echo '' >> /home/$MY_USERNAME/README
  6944. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6945. fi
  6946. echo 'install_gnu_social' >> $COMPLETION_FILE
  6947. }
  6948. function install_redmatrix {
  6949. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  6950. return
  6951. fi
  6952. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  6953. return
  6954. fi
  6955. # if this is exclusively a social setup
  6956. if [[ $SYSTEM_TYPE == "$VARIANT_SOCIAL" ]]; then
  6957. REDMATRIX_DOMAIN_NAME=$DOMAIN_NAME
  6958. REDMATRIX_FREEDNS_SUBDOMAIN_CODE=$FREEDNS_SUBDOMAIN_CODE
  6959. fi
  6960. if [ ! $REDMATRIX_DOMAIN_NAME ]; then
  6961. return
  6962. fi
  6963. install_mariadb
  6964. get_mariadb_password
  6965. repair_databases_script
  6966. apt-get -y --force-yes install php5-common php5-cli php5-curl php5-gd php5-mysql php5-mcrypt git
  6967. if [ ! -d /var/www/$REDMATRIX_DOMAIN_NAME ]; then
  6968. mkdir /var/www/$REDMATRIX_DOMAIN_NAME
  6969. fi
  6970. if [ ! -d /var/www/$REDMATRIX_DOMAIN_NAME/htdocs ]; then
  6971. mkdir /var/www/$REDMATRIX_DOMAIN_NAME/htdocs
  6972. fi
  6973. if [ ! -f /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/index.php ]; then
  6974. cd $INSTALL_DIR
  6975. git clone $REDMATRIX_REPO redmatrix
  6976. rm -rf /var/www/$REDMATRIX_DOMAIN_NAME/htdocs
  6977. mv redmatrix /var/www/$REDMATRIX_DOMAIN_NAME/htdocs
  6978. chown -R www-data:www-data /var/www/$REDMATRIX_DOMAIN_NAME/htdocs
  6979. git clone $REDMATRIX_ADDONS_REPO /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/addon
  6980. # some extra themes
  6981. git clone https://github.com/DeadSuperHero/redmatrix-themes /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/redmatrix-themes1
  6982. cp -r /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/redmatrix-themes1/* view/theme/
  6983. fi
  6984. get_mariadb_redmatrix_admin_password
  6985. if [ ! $REDMATRIX_ADMIN_PASSWORD ]; then
  6986. REDMATRIX_ADMIN_PASSWORD=$(openssl rand -base64 32)
  6987. echo '' >> /home/$MY_USERNAME/README
  6988. echo '' >> /home/$MY_USERNAME/README
  6989. echo 'Red Matrix' >> /home/$MY_USERNAME/README
  6990. echo '==========' >> /home/$MY_USERNAME/README
  6991. echo "Your MariaDB Red Matrix admin password is: $REDMATRIX_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  6992. echo '' >> /home/$MY_USERNAME/README
  6993. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6994. fi
  6995. echo "create database redmatrix;
  6996. CREATE USER 'redmatrixadmin'@'localhost' IDENTIFIED BY '$REDMATRIX_ADMIN_PASSWORD';
  6997. GRANT ALL PRIVILEGES ON redmatrix.* TO 'redmatrixadmin'@'localhost';
  6998. quit" > $INSTALL_DIR/batch.sql
  6999. chmod 600 $INSTALL_DIR/batch.sql
  7000. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  7001. shred -zu $INSTALL_DIR/batch.sql
  7002. if ! grep -q "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs" /etc/crontab; then
  7003. echo "12,22,32,42,52 * * * * root cd /var/www/$REDMATRIX_DOMAIN_NAME/htdocs; /usr/bin/timeout 240 /usr/bin/php include/poller.php" >> /etc/crontab
  7004. fi
  7005. # update the dynamic DNS
  7006. CURRENT_DDNS_DOMAIN=$REDMATRIX_DOMAIN_NAME
  7007. CURRENT_DDNS_CODE=$REDMATRIX_FREEDNS_SUBDOMAIN_CODE
  7008. add_ddns_domain
  7009. echo 'server {' > /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7010. echo ' listen 80;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7011. echo " server_name $REDMATRIX_DOMAIN_NAME;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7012. echo " root /var/www/$REDMATRIX_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7013. echo ' access_log off;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7014. echo " error_log /var/log/nginx/$REDMATRIX_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7015. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7016. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7017. echo ' index index.php;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7018. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7019. echo ' rewrite ^ https://$server_name$request_uri? permanent;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7020. echo '}' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7021. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7022. echo 'server {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7023. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7024. echo " root /var/www/$REDMATRIX_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7025. echo " server_name $REDMATRIX_DOMAIN_NAME;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7026. echo " error_log /var/log/nginx/$REDMATRIX_DOMAIN_NAME_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7027. echo ' index index.php;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7028. echo ' charset utf-8;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7029. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7030. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7031. echo ' access_log off;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7032. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7033. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7034. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7035. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7036. echo ' ssl on;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7037. echo " ssl_certificate /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7038. echo " ssl_certificate_key /etc/ssl/private/$REDMATRIX_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7039. echo " ssl_dhparam /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7040. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7041. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7042. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7043. echo ' ssl_session_cache builtin:1000 shared:SSL:10m;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7044. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7045. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7046. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7047. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7048. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7049. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7050. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7051. echo ' location / {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7052. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7053. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7054. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7055. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7056. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7057. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7058. echo ' allow all;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7059. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7060. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7061. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7062. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7063. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7064. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7065. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7066. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7067. echo ' expires 30d;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7068. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7069. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7070. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7071. echo ' # block these file types' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7072. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7073. echo ' deny all;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7074. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7075. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7076. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7077. echo ' # or a unix socket' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7078. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7079. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7080. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7081. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7082. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7083. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7084. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7085. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7086. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7087. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7088. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7089. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7090. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7091. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7092. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7093. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7094. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7095. echo ' fastcgi_read_timeout 300;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7096. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7097. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7098. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7099. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7100. echo ' deny all;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7101. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7102. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7103. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7104. echo ' deny all;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7105. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7106. echo '}' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7107. configure_php
  7108. if [ ! -f /etc/ssl/private/$REDMATRIX_DOMAIN_NAME.key ]; then
  7109. makecert $REDMATRIX_DOMAIN_NAME
  7110. fi
  7111. if [ ! -d /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/view/tpl/smarty3 ]; then
  7112. mkdir /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/view/tpl/smarty3
  7113. fi
  7114. if [ ! -d "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store" ]; then
  7115. mkdir "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store"
  7116. fi
  7117. if [ ! -d "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]" ]; then
  7118. mkdir "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]"
  7119. fi
  7120. if [ ! -d "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3" ]; then
  7121. mkdir "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3"
  7122. chmod 777 "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3"
  7123. fi
  7124. chmod 777 /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/view/tpl
  7125. chown -R www-data:www-data "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store"
  7126. chmod 777 /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/view/tpl/smarty3
  7127. # Ensure that the database gets backed up locally, if remote
  7128. # backups are not being used
  7129. backup_databases_script_header
  7130. echo '' >> /usr/bin/backupdatabases
  7131. echo '# Backup the Red Matrix database' >> /usr/bin/backupdatabases
  7132. echo 'TEMPFILE=/root/redmatrix.sql' >> /usr/bin/backupdatabases
  7133. echo 'DAILYFILE=/var/backups/redmatrix_daily.sql' >> /usr/bin/backupdatabases
  7134. echo 'mysqldump --password="$MYSQL_PASSWORD" redmatrix > $TEMPFILE' >> /usr/bin/backupdatabases
  7135. echo 'FILESIZE=$(stat -c%s $TEMPFILE)' >> /usr/bin/backupdatabases
  7136. echo 'if [ "$FILESIZE" -eq "0" ]; then' >> /usr/bin/backupdatabases
  7137. echo ' if [ -f $DAILYFILE ]; then' >> /usr/bin/backupdatabases
  7138. echo ' cp $DAILYFILE $TEMPFILE' >> /usr/bin/backupdatabases
  7139. echo '' >> /usr/bin/backupdatabases
  7140. echo ' # try to restore yesterdays database' >> /usr/bin/backupdatabases
  7141. echo ' mysql -u root --password="$MYSQL_PASSWORD" redmatrix -o < $DAILYFILE' >> /usr/bin/backupdatabases
  7142. echo '' >> /usr/bin/backupdatabases
  7143. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  7144. echo ' echo "Unable to create a backup of the Red Matrix database. Attempted to restore from yesterdays backup" | mail -s "Red Matrix backup" $EMAIL' >> /usr/bin/backupdatabases
  7145. echo ' else' >> /usr/bin/backupdatabases
  7146. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  7147. echo ' echo "Unable to create a backup of the Red Matrix database." | mail -s "Red Matrix backup" $EMAIL' >> /usr/bin/backupdatabases
  7148. echo ' fi' >> /usr/bin/backupdatabases
  7149. echo 'else' >> /usr/bin/backupdatabases
  7150. echo ' chmod 600 $TEMPFILE' >> /usr/bin/backupdatabases
  7151. echo ' mv $TEMPFILE $DAILYFILE' >> /usr/bin/backupdatabases
  7152. echo '' >> /usr/bin/backupdatabases
  7153. echo ' # Make the backup readable only by root' >> /usr/bin/backupdatabases
  7154. echo ' chmod 600 $DAILYFILE' >> /usr/bin/backupdatabases
  7155. echo 'fi' >> /usr/bin/backupdatabases
  7156. echo '' >> /etc/cron.weekly/backupdatabasesweekly
  7157. echo '# Red Matrix' >> /etc/cron.weekly/backupdatabasesweekly
  7158. echo 'if [ -f /var/backups/redmatrix_weekly.sql ]; then' >> /etc/cron.weekly/backupdatabasesweekly
  7159. echo ' cp -f /var/backups/redmatrix_weekly.sql /var/backups/redmatrix_2weekly.sql' >> /etc/cron.weekly/backupdatabasesweekly
  7160. echo 'fi' >> /etc/cron.weekly/backupdatabasesweekly
  7161. echo 'if [ -f /var/backups/redmatrix_daily.sql ]; then' >> /etc/cron.weekly/backupdatabasesweekly
  7162. echo ' cp -f /var/backups/redmatrix_daily.sql /var/backups/redmatrix_weekly.sql' >> /etc/cron.weekly/backupdatabasesweekly
  7163. echo 'fi' >> /etc/cron.weekly/backupdatabasesweekly
  7164. echo '' >> /etc/cron.monthly/backupdatabasesmonthly
  7165. echo '# Red Matrix' >> /etc/cron.monthly/backupdatabasesmonthly
  7166. echo 'if [ -f /var/backups/redmatrix_monthly.sql ]; then' >> /etc/cron.monthly/backupdatabasesmonthly
  7167. echo ' cp -f /var/backups/redmatrix_monthly.sql /var/backups/redmatrix_2monthly.sql' >> /etc/cron.monthly/backupdatabasesmonthly
  7168. echo 'fi' >> /etc/cron.monthly/backupdatabasesmonthly
  7169. echo 'if [ -f /var/backups/redmatrix_weekly.sql ]; then' >> /etc/cron.monthly/backupdatabasesmonthly
  7170. echo ' cp -f /var/backups/redmatrix_weekly.sql /var/backups/redmatrix_monthly.sql' >> /etc/cron.monthly/backupdatabasesmonthly
  7171. echo 'fi' >> /etc/cron.monthly/backupdatabasesmonthly
  7172. echo '/usr/bin/repairdatabase redmatrix' >> /etc/cron.hourly/repair
  7173. nginx_ensite $REDMATRIX_DOMAIN_NAME
  7174. service php5-fpm restart
  7175. service nginx restart
  7176. service cron restart
  7177. # some post-install instructions for the user
  7178. if ! grep -q "To set up your Red Matrix" /home/$MY_USERNAME/README; then
  7179. echo '' >> /home/$MY_USERNAME/README
  7180. echo "To set up your Red Matrix site go to" >> /home/$MY_USERNAME/README
  7181. echo "https://$REDMATRIX_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  7182. echo 'You will need to have a non self-signed SSL certificate in order' >> /home/$MY_USERNAME/README
  7183. echo "to use Red Matrix. Put the public certificate in /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.crt" >> /home/$MY_USERNAME/README
  7184. echo "and the private certificate in /etc/ssl/private/$REDMATRIX_DOMAIN_NAME.key." >> /home/$MY_USERNAME/README
  7185. echo 'If there is an intermediate certificate needed (such as with StartSSL) then' >> /home/$MY_USERNAME/README
  7186. echo 'this will need to be concatenated onto the end of the crt file, like this:' >> /home/$MY_USERNAME/README
  7187. echo '' >> /home/$MY_USERNAME/README
  7188. echo " cat /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.crt /etc/ssl/chains/startssl-sub.class1.server.ca.pem > /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.bundle.crt" >> /home/$MY_USERNAME/README
  7189. echo '' >> /home/$MY_USERNAME/README
  7190. echo "Then change ssl_certificate to /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.bundle.crt" >> /home/$MY_USERNAME/README
  7191. echo "within /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  7192. echo '' >> /home/$MY_USERNAME/README
  7193. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7194. fi
  7195. echo 'install_redmatrix' >> $COMPLETION_FILE
  7196. }
  7197. function script_for_attaching_usb_drive {
  7198. if grep -Fxq "script_for_attaching_usb_drive" $COMPLETION_FILE; then
  7199. return
  7200. fi
  7201. echo '#!/bin/bash' > /usr/bin/attach-music
  7202. echo 'remove-music' >> /usr/bin/attach-music
  7203. echo "if [ ! -d $USB_MOUNT ]; then" >> /usr/bin/attach-music
  7204. echo " mkdir $USB_MOUNT" >> /usr/bin/attach-music
  7205. echo 'fi' >> /usr/bin/attach-music
  7206. echo "mount /dev/sda1 $USB_MOUNT" >> /usr/bin/attach-music
  7207. echo "chown root:root $USB_MOUNT" >> /usr/bin/attach-music
  7208. echo "chown -R minidlna:minidlna $USB_MOUNT/*" >> /usr/bin/attach-music
  7209. echo 'service minidlna restart' >> /usr/bin/attach-music
  7210. echo 'minidlnad -R' >> /usr/bin/attach-music
  7211. chmod +x /usr/bin/attach-music
  7212. ln -s /usr/bin/attach-music /usr/bin/attach-usb
  7213. ln -s /usr/bin/attach-music /usr/bin/attach-videos
  7214. ln -s /usr/bin/attach-music /usr/bin/attach-pictures
  7215. ln -s /usr/bin/attach-music /usr/bin/attach-media
  7216. echo '#!/bin/bash' > /usr/bin/remove-music
  7217. echo "if [ -d $USB_MOUNT ]; then" >> /usr/bin/remove-music
  7218. echo " umount $USB_MOUNT" >> /usr/bin/remove-music
  7219. echo " rm -rf $USB_MOUNT" >> /usr/bin/remove-music
  7220. echo 'fi' >> /usr/bin/remove-music
  7221. chmod +x /usr/bin/remove-music
  7222. ln -s /usr/bin/remove-music /usr/bin/detach-music
  7223. ln -s /usr/bin/remove-music /usr/bin/detach-usb
  7224. ln -s /usr/bin/remove-music /usr/bin/remove-usb
  7225. ln -s /usr/bin/remove-music /usr/bin/detach-media
  7226. ln -s /usr/bin/remove-music /usr/bin/remove-media
  7227. ln -s /usr/bin/remove-music /usr/bin/detach-videos
  7228. ln -s /usr/bin/remove-music /usr/bin/remove-videos
  7229. ln -s /usr/bin/remove-music /usr/bin/detach-pictures
  7230. ln -s /usr/bin/remove-music /usr/bin/remove-pictures
  7231. echo 'script_for_attaching_usb_drive' >> $COMPLETION_FILE
  7232. }
  7233. function install_dlna_server {
  7234. if grep -Fxq "install_dlna_server" $COMPLETION_FILE; then
  7235. return
  7236. fi
  7237. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  7238. return
  7239. fi
  7240. apt-get -y --force-yes install minidlna
  7241. if [ ! -f /etc/minidlna.conf ]; then
  7242. echo "ERROR: minidlna does not appear to have installed. $CHECK_MESSAGE"
  7243. exit 55
  7244. fi
  7245. sed -i "s|media_dir=/var/lib/minidlna|media_dir=A,/home/$MY_USERNAME/Music|g" /etc/minidlna.conf
  7246. if ! grep -q "/home/$MY_USERNAME/Pictures" /etc/minidlna.conf; then
  7247. echo "media_dir=P,/home/$MY_USERNAME/Pictures" >> /etc/minidlna.conf
  7248. fi
  7249. if ! grep -q "/home/$MY_USERNAME/Videos" /etc/minidlna.conf; then
  7250. echo "media_dir=V,/home/$MY_USERNAME/Videos" >> /etc/minidlna.conf
  7251. fi
  7252. if ! grep -q "$USB_MOUNT/Music" /etc/minidlna.conf; then
  7253. echo "media_dir=A,$USB_MOUNT/Music" >> /etc/minidlna.conf
  7254. fi
  7255. if ! grep -q "$USB_MOUNT/Pictures" /etc/minidlna.conf; then
  7256. echo "media_dir=P,$USB_MOUNT/Pictures" >> /etc/minidlna.conf
  7257. fi
  7258. if ! grep -q "$USB_MOUNT/Videos" /etc/minidlna.conf; then
  7259. echo "media_dir=V,$USB_MOUNT/Videos" >> /etc/minidlna.conf
  7260. fi
  7261. sed -i 's/#root_container=./root_container=B/g' /etc/minidlna.conf
  7262. sed -i 's/#network_interface=/network_interface=eth0/g' /etc/minidlna.conf
  7263. sed -i 's/#friendly_name=/friendly_name="Freedombone Media"/g' /etc/minidlna.conf
  7264. sed -i 's|#db_dir=/var/cache/minidlna|db_dir=/var/cache/minidlna|g' /etc/minidlna.conf
  7265. sed -i 's/#inotify=yes/inotify=yes/g' /etc/minidlna.conf
  7266. sed -i 's/#notify_interval=895/notify_interval=300/g' /etc/minidlna.conf
  7267. sed -i "s|#presentation_url=/|presentation_url=http://localhost:8200|g" /etc/minidlna.conf
  7268. service minidlna force-reload
  7269. service minidlna reload
  7270. sed -i 's/fs.inotify.max_user_watches*/fs.inotify.max_user_watches=65536/g' /etc/sysctl.conf
  7271. if ! grep -q "max_user_watches" $COMPLETION_FILE; then
  7272. echo 'fs.inotify.max_user_watches=65536' >> /etc/sysctl.conf
  7273. fi
  7274. /sbin/sysctl -p
  7275. echo 'install_dlna_server' >> $COMPLETION_FILE
  7276. }
  7277. function install_mediagoblin {
  7278. # These instructions don't work and need fixing
  7279. return
  7280. if grep -Fxq "install_mediagoblin" $COMPLETION_FILE; then
  7281. return
  7282. fi
  7283. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  7284. return
  7285. fi
  7286. # if this is exclusively a writer setup
  7287. if [[ $SYSTEM_TYPE == "$VARIANT_MEDIA" ]]; then
  7288. MEDIAGOBLIN_DOMAIN_NAME=$DOMAIN_NAME
  7289. MEDIAGOBLIN_FREEDNS_SUBDOMAIN_CODE=$FREEDNS_SUBDOMAIN_CODE
  7290. fi
  7291. if [ ! $MEDIAGOBLIN_DOMAIN_NAME ]; then
  7292. return
  7293. fi
  7294. apt-get -y --force-yes install git-core python python-dev python-lxml python-imaging python-virtualenv
  7295. apt-get -y --force-yes install python-gst-1.0 libjpeg8-dev sqlite3 libapache2-mod-fcgid gstreamer1.0-plugins-base gstreamer1.0-plugins-bad gstreamer1.0-plugins-good gstreamer1.0-plugins-ugly gstreamer1.0-libav python-numpy python-scipy libsndfile1-dev
  7296. apt-get -y --force-yes install postgresql postgresql-client python-psycopg2 python-pip autotools-dev automake
  7297. sudo -u postgres createuser -A -D mediagoblin
  7298. sudo -u postgres createdb -E UNICODE -O mediagoblin mediagoblin
  7299. adduser --system mediagoblin
  7300. MEDIAGOBLIN_DOMAIN_ROOT="/srv/$MEDIAGOBLIN_DOMAIN_NAME"
  7301. MEDIAGOBLIN_PATH="$MEDIAGOBLIN_DOMAIN_ROOT/mediagoblin"
  7302. MEDIAGOBLIN_PATH_BIN="$MEDIAGOBLIN_PATH/mediagoblin/bin"
  7303. if [ ! -d $MEDIAGOBLIN_DOMAIN_ROOT ]; then
  7304. mkdir -p $MEDIAGOBLIN_DOMAIN_ROOT
  7305. fi
  7306. cd $MEDIAGOBLIN_DOMAIN_ROOT
  7307. chown -hR mediagoblin: $MEDIAGOBLIN_DOMAIN_ROOT
  7308. su -c "cd $MEDIAGOBLIN_DOMAIN_ROOT; git clone git://gitorious.org/mediagoblin/mediagoblin.git" - mediagoblin
  7309. su -c "cd $MEDIAGOBLIN_PATH; git submodule init" - mediagoblin
  7310. su -c "cd $MEDIAGOBLIN_PATH; git submodule update" - mediagoblin
  7311. #su -c 'cd $MEDIAGOBLIN_PATH; ./experimental-bootstrap.sh' - mediagoblin
  7312. #su -c 'cd $MEDIAGOBLIN_PATH; ./configure' - mediagoblin
  7313. #su -c 'cd $MEDIAGOBLIN_PATH; make' - mediagoblin
  7314. su -c "cd $MEDIAGOBLIN_PATH; virtualenv --system-site-packages ." - mediagoblin
  7315. su -c "cd $MEDIAGOBLIN_PATH_BIN; python setup.py develop" - mediagoblin
  7316. su -c "cp $MEDIAGOBLIN_PATH/mediagoblin.ini $MEDIAGOBLIN_PATH/mediagoblin_local.ini" - mediagoblin
  7317. su -c "cp $MEDIAGOBLIN_PATH/paste.ini $MEDIAGOBLIN_PATH/paste_local.ini" - mediagoblin
  7318. # update the dynamic DNS
  7319. CURRENT_DDNS_DOMAIN=$MEDIAGOBLIN_DOMAIN_NAME
  7320. CURRENT_DDNS_CODE=$MEDIAGOBLIN_FREEDNS_SUBDOMAIN_CODE
  7321. add_ddns_domain
  7322. # see https://wiki.mediagoblin.org/Deployment / uwsgi with configs
  7323. apt-get -y --force-yes install uwsgi uwsgi-plugin-python nginx-full supervisor
  7324. echo 'server {' > /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7325. echo ' include /etc/nginx/mime.types;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7326. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7327. echo ' autoindex off;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7328. echo ' default_type application/octet-stream;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7329. echo ' sendfile on;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7330. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7331. echo ' # Gzip' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7332. echo ' gzip on;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7333. echo ' gzip_min_length 1024;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7334. echo ' gzip_buffers 4 32k;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7335. echo ' gzip_types text/plain text/html application/x-javascript text/javascript text/xml text/css;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7336. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7337. echo " server_name $MEDIAGOBLIN_DOMAIN_NAME;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7338. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7339. echo ' error_log /var/log/nginx/mg.error.log error;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7340. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7341. echo ' #include global/common.conf;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7342. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7343. echo ' client_max_body_size 100m;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7344. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7345. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7346. echo " root $MEDIAGOBLIN_PATH/;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7347. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7348. echo ' location /mgoblin_static/ {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7349. echo " alias $MEDIAGOBLIN_PATH/static/;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7350. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7351. echo ' location /mgoblin_media/ {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7352. echo " alias $MEDIAGOBL_PATH/media/public/;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7353. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7354. echo ' location /theme_static/ {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7355. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7356. echo ' location /plugin_static/ {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7357. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7358. echo ' location / {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7359. echo ' uwsgi_pass unix:///tmp/mg.uwsgi.sock;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7360. echo ' uwsgi_param SCRIPT_NAME "/";' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7361. echo ' include uwsgi_params;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7362. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7363. echo '}' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  7364. echo 'uwsgi:' > /etc/uwsgi/apps-available/mg.yaml
  7365. echo ' uid: mediagoblin' >> /etc/uwsgi/apps-available/mg.yaml
  7366. echo ' gid: mediagoblin' >> /etc/uwsgi/apps-available/mg.yaml
  7367. echo ' socket: /tmp/mg.uwsgi.sock' >> /etc/uwsgi/apps-available/mg.yaml
  7368. echo ' chown-socket: www-data:www-data' >> /etc/uwsgi/apps-available/mg.yaml
  7369. echo ' plugins: python' >> /etc/uwsgi/apps-available/mg.yaml
  7370. echo " home: $MEDIAGOBLIN_PATH/" >> /etc/uwsgi/apps-available/mg.yaml
  7371. echo " chdir: $MEDIAGOBLIN_PATH/" >> /etc/uwsgi/apps-available/mg.yaml
  7372. echo " ini-paste: $MEDIAGOBLIN_PATH/paste_local.ini" >> /etc/uwsgi/apps-available/mg.yaml
  7373. echo '[program:celery]' > /etc/supervisor/conf.d/mediagoblin.conf
  7374. echo "command=$MEDIAGOBLIN_PATH_BIN/celery worker -l debug" >> /etc/supervisor/conf.d/mediagoblin.conf
  7375. echo '' >> /etc/supervisor/conf.d/mediagoblin.conf
  7376. echo '; Set PYTHONPATH to the directory containing celeryconfig.py' >> /etc/supervisor/conf.d/mediagoblin.conf
  7377. echo "environment=PYTHONPATH='$MEDIAGOBLIN_PATH',MEDIAGOBLIN_CONFIG='$MEDIAGOBLIN_PATH/mediagoblin_local.ini',CELERY_CONFIG_MODULE='mediagoblin.init.celery.from_celery'" >> /etc/supervisor/conf.d/mediagoblin.conf
  7378. echo '' >> /etc/supervisor/conf.d/mediagoblin.conf
  7379. echo "directory=$MEDIAGOBLIN_PATH/" >> /etc/supervisor/conf.d/mediagoblin.conf
  7380. echo 'user=mediagoblin' >> /etc/supervisor/conf.d/mediagoblin.conf
  7381. echo 'numprocs=1' >> /etc/supervisor/conf.d/mediagoblin.conf
  7382. echo '; uncomment below to enable logs saving' >> /etc/supervisor/conf.d/mediagoblin.conf
  7383. echo ";stdout_logfile=/var/log/nginx/celeryd_stdout.log" >> /etc/supervisor/conf.d/mediagoblin.conf
  7384. echo ";stderr_logfile=/var/log/nginx/celeryd_stderr.log" >> /etc/supervisor/conf.d/mediagoblin.conf
  7385. echo 'autostart=true' >> /etc/supervisor/conf.d/mediagoblin.conf
  7386. echo 'autorestart=false' >> /etc/supervisor/conf.d/mediagoblin.conf
  7387. echo 'startsecs=10' >> /etc/supervisor/conf.d/mediagoblin.conf
  7388. echo '' >> /etc/supervisor/conf.d/mediagoblin.conf
  7389. echo '; Need to wait for currently executing tasks to finish at shutdown.' >> /etc/supervisor/conf.d/mediagoblin.conf
  7390. echo '; Increase this if you have very long running tasks.' >> /etc/supervisor/conf.d/mediagoblin.conf
  7391. echo 'stopwaitsecs = 600' >> /etc/supervisor/conf.d/mediagoblin.conf
  7392. ln -s /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME /etc/nginx/sites-enabled/
  7393. ln -s /etc/uwsgi/apps-available/mg.yaml /etc/uwsgi/apps-enabled/
  7394. # change settings
  7395. sed -i "s/notice@mediagoblin.example.org/$MY_EMAIL_ADDRESS/g" $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  7396. sed -i 's/email_debug_mode = true/email_debug_mode = false/g' $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  7397. sed -i 's|# sql_engine = postgresql:///mediagoblin|sql_engine = postgresql:///mediagoblin|g' $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  7398. # add extra media types
  7399. if grep -q "media_types.audio" $MEDIAGOBLIN_PATH/mediagoblin_local.ini; then
  7400. echo '[[mediagoblin.media_types.audio]]' >> $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  7401. fi
  7402. if grep -q "media_types.video" $MEDIAGOBLIN_PATH/mediagoblin_local.ini; then
  7403. echo '[[mediagoblin.media_types.video]]' >> $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  7404. fi
  7405. if grep -q "media_types.stl" $MEDIAGOBLIN_PATH/mediagoblin_local.ini; then
  7406. echo '[[mediagoblin.media_types.stl]]' >> $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  7407. fi
  7408. su -c "cd $MEDIAGOBLIN_PATH_BIN; pip install scikits.audiolab" - mediagoblin
  7409. su -c "cd $MEDIAGOBLIN_PATH_BIN; gmg dbupdate" - mediagoblin
  7410. # systemd init scripts
  7411. echo '[Unit]' > /etc/systemd/system/gmg.service
  7412. echo 'Description=Mediagoblin' >> /etc/systemd/system/gmg.service
  7413. echo '' >> /etc/systemd/system/gmg.service
  7414. echo '[Service]' >> /etc/systemd/system/gmg.service
  7415. echo 'Type=forking' >> /etc/systemd/system/gmg.service
  7416. echo 'User=mediagoblin' >> /etc/systemd/system/gmg.service
  7417. echo 'Group=mediagoblin' >> /etc/systemd/system/gmg.service
  7418. echo '#Environment=CELERY_ALWAYS_EAGER=true' >> /etc/systemd/system/gmg.service
  7419. echo 'Environment=CELERY_ALWAYS_EAGER=false' >> /etc/systemd/system/gmg.service
  7420. echo "WorkingDirectory=$MEDIAGOBLIN_PATH" >> /etc/systemd/system/gmg.service
  7421. echo "ExecStart=$MEDIAGOBLIN_PATH_BIN/paster serve $MEDIAGOBLIN_PATH/paste_local.ini --pid-file=/var/run/mediagoblin/paster.pid --log-file=/var/log/nginx/mediagoblin_paster.log --daemon --server-name=fcgi fcgi_host=127.0.0.1 fcgi_port=26543" >> /etc/systemd/system/gmg.service
  7422. echo "ExecStop=$MEDIAGOBLIN_PATH_BIN/paster serve --pid-file=/var/run/mediagoblin/paster.pid $MEDIAGOBLIN_PATH/paste_local.ini stop" >> /etc/systemd/system/gmg.service
  7423. echo 'PIDFile=/var/run/mediagoblin/mediagoblin.pid' >> /etc/systemd/system/gmg.service
  7424. echo '' >> /etc/systemd/system/gmg.service
  7425. echo '[Install]' >> /etc/systemd/system/gmg.service
  7426. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/gmg.service
  7427. echo '[Unit]' > /etc/systemd/system/gmg-celeryd.service
  7428. echo 'Description=Mediagoblin Celeryd' >> /etc/systemd/system/gmg-celeryd.service
  7429. echo '' >> /etc/systemd/system/gmg-celeryd.service
  7430. echo '[Service]' >> /etc/systemd/system/gmg-celeryd.service
  7431. echo 'User=mediagoblin' >> /etc/systemd/system/gmg-celeryd.service
  7432. echo 'Group=mediagoblin' >> /etc/systemd/system/gmg-celeryd.service
  7433. echo 'Type=simple' >> /etc/systemd/system/gmg-celeryd.service
  7434. echo "WorkingDirectory=$MEDIAGOBLIN_PATH" >> /etc/systemd/system/gmg-celeryd.service
  7435. echo "Environment='MEDIAGOBLIN_CONFIG=$MEDIAGOBLIN_PATH/mediagoblin_local.ini' CELERY_CONFIG_MODULE=mediagoblin.init.celery.from_celery" >> /etc/systemd/system/gmg-celeryd.service
  7436. echo "ExecStart=$MEDIAGOBLIN_PATH_BIN/celeryd" >> /etc/systemd/system/gmg-celeryd.service
  7437. echo 'PIDFile=/var/run/mediagoblin/mediagoblin-celeryd.pid' >> /etc/systemd/system/gmg-celeryd.service
  7438. echo '' >> /etc/systemd/system/gmg-celeryd.service
  7439. echo '[Install]' >> /etc/systemd/system/gmg-celeryd.service
  7440. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/gmg-celeryd.service
  7441. systemctl start gmg.service
  7442. systemctl start gmg-celeryd.service
  7443. echo 'install_mediagoblin' >> $COMPLETION_FILE
  7444. }
  7445. function create_upgrade_script {
  7446. if grep -Fxq "create_upgrade_script" $COMPLETION_FILE; then
  7447. return
  7448. fi
  7449. echo '#!/bin/bash' > /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7450. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7451. echo 'apt-get -y update' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7452. echo 'apt-get -y --force-yes upgrade' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7453. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  7454. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7455. echo '# Red Matrix' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7456. echo "cd /var/www/$REDMATRIX_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7457. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7458. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7459. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7460. echo "cd /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/addon" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7461. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7462. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7463. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7464. echo "chown -R www-data:www-data /var/www/$REDMATRIX_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7465. fi
  7466. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  7467. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7468. echo '# GNU Social' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7469. echo "cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7470. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7471. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7472. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7473. echo "chown -R www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7474. fi
  7475. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  7476. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7477. echo '# Blog' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7478. echo "cd /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7479. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7480. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7481. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7482. echo "chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7483. fi
  7484. if grep -Fxq "install_owncloud_music_app" $COMPLETION_FILE; then
  7485. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7486. echo '# Owncloud music app' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7487. echo "cd /usr/share/owncloud/apps/music" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7488. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7489. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7490. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7491. fi
  7492. if grep -Fxq "install_cjdns" $COMPLETION_FILE; then
  7493. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7494. echo '# cjdns' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7495. echo "cd /etc/cjdns" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7496. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7497. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7498. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7499. fi
  7500. echo 'exit 0' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7501. chmod +x /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  7502. echo 'create_upgrade_script' >> $COMPLETION_FILE
  7503. }
  7504. function intrusion_detection {
  7505. if grep -Fxq "intrusion_detection" $COMPLETION_FILE; then
  7506. return
  7507. fi
  7508. apt-get -y --force-yes install tripwire
  7509. apt-get -y --force-yes autoremove
  7510. cd /etc/tripwire
  7511. cp site.key $DOMAIN_NAME-site.key
  7512. echo ''
  7513. echo ''
  7514. echo '*** Installing intrusion detection. Press Enter when asked for the local and site passphrases. ***'
  7515. echo ''
  7516. echo ''
  7517. tripwire --init
  7518. # make a script for easy resetting of the tripwire
  7519. echo '#!/bin/sh' > /usr/bin/reset-tripwire
  7520. echo 'tripwire --update-policy --secure-mode low /etc/tripwire/twpol.txt' >> /usr/bin/reset-tripwire
  7521. chmod +x /usr/bin/reset-tripwire
  7522. reset-tripwire
  7523. sed -i 's/SYSLOGREPORTING =true/#SYSLOGREPORTING =false/g' /etc/tripwire/twcfg.txt
  7524. sed -i '/# These files change the behavior of the root account/,/}/ s/.*//g' /etc/tripwire/twpol.txt
  7525. reset-tripwire
  7526. echo 'intrusion_detection' >> $COMPLETION_FILE
  7527. }
  7528. # see http://adammelton.com/tor_dongle.php
  7529. # Attach the BeagleBone to a PC via USB and then have an enthernet
  7530. # connection to the internet router
  7531. function create_tor_dongle {
  7532. if grep -Fxq "create_tor_dongle" $COMPLETION_FILE; then
  7533. return
  7534. fi
  7535. if [[ $SYSTEM_TYPE != "$VARIANT_TOR_DONGLE" ]]; then
  7536. return
  7537. fi
  7538. apt-get -y --force-yes install tor tor-arm
  7539. # firewall
  7540. iptables -A INPUT -i usb0 -p tcp --dport 9050 -j ACCEPT
  7541. iptables -A INPUT -i usb0 -p tcp --dport 9051 -j ACCEPT
  7542. save_firewall_settings
  7543. # tor settings
  7544. sed -i "s/#SocksPort 192.168.0.1:9100/SocksPort 192.168.7.2:9050/g" /etc/tor/torrc
  7545. sed -i 's/#ControlPort 9051/ControlPort 9051/g' /etc/tor/torrc
  7546. sed -i 's/#CookieAuthentication 1/CookieAuthentication 1/g' /etc/tor/torrc
  7547. if ! grep -q "DisableDebuggerAttachment" /etc/tor/torrc; then
  7548. echo 'DisableDebuggerAttachment 0' >> /etc/tor/torrc
  7549. fi
  7550. # ensure that USB networking is enabled
  7551. echo '# The loopback network interface' > /etc/network/interfaces
  7552. echo 'auto lo' >> /etc/network/interfaces
  7553. echo 'iface lo inet loopback' >> /etc/network/interfaces
  7554. echo '' >> /etc/network/interfaces
  7555. echo '# The primary network interface' >> /etc/network/interfaces
  7556. echo 'auto eth0' >> /etc/network/interfaces
  7557. echo 'iface eth0 inet dhcp' >> /etc/network/interfaces
  7558. echo '' >> /etc/network/interfaces
  7559. echo '# USB network interface' >> /etc/network/interfaces
  7560. echo 'iface usb0 inet static' >> /etc/network/interfaces
  7561. echo ' address 192.168.7.2' >> /etc/network/interfaces
  7562. echo ' netmask 255.255.255.0' >> /etc/network/interfaces
  7563. echo ' network 192.168.7.0' >> /etc/network/interfaces
  7564. echo ' gateway 192.168.7.1' >> /etc/network/interfaces
  7565. if ! grep -q "Tor Dongle" /home/$MY_USERNAME/README; then
  7566. echo '' >> /home/$MY_USERNAME/README
  7567. echo '' >> /home/$MY_USERNAME/README
  7568. echo 'Tor Dongle' >> /home/$MY_USERNAME/README
  7569. echo '==========' >> /home/$MY_USERNAME/README
  7570. echo 'Connect your PC to the Beaglebone via the USB cable' >> /home/$MY_USERNAME/README
  7571. echo 'and the Beaglebone ethernet to your internet router.' >> /home/$MY_USERNAME/README
  7572. echo '' >> /home/$MY_USERNAME/README
  7573. echo 'Within your network proxy settings set the SOCKS host' >> /home/$MY_USERNAME/README
  7574. echo 'to 192.168.7.2 and the port to 9050, with remote' >> /home/$MY_USERNAME/README
  7575. echo 'DNS enabled. There should be no proxying for localhost' >> /home/$MY_USERNAME/README
  7576. echo 'and 127.0.0.1' >> /home/$MY_USERNAME/README
  7577. fi
  7578. echo 'Freedombone Tor Dongle installation is complete'
  7579. cat /home/$MY_USERNAME/README
  7580. service networking restart
  7581. service tor restart
  7582. exit 873
  7583. }
  7584. # see https://trac.torproject.org/projects/tor/wiki/doc/TransparentProxy
  7585. # Local Redirection and Anonymizing Middlebox
  7586. function route_outgoing_traffic_through_tor {
  7587. if grep -Fxq "route_outgoing_traffic_through_tor" $COMPLETION_FILE; then
  7588. return
  7589. fi
  7590. if [[ $SYSTEM_TYPE == "$VARIANT_TOR_DONGLE" ]]; then
  7591. return
  7592. fi
  7593. if [[ $ROUTE_THROUGH_TOR != "yes" ]]; then
  7594. return
  7595. fi
  7596. apt-get -y --force-yes install tor tor-arm
  7597. ### set variables
  7598. # Destinations you don't want routed through Tor
  7599. _non_tor="192.168.1.0/24 192.168.0.0/24"
  7600. # The user that Tor runs as
  7601. _tor_uid="debian-tor"
  7602. # Tor's TransPort
  7603. _trans_port="9040"
  7604. # Your internal interface
  7605. _int_if="eth0"
  7606. ### Set iptables *nat
  7607. iptables -t nat -A OUTPUT -o lo -j RETURN
  7608. iptables -t nat -A OUTPUT -m owner --uid-owner $_tor_uid -j RETURN
  7609. iptables -t nat -A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 53
  7610. # Allow clearnet access for hosts in $_non_tor
  7611. for _clearnet in $_non_tor; do
  7612. iptables -t nat -A OUTPUT -d $_clearnet -j RETURN
  7613. iptables -t nat -A PREROUTING -i $_int_if -d $_clearnet -j RETURN
  7614. done
  7615. # Redirect all other pre-routing and output to Tor
  7616. iptables -t nat -A OUTPUT -p tcp --syn -j REDIRECT --to-ports $_trans_port
  7617. iptables -t nat -A PREROUTING -i $_int_if -p udp --dport 53 -j REDIRECT --to-ports 53
  7618. iptables -t nat -A PREROUTING -i $_int_if -p tcp --syn -j REDIRECT --to-ports $_trans_port
  7619. ### set iptables *filter
  7620. iptables -A OUTPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
  7621. # Allow clearnet access for hosts in $_non_tor
  7622. for _clearnet in $_non_tor 127.0.0.0/8; do
  7623. iptables -A OUTPUT -d $_clearnet -j ACCEPT
  7624. done
  7625. # Allow only Tor output
  7626. iptables -A OUTPUT -m owner --uid-owner $_tor_uid -j ACCEPT
  7627. iptables -A OUTPUT -j REJECT
  7628. save_firewall_settings
  7629. if ! grep -q "fs.file-max" /etc/sysctl.conf; then
  7630. echo "fs.file-max=100000" >> /etc/sysctl.conf
  7631. /sbin/sysctl -p
  7632. fi
  7633. echo 'domain localdomain' > /etc/resolv.conf
  7634. echo 'search localdomain' >> /etc/resolv.conf
  7635. echo 'nameserver 127.0.0.1' >> /etc/resolv.conf
  7636. if ! grep -q "VirtualAddrNetworkIPv4" /etc/tor/torrc; then
  7637. echo 'VirtualAddrNetworkIPv4 10.192.0.0/10' >> /etc/tor/torrc
  7638. fi
  7639. if ! grep -q "AutomapHostsOnResolve" /etc/tor/torrc; then
  7640. echo 'AutomapHostsOnResolve 1' >> /etc/tor/torrc
  7641. fi
  7642. if ! grep -q "TransPort" /etc/tor/torrc; then
  7643. echo 'TransPort 9040' >> /etc/tor/torrc
  7644. fi
  7645. if ! grep -q "TransListenAddress 127.0.0.1" /etc/tor/torrc; then
  7646. echo 'TransListenAddress 127.0.0.1' >> /etc/tor/torrc
  7647. fi
  7648. if ! grep -q "TransListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" /etc/tor/torrc; then
  7649. echo "TransListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/tor/torrc
  7650. fi
  7651. if ! grep -q "DNSPort" /etc/tor/torrc; then
  7652. echo 'DNSPort 53' >> /etc/tor/torrc
  7653. fi
  7654. if ! grep -q "DNSListenAddress 127.0.0.1" /etc/tor/torrc; then
  7655. echo 'DNSListenAddress 127.0.0.1' >> /etc/tor/torrc
  7656. fi
  7657. if ! grep -q "DNSListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" /etc/tor/torrc; then
  7658. echo "DNSListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/tor/torrc
  7659. fi
  7660. echo 'route_outgoing_traffic_through_tor' >> $COMPLETION_FILE
  7661. }
  7662. # A command to create a git repository for a project
  7663. function create_git_project {
  7664. if grep -Fxq "create_git_project" $COMPLETION_FILE; then
  7665. return
  7666. fi
  7667. apt-get -y install git
  7668. echo '#!/bin/bash' > /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7669. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7670. echo 'GIT_PROJECT_NAME=$1' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7671. echo 'if [ ! $GIT_PROJECT_NAME ]; then' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7672. echo ' echo "Please specify a project name, without any spaces"' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7673. echo ' exit 1' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7674. echo 'fi' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7675. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7676. echo 'if [ ! -d /home/$USER/projects/$GIT_PROJECT_NAME ]; then' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7677. echo ' mkdir -p /home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7678. echo 'fi' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7679. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7680. echo 'cd /home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7681. echo 'git init --bare' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7682. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7683. echo -n 'echo "Your project has been created, ' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7684. echo 'use the following command to clone the repository"' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7685. echo -n " git clone ssh://$MY_USERNAME@$DOMAIN_NAME:$SSH_PORT" >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7686. echo '/home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7687. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7688. echo 'exit 0' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7689. chmod +x /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  7690. echo 'create_git_project' >> $COMPLETION_FILE
  7691. }
  7692. # Create daily backups of any projects on Github
  7693. # Then if Github goes away, turns evil, is censored or has
  7694. # outages then you still have access to your projects
  7695. function backup_github_projects {
  7696. if grep -Fxq "backup_github_projects" $COMPLETION_FILE; then
  7697. return
  7698. fi
  7699. if [ ! $GITHUB_USERNAME ]; then
  7700. return 731
  7701. fi
  7702. if [ ! $GITHUB_BACKUP_DIRECTORY ]; then
  7703. return 732
  7704. fi
  7705. apt-get -y install git
  7706. # create a github backups directory if needed
  7707. if [ ! -d $GITHUB_BACKUP_DIRECTORY ]; then
  7708. mkdir -p $GITHUB_BACKUP_DIRECTORY
  7709. fi
  7710. # get the backup utility
  7711. cd $INSTALL_DIR
  7712. git clone https://github.com/josegonzalez/python-github-backup
  7713. # install it
  7714. cd $INSTALL_DIR/python-github-backup
  7715. python setup.py install
  7716. # add a daily cron entry
  7717. echo '#!/bin/bash' > /etc/cron.daily/github
  7718. echo "github-backup $GITHUB_USERNAME -o $GITHUB_BACKUP_DIRECTORY --repositories" >> /etc/cron.daily/github
  7719. echo 'exit 0' >> /etc/cron.daily/github
  7720. chmod +x /etc/cron.daily/github
  7721. # do an initial backup
  7722. /etc/cron.daily/github
  7723. echo 'backup_github_projects' >> $COMPLETION_FILE
  7724. }
  7725. function install_dynamicdns {
  7726. if grep -Fxq "install_dynamicdns" $COMPLETION_FILE; then
  7727. return
  7728. fi
  7729. # Here we compile from source because the current package
  7730. # doesn't support https, which clould result in passwords
  7731. # being leaked
  7732. cd $INSTALL_DIR
  7733. apt-get -y install build-essential curl libgnutls28-dev automake1.11
  7734. git clone https://github.com/bashrc/inadyn
  7735. cd inadyn
  7736. ./configure
  7737. if [ ! "$?" = "0" ]; then
  7738. exit 74890
  7739. fi
  7740. USE_OPENSSL=1 make
  7741. if [ ! "$?" = "0" ]; then
  7742. exit 74858
  7743. fi
  7744. make install
  7745. if [ ! "$?" = "0" ]; then
  7746. exit 3785
  7747. fi
  7748. # create a configuration file
  7749. echo 'background' > /etc/inadyn.conf
  7750. echo 'verbose 1' >> /etc/inadyn.conf
  7751. echo 'period 300' >> /etc/inadyn.conf
  7752. echo 'startup-delay 60' >> /etc/inadyn.conf
  7753. echo 'cache-dir /run/inadyn' >> /etc/inadyn.conf
  7754. chmod 600 /etc/inadyn.conf
  7755. if [ ! -d /etc/inadyn ]; then
  7756. mkdir /etc/inadyn
  7757. fi
  7758. # add an init script
  7759. echo '#!/bin/sh' > /etc/init.d/inadyn
  7760. echo '### BEGIN INIT INFO' >> /etc/init.d/inadyn
  7761. echo '# Provides: inadyn' >> /etc/init.d/inadyn
  7762. echo '# Required-Start: $network $local_fs $remote_fs $syslog' >> /etc/init.d/inadyn
  7763. echo '# Required-Stop: $network $local_fs $remote_fs $syslog' >> /etc/init.d/inadyn
  7764. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/inadyn
  7765. echo '# Default-Stop: 0 1 6' >> /etc/init.d/inadyn
  7766. echo '# Short-Description: Dynamic DNS client' >> /etc/init.d/inadyn
  7767. echo '# Description: Register an Internet name with your IP address' >> /etc/init.d/inadyn
  7768. echo '### END INIT INFO' >> /etc/init.d/inadyn
  7769. echo '' >> /etc/init.d/inadyn
  7770. echo '# Author: Timur Birsh <taem@linukz.org>' >> /etc/init.d/inadyn
  7771. echo '' >> /etc/init.d/inadyn
  7772. echo 'PATH=/sbin:/usr/sbin:/usr/local/sbin:/bin:/usr/local/bin:/usr/bin' >> /etc/init.d/inadyn
  7773. echo 'DESC="Dynamic DNS client"' >> /etc/init.d/inadyn
  7774. echo 'NAME=inadyn' >> /etc/init.d/inadyn
  7775. echo 'DAEMON=/usr/local/sbin/inadyn' >> /etc/init.d/inadyn
  7776. echo 'CACHEDIR=/run/$NAME' >> /etc/init.d/inadyn
  7777. echo 'PIDFILE=$CACHEDIR/$NAME.pid' >> /etc/init.d/inadyn
  7778. echo 'SCRIPTNAME=/etc/init.d/$NAME' >> /etc/init.d/inadyn
  7779. echo 'DEFAULT=/etc/default/$NAME' >> /etc/init.d/inadyn
  7780. echo 'CONFIG=/etc/$NAME.conf' >> /etc/init.d/inadyn
  7781. echo '' >> /etc/init.d/inadyn
  7782. echo '[ -x $DAEMON ] || exit 0' >> /etc/init.d/inadyn
  7783. echo '' >> /etc/init.d/inadyn
  7784. echo '[ -r $DEFAULT ] && . $DEFAULT' >> /etc/init.d/inadyn
  7785. echo '' >> /etc/init.d/inadyn
  7786. echo '. /lib/lsb/init-functions' >> /etc/init.d/inadyn
  7787. echo '' >> /etc/init.d/inadyn
  7788. echo '# Set defaults values if no DEFAULT exist' >> /etc/init.d/inadyn
  7789. echo 'RUN_DAEMON="yes"' >> /etc/init.d/inadyn
  7790. echo 'USER=debian-inadyn' >> /etc/init.d/inadyn
  7791. echo 'GROUP=debian-inadyn' >> /etc/init.d/inadyn
  7792. echo '' >> /etc/init.d/inadyn
  7793. echo 'DAEMON_ARGS="--pidfile $PIDFILE \' >> /etc/init.d/inadyn
  7794. echo ' --config $CONFIG \' >> /etc/init.d/inadyn
  7795. echo ' --background \' >> /etc/init.d/inadyn
  7796. echo ' --drop-privs $USER:$GROUP"' >> /etc/init.d/inadyn
  7797. echo '' >> /etc/init.d/inadyn
  7798. echo 'create_cache_dir() {' >> /etc/init.d/inadyn
  7799. echo ' # Create the cache empty dir if necessary' >> /etc/init.d/inadyn
  7800. echo ' if [ ! -d $CACHEDIR ]; then' >> /etc/init.d/inadyn
  7801. echo ' mkdir $CACHEDIR' >> /etc/init.d/inadyn
  7802. echo ' chmod 0755 $CACHEDIR' >> /etc/init.d/inadyn
  7803. echo ' chown $USER:$GROUP $CACHEDIR' >> /etc/init.d/inadyn
  7804. echo ' fi' >> /etc/init.d/inadyn
  7805. echo '}' >> /etc/init.d/inadyn
  7806. echo '' >> /etc/init.d/inadyn
  7807. echo 'do_start()' >> /etc/init.d/inadyn
  7808. echo '{' >> /etc/init.d/inadyn
  7809. echo ' start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON --test > /dev/null \' >> /etc/init.d/inadyn
  7810. echo ' || return 1' >> /etc/init.d/inadyn
  7811. echo ' start-stop-daemon --start --quiet --pidfile $PIDFILE --exec $DAEMON -- \' >> /etc/init.d/inadyn
  7812. echo ' $DAEMON_ARGS \' >> /etc/init.d/inadyn
  7813. echo ' || return 2' >> /etc/init.d/inadyn
  7814. echo '}' >> /etc/init.d/inadyn
  7815. echo '' >> /etc/init.d/inadyn
  7816. echo 'do_stop()' >> /etc/init.d/inadyn
  7817. echo '{' >> /etc/init.d/inadyn
  7818. echo ' start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME' >> /etc/init.d/inadyn
  7819. echo ' RETVAL="$?"' >> /etc/init.d/inadyn
  7820. echo ' [ "$RETVAL" = 2 ] && return 2' >> /etc/init.d/inadyn
  7821. echo ' rm -f $PIDFILE' >> /etc/init.d/inadyn
  7822. echo ' return "$RETVAL"' >> /etc/init.d/inadyn
  7823. echo '}' >> /etc/init.d/inadyn
  7824. echo '' >> /etc/init.d/inadyn
  7825. echo 'do_reload() {' >> /etc/init.d/inadyn
  7826. echo ' start-stop-daemon --stop --signal 1 --quiet --pidfile $PIDFILE --name $NAME' >> /etc/init.d/inadyn
  7827. echo ' return 0' >> /etc/init.d/inadyn
  7828. echo '}' >> /etc/init.d/inadyn
  7829. echo '' >> /etc/init.d/inadyn
  7830. echo 'case "$1" in' >> /etc/init.d/inadyn
  7831. echo ' start)' >> /etc/init.d/inadyn
  7832. echo ' log_daemon_msg "Starting $DESC " "$NAME"' >> /etc/init.d/inadyn
  7833. echo ' create_cache_dir' >> /etc/init.d/inadyn
  7834. echo ' do_start' >> /etc/init.d/inadyn
  7835. echo ' case "$?" in' >> /etc/init.d/inadyn
  7836. echo ' 0|1) log_end_msg 0 ;;' >> /etc/init.d/inadyn
  7837. echo ' 2) log_end_msg 1 ;;' >> /etc/init.d/inadyn
  7838. echo ' esac' >> /etc/init.d/inadyn
  7839. echo ' ;;' >> /etc/init.d/inadyn
  7840. echo ' stop)' >> /etc/init.d/inadyn
  7841. echo ' log_daemon_msg "Stopping $DESC" "$NAME"' >> /etc/init.d/inadyn
  7842. echo ' do_stop' >> /etc/init.d/inadyn
  7843. echo ' case "$?" in' >> /etc/init.d/inadyn
  7844. echo ' 0|1) log_end_msg 0 ;;' >> /etc/init.d/inadyn
  7845. echo ' 2) log_end_msg 1 ;;' >> /etc/init.d/inadyn
  7846. echo ' esac' >> /etc/init.d/inadyn
  7847. echo ' ;;' >> /etc/init.d/inadyn
  7848. echo ' status)' >> /etc/init.d/inadyn
  7849. echo ' status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?' >> /etc/init.d/inadyn
  7850. echo ' ;;' >> /etc/init.d/inadyn
  7851. echo ' reload|force-reload)' >> /etc/init.d/inadyn
  7852. echo ' log_daemon_msg "Reloading $DESC" "$NAME"' >> /etc/init.d/inadyn
  7853. echo ' do_reload' >> /etc/init.d/inadyn
  7854. echo ' log_end_msg $?' >> /etc/init.d/inadyn
  7855. echo ' ;;' >> /etc/init.d/inadyn
  7856. echo ' restart)' >> /etc/init.d/inadyn
  7857. echo ' log_daemon_msg "Restarting $DESC" "$NAME"' >> /etc/init.d/inadyn
  7858. echo ' do_stop' >> /etc/init.d/inadyn
  7859. echo ' case "$?" in' >> /etc/init.d/inadyn
  7860. echo ' 0|1)' >> /etc/init.d/inadyn
  7861. echo ' do_start' >> /etc/init.d/inadyn
  7862. echo ' case "$?" in' >> /etc/init.d/inadyn
  7863. echo ' 0) log_end_msg 0 ;;' >> /etc/init.d/inadyn
  7864. echo ' 1) log_end_msg 1 ;; # Old process is still running' >> /etc/init.d/inadyn
  7865. echo ' *) log_end_msg 1 ;; # Failed to start' >> /etc/init.d/inadyn
  7866. echo ' esac' >> /etc/init.d/inadyn
  7867. echo ' ;;' >> /etc/init.d/inadyn
  7868. echo ' *)' >> /etc/init.d/inadyn
  7869. echo ' # Failed to stop' >> /etc/init.d/inadyn
  7870. echo ' log_end_msg 1' >> /etc/init.d/inadyn
  7871. echo ' ;;' >> /etc/init.d/inadyn
  7872. echo ' esac' >> /etc/init.d/inadyn
  7873. echo ' ;;' >> /etc/init.d/inadyn
  7874. echo ' *)' >> /etc/init.d/inadyn
  7875. echo ' echo "Usage: $SCRIPTNAME {start|stop|status|restart|reload|force-reload}" >&2' >> /etc/init.d/inadyn
  7876. echo ' exit 3' >> /etc/init.d/inadyn
  7877. echo ' ;;' >> /etc/init.d/inadyn
  7878. echo 'esac' >> /etc/init.d/inadyn
  7879. echo '' >> /etc/init.d/inadyn
  7880. echo ':' >> /etc/init.d/inadyn
  7881. chmod +x /etc/init.d/inadyn
  7882. update-rc.d inadyn defaults
  7883. service inadyn start
  7884. systemctl daemon-reload
  7885. echo 'install_dynamicdns' >> $COMPLETION_FILE
  7886. }
  7887. function install_final {
  7888. if grep -Fxq "install_final" $COMPLETION_FILE; then
  7889. return
  7890. fi
  7891. # unmount any attached usb drive
  7892. if [ -d $USB_MOUNT ]; then
  7893. umount $USB_MOUNT
  7894. rm -rf $USB_MOUNT
  7895. fi
  7896. echo 'install_final' >> $COMPLETION_FILE
  7897. echo ''
  7898. echo ' *** Freedombone installation is complete. Rebooting... ***'
  7899. echo ''
  7900. if [ -f "/home/$MY_USERNAME/README" ]; then
  7901. echo "See /home/$MY_USERNAME/README for post-installation instructions."
  7902. echo ''
  7903. fi
  7904. reboot
  7905. }
  7906. read_configuration
  7907. parse_args
  7908. install_not_on_BBB
  7909. remove_default_user
  7910. configure_firewall
  7911. configure_firewall_for_ssh
  7912. configure_firewall_for_dns
  7913. configure_firewall_for_ftp
  7914. configure_firewall_for_web_access
  7915. configure_firewall_for_cjdns
  7916. remove_proprietary_repos
  7917. change_debian_repos
  7918. enable_backports
  7919. configure_dns
  7920. install_dynamicdns
  7921. initial_setup
  7922. enforce_good_passwords
  7923. install_editor
  7924. change_login_message
  7925. update_the_kernel
  7926. enable_zram
  7927. random_number_generator
  7928. set_your_domain_name
  7929. time_synchronisation
  7930. configure_internet_protocol
  7931. create_git_project
  7932. install_cjdns
  7933. install_cjdns_tools
  7934. backup_github_projects
  7935. configure_ssh
  7936. check_hwrng
  7937. search_for_attached_usb_drive
  7938. regenerate_ssh_keys
  7939. script_to_make_self_signed_certificates
  7940. create_upgrade_script
  7941. route_outgoing_traffic_through_tor
  7942. install_watchdog_script
  7943. configure_email
  7944. create_procmail
  7945. #spam_filtering
  7946. configure_imap
  7947. configure_gpg
  7948. encrypt_incoming_email
  7949. encrypt_outgoing_email
  7950. email_client
  7951. email_archiving
  7952. email_from_address
  7953. configure_firewall_for_email
  7954. folders_for_mailing_lists
  7955. folders_for_email_addresses
  7956. create_public_mailing_list
  7957. #create_private_mailing_list
  7958. encrypt_all_email
  7959. import_email
  7960. script_for_attaching_usb_drive
  7961. install_web_server
  7962. configure_firewall_for_web_server
  7963. install_owncloud
  7964. install_owncloud_music_app
  7965. install_xmpp
  7966. configure_firewall_for_xmpp
  7967. install_irc_server
  7968. configure_firewall_for_irc
  7969. install_wiki
  7970. install_blog
  7971. install_gnu_social
  7972. install_redmatrix
  7973. install_dlna_server
  7974. configure_firewall_for_dlna
  7975. install_mediagoblin
  7976. repair_databases_script
  7977. create_backup_script
  7978. create_restore_script
  7979. backup_to_friends_servers
  7980. restore_from_friend
  7981. create_tor_dongle
  7982. intrusion_detection
  7983. install_final
  7984. echo 'Freedombone installation is complete'
  7985. exit 0