freedombone 518KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381
  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. # License
  14. # =======
  15. #
  16. # Copyright (C) 2014-2015 Bob Mottram <bob@robotics.uk.to>
  17. #
  18. # This program is free software: you can redistribute it and/or modify
  19. # it under the terms of the GNU General Public License as published by
  20. # the Free Software Foundation, either version 3 of the License, or
  21. # (at your option) any later version.
  22. #
  23. # This program is distributed in the hope that it will be useful,
  24. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  25. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  26. # GNU General Public License for more details.
  27. #
  28. # You should have received a copy of the GNU General Public License
  29. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  30. NO_OF_ARGS=$#
  31. # Web site
  32. FREEDOMBONE_WEBSITE="http://freedombone.uk.to"
  33. # Contact details
  34. FREEDOMBONE_BITMESSAGE="BM-2cWuhmBvVdfrHhLoZTdspCkKeiTorUesSL"
  35. # Are we installing on a Beaglebone Black (BBB) or some other system?
  36. INSTALLING_ON_BBB="no"
  37. # Version number of this script
  38. VERSION="1.00"
  39. # Different system variants which may be specified within
  40. # the SYSTEM_TYPE option
  41. VARIANT_FULL="full"
  42. VARIANT_WRITER="writer"
  43. VARIANT_CLOUD="cloud"
  44. VARIANT_CHAT="chat"
  45. VARIANT_MAILBOX="mailbox"
  46. VARIANT_NONMAILBOX="nonmailbox"
  47. VARIANT_SOCIAL="social"
  48. VARIANT_MEDIA="media"
  49. VARIANT_DEVELOPER="developer"
  50. DEFAULT_DOMAIN_NAME=
  51. DEFAULT_DOMAIN_CODE=
  52. MY_USERNAME=
  53. SYSTEM_TYPE=$VARIANT_FULL
  54. # whether the system is being installed from a pre-created configuration file
  55. INSTALLING_FROM_CONFIGURATION_FILE="no"
  56. # An optional configuration file which overrides some of these variables
  57. CONFIGURATION_FILE="freedombone.cfg"
  58. SSH_PORT=2222
  59. # parameters used when adding a new domain
  60. DDNS_PROVIDER="default@freedns.afraid.org"
  61. DDNS_USERNAME=
  62. DDNS_PASSWORD=
  63. CURRENT_DDNS_DOMAIN=
  64. # Minimum number of characters in a password
  65. MINIMUM_PASSWORD_LENGTH=10
  66. # number of CPU cores
  67. CPU_CORES=1
  68. # The static IP address of the system within the local network
  69. LOCAL_NETWORK_STATIC_IP_ADDRESS="192.168.1.60"
  70. # IP address of the router (gateway)
  71. ROUTER_IP_ADDRESS="192.168.1.254"
  72. # DNS
  73. NAMESERVER1='213.73.91.35'
  74. NAMESERVER2='85.214.20.141'
  75. # whether to route outgoing traffic through Tor
  76. ROUTE_THROUGH_TOR="no"
  77. # Why use Google as a time source?
  78. # The thinking here is that it's likely to be reliable and fast.
  79. # The ping doesn't reveal any information other than that the server
  80. # is running, and if anyone maliciously alters the time on Google's
  81. # servers then that would certainly be newsworthy and they'd be
  82. # likely to do something about it quickly.
  83. # If you have better time sources then change them here.
  84. TLS_TIME_SOURCE1="google.com"
  85. TLS_TIME_SOURCE2="www.ptb.de"
  86. # kernel specifically tweaked for the Beaglebone Black
  87. # See http://rcn-ee.net/deb/jessie-armhf/
  88. KERNEL_VERSION="v3.15.10-bone8"
  89. # The type of hardware random number generator being used
  90. # This can be empty, "beaglebone" or "onerng"
  91. HWRNG_TYPE=
  92. # Download location for OneRNG driver
  93. ONERNG_PACKAGE="onerng_3.4-1_all.deb"
  94. ONERNG_PACKAGE_DOWNLOAD="https://github.com/OneRNG/onerng.github.io/blob/master/sw/$ONERNG_PACKAGE?raw=true"
  95. # Hash for OneRNG driver
  96. ONERNG_PACKAGE_HASH='78f1c2f52ae573e3b398a695ece7ab9f41868252657ea269f0d5cf0bd4f2eb59'
  97. # device name for OneRNG
  98. ONERNG_DEVICE='ttyACM0'
  99. # Whether this system is being installed within a docker container
  100. INSTALLED_WITHIN_DOCKER="no"
  101. # If you want to run a public mailing list specify its name here.
  102. # There should be no spaces in the name
  103. PUBLIC_MAILING_LIST=
  104. # Optional different domain name for the public mailing list
  105. PUBLIC_MAILING_LIST_DOMAIN_NAME=
  106. # Directory where the public mailing list data is stored
  107. PUBLIC_MAILING_LIST_DIRECTORY="/var/spool/mlmmj"
  108. # If you want to run an encrypted mailing list specify its name here.
  109. # There should be no spaces in the name
  110. PRIVATE_MAILING_LIST=
  111. # Domain name for mediagoblin installation
  112. MEDIAGOBLIN_DOMAIN_NAME=
  113. MEDIAGOBLIN_CODE=
  114. MEDIAGOBLIN_REPO="https://gitorious.org/mediagoblin/mediagoblin.git"
  115. MEDIAGOBLIN_ADMIN_PASSWORD=
  116. # Domain name for microblog installation
  117. MICROBLOG_DOMAIN_NAME=
  118. MICROBLOG_CODE=
  119. MICROBLOG_REPO="git://gitorious.org/social/mainline.git"
  120. MICROBLOG_ADMIN_PASSWORD=
  121. # Domain name for redmatrix installation
  122. REDMATRIX_DOMAIN_NAME=
  123. REDMATRIX_CODE=
  124. REDMATRIX_REPO="https://github.com/redmatrix/redmatrix.git"
  125. REDMATRIX_ADDONS_REPO="https://github.com/redmatrix/redmatrix-addons.git"
  126. REDMATRIX_ADMIN_PASSWORD=
  127. # Domain name for git hosting installation
  128. GIT_DOMAIN_NAME=
  129. GIT_CODE=
  130. GIT_DOMAIN_REPO="https://github.com/gogits/gogs.git"
  131. GIT_ADMIN_PASSWORD=
  132. # Domain name for Owncloud installation
  133. OWNCLOUD_DOMAIN_NAME=
  134. OWNCLOUD_CODE=
  135. OWNCLOUD_ADMIN_PASSWORD=
  136. # Domain name for your wiki
  137. WIKI_DOMAIN_NAME=
  138. WIKI_ADMIN_PASSWORD=
  139. WIKI_TITLE="Freedombone Wiki"
  140. WIKI_CODE=
  141. # Domain name for your blog
  142. FULLBLOG_DOMAIN_NAME=
  143. FULLBLOG_CODE=
  144. MY_BLOG_TITLE="My Blog"
  145. MY_BLOG_SUBTITLE="Another Freedombone Blog"
  146. GPG_KEYSERVER="hkp://keys.gnupg.net"
  147. # whether to encrypt all incoming email with your public key
  148. GPG_ENCRYPT_STORED_EMAIL="yes"
  149. # gets set to yes if gpg keys are imported from usb
  150. GPG_KEYS_IMPORTED="no"
  151. # optionally you can provide your exported GPG key pair here
  152. # Note that the private key file will be deleted after use
  153. # If these are unspecified then a new GPG key will be created
  154. MY_GPG_PUBLIC_KEY=
  155. MY_GPG_PRIVATE_KEY=
  156. # optionally specify your public key ID
  157. MY_GPG_PUBLIC_KEY_ID=
  158. # If you have existing mail within a Maildir
  159. # you can specify the directory here and the files
  160. # will be imported
  161. IMPORT_MAILDIR=
  162. # The Debian package repository to use.
  163. DEBIAN_REPO="ftp.us.debian.org"
  164. DEBIAN_VERSION="jessie"
  165. # Directory where source code is downloaded and compiled
  166. INSTALL_DIR=$HOME/build
  167. # device name for an attached usb drive
  168. USB_DRIVE=/dev/sda1
  169. # Location where the USB drive is mounted to
  170. USB_MOUNT=/mnt/usb
  171. # name of a script used to upgrade the system
  172. UPGRADE_SCRIPT_NAME="freedombone-upgrade"
  173. # name of a script which keeps running processes going even if they crash
  174. WATCHDOG_SCRIPT_NAME="keepon"
  175. # Name of a script used to create a backup of the system on usb drive
  176. BACKUP_SCRIPT_NAME="backup"
  177. # Name of a script used to restore the system from usb drive
  178. RESTORE_SCRIPT_NAME="restore"
  179. # name of a script used to backup to friends servers
  180. BACKUP_TO_FRIENDS_SCRIPT_NAME="backup2friends"
  181. # name of a script used to restore backed up data from a friend
  182. RESTORE_FROM_FRIEND_SCRIPT_NAME="restorefromfriend"
  183. # Location of the certificate used to encrypt backups
  184. BACKUP_CERTIFICATE=/etc/ssl/private/backup.key
  185. # memory limit for php in MB
  186. MAX_PHP_MEMORY=64
  187. # default MariaDB password
  188. MARIADB_PASSWORD=
  189. # Directory where XMPP settings are stored
  190. XMPP_DIRECTORY="/var/lib/prosody"
  191. # file containing a list of remote locations to backup to
  192. # Format: [username@friendsdomain//home/username] [ssh_password]
  193. # With the only space character being between the server and the password
  194. FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
  195. # list of encryption protocols
  196. SSL_PROTOCOLS="TLSv1 TLSv1.1 TLSv1.2"
  197. # list of ciphers to use. See bettercrypto.org recommendations
  198. 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"
  199. # ssh (from https://stribika.github.io/2015/01/04/secure-secure-shell.html)
  200. SSH_CIPHERS="chacha20-poly1305@openssh.com,aes256-gcm@openssh.com,aes128-gcm@openssh.com,aes256-ctr,aes192-ctr,aes128-ctr"
  201. SSH_MACS="hmac-sha2-512-etm@openssh.com,hmac-sha2-256-etm@openssh.com,hmac-ripemd160-etm@openssh.com,umac-128-etm@openssh.com,hmac-sha2-512,hmac-sha2-256,hmac-ripemd160,umac-128@openssh.com"
  202. SSH_KEX="curve25519-sha256@libssh.org,diffie-hellman-group-exchange-sha256"
  203. SSH_HOST_KEY_ALGORITHMS="ssh-ed25519-cert-v01@openssh.com,ssh-rsa-cert-v01@openssh.com,ssh-rsa-cert-v00@openssh.com,ssh-ed25519,ssh-rsa"
  204. # xmpp ciphers and curve
  205. 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"'
  206. XMPP_ECC_CURVE='"secp384r1"'
  207. # the default email address
  208. MY_EMAIL_ADDRESS=$MY_USERNAME@$DEFAULT_DOMAIN_NAME
  209. # optionally specify your name to appear on the blog
  210. MY_NAME=$DEFAULT_DOMAIN_NAME
  211. export DEBIAN_FRONTEND=noninteractive
  212. # logging level for Nginx
  213. WEBSERVER_LOG_LEVEL='crit'
  214. # used to limit CPU usage
  215. CPULIMIT='/usr/bin/cpulimit -l 20 -e'
  216. # command to create a git repository
  217. CREATE_GIT_PROJECT_COMMAND='create-project'
  218. # File which keeps track of what has already been installed
  219. COMPLETION_FILE=$HOME/freedombone-completed.txt
  220. if [ ! -f $COMPLETION_FILE ]; then
  221. touch $COMPLETION_FILE
  222. fi
  223. # Your github username
  224. GITHUB_USERNAME=
  225. # Directory where github projects will be backed up
  226. GITHUB_BACKUP_DIRECTORY=/var/backups/github
  227. # Used to indicate whether the backup contains MariaDB databases or not
  228. BACKUP_INCLUDES_DATABASES="no"
  229. # contains the mysql root password which
  230. # is used for backups and repair
  231. DATABASE_PASSWORD_FILE=/root/dbpass
  232. # log file where details of remote backups are stored
  233. REMOTE_BACKUPS_LOG=/var/log/remotebackups.log
  234. # message if something fails to install
  235. 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."
  236. # web site used to obtain the external IP address of the system
  237. GET_IP_ADDRESS_URL="checkip.two-dns.de"
  238. # Password used for VoIP server
  239. VOIP_SERVER_PASSWORD=
  240. # Port on which VoIP server listens
  241. VOIP_PORT=64738
  242. # Location of VoIP database and configuration
  243. VOIP_DATABASE="mumble-server.sqlite"
  244. VOIP_CONFIG_FILE="mumble-server.ini"
  245. # other possible services to obtain the external IP address
  246. EXTERNAL_IP_SERVICES=( \
  247. 'https://check.torproject.org/' \
  248. 'https://www.whatsmydns.net/whats-my-ip-address.html' \
  249. 'https://www.privateinternetaccess.com/pages/whats-my-ip/' \
  250. 'http://checkip.two-dns.de' \
  251. 'http://ip.dnsexit.com' \
  252. 'http://ifconfig.me/ip' \
  253. 'http://ipecho.net/plain' \
  254. 'http://checkip.dyndns.org/plain' \
  255. 'http://ipogre.com/linux.php' \
  256. 'http://whatismyipaddress.com/' \
  257. 'http://ip.my-proxy.com/' \
  258. 'http://websiteipaddress.com/WhatIsMyIp' \
  259. 'http://getmyipaddress.org/' \
  260. 'http://www.my-ip-address.net/' \
  261. 'http://myexternalip.com/raw' \
  262. 'http://www.canyouseeme.org/' \
  263. 'http://www.trackip.net/' \
  264. 'http://icanhazip.com/' \
  265. 'http://www.iplocation.net/' \
  266. 'http://www.howtofindmyipaddress.com/' \
  267. 'http://www.ipchicken.com/' \
  268. 'http://whatsmyip.net/' \
  269. 'http://www.ip-adress.com/' \
  270. 'http://checkmyip.com/' \
  271. 'http://www.tracemyip.org/' \
  272. 'http://checkmyip.net/' \
  273. 'http://www.lawrencegoetz.com/programs/ipinfo/' \
  274. 'http://www.findmyip.co/' \
  275. 'http://ip-lookup.net/' \
  276. 'http://www.dslreports.com/whois' \
  277. 'http://www.mon-ip.com/en/my-ip/' \
  278. 'http://www.myip.ru' \
  279. 'http://ipgoat.com/' \
  280. 'http://www.myipnumber.com/my-ip-address.asp' \
  281. 'http://www.whatsmyipaddress.net/' \
  282. 'http://formyip.com/' \
  283. 'http://www.displaymyip.com/' \
  284. 'http://www.bobborst.com/tools/whatsmyip/' \
  285. 'http://www.geoiptool.com/' \
  286. 'http://checkip.dyndns.com/' \
  287. 'http://myexternalip.com/' \
  288. 'http://www.ip-adress.eu/' \
  289. 'http://www.infosniper.net/' \
  290. 'http://wtfismyip.com/' \
  291. 'http://ipinfo.io/' \
  292. 'http://httpbin.org/ip')
  293. # cjdns settings
  294. ENABLE_CJDNS="no"
  295. CJDNS_PRIVATE_KEY=
  296. CJDNS_PUBLIC_KEY=
  297. CJDNS_IPV6=
  298. CJDNS_PASSWORD=
  299. CJDNS_PORT=
  300. # B.A.T.M.A.N settings
  301. ENABLE_BATMAN="no"
  302. BATMAN_IP='10.47.254.254'
  303. function show_help {
  304. echo ''
  305. echo 'freedombone -c [configuration file]'
  306. echo ''
  307. echo ' -h --help Show help'
  308. echo ' menuconfig Easy interactive installation'
  309. echo ' -c --config Installing from a configuration file'
  310. echo ' --bbb Installing on Beaglebone Black'
  311. echo ' -u --user User to install the system as'
  312. echo ' -d --domain Default domain name'
  313. echo ' -s --system System type'
  314. echo ' --ip Static LAN IP address of the system'
  315. echo ' --iprouter LAN IP address of the internet router'
  316. echo ' --ddns Dynamic DNS provider domain'
  317. echo ' --ddnsuser Dynamic DNS provider username'
  318. echo ' --ddnspass Dynamic DNS provider password'
  319. echo ''
  320. echo ' --microblogdomain Microblog domain name'
  321. echo ' --wikidomain Wiki domain name'
  322. echo ' --blogdomain Blog domain name'
  323. echo ' --ownclouddomain Owncloud domain name'
  324. echo ' --redmatrixdomain Redmatrix domain name'
  325. echo ' --gitdomain Git hosting domain name'
  326. echo ' -t --time Domain used as a TLS time source'
  327. echo ' --ssh ssh port number'
  328. echo ' --list Public mailing list name'
  329. echo ' --cores Number of CPU cores'
  330. echo ' --name Your name'
  331. echo ' --email Your email address'
  332. echo ' --usb Path for the USB drive (eg. /dev/sdb1)'
  333. echo ' --cjdns Enable CJDNS'
  334. echo ' --vpass VoIP server password'
  335. echo ' --vport VoIP server port'
  336. echo ' --ns1 First DNS nameserver'
  337. echo ' --ns2 Second DNS nameserver'
  338. echo ' --repo Debian repository'
  339. echo ''
  340. echo 'system types'
  341. echo '------------'
  342. echo 'This can either be blank if you wish to install the full system,'
  343. echo "or for more specialised variants you can specify '$VARIANT_MAILBOX', '$VARIANT_CLOUD',"
  344. echo "'$VARIANT_CHAT', '$VARIANT_SOCIAL', '$VARIANT_MEDIA', '$VARIANT_WRITER' or '$VARIANT_DEVELOPER'."
  345. echo "If you wish to install everything except email then use the '$VARIANT_NONMAILBOX' variaint."
  346. echo ''
  347. exit 0
  348. }
  349. function interactive_configuration_remote_backups {
  350. if [ ! -f /usr/local/bin/freedombone-remote ]; then
  351. if [ ! -f /usr/bin/freedombone-remote ]; then
  352. echo 'The command freedombone-remote was not found'
  353. exit 87354
  354. fi
  355. fi
  356. freedombone-remote -u $MY_USERNAME -l $FRIENDS_SERVERS_LIST -m $MINIMUM_PASSWORD_LENGTH
  357. if [ ! "$?" = "0" ]; then
  358. echo 'Command failed:'
  359. echo ''
  360. echo " freedombone-remote -u $MY_USERNAME -l $FRIENDS_SERVERS_LIST -m $MINIMUM_PASSWORD_LENGTH"
  361. echo ''
  362. exit 65892
  363. fi
  364. }
  365. # test a domain name to see if it's valid
  366. function validate_domain_name {
  367. # count the number of dots in the domain name
  368. dots=${TEST_DOMAIN_NAME//[^.]}
  369. no_of_dots=${#dots}
  370. if (( $no_of_dots > 3 )); then
  371. TEST_DOMAIN_NAME="The domain $TEST_DOMAIN_NAME has too many subdomains. It should be of the type w.x.y.z, x.y.z or y.z"
  372. fi
  373. if (( $no_of_dots == 0 )); then
  374. TEST_DOMAIN_NAME="The domain $TEST_DOMAIN_NAME has no top level domain. It should be of the type w.x.y.z, x.y.z or y.z"
  375. fi
  376. }
  377. function interactive_configuration {
  378. if [ ! -f /usr/local/bin/freedombone-config ]; then
  379. if [ ! -f /usr/bin/freedombone-config ]; then
  380. echo 'The command freedombone-config was not found'
  381. exit 63935
  382. fi
  383. fi
  384. freedombone-config \
  385. -f $CONFIGURATION_FILE \
  386. -w $FREEDOMBONE_WEBSITE \
  387. -b $FREEDOMBONE_BITMESSAGE \
  388. -m $MINIMUM_PASSWORD_LENGTH
  389. if [ ! "$?" = "0" ]; then
  390. echo 'Command failed:'
  391. echo ''
  392. echo " freedombone-config -u $MY_USERNAME -f $CONFIGURATION_FILE -w $FREEDOMBONE_WEBSITE -b $FREEDOMBONE_BITMESSAGE -m $MINIMUM_PASSWORD_LENGTH"
  393. echo ''
  394. exit 73594
  395. fi
  396. FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
  397. dialog --title "Encrypted backup to other servers" \
  398. --backtitle "Freedombone Configuration" \
  399. --defaultno \
  400. --yesno "\nDo you wish to configure some remote backup locations?" 7 60
  401. sel=$?
  402. case $sel in
  403. 0) interactive_configuration_remote_backups;;
  404. esac
  405. }
  406. if [[ $1 == "menuconfig" ]]; then
  407. interactive_configuration
  408. else
  409. while [[ $# > 1 ]]
  410. do
  411. key="$1"
  412. case $key in
  413. -h|--help)
  414. show_help
  415. ;;
  416. # load a configuration file
  417. -c|--config)
  418. shift
  419. CONFIGURATION_FILE="$1"
  420. INSTALLING_FROM_CONFIGURATION_FILE="yes"
  421. break
  422. ;;
  423. # username within /home
  424. -u|--user)
  425. shift
  426. MY_USERNAME="$1"
  427. ;;
  428. # microblog domain name
  429. --microblogdomain)
  430. shift
  431. MICROBLOG_DOMAIN_NAME="$1"
  432. ;;
  433. # wiki domain name
  434. --wikidomain)
  435. shift
  436. WIKI_DOMAIN_NAME="$1"
  437. ;;
  438. # blog domain name
  439. --blogdomain)
  440. shift
  441. FULLBLOG_DOMAIN_NAME="$1"
  442. ;;
  443. # owncloud domain name
  444. --ownclouddomain)
  445. shift
  446. OWNCLOUD_DOMAIN_NAME="$1"
  447. ;;
  448. # redmatrix domain name
  449. --redmatrixdomain)
  450. shift
  451. REDMATRIX_DOMAIN_NAME="$1"
  452. ;;
  453. # git hosting domain name
  454. --gitdomain)
  455. shift
  456. GIT_DOMAIN_NAME="$1"
  457. ;;
  458. # default domain name
  459. -d|--domain)
  460. shift
  461. DEFAULT_DOMAIN_NAME="$1"
  462. ;;
  463. # The type of system
  464. -s|--system)
  465. shift
  466. SYSTEM_TYPE="$1"
  467. ;;
  468. # The dynamic DNS provider
  469. --ddns)
  470. shift
  471. DDNS_PROVIDER="$1"
  472. ;;
  473. # Username for the synamic DNS provider
  474. --ddnsuser)
  475. shift
  476. DDNS_USERNAME="$1"
  477. ;;
  478. # Password for the synamic DNS provider
  479. --ddnspass)
  480. shift
  481. DDNS_PASSWORD="$1"
  482. ;;
  483. # Whether this installation is on a Beaglebone Black
  484. --bbb)
  485. INSTALLING_ON_BBB="yes"
  486. ;;
  487. # Domain name to use as a TLS time source
  488. -t|--time)
  489. shift
  490. TLS_TIME_SOURCE1="$1"
  491. ;;
  492. # Static IP address for the system
  493. --ip)
  494. shift
  495. LOCAL_NETWORK_STATIC_IP_ADDRESS=$1
  496. ;;
  497. # IP address for the internet router
  498. --iprouter)
  499. shift
  500. ROUTER_IP_ADDRESS=$1
  501. ;;
  502. # ssh port
  503. --ssh)
  504. shift
  505. SSH_PORT=$1
  506. ;;
  507. # public mailing list name
  508. --list)
  509. shift
  510. PUBLIC_MAILING_LIST="$1"
  511. ;;
  512. # Number of CPU cores
  513. --cores)
  514. shift
  515. CPU_CORES=$1
  516. ;;
  517. # my name
  518. --name)
  519. shift
  520. MY_NAME="$1"
  521. ;;
  522. # my email address
  523. --email)
  524. shift
  525. MY_EMAIL_ADDRESS="$1"
  526. ;;
  527. # USB drive
  528. --usb)
  529. shift
  530. USB_DRIVE=$1
  531. ;;
  532. # Enable CJDNS
  533. --cjdns)
  534. shift
  535. ENABLE_CJDNS="yes"
  536. ;;
  537. # Enable B.A.T.M.A.N
  538. --batman)
  539. shift
  540. ENABLE_BATMAN="yes"
  541. ;;
  542. # VoIP server password
  543. --vpass)
  544. shift
  545. VOIP_SERVER_PASSWORD=$1
  546. ;;
  547. # VoIP server port
  548. --vport)
  549. shift
  550. VOIP_PORT=$1
  551. ;;
  552. # DNS Nameserver 1
  553. --ns1)
  554. shift
  555. NAMESERVER1=$1
  556. ;;
  557. # DNS Nameserver 2
  558. --ns2)
  559. shift
  560. NAMESERVER2=$1
  561. ;;
  562. # Debian repository
  563. --repo)
  564. shift
  565. DEBIAN_REPO=$1
  566. ;;
  567. *)
  568. # unknown option
  569. ;;
  570. esac
  571. shift
  572. done
  573. fi
  574. function parse_args {
  575. if [[ $NO_OF_ARGS == 0 ]]; then
  576. echo 'no_of_args = 0'
  577. show_help
  578. exit 0
  579. fi
  580. if [ ! -d /home/$MY_USERNAME ]; then
  581. echo "There is no user '$MY_USERNAME' on the system. Use 'adduser $MY_USERNAME' to create the user."
  582. exit 1
  583. fi
  584. if [ ! "$DEFAULT_DOMAIN_NAME" ]; then
  585. echo 'No default domain specified'
  586. show_help
  587. exit 2
  588. fi
  589. if [ ! $MY_USERNAME ]; then
  590. echo 'No username specified'
  591. show_help
  592. exit 3
  593. fi
  594. if [ ! $DDNS_USERNAME ]; then
  595. echo 'Please provide the username for your dynamic DNS provider with the --ddnsuser option'
  596. exit 7823
  597. fi
  598. if [ ! $DDNS_PASSWORD ]; then
  599. echo 'Please provide the password for your dynamic DNS provider with the --ddnspass option'
  600. exit 6382
  601. fi
  602. if [ ! $SYSTEM_TYPE ]; then
  603. SYSTEM_TYPE=$VARIANT_FULL
  604. fi
  605. 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_DEVELOPER && $SYSTEM_TYPE != $VARIANT_FULL ]]; then
  606. echo "'$SYSTEM_TYPE' is an unrecognised Freedombone variant."
  607. exit 30
  608. fi
  609. }
  610. function read_configuration {
  611. # if not installing on a Beaglebone then use sdb as the USB drive by default
  612. if [ ! $INSTALLING_ON_BBB ]; then
  613. if [[ $USB_DRIVE == /dev/sda1 ]]; then
  614. USB_DRIVE=/dev/sdb1
  615. fi
  616. fi
  617. if [[ $INSTALLING_FROM_CONFIGURATION_FILE == "yes" ]]; then
  618. if [ ! -f $CONFIGURATION_FILE ]; then
  619. echo "The configuration file $CONFIGURATION_FILE was not found"
  620. exit 8935
  621. fi
  622. fi
  623. if [ -f $CONFIGURATION_FILE ]; then
  624. if grep -q "HWRNG_TYPE" $CONFIGURATION_FILE; then
  625. HWRNG_TYPE=$(grep "HWRNG_TYPE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  626. fi
  627. if grep -q "MEDIAGOBLIN_DOMAIN_NAME" $CONFIGURATION_FILE; then
  628. MEDIAGOBLIN_DOMAIN_NAME=$(grep "MEDIAGOBLIN_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  629. fi
  630. if grep -q "MEDIAGOBLIN_CODE" $CONFIGURATION_FILE; then
  631. MEDIAGOBLIN_CODE=$(grep "MEDIAGOBLIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  632. fi
  633. if grep -q "GIT_ADMIN_PASSWORD" $CONFIGURATION_FILE; then
  634. GIT_ADMIN_PASSWORD=$(grep "GIT_ADMIN_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  635. fi
  636. if grep -q "GIT_DOMAIN_NAME" $CONFIGURATION_FILE; then
  637. GIT_DOMAIN_NAME=$(grep "GIT_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  638. fi
  639. if grep -q "GIT_CODE" $CONFIGURATION_FILE; then
  640. GIT_CODE=$(grep "GIT_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  641. fi
  642. if grep -q "SYSTEM_TYPE" $CONFIGURATION_FILE; then
  643. SYSTEM_TYPE=$(grep "SYSTEM_TYPE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  644. fi
  645. if grep -q "SSL_PROTOCOLS" $CONFIGURATION_FILE; then
  646. SSL_PROTOCOLS=$(grep "SSL_PROTOCOLS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  647. fi
  648. if grep -q "SSL_CIPHERS" $CONFIGURATION_FILE; then
  649. SSL_CIPHERS=$(grep "SSL_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  650. fi
  651. if grep -q "SSH_CIPHERS" $CONFIGURATION_FILE; then
  652. SSH_CIPHERS=$(grep "SSH_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  653. fi
  654. if grep -q "SSH_MACS" $CONFIGURATION_FILE; then
  655. SSH_MACS=$(grep "SSH_MACS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  656. fi
  657. if grep -q "SSH_KEX" $CONFIGURATION_FILE; then
  658. SSH_KEX=$(grep "SSH_KEX" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  659. fi
  660. if grep -q "SSH_HOST_KEY_ALGORITHMS" $CONFIGURATION_FILE; then
  661. SSH_HOST_KEY_ALGORITHMS=$(grep "SSH_HOST_KEY_ALGORITHMS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  662. fi
  663. if grep -q "SSH_PASSWORDS" $CONFIGURATION_FILE; then
  664. SSH_PASSWORDS=$(grep "SSH_PASSWORDS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  665. fi
  666. if grep -q "XMPP_CIPHERS" $CONFIGURATION_FILE; then
  667. XMPP_CIPHERS=$(grep "XMPP_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  668. fi
  669. if grep -q "XMPP_ECC_CURVE" $CONFIGURATION_FILE; then
  670. XMPP_ECC_CURVE=$(grep "XMPP_ECC_CURVE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  671. fi
  672. if grep -q "MY_USERNAME" $CONFIGURATION_FILE; then
  673. MY_USERNAME=$(grep "MY_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  674. fi
  675. if grep -q "DOMAIN_NAME" $CONFIGURATION_FILE; then
  676. # for backwards compatability
  677. DEFAULT_DOMAIN_NAME=$(grep "DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  678. fi
  679. if grep -q "DEFAULT_DOMAIN_NAME" $CONFIGURATION_FILE; then
  680. DEFAULT_DOMAIN_NAME=$(grep "DEFAULT_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  681. fi
  682. if grep -q "DEFAULT_DOMAIN_CODE" $CONFIGURATION_FILE; then
  683. DEFAULT_DOMAIN_CODE=$(grep "DEFAULT_DOMAIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  684. fi
  685. if grep -q "NAMESERVER1" $CONFIGURATION_FILE; then
  686. NAMESERVER1=$(grep "NAMESERVER1" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  687. fi
  688. if grep -q "NAMESERVER2" $CONFIGURATION_FILE; then
  689. NAMESERVER2=$(grep "NAMESERVER2" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  690. fi
  691. if grep -q "DEBIAN_REPO" $CONFIGURATION_FILE; then
  692. DEBIAN_REPO=$(grep "DEBIAN_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  693. 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."
  694. fi
  695. if grep -q "VOIP_PORT" $CONFIGURATION_FILE; then
  696. VOIP_PORT=$(grep "VOIP_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  697. fi
  698. if grep -q "VOIP_SERVER_PASSWORD" $CONFIGURATION_FILE; then
  699. VOIP_SERVER_PASSWORD=$(grep "VOIP_SERVER_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  700. fi
  701. if grep -q "GET_IP_ADDRESS_URL" $CONFIGURATION_FILE; then
  702. GET_IP_ADDRESS_URL=$(grep "GET_IP_ADDRESS_URL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  703. fi
  704. if grep -q "DDNS_PROVIDER" $CONFIGURATION_FILE; then
  705. DDNS_PROVIDER=$(grep "DDNS_PROVIDER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  706. fi
  707. if grep -q "DDNS_USERNAME" $CONFIGURATION_FILE; then
  708. DDNS_USERNAME=$(grep "DDNS_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  709. fi
  710. if grep -q "DDNS_PASSWORD" $CONFIGURATION_FILE; then
  711. DDNS_PASSWORD=$(grep "DDNS_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  712. fi
  713. if grep -q "LOCAL_NETWORK_STATIC_IP_ADDRESS" $CONFIGURATION_FILE; then
  714. LOCAL_NETWORK_STATIC_IP_ADDRESS=$(grep "LOCAL_NETWORK_STATIC_IP_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  715. fi
  716. if grep -q "ENABLE_BATMAN" $CONFIGURATION_FILE; then
  717. ENABLE_BATMAN=$(grep "ENABLE_BATMAN" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  718. fi
  719. if grep -q "BATMAN_IP" $CONFIGURATION_FILE; then
  720. BATMAN_IP=$(grep "BATMAN_IP" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  721. fi
  722. if grep -q "ENABLE_CJDNS" $CONFIGURATION_FILE; then
  723. ENABLE_CJDNS=$(grep "ENABLE_CJDNS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  724. fi
  725. if grep -q "CJDNS_IPV6" $CONFIGURATION_FILE; then
  726. CJDNS_IPV6=$(grep "CJDNS_IPV6" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  727. fi
  728. if grep -q "CJDNS_PUBLIC_KEY" $CONFIGURATION_FILE; then
  729. CJDNS_PUBLIC_KEY=$(grep "CJDNS_PUBLIC_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  730. fi
  731. if grep -q "CJDNS_PRIVATE_KEY" $CONFIGURATION_FILE; then
  732. CJDNS_PRIVATE_KEY=$(grep "CJDNS_PRIVATE_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  733. fi
  734. if grep -q "BACKUP_CERTIFICATE" $CONFIGURATION_FILE; then
  735. BACKUP_CERTIFICATE=$(grep "BACKUP_CERTIFICATE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  736. fi
  737. if grep -q "ROUTER_IP_ADDRESS" $CONFIGURATION_FILE; then
  738. ROUTER_IP_ADDRESS=$(grep "ROUTER_IP_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  739. fi
  740. if grep -q "GITHUB_USERNAME" $CONFIGURATION_FILE; then
  741. GITHUB_USERNAME=$(grep "GITHUB_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  742. fi
  743. if grep -q "GITHUB_BACKUP_DIRECTORY" $CONFIGURATION_FILE; then
  744. GITHUB_BACKUP_DIRECTORY=$(grep "GITHUB_BACKUP_DIRECTORY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  745. fi
  746. if grep -q "CPU_CORES" $CONFIGURATION_FILE; then
  747. CPU_CORES=$(grep "CPU_CORES" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  748. fi
  749. if grep -q "WEBSERVER_LOG_LEVEL" $CONFIGURATION_FILE; then
  750. WEBSERVER_LOG_LEVEL=$(grep "WEBSERVER_LOG_LEVEL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  751. fi
  752. if grep -q "ROUTE_THROUGH_TOR" $CONFIGURATION_FILE; then
  753. ROUTE_THROUGH_TOR=$(grep "ROUTE_THROUGH_TOR" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  754. fi
  755. if grep -q "WIKI_TITLE" $CONFIGURATION_FILE; then
  756. WIKI_TITLE=$(grep "WIKI_TITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  757. fi
  758. if grep -q "MY_NAME" $CONFIGURATION_FILE; then
  759. MY_NAME=$(grep "MY_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  760. fi
  761. if grep -q "MY_EMAIL_ADDRESS" $CONFIGURATION_FILE; then
  762. MY_EMAIL_ADDRESS=$(grep "MY_EMAIL_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  763. fi
  764. if grep -q "INSTALLING_ON_BBB" $CONFIGURATION_FILE; then
  765. INSTALLING_ON_BBB=$(grep "INSTALLING_ON_BBB" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  766. fi
  767. if grep -q "SSH_PORT" $CONFIGURATION_FILE; then
  768. SSH_PORT=$(grep "SSH_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  769. fi
  770. if grep -q "INSTALLED_WITHIN_DOCKER" $CONFIGURATION_FILE; then
  771. INSTALLED_WITHIN_DOCKER=$(grep "INSTALLED_WITHIN_DOCKER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  772. fi
  773. if grep -q "PUBLIC_MAILING_LIST" $CONFIGURATION_FILE; then
  774. PUBLIC_MAILING_LIST=$(grep "PUBLIC_MAILING_LIST" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  775. fi
  776. if grep -q "MICROBLOG_DOMAIN_NAME" $CONFIGURATION_FILE; then
  777. MICROBLOG_DOMAIN_NAME=$(grep "MICROBLOG_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  778. fi
  779. if grep -q "MICROBLOG_CODE" $CONFIGURATION_FILE; then
  780. MICROBLOG_CODE=$(grep "MICROBLOG_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  781. fi
  782. if grep -q "REDMATRIX_DOMAIN_NAME" $CONFIGURATION_FILE; then
  783. REDMATRIX_DOMAIN_NAME=$(grep "REDMATRIX_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  784. fi
  785. if grep -q "REDMATRIX_CODE" $CONFIGURATION_FILE; then
  786. REDMATRIX_CODE=$(grep "REDMATRIX_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  787. fi
  788. if grep -q "OWNCLOUD_DOMAIN_NAME" $CONFIGURATION_FILE; then
  789. OWNCLOUD_DOMAIN_NAME=$(grep "OWNCLOUD_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  790. fi
  791. if grep -q "OWNCLOUD_CODE" $CONFIGURATION_FILE; then
  792. OWNCLOUD_CODE=$(grep "OWNCLOUD_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  793. fi
  794. if grep -q "WIKI_DOMAIN_NAME" $CONFIGURATION_FILE; then
  795. WIKI_DOMAIN_NAME=$(grep "WIKI_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  796. fi
  797. if grep -q "WIKI_CODE" $CONFIGURATION_FILE; then
  798. WIKI_CODE=$(grep "WIKI_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  799. fi
  800. if grep -q "FULLBLOG_DOMAIN_NAME" $CONFIGURATION_FILE; then
  801. FULLBLOG_DOMAIN_NAME=$(grep "FULLBLOG_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  802. fi
  803. if grep -q "FULLBLOG_CODE" $CONFIGURATION_FILE; then
  804. FULLBLOG_CODE=$(grep "FULLBLOG_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  805. fi
  806. if grep -q "MY_BLOG_TITLE" $CONFIGURATION_FILE; then
  807. MY_BLOG_TITLE=$(grep "MY_BLOG_TITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  808. fi
  809. if grep -q "MY_BLOG_SUBTITLE" $CONFIGURATION_FILE; then
  810. MY_BLOG_SUBTITLE=$(grep "MY_BLOG_SUBTITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  811. fi
  812. if grep -q "GPG_ENCRYPT_STORED_EMAIL" $CONFIGURATION_FILE; then
  813. GPG_ENCRYPT_STORED_EMAIL=$(grep "GPG_ENCRYPT_STORED_EMAIL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  814. fi
  815. if grep -q "MY_GPG_PUBLIC_KEY" $CONFIGURATION_FILE; then
  816. MY_GPG_PUBLIC_KEY=$(grep "MY_GPG_PUBLIC_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  817. fi
  818. if grep -q "MY_GPG_PRIVATE_KEY" $CONFIGURATION_FILE; then
  819. MY_GPG_PRIVATE_KEY=$(grep "MY_GPG_PRIVATE_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  820. fi
  821. if grep -q "MY_GPG_PUBLIC_KEY_ID" $CONFIGURATION_FILE; then
  822. MY_GPG_PUBLIC_KEY_ID=$(grep "MY_GPG_PUBLIC_KEY_ID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  823. fi
  824. if grep -q "USB_DRIVE" $CONFIGURATION_FILE; then
  825. USB_DRIVE=$(grep "USB_DRIVE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  826. fi
  827. if grep -q "MAX_PHP_MEMORY" $CONFIGURATION_FILE; then
  828. MAX_PHP_MEMORY=$(grep "MAX_PHP_MEMORY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  829. fi
  830. if grep -q "TLS_TIME_SOURCE1" $CONFIGURATION_FILE; then
  831. TLS_TIME_SOURCE1=$(grep "TLS_TIME_SOURCE1" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  832. fi
  833. if grep -q "TLS_TIME_SOURCE2" $CONFIGURATION_FILE; then
  834. TLS_TIME_SOURCE2=$(grep "TLS_TIME_SOURCE2" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  835. fi
  836. fi
  837. }
  838. # check an individual domain name
  839. function test_domain_name {
  840. if [ $1 ]; then
  841. TEST_DOMAIN_NAME=$1
  842. validate_domain_name
  843. if [[ $TEST_DOMAIN_NAME != $1 ]]; then
  844. echo $TEST_DOMAIN_NAME
  845. exit 8528
  846. fi
  847. fi
  848. }
  849. # check that domain names are sensible
  850. function check_domains {
  851. if [ $WIKI_DOMAIN_NAME ]; then
  852. test_domain_name "$WIKI_DOMAIN_NAME"
  853. if [[ "$WIKI_DOMAIN_NAME" == "$OWNCLOUD_DOMAIN_NAME" ]]; then
  854. echo 'Wiki domain name is the same as Owncloud domain name. They must be different'
  855. exit 73863
  856. fi
  857. if [[ "$WIKI_DOMAIN_NAME" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  858. echo 'Wiki domain name is the same as blog domain name. They must be different'
  859. exit 97326
  860. fi
  861. if [[ "$WIKI_DOMAIN_NAME" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  862. echo 'Wiki domain name is the same as microblog domain name. They must be different'
  863. exit 36827
  864. fi
  865. if [[ "$WIKI_DOMAIN_NAME" == "$REDMATRIX_DOMAIN_NAME" ]]; then
  866. echo 'Wiki domain name is the same as redmatrix domain name. They must be different'
  867. exit 93637
  868. fi
  869. fi
  870. if [ $OWNCLOUD_DOMAIN_NAME ]; then
  871. test_domain_name "$OWNCLOUD_DOMAIN_NAME"
  872. if [[ "$OWNCLOUD_DOMAIN_NAME" == "$WIKI_DOMAIN_NAME" ]]; then
  873. echo 'Owncloud domain name is the same as wiki domain name. They must be different'
  874. exit 37994
  875. fi
  876. if [[ "$OWNCLOUD_DOMAIN_NAME" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  877. echo 'Owncloud domain name is the same as blog domain name. They must be different'
  878. exit 37936
  879. fi
  880. if [[ "$OWNCLOUD_DOMAIN_NAME" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  881. echo 'Owncloud domain name is the same as microblog domain name. They must be different'
  882. exit 36896
  883. fi
  884. if [[ "$OWNCLOUD_DOMAIN_NAME" == "$REDMATRIX_DOMAIN_NAME" ]]; then
  885. echo 'Owncloud domain name is the same as redmatrix domain name. They must be different'
  886. exit 79362
  887. fi
  888. fi
  889. if [ $FULLBLOG_DOMAIN_NAME ]; then
  890. test_domain_name "$FULLBLOG_DOMAIN_NAME"
  891. if [[ "$FULLBLOG_DOMAIN_NAME" == "$WIKI_DOMAIN_NAME" ]]; then
  892. echo 'Blog domain name is the same as wiki domain name. They must be different'
  893. exit 62348
  894. fi
  895. if [[ "$FULLBLOG_DOMAIN_NAME" == "$OWNCLOUD_DOMAIN_NAME" ]]; then
  896. echo 'Blog domain name is the same as Owncloud domain name. They must be different'
  897. exit 84682
  898. fi
  899. if [[ "$FULLBLOG_DOMAIN_NAME" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  900. echo 'Blog domain name is the same as microblog domain name. They must be different'
  901. exit 38236
  902. fi
  903. if [[ "$FULLBLOG_DOMAIN_NAME" == "$REDMATRIX_DOMAIN_NAME" ]]; then
  904. echo 'Blog domain name is the same as redmatrix domain name. They must be different'
  905. exit 36813
  906. fi
  907. fi
  908. if [ $MICROBLOG_DOMAIN_NAME ]; then
  909. test_domain_name "$MICROBLOG_DOMAIN_NAME"
  910. if [[ "$MICROBLOG_DOMAIN_NAME" == "$WIKI_DOMAIN_NAME" ]]; then
  911. echo 'Microblog domain name is the same as wiki domain name. They must be different'
  912. exit 73924
  913. fi
  914. if [[ "$MICROBLOG_DOMAIN_NAME" == "$OWNCLOUD_DOMAIN_NAME" ]]; then
  915. echo 'Microblog domain name is the same as Owncloud domain name. They must be different'
  916. exit 73683
  917. fi
  918. if [[ "$MICROBLOG_DOMAIN_NAME" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  919. echo 'Microblog domain name is the same as blog domain name. They must be different'
  920. exit 26832
  921. fi
  922. if [[ "$MICROBLOG_DOMAIN_NAME" == "$REDMATRIX_DOMAIN_NAME" ]]; then
  923. echo 'Microblog domain name is the same as redmatrix domain name. They must be different'
  924. exit 36373
  925. fi
  926. fi
  927. if [ $REDMATRIX_DOMAIN_NAME ]; then
  928. test_domain_name "$REDMATRIX_DOMAIN_NAME"
  929. if [[ "$REDMATRIX_DOMAIN_NAME" == "$WIKI_DOMAIN_NAME" ]]; then
  930. echo 'RedMatrix domain name is the same as wiki domain name. They must be different'
  931. exit 83682
  932. fi
  933. if [[ "$REDMATRIX_DOMAIN_NAME" == "$OWNCLOUD_DOMAIN_NAME" ]]; then
  934. echo 'RedMatrix domain name is the same as Owncloud domain name. They must be different'
  935. exit 65192
  936. fi
  937. if [[ "$REDMATRIX_DOMAIN_NAME" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  938. echo 'RedMatrix domain name is the same as blog domain name. They must be different'
  939. exit 74817
  940. fi
  941. if [[ "$REDMATRIX_DOMAIN_NAME" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  942. echo 'RedMatrix domain name is the same as microblog domain name. They must be different'
  943. exit 83683
  944. fi
  945. fi
  946. }
  947. # Checks whether certificates were generated for the given hostname
  948. function check_certificates {
  949. if [ ! $1 ]; then
  950. return
  951. fi
  952. if [ ! -f /etc/ssl/private/$1.key ]; then
  953. echo "Private certificate for $CHECK_HOSTNAME was not created"
  954. exit 63959
  955. fi
  956. if [ ! -f /etc/ssl/certs/$1.crt ]; then
  957. echo "Public certificate for $CHECK_HOSTNAME was not created"
  958. exit 7679
  959. fi
  960. if [ ! -f /etc/ssl/certs/$1.dhparam ]; then
  961. echo "Diffie–Hellman parameters for $CHECK_HOSTNAME were not created"
  962. exit 5989
  963. fi
  964. }
  965. function install_not_on_BBB {
  966. if grep -Fxq "install_not_on_BBB" $COMPLETION_FILE; then
  967. return
  968. fi
  969. if [[ INSTALLING_ON_BBB == "yes" ]]; then
  970. return
  971. fi
  972. echo '# This file describes the network interfaces available on your system' > /etc/network/interfaces
  973. echo '# and how to activate them. For more information, see interfaces(5).' >> /etc/network/interfaces
  974. echo '' >> /etc/network/interfaces
  975. echo '# The loopback network interface' >> /etc/network/interfaces
  976. echo 'auto lo' >> /etc/network/interfaces
  977. echo 'iface lo inet loopback' >> /etc/network/interfaces
  978. echo '' >> /etc/network/interfaces
  979. echo '# The primary network interface' >> /etc/network/interfaces
  980. echo 'auto eth0' >> /etc/network/interfaces
  981. echo 'iface eth0 inet static' >> /etc/network/interfaces
  982. echo " address $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/network/interfaces
  983. echo ' netmask 255.255.255.0' >> /etc/network/interfaces
  984. echo " gateway $ROUTER_IP_ADDRESS" >> /etc/network/interfaces
  985. echo " dns-nameservers $NAMESERVER1 $NAMESERVER2" >> /etc/network/interfaces
  986. echo '# Example to keep MAC address between reboots' >> /etc/network/interfaces
  987. echo '#hwaddress ether DE:AD:BE:EF:CA:FE' >> /etc/network/interfaces
  988. echo '' >> /etc/network/interfaces
  989. echo '# The secondary network interface' >> /etc/network/interfaces
  990. echo '#auto eth1' >> /etc/network/interfaces
  991. echo '#iface eth1 inet dhcp' >> /etc/network/interfaces
  992. echo '' >> /etc/network/interfaces
  993. echo '# WiFi Example' >> /etc/network/interfaces
  994. echo '#auto wlan0' >> /etc/network/interfaces
  995. echo '#iface wlan0 inet dhcp' >> /etc/network/interfaces
  996. echo '# wpa-ssid "essid"' >> /etc/network/interfaces
  997. echo '# wpa-psk "password"' >> /etc/network/interfaces
  998. echo '' >> /etc/network/interfaces
  999. echo '# Ethernet/RNDIS gadget (g_ether)' >> /etc/network/interfaces
  1000. echo '# ... or on host side, usbnet and random hwaddr' >> /etc/network/interfaces
  1001. echo '# Note on some boards, usb0 is automaticly setup with an init script' >> /etc/network/interfaces
  1002. echo '#iface usb0 inet static' >> /etc/network/interfaces
  1003. echo '# address 192.168.7.2' >> /etc/network/interfaces
  1004. echo '# netmask 255.255.255.0' >> /etc/network/interfaces
  1005. echo '# network 192.168.7.0' >> /etc/network/interfaces
  1006. echo '# gateway 192.168.7.1' >> /etc/network/interfaces
  1007. echo 'install_not_on_BBB' >> $COMPLETION_FILE
  1008. }
  1009. function randomize_cron {
  1010. # The predictable default timing of Debian cron jobs might
  1011. # be exploitable knowledge. Avoid too much predictability
  1012. # by randomizing the times when cron jobs run
  1013. if grep -Fxq "randomize_cron" $COMPLETION_FILE; then
  1014. return
  1015. fi
  1016. # randomize the day on which the weekly cron job runs
  1017. randdow=$(($RANDOM%6+1))
  1018. sed -i "s|\* \* 7|* * $randdow|g" /etc/crontab
  1019. # randomize the time when the weekly cron job runs
  1020. randmin=$(($RANDOM%60))
  1021. randhr=$(($RANDOM%3+1))
  1022. sed -i "s|47 6|$randmin $randhr|g" /etc/crontab
  1023. # randomize the time when the daily cron job runs
  1024. randmin=$(($RANDOM%60))
  1025. randhr=$(($RANDOM%3+4))
  1026. sed -i "s|25 6\t\* \* \*|$randmin $randhr\t* * *|g" /etc/crontab
  1027. # randomize the time when the hourly cron job runs
  1028. randmin=$(($RANDOM%60))
  1029. sed -i "s|17 \*\t|$randmin *\t|g" /etc/crontab
  1030. # randomize monthly cron job time and day
  1031. randmin=$(($RANDOM%60))
  1032. randhr=$(($RANDOM%22+1))
  1033. randdom=$(($RANDOM%27+1))
  1034. sed -i "s|52 6\t|$randmin $randhr\t|g" /etc/crontab
  1035. sed -i "s|\t1 \* \*|\t$randdom * *|g" /etc/crontab
  1036. service cron restart
  1037. echo 'randomize_cron' >> $COMPLETION_FILE
  1038. }
  1039. function get_cjdns_public_key {
  1040. if [ -f /home/$MY_USERNAME/README ]; then
  1041. if grep -q "cjdns public key" /home/$MY_USERNAME/README; then
  1042. if [ ! $CJDNS_PUBLIC_KEY ]; then
  1043. CJDNS_PUBLIC_KEY=$(cat /home/$MY_USERNAME/README | grep "cjdns public key" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1044. fi
  1045. fi
  1046. fi
  1047. }
  1048. function get_cjdns_private_key {
  1049. if [ -f /home/$MY_USERNAME/README ]; then
  1050. if grep -q "cjdns private key" /home/$MY_USERNAME/README; then
  1051. if [ ! $CJDNS_PRIVATE_KEY ]; then
  1052. CJDNS_PRIVATE_KEY=$(cat /home/$MY_USERNAME/README | grep "cjdns private key" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1053. fi
  1054. fi
  1055. fi
  1056. }
  1057. function get_cjdns_ipv6_address {
  1058. if [ -f /home/$MY_USERNAME/README ]; then
  1059. if grep -q "cjdns IPv6 address" /home/$MY_USERNAME/README; then
  1060. if [ ! $CJDNS_IPV6 ]; then
  1061. CJDNS_IPV6=$(cat /home/$MY_USERNAME/README | grep "cjdns IPv6 address" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1062. fi
  1063. fi
  1064. fi
  1065. }
  1066. function get_cjdns_port {
  1067. if [ -f /home/$MY_USERNAME/README ]; then
  1068. if grep -q "cjdns port" /home/$MY_USERNAME/README; then
  1069. if [ ! $CJDNS_PORT ]; then
  1070. CJDNS_PORT=$(cat /home/$MY_USERNAME/README | grep "cjdns port" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1071. fi
  1072. fi
  1073. fi
  1074. }
  1075. function get_cjdns_password {
  1076. if [ -f /home/$MY_USERNAME/README ]; then
  1077. if grep -q "cjdns password" /home/$MY_USERNAME/README; then
  1078. if [ ! $CJDNS_PASSWORD ]; then
  1079. CJDNS_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "cjdns password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1080. fi
  1081. fi
  1082. fi
  1083. }
  1084. function mesh_cjdns {
  1085. if grep -Fxq "mesh_cjdns" $COMPLETION_FILE; then
  1086. return
  1087. fi
  1088. if [[ $ENABLE_CJDNS != "yes" ]]; then
  1089. return
  1090. fi
  1091. apt-get -y install nodejs git build-essential nmap
  1092. # if a README exists then obtain the cjdns parameters
  1093. get_cjdns_ipv6_address
  1094. get_cjdns_public_key
  1095. get_cjdns_private_key
  1096. get_cjdns_port
  1097. get_cjdns_password
  1098. # special compile settings for running ./do on the Beaglebone Black
  1099. if [[ $INSTALLING_ON_BBB == "yes" ]]; then
  1100. CFLAGS="-O2 -march=armv7-a -mtune=cortex-a8 -mfpu=neon -ftree-vectorize -ffast-math -mfloat-abi=hard -marm -Wno-error=maybe-uninitialized"
  1101. export LDFLAGS="$CFLAGS"
  1102. fi
  1103. if [ ! -d /etc/cjdns ]; then
  1104. git clone https://github.com/cjdelisle/cjdns.git /etc/cjdns
  1105. cd /etc/cjdns
  1106. ./do
  1107. if [ ! "$?" = "0" ]; then
  1108. exit 7439
  1109. fi
  1110. # create a configuration
  1111. if [ ! -f /etc/cjdns/cjdroute.conf ]; then
  1112. ./cjdroute --genconf > /etc/cjdns/cjdroute.conf
  1113. if [ ! "$?" = "0" ]; then
  1114. exit 5922
  1115. fi
  1116. fi
  1117. # create a user to run as
  1118. useradd cjdns
  1119. else
  1120. cd /etc/cjdns
  1121. git pull
  1122. ./do
  1123. if [ ! "$?" = "0" ]; then
  1124. exit 9926
  1125. fi
  1126. fi
  1127. # set permissions
  1128. chown -R cjdns:cjdns /etc/cjdns
  1129. chmod 600 /etc/cjdns/cjdroute.conf
  1130. /sbin/ip tuntap add mode tun user cjdns dev cjdroute0
  1131. # insert values into the configuration file
  1132. if [ $CJDNS_PRIVATE_KEY ]; then
  1133. sed -i "s/\"privateKey\":.*/\"privateKey\": \"$CJDNS_PRIVATE_KEY\",/g" /etc/cjdns/cjdroute.conf
  1134. else
  1135. CJDNS_PRIVATE_KEY=$(cat /etc/cjdns/cjdroute.conf | grep '"privateKey"' | awk -F '"' '{print $4}' | sed -n 1p)
  1136. fi
  1137. if [ $CJDNS_PUBLIC_KEY ]; then
  1138. sed -i "s/\"publicKey\":.*/\"publicKey\": \"$CJDNS_PUBLIC_KEY\",/g" /etc/cjdns/cjdroute.conf
  1139. else
  1140. CJDNS_PUBLIC_KEY=$(cat /etc/cjdns/cjdroute.conf | grep '"publicKey"' | awk -F '"' '{print $4}' | sed -n 1p)
  1141. fi
  1142. if [ $CJDNS_IPV6 ]; then
  1143. sed -i "s/\"ipv6\":.*/\"ipv6\": \"$CJDNS_IPV6\",/g" /etc/cjdns/cjdroute.conf
  1144. else
  1145. CJDNS_IPV6=$(cat /etc/cjdns/cjdroute.conf | grep '"ipv6"' | awk -F '"' '{print $4}' | sed -n 1p)
  1146. fi
  1147. if [ $CJDNS_PASSWORD ]; then
  1148. sed -i "0,/{\"password\":.*/s//{\"password\": \"$CJDNS_PASSWORD\"}/g" /etc/cjdns/cjdroute.conf
  1149. else
  1150. CJDNS_PASSWORD=$(cat /etc/cjdns/cjdroute.conf | grep '"password"' | awk -F '"' '{print $4}' | sed -n 1p)
  1151. fi
  1152. if [ $CJDNS_PORT ]; then
  1153. sed -i "s/\"bind\": \"0.0.0.0:.*/\"bind\": \"0.0.0.0:$CJDNS_PORT\",/g" /etc/cjdns/cjdroute.conf
  1154. else
  1155. CJDNS_PORT=$(cat /etc/cjdns/cjdroute.conf | grep '"bind": "0.0.0.0:' | awk -F '"' '{print $4}' | awk -F ':' '{print $2}' | sed -n 1p)
  1156. fi
  1157. # endure that ipv6 is enabled and can route
  1158. sed -i 's/net.ipv6.conf.all.disable_ipv6.*/net.ipv6.conf.all.disable_ipv6 = 0/g' /etc/sysctl.conf
  1159. #sed -i "s/net.ipv6.conf.all.accept_redirects.*/net.ipv6.conf.all.accept_redirects = 1/g" /etc/sysctl.conf
  1160. #sed -i "s/net.ipv6.conf.all.accept_source_route.*/net.ipv6.conf.all.accept_source_route = 1/g" /etc/sysctl.conf
  1161. sed -i "s/net.ipv6.conf.all.forwarding.*/net.ipv6.conf.all.forwarding=1/g" /etc/sysctl.conf
  1162. echo 1 > /proc/sys/net/ipv6/conf/all/forwarding
  1163. echo '#!/bin/sh -e' > /etc/init.d/cjdns
  1164. echo '### BEGIN INIT INFO' >> /etc/init.d/cjdns
  1165. echo '# hyperboria.sh - An init script (/etc/init.d/) for cjdns' >> /etc/init.d/cjdns
  1166. echo '# Provides: cjdroute' >> /etc/init.d/cjdns
  1167. echo '# Required-Start: $remote_fs $network' >> /etc/init.d/cjdns
  1168. echo '# Required-Stop: $remote_fs $network' >> /etc/init.d/cjdns
  1169. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/cjdns
  1170. echo '# Default-Stop: 0 1 6' >> /etc/init.d/cjdns
  1171. echo '# Short-Description: Cjdns router' >> /etc/init.d/cjdns
  1172. echo '# Description: A routing engine designed for security, scalability, speed and ease of use.' >> /etc/init.d/cjdns
  1173. echo '# cjdns git repo: https://github.com/cjdelisle/cjdns/' >> /etc/init.d/cjdns
  1174. echo '### END INIT INFO' >> /etc/init.d/cjdns
  1175. echo '' >> /etc/init.d/cjdns
  1176. echo 'PROG="cjdroute"' >> /etc/init.d/cjdns
  1177. echo 'GIT_PATH="/etc/cjdns"' >> /etc/init.d/cjdns
  1178. echo 'PROG_PATH="/etc/cjdns"' >> /etc/init.d/cjdns
  1179. echo 'CJDNS_CONFIG="cjdroute.conf"' >> /etc/init.d/cjdns
  1180. echo 'CJDNS_USER="cjdns"' >> /etc/init.d/cjdns
  1181. echo "CJDNS_IP='$CJDNS_IPV6'" >> /etc/init.d/cjdns
  1182. echo '' >> /etc/init.d/cjdns
  1183. echo 'start() {' >> /etc/init.d/cjdns
  1184. echo ' # Start it up with the user cjdns' >> /etc/init.d/cjdns
  1185. echo ' if [ $(pgrep cjdroute | wc -l) != 0 ];' >> /etc/init.d/cjdns
  1186. echo ' then' >> /etc/init.d/cjdns
  1187. echo ' echo "cjdroute is already running. Doing nothing..."' >> /etc/init.d/cjdns
  1188. echo ' else' >> /etc/init.d/cjdns
  1189. echo ' echo " * Starting cjdroute"' >> /etc/init.d/cjdns
  1190. echo ' su -c "$PROG_PATH/$PROG < $PROG_PATH/$CJDNS_CONFIG" - $CJDNS_USER' >> /etc/init.d/cjdns
  1191. echo ' /sbin/ip addr add $CJDNS_IP/8 dev tun0' >> /etc/init.d/cjdns
  1192. echo ' /sbin/ip link set mtu 1312 dev tun0' >> /etc/init.d/cjdns
  1193. echo ' /sbin/ip link set tun0 up' >> /etc/init.d/cjdns
  1194. echo ' /sbin/ip tuntap add mode tun user cjdns dev tun0' >> /etc/init.d/cjdns
  1195. echo ' fi' >> /etc/init.d/cjdns
  1196. echo '}' >> /etc/init.d/cjdns
  1197. echo '' >> /etc/init.d/cjdns
  1198. echo 'stop() {' >> /etc/init.d/cjdns
  1199. echo '' >> /etc/init.d/cjdns
  1200. echo ' if [ $(pgrep cjdroute | wc -l) != 2 ];' >> /etc/init.d/cjdns
  1201. echo ' then' >> /etc/init.d/cjdns
  1202. echo ' echo "cjdns isnt running."' >> /etc/init.d/cjdns
  1203. echo ' else' >> /etc/init.d/cjdns
  1204. echo ' echo "Killing cjdroute"' >> /etc/init.d/cjdns
  1205. echo ' killall cjdroute' >> /etc/init.d/cjdns
  1206. echo ' fi' >> /etc/init.d/cjdns
  1207. echo '}' >> /etc/init.d/cjdns
  1208. echo '' >> /etc/init.d/cjdns
  1209. echo 'status() {' >> /etc/init.d/cjdns
  1210. echo ' if [ $(pgrep cjdroute | wc -l) != 0 ];' >> /etc/init.d/cjdns
  1211. echo ' then' >> /etc/init.d/cjdns
  1212. echo ' echo "Cjdns is running"' >> /etc/init.d/cjdns
  1213. echo ' else' >> /etc/init.d/cjdns
  1214. echo ' echo "Cjdns is not running"' >> /etc/init.d/cjdns
  1215. echo ' fi' >> /etc/init.d/cjdns
  1216. echo '}' >> /etc/init.d/cjdns
  1217. echo '' >> /etc/init.d/cjdns
  1218. echo ' update() {' >> /etc/init.d/cjdns
  1219. echo ' cd $GIT_PATH' >> /etc/init.d/cjdns
  1220. echo ' echo "Updating..."' >> /etc/init.d/cjdns
  1221. echo ' git pull' >> /etc/init.d/cjdns
  1222. echo ' ./do' >> /etc/init.d/cjdns
  1223. echo '}' >> /etc/init.d/cjdns
  1224. echo '' >> /etc/init.d/cjdns
  1225. echo '## Check to see if we are running as root first.' >> /etc/init.d/cjdns
  1226. echo 'if [ "$(id -u)" != "0" ]; then' >> /etc/init.d/cjdns
  1227. echo ' echo "This script must be run as root" 1>&2' >> /etc/init.d/cjdns
  1228. echo ' exit 1' >> /etc/init.d/cjdns
  1229. echo 'fi' >> /etc/init.d/cjdns
  1230. echo '' >> /etc/init.d/cjdns
  1231. echo 'case $1 in' >> /etc/init.d/cjdns
  1232. echo ' start)' >> /etc/init.d/cjdns
  1233. echo ' start' >> /etc/init.d/cjdns
  1234. echo ' exit 0' >> /etc/init.d/cjdns
  1235. echo ' ;;' >> /etc/init.d/cjdns
  1236. echo ' stop)' >> /etc/init.d/cjdns
  1237. echo ' stop' >> /etc/init.d/cjdns
  1238. echo ' exit 0' >> /etc/init.d/cjdns
  1239. echo ' ;;' >> /etc/init.d/cjdns
  1240. echo ' reload|restart|force-reload)' >> /etc/init.d/cjdns
  1241. echo ' stop' >> /etc/init.d/cjdns
  1242. echo ' sleep 1' >> /etc/init.d/cjdns
  1243. echo ' start' >> /etc/init.d/cjdns
  1244. echo ' exit 0' >> /etc/init.d/cjdns
  1245. echo ' ;;' >> /etc/init.d/cjdns
  1246. echo ' status)' >> /etc/init.d/cjdns
  1247. echo ' status' >> /etc/init.d/cjdns
  1248. echo ' exit 0' >> /etc/init.d/cjdns
  1249. echo ' ;;' >> /etc/init.d/cjdns
  1250. echo ' update|upgrade)' >> /etc/init.d/cjdns
  1251. echo ' update' >> /etc/init.d/cjdns
  1252. echo ' stop' >> /etc/init.d/cjdns
  1253. echo ' sleep 2' >> /etc/init.d/cjdns
  1254. echo ' start' >> /etc/init.d/cjdns
  1255. echo ' exit 0' >> /etc/init.d/cjdns
  1256. echo ' ;;' >> /etc/init.d/cjdns
  1257. echo ' **)' >> /etc/init.d/cjdns
  1258. echo ' echo "Usage: $0 (start|stop|restart|status|update)" 1>&2' >> /etc/init.d/cjdns
  1259. echo ' exit 1' >> /etc/init.d/cjdns
  1260. echo ' ;;' >> /etc/init.d/cjdns
  1261. echo 'esac' >> /etc/init.d/cjdns
  1262. chmod +x /etc/init.d/cjdns
  1263. update-rc.d cjdns defaults
  1264. service cjdns start
  1265. if [ ! "$?" = "0" ]; then
  1266. systemctl status cjdns.service
  1267. exit 8260
  1268. fi
  1269. apt-get -y install radvd
  1270. echo 'interface eth0' > /etc/radvd.conf
  1271. echo '{' >> /etc/radvd.conf
  1272. echo ' AdvSendAdvert on;' >> /etc/radvd.conf
  1273. echo ' prefix fdfc::1/64' >> /etc/radvd.conf
  1274. echo ' {' >> /etc/radvd.conf
  1275. echo ' AdvRouterAddr on;' >> /etc/radvd.conf
  1276. echo ' };' >> /etc/radvd.conf
  1277. echo '};' >> /etc/radvd.conf
  1278. service radvd restart
  1279. if [ ! "$?" = "0" ]; then
  1280. systemctl status radvd.service
  1281. exit 4395
  1282. fi
  1283. if ! grep -q "# Mesh network cjdns" /etc/network/interfaces; then
  1284. echo '' >> /etc/network/interfaces
  1285. echo '# Mesh Networking (cjdns)' >> /etc/network/interfaces
  1286. echo 'iface eth0 inet6 static' >> /etc/network/interfaces
  1287. echo ' pre-up modprobe ipv6' >> /etc/network/interfaces
  1288. echo ' address fdfc:0000:0000:0000:0000:0000:0000:0001' >> /etc/network/interfaces
  1289. echo ' netmask 64' >> /etc/network/interfaces
  1290. service networking restart
  1291. if [ ! "$?" = "0" ]; then
  1292. systemctl status networking.service
  1293. exit 6949
  1294. fi
  1295. fi
  1296. ip6tables -A INPUT -i eth0 -p udp --dport $CJDNS_PORT -j ACCEPT
  1297. ip6tables -A INPUT -i eth0 -p tcp --dport $CJDNS_PORT -j ACCEPT
  1298. save_firewall_settings
  1299. if ! grep -q "Mesh Networking (cjdns)" /home/$MY_USERNAME/README; then
  1300. CURRENT_IP_ADDRESS=$(ip addr show | grep "inet " | sed -n 2p | awk -F ' ' '{print $2}' | awk -F '/' '{print $1}')
  1301. echo '' >> /home/$MY_USERNAME/README
  1302. echo '' >> /home/$MY_USERNAME/README
  1303. echo 'Mesh Networking (cjdns)' >> /home/$MY_USERNAME/README
  1304. echo '=======================' >> /home/$MY_USERNAME/README
  1305. echo "cjdns IPv6 address: $CJDNS_IPV6" >> /home/$MY_USERNAME/README
  1306. echo "cjdns public key: $CJDNS_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  1307. echo "cjdns private key: $CJDNS_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  1308. echo "cjdns password: $CJDNS_PASSWORD" >> /home/$MY_USERNAME/README
  1309. echo "cjdns port: $CJDNS_PORT" >> /home/$MY_USERNAME/README
  1310. echo '' >> /home/$MY_USERNAME/README
  1311. echo "Forward port $CJDNS_PORT from your internet router to the Freedombone" >> /home/$MY_USERNAME/README
  1312. echo '' >> /home/$MY_USERNAME/README
  1313. echo 'Below is an example of your connection credentials' >> /home/$MY_USERNAME/README
  1314. echo 'that you can give to other people so they can connect' >> /home/$MY_USERNAME/README
  1315. echo 'to you using your default password' >> /home/$MY_USERNAME/README
  1316. echo 'Adding a unique password for each user is advisable' >> /home/$MY_USERNAME/README
  1317. echo 'so that leaks can be isolated.' >> /home/$MY_USERNAME/README
  1318. echo '' >> /home/$MY_USERNAME/README
  1319. echo "\"$CURRENT_IP_ADDRESS:$CJDNS_PORT\":{\"password\":\"$CJDNS_PASSWORD\",\"publicKey\":\"$CJDNS_PUBLIC_KEY\"}" >> /home/$MY_USERNAME/README
  1320. echo '' >> /home/$MY_USERNAME/README
  1321. echo 'More is not better. 3-5 cjdns peers is good. 30 peers is bad.' >> /home/$MY_USERNAME/README
  1322. echo '' >> /home/$MY_USERNAME/README
  1323. echo 'NEVER USE A PUBLIC PEER. These degrade the network and make it centralized.' >> /home/$MY_USERNAME/README
  1324. echo 'Each node can handle many peers, but no node can handle the entire internet.' >> /home/$MY_USERNAME/README
  1325. echo 'As this network grows any public peer will simply become saturated and' >> /home/$MY_USERNAME/README
  1326. echo 'useless causing issues for the entire network.' >> /home/$MY_USERNAME/README
  1327. echo 'Please report anyone offering you a public peer as they are promoting shared' >> /home/$MY_USERNAME/README
  1328. echo 'passwords which could lead to people pretending to be you. A peering pass' >> /home/$MY_USERNAME/README
  1329. echo 'should not contain someone elses nickname or info but should contain yours' >> /home/$MY_USERNAME/README
  1330. echo 'to ensure it is not shared. It also helps when editing the conf to know who' >> /home/$MY_USERNAME/README
  1331. echo 'each password is for.' >> /home/$MY_USERNAME/README
  1332. echo '' >> /home/$MY_USERNAME/README
  1333. echo 'Possible cjdns destinations of interest:' >> /home/$MY_USERNAME/README
  1334. echo ' http://transitiontech.ca/faq' >> /home/$MY_USERNAME/README
  1335. echo ' http://cjdns.ca/hypeirc.txt' >> /home/$MY_USERNAME/README
  1336. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  1337. fi
  1338. echo 'mesh_cjdns' >> $COMPLETION_FILE
  1339. }
  1340. function mesh_cjdns_tools {
  1341. if grep -Fxq "mesh_cjdns_tools" $COMPLETION_FILE; then
  1342. return
  1343. fi
  1344. if [[ $ENABLE_CJDNS != "yes" ]]; then
  1345. return
  1346. fi
  1347. if [ ! -d /etc/cjdns ]; then
  1348. mesh_cjdns
  1349. fi
  1350. apt-get -y install golang mercurial
  1351. if [ ! -f ~/.bashrc ]; then
  1352. touch ~/.bashrc
  1353. fi
  1354. if ! grep -q "export GOPATH=" ~/.bashrc; then
  1355. echo 'export GOPATH=$HOME/projects/go' >> ~/.bashrc
  1356. fi
  1357. if ! grep -q "export PATH=$PATH:$HOME/projects/go/bin" ~/.bashrc; then
  1358. echo 'export PATH=$PATH:$HOME/projects/go/bin' >> ~/.bashrc
  1359. fi
  1360. . ~/.bashrc
  1361. export GOPATH=$HOME/projects/go
  1362. export PATH=$PATH:$HOME/projects/go/bin
  1363. go get github.com/inhies/cjdcmd
  1364. if [ ! -f $HOME/projects/go/bin/cjdcmd ]; then
  1365. echo 'cjdcmd was not compiled. Check your golang installation'
  1366. exit 7439
  1367. fi
  1368. cp $HOME/projects/go/bin/cjdcmd /usr/bin
  1369. # initialise from the cjdns config
  1370. /usr/bin/cjdcmd cjdnsadmin -file /etc/cjdns/cjdroute.conf
  1371. echo 'mesh_cjdns_tools' >> $COMPLETION_FILE
  1372. }
  1373. function mesh_batman {
  1374. # https://sudoroom.org/wiki/Mesh/Relay_setup
  1375. # also see http://www.netlore.co.uk/airmesh/
  1376. if grep -Fxq "mesh_batman" $COMPLETION_FILE; then
  1377. return
  1378. fi
  1379. if [[ $ENABLE_BATMAN != "yes" ]]; then
  1380. return
  1381. fi
  1382. modprobe batman-adv
  1383. [ $? -ne 0 ] && echo "B.A.T.M.A.N module not available" && exit 76482
  1384. if ! grep -q "batman_adv" /etc/modules; then
  1385. echo 'batman_adv' >> /etc/modules
  1386. fi
  1387. modprobe l2tp_core
  1388. [ $? -ne 0 ] && echo "l2tp_core module not available" && exit 7358
  1389. if ! grep -q "l2tp_core" /etc/modules; then
  1390. echo 'l2tp_core' >> /etc/modules
  1391. fi
  1392. modprobe l2tp_eth
  1393. [ $? -ne 0 ] && echo "l2tp_eth module not available" && exit 8735
  1394. if ! grep -q "l2tp_eth" /etc/modules; then
  1395. echo 'l2tp_eth' >> /etc/modules
  1396. fi
  1397. modprobe l2tp_netlink
  1398. [ $? -ne 0 ] && echo "l2tp_netlink module not available" && exit 87367
  1399. if ! grep -q "l2tp_netlink" /etc/modules; then
  1400. echo 'l2tp_netlink' >> /etc/modules
  1401. fi
  1402. if ! grep -q "Mesh Networking (B.A.T.M.A.N)" /etc/network/interfaces; then
  1403. echo '' >> /etc/network/interfaces
  1404. echo '# Mesh Networking (B.A.T.M.A.N)' >> /etc/network/interfaces
  1405. echo 'iface bat0 inet static' >> /etc/network/interfaces
  1406. echo " address $BATMAN_IP" >> /etc/network/interfaces
  1407. echo ' netmask 255.0.0.0' >> /etc/network/interfaces
  1408. fi
  1409. apt-get -y install iproute bridge-utils libnetfilter-conntrack3 python-dev libevent-dev ebtables python-pip git
  1410. cd $BUILD_PATH
  1411. git clone https://github.com/wlanslovenija/tunneldigger.git /opt/tunneldigger
  1412. chown root:root -R /opt/tunneldigger
  1413. cd /opt/tunneldigger/broker
  1414. pip install -r requirements.txt
  1415. EXTERNAL_IP=$(TODO)
  1416. sed -i 's|address=.*|address=$EXTERNAL_IP|g' l2tp_broker.cfg
  1417. sed -i 's|interface=.*|interface=eth0|g' l2tp_broker.cfg
  1418. sed -i 's|session.up=.*|session.up=/opt/tunneldigger/broker/scripts/up_hook.sh|g' l2tp_broker.cfg
  1419. cd /opt/tunneldigger/broker/scripts
  1420. echo '#!/bin/sh' > /opt/tunneldigger/broker/scripts/up_hook.sh
  1421. echo 'INTERFACE="$3"' >> /opt/tunneldigger/broker/scripts/up_hook.sh
  1422. echo 'ifconfig $INTERFACE up' >> /opt/tunneldigger/broker/scripts/up_hook.sh
  1423. echo 'batctl if add $INTERFACE' >> /opt/tunneldigger/broker/scripts/up_hook.sh
  1424. echo 'if [ `cat /sys/class/net/bat0/operstate` != "up" ]; then' >> /opt/tunneldigger/broker/scripts/up_hook.sh
  1425. echo " ifconfig bat0 $BATMAN_IP netmask 255.0.0.0 up" >> /opt/tunneldigger/broker/scripts/up_hook.sh
  1426. echo 'fi' >> /opt/tunneldigger/broker/scripts/up_hook.sh
  1427. chmod 755 up_hook.sh
  1428. # TODO make a systemd service to run ./l2tp_broker.py l2tp_broker.cfg
  1429. echo 'mesh_batman' >> $COMPLETION_FILE
  1430. }
  1431. function remove_instructions_from_motd {
  1432. sed -i '/## /d' /etc/motd
  1433. }
  1434. function check_hwrng {
  1435. if [[ $HWRNG_TYPE == "beaglebone" ]]; then
  1436. # If hardware random number generation was enabled then make sure that the device exists.
  1437. # if /dev/hwrng is not found then any subsequent cryptographic key generation would
  1438. # suffer from low entropy and might be insecure
  1439. if [ ! -e /dev/hwrng ]; then
  1440. ls /dev/hw*
  1441. echo 'The hardware random number generator is enabled but could not be detected on'
  1442. echo '/dev/hwrng. There may be a problem with the installation or the Beaglebone hardware.'
  1443. exit 75
  1444. fi
  1445. fi
  1446. # If a OneRNG device was installed then verify its firmware
  1447. check_onerng_verification
  1448. }
  1449. function get_mariadb_password {
  1450. if [ -f /home/$MY_USERNAME/README ]; then
  1451. if grep -q "MariaDB password" /home/$MY_USERNAME/README; then
  1452. if [ -f $DATABASE_PASSWORD_FILE ]; then
  1453. MARIADB_PASSWORD=$(cat $DATABASE_PASSWORD_FILE)
  1454. else
  1455. MARIADB_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1456. echo "$MARIADB_PASSWORD" > $DATABASE_PASSWORD_FILE
  1457. chmod 600 $DATABASE_PASSWORD_FILE
  1458. fi
  1459. fi
  1460. fi
  1461. }
  1462. function get_mariadb_gnusocial_admin_password {
  1463. if [ -f /home/$MY_USERNAME/README ]; then
  1464. if grep -q "MariaDB gnusocial admin password" /home/$MY_USERNAME/README; then
  1465. MICROBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB gnusocial admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1466. fi
  1467. fi
  1468. }
  1469. function get_mariadb_git_admin_password {
  1470. if [ -f /home/$MY_USERNAME/README ]; then
  1471. if grep -q "Gogs admin user password" /home/$MY_USERNAME/README; then
  1472. GIT_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Gogs admin user password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1473. fi
  1474. fi
  1475. }
  1476. function get_mariadb_redmatrix_admin_password {
  1477. if [ -f /home/$MY_USERNAME/README ]; then
  1478. if grep -q "MariaDB Red Matrix admin password" /home/$MY_USERNAME/README; then
  1479. REDMATRIX_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB Red Matrix admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1480. fi
  1481. fi
  1482. }
  1483. function get_mariadb_owncloud_admin_password {
  1484. if [ -f /home/$MY_USERNAME/README ]; then
  1485. if grep -q "Owncloud database password" /home/$MY_USERNAME/README; then
  1486. OWNCLOUD_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Owncloud database password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1487. fi
  1488. fi
  1489. }
  1490. # For rsyncrypto usage see http://archive09.linux.com/feature/125322
  1491. function create_backup_script {
  1492. if grep -Fxq "create_backup_script" $COMPLETION_FILE; then
  1493. return
  1494. fi
  1495. apt-get -y install rsyncrypto cryptsetup
  1496. get_mariadb_password
  1497. get_mariadb_gnusocial_admin_password
  1498. get_mariadb_redmatrix_admin_password
  1499. get_mariadb_owncloud_admin_password
  1500. get_mariadb_git_admin_password
  1501. echo '#!/bin/bash' > /usr/bin/$BACKUP_SCRIPT_NAME
  1502. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1503. echo "USB_DRIVE=$USB_DRIVE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1504. echo 'if [ $1 ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1505. echo ' USB_DRIVE=/dev/${1}1' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1506. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1507. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1508. echo 'if [ ! -b $USB_DRIVE ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1509. echo ' echo "Please attach a USB drive"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1510. echo ' exit 1' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1511. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1512. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1513. echo "umount -f $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1514. echo "if [ ! -d $USB_MOUNT ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1515. echo " mkdir $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1516. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1517. echo 'if [ -f /dev/mapper/encrypted_usb ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1518. echo ' rm -rf /dev/mapper/encrypted_usb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1519. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1520. echo 'cryptsetup luksClose encrypted_usb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1521. echo 'cryptsetup luksOpen $USB_DRIVE encrypted_usb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1522. echo 'if [ "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1523. echo ' USB_DRIVE=/dev/mapper/encrypted_usb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1524. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1525. echo -n 'mount $USB_DRIVE ' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1526. echo "$USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1527. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1528. echo " echo 'There was a problem mounting the USB drive to $USB_MOUNT'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1529. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1530. echo ' exit 6392' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1531. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1532. echo "if [ ! -d $USB_MOUNT/backup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1533. echo " mkdir $USB_MOUNT/backup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1534. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1535. echo "if [ ! -d $USB_MOUNT/backup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1536. echo " echo 'There was a problem making the directory $USB_MOUNT/backup.'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1537. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1538. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1539. echo ' exit 27' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1540. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1541. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1542. echo "if [ ! -f $BACKUP_CERTIFICATE ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1543. echo ' echo "Creating backup key"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1544. echo ' freedombone-addcert -h backup' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1545. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1546. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1547. echo "if [ ! -f $BACKUP_CERTIFICATE.gpg ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1548. echo ' echo "GPG encrypt the backup key"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1549. echo " gpg -c $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1550. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1551. echo "cp $BACKUP_CERTIFICATE.gpg $USB_MOUNT/backup/key.gpg" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1552. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1553. echo '# MariaDB password' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1554. echo -n 'DATABASE_PASSWORD=$(cat ' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1555. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1556. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1557. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  1558. BACKUP_INCLUDES_DATABASES="yes"
  1559. echo "if [ ! -d $USB_MOUNT/backup/gnusocial ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1560. echo " mkdir -p $USB_MOUNT/backup/gnusocial" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1561. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1562. echo "if [ ! -d $USB_MOUNT/backup/gnusocialdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1563. echo " mkdir -p $USB_MOUNT/backup/gnusocialdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1564. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1565. echo "if [ ! -d /root/tempgnusocialdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1566. echo " mkdir -p /root/tempgnusocialdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1567. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1568. echo 'echo "Obtaining GNU Social database backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1569. echo 'mysqldump --password=$DATABASE_PASSWORD gnusocial > /root/tempgnusocialdata/gnusocial.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1570. echo "if [ ! -s /root/tempgnusocialdata/gnusocial.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1571. echo ' echo "GNU social database could not be saved"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1572. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1573. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1574. echo " fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1575. echo ' shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1576. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1577. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1578. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1579. echo ' exit 296' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1580. echo "fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1581. echo "rsyncrypto -v -r /root/tempgnusocialdata $USB_MOUNT/backup/gnusocialdata $USB_MOUNT/backup/gnusocialdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1582. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1583. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1584. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1585. echo ' shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1586. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1587. echo ' exit 853' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1588. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1589. echo 'shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1590. echo 'rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1591. echo 'echo "Backing up GNU social installation"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1592. 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
  1593. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1594. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1595. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1596. echo ' exit 846' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1597. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1598. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1599. fi
  1600. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  1601. BACKUP_INCLUDES_DATABASES="yes"
  1602. echo "if [ ! -d $USB_MOUNT/backup/redmatrix ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1603. echo " mkdir -p $USB_MOUNT/backup/redmatrix" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1604. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1605. echo "if [ ! -d $USB_MOUNT/backup/redmatrixdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1606. echo " mkdir -p $USB_MOUNT/backup/redmatrixdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1607. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1608. echo "if [ ! -d /root/tempredmatrixdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1609. echo " mkdir -p /root/tempredmatrixdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1610. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1611. echo 'echo "Obtaining Red Matrix database backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1612. echo 'mysqldump --password=$DATABASE_PASSWORD redmatrix > /root/tempredmatrixdata/redmatrix.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1613. echo "if [ ! -s /root/tempredmatrixdata/redmatrix.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1614. echo ' echo "Red Matrix database could not be saved"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1615. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1616. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1617. echo " fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1618. echo ' shred -zu /root/tempredmatrixdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1619. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1620. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1621. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1622. echo ' exit 378' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1623. echo "fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1624. echo "rsyncrypto -v -r /root/tempredmatrixdata $USB_MOUNT/backup/redmatrixdata $USB_MOUNT/backup/redmatrixdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1625. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1626. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1627. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1628. echo ' exit 285' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1629. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1630. echo 'shred -zu /root/tempredmatrixdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1631. echo 'rm -rf /root/tempredmatrixdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1632. echo 'echo "Backing up Red Matrix installation"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1633. 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
  1634. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1635. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1636. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1637. echo ' exit 593' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1638. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1639. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1640. fi
  1641. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  1642. BACKUP_INCLUDES_DATABASES="yes"
  1643. echo "if [ ! -d $USB_MOUNT/backup/owncloud ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1644. echo " mkdir -p $USB_MOUNT/backup/owncloud" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1645. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1646. echo "if [ ! -d $USB_MOUNT/backup/owncloud2 ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1647. echo " mkdir -p $USB_MOUNT/backup/owncloud2" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1648. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1649. echo "if [ ! -d $USB_MOUNT/backup/ownclouddata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1650. echo " mkdir -p $USB_MOUNT/backup/ownclouddata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1651. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1652. echo "if [ ! -d /root/tempownclouddata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1653. echo " mkdir -p /root/tempownclouddata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1654. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1655. echo 'mysqldump --password=$DATABASE_PASSWORD owncloud > /root/tempownclouddata/owncloud.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1656. echo "if [ ! -s /root/tempownclouddata/owncloud.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1657. echo ' echo "Owncloud database could not be saved"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1658. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1659. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1660. echo " fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1661. echo ' shred -zu /root/tempownclouddata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1662. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1663. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1664. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1665. echo ' exit 377' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1666. echo "fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1667. echo "rsyncrypto -v -r /root/tempownclouddata $USB_MOUNT/backup/ownclouddata $USB_MOUNT/backup/ownclouddata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1668. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1669. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1670. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1671. echo ' exit 188' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1672. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1673. echo 'shred -zu /root/tempownclouddata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1674. echo 'rm -rf /root/tempownclouddata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1675. echo 'echo "Obtaining Owncloud data backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1676. echo "rsyncrypto -v -r /var/lib/owncloud $USB_MOUNT/backup/owncloud $USB_MOUNT/backup/owncloud.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1677. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1678. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1679. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1680. echo ' exit 632' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1681. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1682. echo "rsyncrypto -v -r /etc/owncloud $USB_MOUNT/backup/owncloud2 $USB_MOUNT/backup/owncloud2.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1683. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1684. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1685. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1686. echo ' exit 632' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1687. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1688. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1689. fi
  1690. if grep -Fxq "install_gogs" $COMPLETION_FILE; then
  1691. BACKUP_INCLUDES_DATABASES="yes"
  1692. echo "if [ ! -d $USB_MOUNT/backup/gogs ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1693. echo " mkdir -p $USB_MOUNT/backup/gogs" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1694. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1695. echo "if [ ! -d $USB_MOUNT/backup/gogsrepos ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1696. echo " mkdir -p $USB_MOUNT/backup/gogsrepos" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1697. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1698. echo "if [ ! -d $USB_MOUNT/backup/gogsdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1699. echo " mkdir -p $USB_MOUNT/backup/gogsdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1700. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1701. echo "if [ ! -d /root/tempgogsdata ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1702. echo " mkdir -p /root/tempgogsdata" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1703. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1704. echo 'mysqldump --password=$DATABASE_PASSWORD gogs > /root/tempgogsdata/gogs.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1705. echo "if [ ! -s /root/tempgogsdata/gogs.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1706. echo ' echo "Gogs database could not be saved"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1707. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1708. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1709. echo " fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1710. echo ' shred -zu /root/tempgogsdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1711. echo ' rm -rf /root/tempgogsdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1712. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1713. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1714. echo ' exit 377' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1715. echo "fi" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1716. echo "rsyncrypto -v -r /root/tempgogsdata $USB_MOUNT/backup/gogsdata $USB_MOUNT/backup/gogsdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1717. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1718. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1719. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1720. echo ' exit 188' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1721. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1722. echo 'shred -zu /root/tempgogsdata/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1723. echo 'rm -rf /root/tempgogsdata' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1724. echo 'echo "Obtaining Gogs settings backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1725. echo "rsyncrypto -v -r /home/git/go/src/github.com/gogits/gogs/custom $USB_MOUNT/backup/gogs $USB_MOUNT/backup/gogs.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1726. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1727. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1728. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1729. echo ' exit 632' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1730. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1731. echo 'echo "Obtaining Gogs repos backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1732. echo "rsyncrypto -v -r /home/git/gogs-repositories $USB_MOUNT/backup/gogsrepos $USB_MOUNT/backup/gogsrepos.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1733. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1734. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1735. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1736. echo ' exit 6784' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1737. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1738. echo 'echo "Obtaining Gogs authorized_keys backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1739. echo "rsyncrypto -v -r /home/git/.ssh $USB_MOUNT/backup/gogsssh $USB_MOUNT/backup/gogsssh.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1740. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1741. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1742. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1743. echo ' exit 58932' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1744. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1745. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1746. fi
  1747. if grep -Fxq "install_wiki" $COMPLETION_FILE; then
  1748. echo "if [ ! -d $USB_MOUNT/backup/wiki ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1749. echo " mkdir -p $USB_MOUNT/backup/wiki" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1750. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1751. echo "if [ ! -d $USB_MOUNT/backup/wiki2 ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1752. echo " mkdir -p $USB_MOUNT/backup/wiki2" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1753. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1754. echo 'echo "Obtaining wiki data backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1755. echo "rsyncrypto -v -r /var/lib/dokuwiki $USB_MOUNT/backup/wiki $USB_MOUNT/backup/wiki.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1756. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1757. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1758. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1759. echo ' exit 964' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1760. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1761. echo "rsyncrypto -v -r /etc/dokuwiki $USB_MOUNT/backup/wiki2 $USB_MOUNT/backup/wiki2.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1762. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1763. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1764. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1765. echo ' exit 964' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1766. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1767. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1768. fi
  1769. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  1770. echo "if [ ! -d $USB_MOUNT/backup/blog ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1771. echo " mkdir -p $USB_MOUNT/backup/blog" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1772. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1773. echo 'echo "Obtaining blog backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1774. 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
  1775. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1776. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1777. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1778. echo ' exit 854' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1779. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1780. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1781. fi
  1782. if grep -Fxq "mesh_cjdns" $COMPLETION_FILE; then
  1783. echo "if [ ! -d $USB_MOUNT/backup/cjdns ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1784. echo " mkdir -p $USB_MOUNT/backup/cjdns" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1785. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1786. echo 'echo "Obtaining cjdns backup"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1787. echo "rsyncrypto -v -r /etc/cjdns $USB_MOUNT/backup/blog $USB_MOUNT/backup/cjdns.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1788. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1789. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1790. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1791. echo ' exit 7438' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1792. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1793. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1794. fi
  1795. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1796. echo '# Backup certificates' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1797. echo "if [ -d /etc/ssl ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1798. echo ' echo "Backing up certificates"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1799. echo " if [ ! -d $USB_MOUNT/backup/ssl ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1800. echo " mkdir -p $USB_MOUNT/backup/ssl" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1801. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1802. echo " rsyncrypto -v -r /etc/ssl $USB_MOUNT/backup/ssl $USB_MOUNT/backup/ssl.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1803. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1804. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1805. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1806. echo ' exit 343' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1807. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1808. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1809. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1810. echo '# Backup projects' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1811. echo "if [ -d /home/$MY_USERNAME/projects ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1812. echo ' echo "Backing up projects"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1813. echo " if [ ! -d $USB_MOUNT/backup/projects ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1814. echo " mkdir -p $USB_MOUNT/backup/projects" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1815. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1816. echo " rsyncrypto -v -r /home/$MY_USERNAME/projects $USB_MOUNT/backup/projects $USB_MOUNT/backup/projects.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1817. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1818. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1819. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1820. echo ' exit 873' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1821. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1822. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1823. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1824. echo '# Backup personal settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1825. echo "if [ -d /home/$MY_USERNAME/personal ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1826. echo ' echo "Backing up personal settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1827. echo " if [ ! -d $USB_MOUNT/backup/personal ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1828. echo " mkdir -p $USB_MOUNT/backup/personal" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1829. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1830. echo " rsyncrypto -v -r /home/$MY_USERNAME/personal $USB_MOUNT/backup/personal $USB_MOUNT/backup/personal.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1831. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1832. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1833. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1834. echo ' exit 649' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1835. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1836. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1837. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1838. echo '# Backup the public mailing list' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1839. echo "if [ -d $PUBLIC_MAILING_LIST_DIRECTORY ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1840. echo ' echo "Backing up the public mailing list"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1841. echo " if [ ! -d $USB_MOUNT/backup/mailinglist ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1842. echo " mkdir -p $USB_MOUNT/backup/mailinglist" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1843. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1844. echo " rsyncrypto -v -r $PUBLIC_MAILING_LIST_DIRECTORY $USB_MOUNT/backup/mailinglist $USB_MOUNT/backup/mailinglist.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1845. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1846. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1847. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1848. echo ' exit 938' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1849. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1850. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1851. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1852. echo '# Backup xmpp settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1853. echo "if [ -d $XMPP_DIRECTORY ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1854. echo ' echo "Backing up the XMPP settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1855. echo " if [ ! -d $USB_MOUNT/backup/xmpp ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1856. echo " mkdir -p $USB_MOUNT/backup/xmpp" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1857. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1858. echo " rsyncrypto -v -r $XMPP_DIRECTORY $USB_MOUNT/backup/xmpp $USB_MOUNT/backup/xmpp.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1859. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1860. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1861. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1862. echo ' exit 593' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1863. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1864. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1865. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1866. echo '# Backup gpg keys' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1867. echo "if [ -d /home/$MY_USERNAME/.gnupg ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1868. echo ' echo "Backing up gpg keys"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1869. echo " if [ ! -d $USB_MOUNT/backup/gnupg ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1870. echo " mkdir -p $USB_MOUNT/backup/gnupg" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1871. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1872. echo " rsyncrypto -v -r /home/$MY_USERNAME/.gnupg $USB_MOUNT/backup/gnupg $USB_MOUNT/backup/gnupg.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1873. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1874. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1875. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1876. echo ' exit 491' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1877. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1878. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1879. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1880. echo '# Backup ssh keys' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1881. echo "if [ -d /home/$MY_USERNAME/.ssh ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1882. echo ' echo "Backing up ssh keys"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1883. echo " if [ ! -d $USB_MOUNT/backup/ssh ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1884. echo " mkdir -p $USB_MOUNT/backup/ssh" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1885. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1886. echo " rsyncrypto -v -r /home/$MY_USERNAME/.ssh $USB_MOUNT/backup/ssh $USB_MOUNT/backup/ssh.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1887. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1888. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1889. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1890. echo ' exit 731' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1891. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1892. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1893. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1894. echo '# Backup web sites' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1895. echo "if [ -d /etc/nginx ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1896. echo ' echo "Backing up web settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1897. echo " if [ ! -d $USB_MOUNT/backup/web ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1898. echo " mkdir -p $USB_MOUNT/backup/web" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1899. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1900. echo " rsyncrypto -v -r /etc/nginx/sites-available $USB_MOUNT/backup/web $USB_MOUNT/backup/web.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1901. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1902. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1903. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1904. echo ' exit 848' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1905. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1906. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1907. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1908. echo '# Backup README file' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1909. echo "if [ -f /home/$MY_USERNAME/README ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1910. echo ' echo "Backing up README"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1911. echo " if [ ! -d $USB_MOUNT/backup/readme ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1912. echo " mkdir -p $USB_MOUNT/backup/readme" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1913. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1914. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1915. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1916. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1917. echo " cp -f /home/$MY_USERNAME/README /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1918. echo " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup $USB_MOUNT/backup/readme $USB_MOUNT/backup/readme.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1919. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1920. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1921. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1922. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1923. echo ' exit 848' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1924. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1925. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1926. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1927. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1928. echo '# Backup Mutt settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1929. echo "if [ -f /home/$MY_USERNAME/.muttrc ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1930. echo ' echo "Backing up Mutt settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1931. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1932. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1933. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1934. echo " cp /home/$MY_USERNAME/.muttrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1935. echo ' if [ -f /etc/Muttrc ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1936. echo " cp /etc/Muttrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1937. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1938. echo " if [ ! -d $USB_MOUNT/backup/mutt ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1939. echo " mkdir -p $USB_MOUNT/backup/mutt" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1940. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1941. echo " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup $USB_MOUNT/backup/mutt $USB_MOUNT/backup/mutt.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1942. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1943. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1944. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1945. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1946. echo ' exit 492' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1947. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1948. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1949. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1950. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1951. echo '# Backup procmail settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1952. echo "if [ -f /home/$MY_USERNAME/.procmailrc ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1953. echo ' echo "Backing up procmail settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1954. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1955. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1956. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1957. echo " cp /home/$MY_USERNAME/.procmailrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1958. echo " if [ ! -d $USB_MOUNT/backup/procmail ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1959. echo " mkdir -p $USB_MOUNT/backup/procmail" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1960. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1961. echo " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup $USB_MOUNT/backup/procmail $USB_MOUNT/backup/procmail.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1962. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1963. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1964. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1965. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1966. echo ' exit 492' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1967. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1968. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1969. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1970. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1971. echo '# Backup spamassassin settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1972. echo "if [ -d /home/$MY_USERNAME/.spamassassin ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1973. echo ' echo "Backing up spamassassin settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1974. echo " if [ ! -d $USB_MOUNT/backup/spamassassin ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1975. echo " mkdir -p $USB_MOUNT/backup/spamassassin" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1976. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1977. echo " rsyncrypto -v -r /home/$MY_USERNAME/.spamassassin $USB_MOUNT/backup/spamassassin $USB_MOUNT/backup/spamassassin.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1978. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1979. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1980. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1981. echo ' exit 492' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1982. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1983. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1984. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1985. echo '# Backup email' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1986. echo "if [ -d /home/$MY_USERNAME/Maildir ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1987. echo ' echo "Creating an email archive"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1988. echo ' if [ ! -d /root/backupemail ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1989. echo " mkdir -p /root/backupemail" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1990. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1991. echo " tar -czvf /root/backupemail/maildir.tar.gz /home/$MY_USERNAME/Maildir" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1992. echo ' echo "Backing up emails"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1993. echo " if [ ! -d $USB_MOUNT/backup/mail ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1994. echo " mkdir -p $USB_MOUNT/backup/mail" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1995. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1996. echo " rsyncrypto -v -r /root/backupemail $USB_MOUNT/backup/mail $USB_MOUNT/backup/mail.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1997. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  1998. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  1999. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2000. echo ' rm -rf /root/backupemail' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2001. echo ' exit 396' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2002. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2003. echo ' rm -rf /root/backupemail' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2004. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2005. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2006. echo '# Backup DLNA cache' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2007. echo "if [ -d /var/cache/minidlna ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2008. echo ' echo "Backing up DLNA cache"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2009. echo " if [ ! -d $USB_MOUNT/backup/dlna ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2010. echo " mkdir -p $USB_MOUNT/backup/dlna" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2011. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2012. echo " rsyncrypto -v -r /var/cache/minidlna $USB_MOUNT/backup/dlna $USB_MOUNT/backup/dlna.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2013. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2014. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2015. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2016. echo ' exit 498' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2017. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2018. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2019. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2020. echo '# Backup VoIP settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2021. echo "if [ -f /etc/$VOIP_CONFIG_FILE ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2022. echo ' echo "Backing up VoIP settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2023. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2024. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2025. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2026. echo " cp -f /etc/$VOIP_CONFIG_FILE /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2027. echo " cp -f /var/lib/mumble-server/$VOIP_DATABASE /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2028. echo " if [ ! -d $USB_MOUNT/backup/voip ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2029. echo " mkdir -p $USB_MOUNT/backup/voip" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2030. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2031. echo " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup $USB_MOUNT/backup/voip $USB_MOUNT/backup/voip.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2032. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2033. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2034. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2035. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2036. echo ' exit 2492' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2037. echo ' fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2038. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2039. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2040. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2041. if [[ $BACKUP_INCLUDES_DATABASES == "yes" ]]; then
  2042. echo '# Mysql settings' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2043. echo "if [ ! -d $USB_MOUNT/backup/mariadb ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2044. echo " mkdir -p $USB_MOUNT/backup/mariadb" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2045. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2046. echo 'if [ ! -d /root/tempmariadb ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2047. echo ' mkdir /root/tempmariadb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2048. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2049. echo 'mysqldump --password=$DATABASE_PASSWORD mysql user > /root/tempmariadb/mysql.sql' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2050. echo "if [ ! -s /root/tempmariadb/mysql.sql ]; then" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2051. echo ' echo "Unable to backup mysql settings"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2052. echo ' rm -rf /root/tempmariadb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2053. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2054. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2055. echo ' exit 653' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2056. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2057. echo 'echo "$DATABASE_PASSWORD" > /root/tempmariadb/db' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2058. echo 'chmod 400 /root/tempmariadb/db' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2059. echo "rsyncrypto -v -r /root/tempmariadb $USB_MOUNT/backup/mariadb $USB_MOUNT/backup/mariadb.keys $BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2060. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2061. echo " umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2062. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2063. echo ' exit 794' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2064. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2065. echo 'shred -zu /root/tempmariadb/*' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2066. echo 'rm -rf /root/tempmariadb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2067. echo '' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2068. fi
  2069. echo 'sync' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2070. echo 'ls -lh $USB_MOUNT/backup' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2071. echo "umount $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2072. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2073. echo ' echo "Unable to unmount the drive. This means that the backup did not work"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2074. echo " rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2075. echo ' exit 46994' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2076. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2077. echo "rm -rf $USB_MOUNT" >> /usr/bin/$BACKUP_SCRIPT_NAME
  2078. echo 'if [[ $USB_DRIVE == /dev/mapper/encrypted_usb ]]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2079. echo ' echo "Unmount encrypted USB"' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2080. echo ' cryptsetup luksClose encrypted_usb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2081. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2082. echo 'if [ -f /dev/mapper/encrypted_usb ]; then' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2083. echo ' rm -rf /dev/mapper/encrypted_usb' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2084. echo 'fi' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2085. echo 'echo "Backup to USB drive is complete. You can now unplug it."' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2086. echo 'exit 0' >> /usr/bin/$BACKUP_SCRIPT_NAME
  2087. chmod 400 /usr/bin/$BACKUP_SCRIPT_NAME
  2088. chmod +x /usr/bin/$BACKUP_SCRIPT_NAME
  2089. echo 'create_backup_script' >> $COMPLETION_FILE
  2090. }
  2091. function create_restore_script {
  2092. if grep -Fxq "create_restore_script" $COMPLETION_FILE; then
  2093. return
  2094. fi
  2095. apt-get -y install rsyncrypto cryptsetup
  2096. get_mariadb_password
  2097. get_mariadb_gnusocial_admin_password
  2098. get_mariadb_redmatrix_admin_password
  2099. get_mariadb_owncloud_admin_password
  2100. get_mariadb_git_admin_password
  2101. echo '#!/bin/bash' > /usr/bin/$RESTORE_SCRIPT_NAME
  2102. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2103. echo "USB_DRIVE=$USB_DRIVE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2104. echo 'if [ $1 ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2105. echo ' USB_DRIVE=/dev/${1}1' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2106. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2107. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2108. echo 'if [ ! -b $USB_DRIVE ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2109. echo ' echo "Please attach a USB drive"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2110. echo ' exit 1' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2111. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2112. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2113. echo "if [ ! -d $USB_MOUNT ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2114. echo " mkdir $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2115. echo ' if [ -f /dev/mapper/encrypted_usb ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2116. echo ' rm -rf /dev/mapper/encrypted_usb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2117. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2118. echo ' cryptsetup luksClose encrypted_usb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2119. echo ' cryptsetup luksOpen $USB_DRIVE encrypted_usb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2120. echo ' if [ "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2121. echo ' USB_DRIVE=/dev/mapper/encrypted_usb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2122. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2123. echo -n ' mount $USB_DRIVE ' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2124. echo "$USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2125. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2126. echo "if [ ! -d $USB_MOUNT/backup ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2127. echo ' echo "No backup directory found on the USB drive."' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2128. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2129. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2130. echo ' exit 2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2131. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2132. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2133. echo 'echo "Checking that user exists"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2134. echo "if [ ! -d /home/$MY_USERNAME ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2135. echo " echo 'Username $MY_USERNAME not found. Reinstall Freedombone with this username.'" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2136. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2137. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2138. echo ' exit 295' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2139. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2140. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2141. echo 'echo "Copying GPG keys to root"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2142. echo "cp -r /home/$MY_USERNAME/.gnupg /root" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2143. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2144. echo "if [ -f $USB_MOUNT/backup/key.gpg ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2145. echo " if [ -f $BACKUP_CERTIFICATE.new ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2146. echo " rm $BACKUP_CERTIFICATE.new" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2147. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2148. echo " cp $USB_MOUNT/backup/key.gpg /root/tempbackupkey.gpg" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2149. echo " gpg /root/tempbackupkey.gpg" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2150. echo " if [ -f /root/tempbackupkey ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2151. echo ' echo "Backup key decrypted"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2152. echo " cp /root/tempbackupkey $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2153. echo " shred -zu /root/tempbackupkey" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2154. echo " chmod 400 $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2155. echo ' echo "Backup certificate installed"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2156. echo ' else' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2157. echo ' echo "Unable to decrypt the backup key"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2158. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2159. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2160. echo ' exit 735' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2161. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2162. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2163. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2164. echo "if [ ! -f $BACKUP_CERTIFICATE ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2165. echo " echo 'No backup key was found. Copy your backup key to $BACKUP_CERTIFICATE'" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2166. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2167. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2168. echo ' exit 563' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2169. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2170. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2171. echo '# MariaDB password' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2172. echo -n 'DATABASE_PASSWORD=$(cat ' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2173. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2174. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2175. echo '# Make a backup of the original README file' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2176. echo '# incase old passwords need to be used' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2177. echo "if [ -f /home/$MY_USERNAME/README ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2178. echo " if [ ! -f /home/$MY_USERNAME/README_original ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2179. echo " cp /home/$MY_USERNAME/README /home/$MY_USERNAME/README_original" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2180. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2181. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2182. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2183. if [[ $BACKUP_INCLUDES_DATABASES == "yes" ]]; then
  2184. echo "if [ -d $USB_MOUNT/backup/mariadb ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2185. echo ' echo "Restoring mysql settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2186. echo ' if [ ! -d /root/tempmariadb ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2187. echo ' mkdir /root/tempmariadb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2188. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2189. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/mariadb /root/tempmariadb $USB_MOUNT/backup/mariadb.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2190. echo ' echo "Get the MariaDB password from the backup"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2191. echo ' if [ ! -f /root/tempmariadb/usb/backup/mariadb/tempmariadb/db ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2192. echo ' echo "MariaDB password file not found"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2193. echo ' exit 495' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2194. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2195. echo ' BACKUP_MARIADB_PASSWORD=$(cat /root/tempmariadb/usb/backup/mariadb/tempmariadb/db)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2196. echo ' if [[ $BACKUP_MARIADB_PASSWORD != $DATABASE_PASSWORD ]]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2197. echo ' echo "Restore the MariaDB user table"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2198. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD mysql -o < /root/tempmariadb/usb/backup/mariadb/tempmariadb/mysql.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2199. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2200. echo ' echo "Try again using the password obtained from backup"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2201. echo ' mysqlsuccess=$(mysql -u root --password=$BACKUP_MARIADB_PASSWORD mysql -o < /root/tempmariadb/usb/backup/mariadb/tempmariadb/mysql.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2202. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2203. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2204. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2205. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2206. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2207. echo ' exit 962' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2208. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2209. echo ' echo "Restarting database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2210. echo ' service mysql restart' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2211. echo ' echo "Change the MariaDB password to the backup version"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2212. echo ' DATABASE_PASSWORD=$BACKUP_MARIADB_PASSWORD' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2213. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2214. echo ' shred -zu /root/tempmariadb/usb/backup/mariadb/tempmariadb/db' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2215. echo ' rm -rf /root/tempmariadb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2216. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2217. echo ' # Change database password file' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2218. echo -n ' echo "$DATABASE_PASSWORD" > ' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2219. echo "$DATABASE_PASSWORD_FILE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2220. echo " chmod 600 $DATABASE_PASSWORD_FILE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2221. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2222. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2223. fi
  2224. echo "if [ -d $USB_MOUNT/backup/mutt ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2225. echo ' echo "Restoring Mutt settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2226. echo ' mkdir /root/tempmutt' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2227. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/mutt /root/tempmutt $USB_MOUNT/backup/mutt.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2228. echo " if [ -f /root/tempmutt/usb/backup/mutt/$MY_USERNAME/tempbackup/.muttrc ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2229. echo " cp -f /root/tempmutt/usb/backup/mutt/$MY_USERNAME/tempbackup/.muttrc /home/$MY_USERNAME/.muttrc" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2230. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2231. echo " if [ -f /root/tempmutt/usb/backup/mutt/$MY_USERNAME/tempbackup/Muttrc ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2232. echo " cp -f /root/tempmutt/usb/backup/mutt/$MY_USERNAME/tempbackup/Muttrc /etc/Muttrc" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2233. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2234. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2235. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2236. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2237. echo ' rm -rf /root/tempmutt' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2238. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2239. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2240. echo ' rm -rf /root/tempmutt' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2241. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2242. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2243. echo "if [ -d $USB_MOUNT/backup/gnupg ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2244. echo ' echo "Restoring gnupg settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2245. echo ' mkdir /root/tempgnupg' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2246. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gnupg /root/tempgnupg $USB_MOUNT/backup/gnupg.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2247. echo " cp -r /root/tempgnupg/usb/backup/gnupg/$MY_USERNAME/.gnupg /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2248. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2249. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2250. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2251. echo ' rm -rf /root/tempgnupg' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2252. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2253. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2254. echo ' rm -rf /root/tempgnupg' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2255. echo " cp -r /home/$MY_USERNAME/.gnupg /root" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2256. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2257. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2258. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2259. echo ' exit 283' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2260. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2261. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2262. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2263. echo "if [ -d $USB_MOUNT/backup/procmail ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2264. echo ' echo "Restoring procmail settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2265. echo ' mkdir /root/tempprocmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2266. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/procmail /root/tempprocmail $USB_MOUNT/backup/procmail.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2267. echo " cp -f /root/tempprocmail/usb/backup/procmail/$MY_USERNAME/tempbackup/.procmailrc /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2268. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2269. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2270. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2271. echo ' rm -rf /root/tempprocmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2272. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2273. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2274. echo ' rm -rf /root/tempprocmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2275. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2276. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2277. echo "if [ -d $USB_MOUNT/backup/spamassassin ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2278. echo ' echo "Restoring spamassassin settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2279. echo ' mkdir /root/tempspamassassin' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2280. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/spamassassin /root/tempspamassassin $USB_MOUNT/backup/spamassassin.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2281. echo " cp -rf /root/tempspamassassin/usb/backup/spamassassin/$MY_USERNAME/.spamassassin /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2282. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2283. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2284. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2285. echo ' rm -rf /root/tempspamassassin' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2286. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2287. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2288. echo ' rm -rf /root/tempspamassassin' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2289. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2290. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2291. echo "if [ -d $USB_MOUNT/backup/readme ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2292. echo ' echo "Restoring README"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2293. echo ' mkdir /root/tempreadme' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2294. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/readme /root/tempreadme $USB_MOUNT/backup/readme.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2295. echo " cp -f /root/tempreadme/usb/backup/readme/$MY_USERNAME/tempbackup/README /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2296. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2297. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2298. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2299. echo ' rm -rf /root/tempreadme' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2300. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2301. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2302. echo ' rm -rf /root/tempreadme' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2303. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2304. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2305. echo "if [ -d $USB_MOUNT/backup/ssh ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2306. echo ' echo "Restoring ssh keys"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2307. echo ' mkdir /root/tempssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2308. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/ssh /root/tempssh $USB_MOUNT/backup/ssh.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2309. echo " cp -r /root/tempssh/usb/backup/ssh/$MY_USERNAME/.ssh /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2310. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2311. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2312. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2313. echo ' rm -rf /root/tempssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2314. echo ' exit 664' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2315. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2316. echo ' rm -rf /root/tempssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2317. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2318. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2319. echo "if [ -d $USB_MOUNT/backup/ssl ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2320. echo ' echo "Restoring certificates"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2321. echo ' mkdir /root/tempssl' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2322. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/ssl /root/tempssl $USB_MOUNT/backup/ssl.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2323. echo ' cp -r /root/tempssl/usb/backup/ssl/ssl/* /etc/ssl' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2324. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2325. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2326. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2327. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2328. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2329. echo ' rm -rf /root/tempssl' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2330. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2331. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2332. echo "if [ -d $USB_MOUNT/backup/projects ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2333. echo ' echo "Restoring projects"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2334. echo ' mkdir /root/tempprojects' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2335. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/projects /root/tempprojects $USB_MOUNT/backup/projects.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2336. echo " if [ -d /home/$MY_USERNAME/projects ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2337. echo " rm -rf /home/$MY_USERNAME/projects" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2338. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2339. echo " mv /root/tempprojects/usb/backup/projects/$MY_USERNAME/projects /home/$MY_USERNAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2340. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2341. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2342. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2343. echo ' exit 166' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2344. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2345. echo ' rm -rf /root/tempprojects' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2346. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2347. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2348. echo "if [ -d $USB_MOUNT/backup/personal ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2349. echo ' echo "Restoring personal settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2350. echo ' mkdir /root/temppersonal' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2351. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/personal /root/temppersonal $USB_MOUNT/backup/personal.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2352. echo " if [ -d /home/$MY_USERNAME/personal ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2353. echo " rm -rf /home/$MY_USERNAME/personal" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2354. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2355. echo " mv /root/temppersonal/usb/backup/personal/$MY_USERNAME/personal /home/$MY_USERNAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2356. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2357. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2358. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2359. echo ' exit 184' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2360. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2361. echo ' rm -rf /root/temppersonal' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2362. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2363. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2364. echo "if [ -d $PUBLIC_MAILING_LIST_DIRECTORY ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2365. echo ' echo "Restoring public mailing list"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2366. echo ' mkdir /root/tempmailinglist' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2367. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/mailinglist /root/tempmailinglist $USB_MOUNT/backup/mailinglist.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2368. echo " cp -r /root/tempmailinglist/usb/backup/mailinglist/spool/mlmmj/* $PUBLIC_MAILING_LIST_DIRECTORY" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2369. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2370. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2371. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2372. echo ' exit 526' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2373. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2374. echo ' rm -rf /root/tempmailinglist' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2375. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2376. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2377. echo "if [ -d $XMPP_DIRECTORY ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2378. echo ' echo "Restoring XMPP settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2379. echo ' mkdir /root/tempxmpp' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2380. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/xmpp /root/tempxmpp $USB_MOUNT/backup/xmpp.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2381. echo " cp -r /root/tempxmpp/usb/backup/xmpp/lib/prosody/* $XMPP_DIRECTORY" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2382. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2383. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2384. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2385. echo ' exit 725' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2386. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2387. echo ' rm -rf /root/tempxmpp' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2388. echo ' service prosody restart' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2389. echo ' chown -R prosody:prosody /var/lib/prosody/*' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2390. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2391. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2392. BACKUP_INCLUDES_WEBSITES="no"
  2393. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  2394. BACKUP_INCLUDES_WEBSITES="yes"
  2395. echo "if [ -d $USB_MOUNT/backup/gnusocial ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2396. echo ' echo "Restoring microblog database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2397. echo ' if [ ! -d /root/tempgnusocialdata ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2398. echo ' mkdir /root/tempgnusocialdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2399. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2400. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gnusocialdata /root/tempgnusocialdata $USB_MOUNT/backup/gnusocialdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2401. echo ' if [ ! -f /root/tempgnusocialdata/usb/backup/gnusocialdata/tempgnusocialdata/gnusocial.sql ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2402. echo ' echo "Unable to restore microblog database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2403. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2404. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2405. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2406. echo ' exit 503' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2407. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2408. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD gnusocial -o < /root/tempgnusocialdata/usb/backup/gnusocialdata/tempgnusocialdata/gnusocial.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2409. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2410. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2411. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2412. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2413. echo ' exit 964' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2414. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2415. echo ' shred -zu /root/tempgnusocialdata/usb/backup/gnusocialdata/tempgnusocialdata/*' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2416. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2417. echo ' echo "Restoring microblog installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2418. echo ' if [ ! -d /root/tempgnusocial ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2419. echo ' mkdir /root/tempgnusocial' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2420. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2421. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gnusocial /root/tempgnusocial $USB_MOUNT/backup/gnusocial.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2422. echo " rm -rf /var/www/$MICROBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2423. echo " mv /root/tempgnusocial/usb/backup/gnusocial/www/$MICROBLOG_DOMAIN_NAME/htdocs /var/www/$MICROBLOG_DOMAIN_NAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2424. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2425. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2426. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2427. echo ' exit 683' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2428. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2429. echo ' rm -rf /root/tempgnusocial' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2430. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2431. echo " if [ -f /etc/ssl/certs/$MICROBLOG_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2432. echo " sed -i 's|$MICROBLOG_DOMAIN_NAME.crt|$MICROBLOG_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2433. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2434. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2435. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2436. fi
  2437. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  2438. BACKUP_INCLUDES_WEBSITES="yes"
  2439. echo "if [ -d $USB_MOUNT/backup/redmatrix ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2440. echo ' echo "Restoring Red Matrix database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2441. echo ' if [ ! -d /root/tempredmatrixdata ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2442. echo ' mkdir /root/tempredmatrixdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2443. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2444. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/redmatrixdata /root/tempredmatrixdata $USB_MOUNT/backup/redmatrixdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2445. echo ' if [ ! -f /root/tempredmatrixdata/usb/backup/redmatrixdata/tempredmatrixdata/redmatrix.sql ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2446. echo ' echo "Unable to restore Red Matrix database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2447. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2448. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2449. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2450. echo ' exit 504' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2451. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2452. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD redmatrix -o < /root/tempredmatrixdata/usb/backup/redmatrixdata/tempredmatrixdata/redmatrix.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2453. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2454. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2455. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2456. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2457. echo ' exit 965' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2458. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2459. echo ' shred -zu /root/tempredmatrixdata/usb/backup/redmatrixdata/tempredmatrixdata/*' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2460. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2461. echo ' echo "Restoring Red Matrix installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2462. echo ' if [ ! -d /root/tempredmatrix ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2463. echo ' mkdir /root/tempredmatrix' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2464. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2465. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/redmatrix /root/tempredmatrix $USB_MOUNT/backup/redmatrix.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2466. echo " rm -rf /var/www/$REDMATRIX_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2467. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2468. echo " cp -r /root/tempredmatrix/usb/backup/redmatrix/www/$REDMATRIX_DOMAIN_NAME/htdocs/* /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2469. echo ' else' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2470. echo " mv /root/tempredmatrix/usb/backup/redmatrix/www/$REDMATRIX_DOMAIN_NAME/htdocs /var/www/$REDMATRIX_DOMAIN_NAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2471. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2472. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2473. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2474. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2475. echo ' exit 759' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2476. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2477. echo ' rm -rf /root/tempredmatrix' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2478. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2479. echo " if [ -f /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2480. echo " sed -i 's|$REDMATRIX_DOMAIN_NAME.crt|$REDMATRIX_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2481. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2482. echo " chmod 777 /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2483. echo " chown -R www-data:www-data /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/*" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2484. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2485. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2486. fi
  2487. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  2488. BACKUP_INCLUDES_WEBSITES="yes"
  2489. echo "if [ -d $USB_MOUNT/backup/owncloud ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2490. echo ' echo "Restoring owncloud database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2491. echo ' if [ ! -d /root/tempownclouddata ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2492. echo ' mkdir /root/tempownclouddata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2493. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2494. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/ownclouddata /root/tempownclouddata $USB_MOUNT/backup/ownclouddata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2495. echo ' if [ ! -f /root/tempownclouddata/usb/backup/ownclouddata/tempownclouddata/owncloud.sql ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2496. echo ' echo "Unable to restore Owncloud database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2497. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2498. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2499. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2500. echo ' exit 505' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2501. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2502. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD owncloud -o < /root/tempownclouddata/usb/backup/ownclouddata/tempownclouddata/owncloud.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2503. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2504. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2505. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2506. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2507. echo ' exit 965' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2508. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2509. echo ' echo "Restoring Owncloud installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2510. echo ' if [ ! -d /root/tempowncloud ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2511. echo ' mkdir /root/tempowncloud' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2512. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2513. echo ' if [ ! -d /root/tempowncloud2 ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2514. echo ' mkdir /root/tempowncloud2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2515. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2516. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/owncloud /root/tempowncloud $USB_MOUNT/backup/owncloud.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2517. echo " cp -r /root/tempowncloud/usb/backup/owncloud/lib/owncloud/* /var/lib/owncloud/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2518. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2519. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2520. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2521. echo ' exit 981' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2522. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2523. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/owncloud2 /root/tempowncloud2 $USB_MOUNT/backup/owncloud2.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2524. echo " cp -r /root/tempowncloud2/usb/backup/owncloud2/owncloud/* /etc/owncloud/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2525. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2526. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2527. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2528. echo ' exit 982' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2529. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2530. echo ' rm -rf /root/tempowncloud' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2531. echo ' rm -rf /root/tempowncloud2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2532. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2533. echo ' chown -R www-data:www-data /var/lib/owncloud/data' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2534. echo ' chown -R www-data:www-data /var/lib/owncloud/backup' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2535. echo ' chown -R www-data:www-data /var/lib/owncloud/assets' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2536. echo " occ files:scan $MY_USERNAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2537. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2538. echo " if [ -f /etc/ssl/certs/$OWNCLOUD_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2539. echo " sed -i 's|$OWNCLOUD_DOMAIN_NAME.crt|$OWNCLOUD_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME" >> /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. fi
  2544. if grep -Fxq "install_gogs" $COMPLETION_FILE; then
  2545. BACKUP_INCLUDES_WEBSITES="yes"
  2546. echo "if [ -d $USB_MOUNT/backup/gogs ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2547. echo ' echo "Restoring gogs database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2548. echo ' if [ ! -d /root/tempgogsdata ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2549. echo ' mkdir /root/tempgogsdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2550. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2551. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gogsdata /root/tempgogsdata $USB_MOUNT/backup/gogsdata.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2552. echo ' if [ ! -f /root/tempgogsdata/usb/backup/gogsdata/tempgogsdata/gogs.sql ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2553. echo ' echo "Unable to restore Gogs database"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2554. echo ' rm -rf /root/tempgogsdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2555. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2556. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2557. echo ' exit 505' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2558. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2559. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD gogs -o < /root/tempgogsdata/usb/backup/gogsdata/tempgogsdata/gogs.sql)' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2560. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2561. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2562. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2563. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2564. echo ' exit 965' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2565. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2566. echo ' echo "Restoring Gogs settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2567. echo ' if [ ! -d /root/tempgogs ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2568. echo ' mkdir /root/tempgogs' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2569. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2570. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gogs /root/tempgogs $USB_MOUNT/backup/gogs.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2571. echo ' if [ ! -d /home/git/go/src/github.com/gogits/gogs/custom ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2572. echo ' mkdir -p /home/git/go/src/github.com/gogits/gogs/custom' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2573. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2574. echo " cp -r /root/tempgogs/usb/backup/gogs/git/go/src/github.com/gogits/gogs/custom/* /home/git/go/src/github.com/gogits/gogs/custom" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2575. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2576. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2577. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2578. echo ' exit 981' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2579. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2580. echo ' echo "Restoring Gogs repos"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2581. echo ' if [ ! -d /root/tempgogsrepos ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2582. echo ' mkdir /root/tempgogsrepos' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2583. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2584. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gogsrepos /root/tempgogsrepos $USB_MOUNT/backup/gogsrepos.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2585. echo " cp -r /root/tempgogsrepos/usb/backup/gogsrepos/git/gog-repositories/* /home/git/gogs-repositories/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2586. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2587. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2588. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2589. echo ' exit 67574' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2590. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2591. echo ' echo "Restoring Gogs authorized_keys"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2592. echo ' if [ ! -d /root/tempgogsssh ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2593. echo ' mkdir /root/tempgogsssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2594. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2595. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/gogsssh /root/tempgogsssh $USB_MOUNT/backup/gogsssh.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2596. echo ' if [ ! -d /home/git/.ssh ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2597. echo ' mkdir /home/git/.ssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2598. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2599. echo " cp -r /root/tempgogsssh/usb/backup/gogsssh/git/.ssh/* /home/git/.ssh/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2600. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2601. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2602. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2603. echo ' exit 8463' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2604. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2605. echo ' rm -rf /root/tempgogs' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2606. echo ' rm -rf /root/tempgogsdata' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2607. echo ' rm -rf /root/tempgogsrepos' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2608. echo ' rm -rf /root/tempgogsssh' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2609. echo ' chown -R git:git /home/git' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2610. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2611. echo " if [ -f /etc/ssl/certs/$GIT_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2612. echo " sed -i 's|$GIT_DOMAIN_NAME.crt|$GIT_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$GIT_DOMAIN_NAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2613. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2614. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2615. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2616. fi
  2617. echo "if [ -d $USB_MOUNT/backup/wiki ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2618. echo ' echo "Restoring Wiki installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2619. echo ' mkdir /root/tempwiki' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2620. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/wiki /root/tempwiki $USB_MOUNT/backup/wiki.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2621. echo " cp -r /root/tempwiki/usb/backup/wiki/lib/dokuwiki/* /var/lib/dokuwiki/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2622. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2623. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2624. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2625. echo ' exit 868' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2626. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2627. echo ' mkdir /root/tempwiki2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2628. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/wiki2 /root/tempwiki2 $USB_MOUNT/backup/wiki2.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2629. echo " cp -r /root/tempwiki2/usb/backup/wiki2/dokuwiki/* /etc/dokuwiki/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2630. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2631. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2632. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2633. echo ' exit 869' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2634. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2635. echo ' rm -rf /root/tempwiki' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2636. echo ' rm -rf /root/tempwiki2' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2637. echo ' chown -R www-data:www-data /var/lib/dokuwiki/*' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2638. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2639. echo " if [ -f /etc/ssl/certs/$WIKI_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2640. echo " sed -i 's|$WIKI_DOMAIN_NAME.crt|$WIKI_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$WIKI_DOMAIN_NAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2641. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2642. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2643. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2644. echo "if [ -d $USB_MOUNT/backup/blog ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2645. echo ' echo "Restoring blog installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2646. echo ' mkdir /root/tempblog' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2647. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/blog /root/tempblog $USB_MOUNT/backup/blog.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2648. echo " rm -rf /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2649. echo " cp -r /root/tempblog/usb/backup/blog/www/$FULLBLOG_DOMAIN_NAME/htdocs /var/www/$FULLBLOG_DOMAIN_NAME/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2650. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2651. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2652. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2653. echo ' exit 593' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2654. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2655. echo ' rm -rf /root/tempblog' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2656. echo " if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/content ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2657. echo ' echo "No content directory found after restoring blog"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2658. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2659. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2660. echo ' exit 287' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2661. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2662. echo " chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2663. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2664. echo " if [ -f /etc/ssl/certs/$FULLBLOG_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2665. echo " sed -i 's|$FULLBLOG_DOMAIN_NAME.crt|$FULLBLOG_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2666. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2667. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2668. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2669. echo "if [ -d $USB_MOUNT/backup/cjdns ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2670. echo ' echo "Restoring cjdns installation"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2671. echo ' mkdir /root/tempcjdns' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2672. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/cjdns /root/tempcjdns $USB_MOUNT/backup/cjdns.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2673. echo " rm -rf /etc/cjdns" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2674. echo " cp -r /root/tempcjdns/usb/backup/cjdns/cjdns /etc/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2675. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2676. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2677. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2678. echo ' exit 8472' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2679. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2680. echo ' rm -rf /root/tempcjdns' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2681. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2682. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2683. echo "if [ -d $USB_MOUNT/backup/mail ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2684. echo ' echo "Restoring emails"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2685. echo ' mkdir /root/tempmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2686. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/mail /root/tempmail $USB_MOUNT/backup/mail.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2687. echo " if [ ! -d /home/$MY_USERNAME/Maildir ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2688. echo " mkdir /home/$MY_USERNAME/Maildir" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2689. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2690. echo ' tar -xzvf /root/tempmail/usb/backup/mail/backupemail/maildir.tar.gz' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2691. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2692. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2693. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2694. echo ' exit 927' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2695. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2696. echo ' rm -rf /root/tempmail' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2697. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2698. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2699. echo "if [ -d /var/cache/minidlna ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2700. echo " if [ -d $USB_MOUNT/backup/dlna ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2701. echo ' echo "Restoring DLNA cache"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2702. echo ' mkdir /root/tempdlna' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2703. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/dlna /root/tempdlna $USB_MOUNT/backup/dlna.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2704. echo " cp -r /root/tempdlna/usb/backup/dlna/cache/minidlna/* /var/cache/minidlna/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2705. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2706. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2707. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2708. echo ' exit 982' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2709. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2710. echo ' rm -rf /root/tempdlna' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2711. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2712. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2713. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2714. echo "if [ -d $USB_MOUNT/backup/voip ]; then" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2715. echo ' echo "Restoring VoIP settings"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2716. echo ' mkdir /root/tempvoip' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2717. echo " rsyncrypto -v -d -r $USB_MOUNT/backup/voip /root/tempvoip $USB_MOUNT/backup/voip.keys $BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2718. echo " cp -f /root/tempvoip/usb/backup/voip/$MY_USERNAME/tempbackup/$VOIP_CONFIG_FILE /etc/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2719. echo " cp -f /root/tempvoip/usb/backup/voip/$MY_USERNAME/tempbackup/$VOIP_DATABASE /var/lib/mumble-server/" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2720. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2721. echo " umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2722. echo " rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2723. echo ' rm -rf /root/tempvoip' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2724. echo ' exit 276' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2725. echo ' fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2726. echo ' rm -rf /root/tempvoip' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2727. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2728. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2729. echo 'sync' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2730. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2731. echo "# Unmount the USB drive" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2732. echo "umount $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2733. echo "rm -rf $USB_MOUNT" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2734. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2735. if [[ $BACKUP_INCLUDES_WEBSITES == "yes" ]]; then
  2736. echo "# Restart the web server" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2737. echo "service nginx restart" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2738. echo "service php5-fpm restart" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2739. fi
  2740. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2741. echo 'echo "Setting permissions"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2742. echo "chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  2743. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2744. echo 'if [[ $USB_DRIVE == /dev/mapper/encrypted_usb ]]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2745. echo ' echo "Unmount encrypted USB"' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2746. echo ' cryptsetup luksClose encrypted_usb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2747. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2748. echo 'if [ -f /dev/mapper/encrypted_usb ]; then' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2749. echo ' rm -rf /dev/mapper/encrypted_usb' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2750. echo 'fi' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2751. echo '' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2752. echo 'echo "Restore from USB drive is complete. You can now remove it."' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2753. echo 'exit 0' >> /usr/bin/$RESTORE_SCRIPT_NAME
  2754. chmod 400 /usr/bin/$RESTORE_SCRIPT_NAME
  2755. chmod +x /usr/bin/$RESTORE_SCRIPT_NAME
  2756. echo 'create_restore_script' >> $COMPLETION_FILE
  2757. }
  2758. function create_freedns_updater {
  2759. # currently inadyn doesn't work as expected with freeDNS, so this is a workaround
  2760. if grep -Fxq "create_freedns_updater" $COMPLETION_FILE; then
  2761. return
  2762. fi
  2763. if [[ $DDNS_PROVIDER != "default@freedns.afraid.org" ]]; then
  2764. return
  2765. fi
  2766. FREEDNS_WGET='wget -q --read-timeout=0.0 --waitretry=5 --tries=4 https://freedns.afraid.org/dynamic/update.php?'
  2767. echo '#!/bin/bash' > /usr/bin/dynamicdns
  2768. echo 'cd /tmp' >> /usr/bin/dynamicdns
  2769. if [ $DEFAULT_DOMAIN_CODE ]; then
  2770. echo "# $DEFAULT_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2771. echo "$FREEDNS_WGET$DEFAULT_DOMAIN_CODE=" >> /usr/bin/dynamicdns
  2772. fi
  2773. if [ $WIKI_CODE ]; then
  2774. if [[ $WIKI_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2775. echo "# $WIKI_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2776. echo "$FREEDNS_WGET$WIKI_CODE=" >> /usr/bin/dynamicdns
  2777. fi
  2778. fi
  2779. if [ $FULLBLOG_CODE ]; then
  2780. if [[ $FULLBLOG_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2781. echo "# $FULLBLOG_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2782. echo "$FREEDNS_WGET$FULLBLOG_CODE=" >> /usr/bin/dynamicdns
  2783. fi
  2784. fi
  2785. if [ $REDMATRIX_CODE ]; then
  2786. if [[ $REDMATRIX_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2787. echo "# $REDMATRIX_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2788. echo "$FREEDNS_WGET$REDMATRIX_CODE=" >> /usr/bin/dynamicdns
  2789. fi
  2790. fi
  2791. if [ $OWNCLOUD_CODE ]; then
  2792. if [[ $OWNCLOUD_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2793. echo "# $OWNCLOUD_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2794. echo "$FREEDNS_WGET$OWNCLOUD_CODE=" >> /usr/bin/dynamicdns
  2795. fi
  2796. fi
  2797. if [ $MICROBLOG_CODE ]; then
  2798. if [[ $MICROBLOG_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2799. echo "# $MICROBLOG_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2800. echo "$FREEDNS_WGET$MICROBLOG_CODE=" >> /usr/bin/dynamicdns
  2801. fi
  2802. fi
  2803. if [ $GIT_CODE ]; then
  2804. if [[ $GIT_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2805. echo "# $GIT_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2806. echo "$FREEDNS_WGET$GIT_CODE=" >> /usr/bin/dynamicdns
  2807. fi
  2808. fi
  2809. if [ $MEDIAGOBLIN_CODE ]; then
  2810. if [[ $MEDIAGOBLIN_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2811. echo "# $MEDIAGOBLIN_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2812. echo "$FREEDNS_WGET$MEDIAGOBLIN_CODE=" >> /usr/bin/dynamicdns
  2813. fi
  2814. fi
  2815. echo 'exit 0' >> /usr/bin/dynamicdns
  2816. chmod 600 /usr/bin/dynamicdns
  2817. chmod +x /usr/bin/dynamicdns
  2818. if ! grep -q "/usr/bin/dynamicdns" /etc/crontab; then
  2819. echo '*/3 * * * * root /usr/bin/dynamicdns' >> /etc/crontab
  2820. service cron restart
  2821. fi
  2822. echo 'create_freedns_updater' >> $COMPLETION_FILE
  2823. }
  2824. function backup_to_friends_servers {
  2825. if grep -Fxq "backup_to_friends_servers" $COMPLETION_FILE; then
  2826. return
  2827. fi
  2828. if [ ! $FRIENDS_SERVERS_LIST ]; then
  2829. return
  2830. fi
  2831. apt-get -y install rsyncrypto sshpass
  2832. get_mariadb_password
  2833. get_mariadb_gnusocial_admin_password
  2834. get_mariadb_redmatrix_admin_password
  2835. get_mariadb_owncloud_admin_password
  2836. get_mariadb_git_admin_password
  2837. if ! grep -q "backups on friends servers" /home/$MY_USERNAME/README; then
  2838. echo '' >> /home/$MY_USERNAME/README
  2839. echo '' >> /home/$MY_USERNAME/README
  2840. echo 'Backups' >> /home/$MY_USERNAME/README
  2841. echo '=======' >> /home/$MY_USERNAME/README
  2842. echo 'Key file: /root/backupkey' >> /home/$MY_USERNAME/README
  2843. echo "To add friends servers create a file called $FRIENDS_SERVERS_LIST" >> /home/$MY_USERNAME/README
  2844. echo 'and add entries like this:' >> /home/$MY_USERNAME/README
  2845. echo '' >> /home/$MY_USERNAME/README
  2846. echo "username1@domain1:$SSH_PORT//home/username1 ssh_password1" >> /home/$MY_USERNAME/README
  2847. echo "username2@domain2:$SSH_PORT//home/username2 ssh_password2" >> /home/$MY_USERNAME/README
  2848. echo '...' >> /home/$MY_USERNAME/README
  2849. echo '' >> /home/$MY_USERNAME/README
  2850. echo 'The system will try to backup to these remote locations once per day.' >> /home/$MY_USERNAME/README
  2851. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  2852. fi
  2853. echo '#!/bin/bash' > /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2854. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2855. echo '# Temporary location for data to be backed up to other servers' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2856. echo 'SERVER_DIRECTORY=/root/remotebackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2857. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2858. echo "if [ ! -f $BACKUP_CERTIFICATE ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2859. echo ' echo "Creating backup key"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2860. echo ' freedombone-addcert -h backup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2861. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2862. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2863. echo "if [ ! -f $FRIENDS_SERVERS_LIST ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2864. echo ' exit 1' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2865. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2866. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2867. echo '# MariaDB password' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2868. echo -n 'DATABASE_PASSWORD=$(cat ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2869. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2870. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2871. echo '# local directory where the backup will be made' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2872. echo 'if [ ! -d $SERVER_DIRECTORY ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2873. echo ' mkdir $SERVER_DIRECTORY' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2874. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2875. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2876. echo 'if [ ! -d $SERVER_DIRECTORY/backup ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2877. echo ' mkdir -p $SERVER_DIRECTORY/backup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2878. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2879. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2880. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  2881. BACKUP_INCLUDES_DATABASES="yes"
  2882. echo 'if [ ! -d $SERVER_DIRECTORY/backup/gnusocial ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2883. echo ' mkdir -p $SERVER_DIRECTORY/backup/gnusocial' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2884. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2885. echo 'if [ ! -d $SERVER_DIRECTORY/backup/gnusocialdata ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2886. echo ' mkdir -p $SERVER_DIRECTORY/backup/gnusocialdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2887. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2888. echo "if [ ! -d /root/tempgnusocialdata ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2889. echo " mkdir -p /root/tempgnusocialdata" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2890. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2891. echo 'echo "Obtaining GNU Social database backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2892. echo 'mysqldump --password=$DATABASE_PASSWORD gnusocial > /root/tempgnusocialdata/gnusocial.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2893. echo "if [ ! -s /root/tempgnusocialdata/gnusocial.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2894. echo ' echo "GNU social database could not be saved"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2895. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2896. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2897. echo " fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2898. echo ' shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2899. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2900. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2901. echo -n ' echo "Unable to export gnusocial database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2902. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2903. echo ' exit 296' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2904. echo "fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2905. echo -n 'rsyncrypto -v -r /root/tempgnusocialdata $SERVER_DIRECTORY/backup/gnusocialdata $SERVER_DIRECTORY/backup/gnusocialdata.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2906. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2907. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2908. echo ' shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2909. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2910. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2911. echo -n ' echo "Unable to encrypt gnusocial database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2912. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2913. echo ' exit 853' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2914. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2915. echo 'shred -zu /root/tempgnusocialdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2916. echo 'rm -rf /root/tempgnusocialdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2917. echo 'echo "Backing up GNU social installation"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2918. echo -n "rsyncrypto -v -r /var/www/$MICROBLOG_DOMAIN_NAME/htdocs " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2919. echo -n '$SERVER_DIRECTORY/backup/gnusocial $SERVER_DIRECTORY/backup/gnusocial.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2920. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2921. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2922. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2923. echo -n ' echo "Unable to encrypt gnusocial installation" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2924. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2925. echo ' exit 846' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2926. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2927. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2928. fi
  2929. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  2930. BACKUP_INCLUDES_DATABASES="yes"
  2931. echo 'if [ ! -d $SERVER_DIRECTORY/backup/redmatrix ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2932. echo ' mkdir -p $SERVER_DIRECTORY/backup/redmatrix' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2933. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2934. echo 'if [ ! -d $SERVER_DIRECTORY/backup/redmatrixdata ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2935. echo ' mkdir -p $SERVER_DIRECTORY/backup/redmatrixdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2936. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2937. echo "if [ ! -d /root/tempredmatrixdata ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2938. echo " mkdir -p /root/tempredmatrixdata" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2939. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2940. echo 'echo "Obtaining Red Matrix database backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2941. echo 'mysqldump --password=$DATABASE_PASSWORD redmatrix > /root/tempredmatrixdata/redmatrix.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2942. echo "if [ ! -s /root/tempredmatrixdata/redmatrix.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2943. echo ' echo "Red Matrix database could not be saved"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2944. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2945. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2946. echo " fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2947. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2948. echo -n ' echo "Unable to export redmatrix database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2949. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2950. echo ' exit 378' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2951. echo "fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2952. echo -n 'rsyncrypto -v -r /root/tempredmatrixdata $SERVER_DIRECTORY/backup/redmatrixdata $SERVER_DIRECTORY/backup/redmatrixdata.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2953. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2954. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2955. echo ' shred -zu /root/tempredmatrixdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2956. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2957. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2958. echo -n ' echo "Unable to encrypt redmatrix database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2959. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2960. echo ' exit 285' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2961. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2962. echo 'shred -zu /root/tempredmatrixdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2963. echo 'rm -rf /root/tempredmatrixdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2964. echo 'echo "Backing up Red Matrix installation"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2965. echo -n "rsyncrypto -v -r /var/www/$REDMATRIX_DOMAIN_NAME/htdocs " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2966. echo -n '$SERVER_DIRECTORY/backup/redmatrix $SERVER_DIRECTORY/backup/redmatrix.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 redmatrix installation" | 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 593' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2973. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2974. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2975. fi
  2976. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  2977. BACKUP_INCLUDES_DATABASES="yes"
  2978. echo 'if [ ! -d $SERVER_DIRECTORY/backup/owncloud ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2979. echo ' mkdir -p $SERVER_DIRECTORY/backup/owncloud' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2980. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2981. echo 'if [ ! -d $SERVER_DIRECTORY/backup/owncloud2 ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2982. echo ' mkdir -p $SERVER_DIRECTORY/backup/owncloud2' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2983. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2984. echo 'if [ ! -d $SERVER_DIRECTORY/backup/ownclouddata ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2985. echo ' mkdir -p $SERVER_DIRECTORY/backup/ownclouddata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2986. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2987. echo "if [ ! -d /root/tempownclouddata ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2988. echo " mkdir -p /root/tempownclouddata" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2989. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2990. echo 'mysqldump --password=$DATABASE_PASSWORD owncloud > /root/tempownclouddata/owncloud.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2991. echo "if [ ! -s /root/tempownclouddata/owncloud.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2992. echo ' echo "Owncloud database could not be saved"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2993. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2994. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2995. echo " fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2996. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2997. echo -n ' echo "Unable to export owncloud database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2998. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  2999. echo ' exit 377' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3000. echo "fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3001. echo -n 'rsyncrypto -v -r /root/tempownclouddata $SERVER_DIRECTORY/backup/ownclouddata $SERVER_DIRECTORY/backup/ownclouddata.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3002. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3003. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3004. echo ' shred -zu /root/tempownclouddata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3005. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3006. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3007. echo -n ' echo "Unable to encrypt owncloud database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3008. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3009. echo ' exit 188' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3010. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3011. echo 'shred -zu /root/tempownclouddata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3012. echo 'rm -rf /root/tempownclouddata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3013. echo 'echo "Obtaining Owncloud data backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3014. echo -n 'rsyncrypto -v -r /var/lib/owncloud $SERVER_DIRECTORY/backup/owncloud $SERVER_DIRECTORY/backup/owncloud.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3015. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3016. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3017. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3018. echo -n ' echo "Unable to encrypt owncloud installation (/var/lib/owncloud)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3019. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3020. echo ' exit 632' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3021. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3022. echo -n 'rsyncrypto -v -r /etc/owncloud $SERVER_DIRECTORY/backup/owncloud2 $SERVER_DIRECTORY/backup/owncloud2.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3023. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3024. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3025. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3026. echo -n ' echo "Unable to encrypt owncloud installation (/etc/owncloud)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3027. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3028. echo ' exit 632' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3029. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3030. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3031. fi
  3032. if grep -Fxq "install_gogs" $COMPLETION_FILE; then
  3033. BACKUP_INCLUDES_DATABASES="yes"
  3034. echo 'if [ ! -d $SERVER_DIRECTORY/backup/gogs ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3035. echo ' mkdir -p $SERVER_DIRECTORY/backup/gogs' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3036. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3037. echo 'if [ ! -d $SERVER_DIRECTORY/backup/gogsdata ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3038. echo ' mkdir -p $SERVER_DIRECTORY/backup/gogsdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3039. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3040. echo 'if [ ! -d $SERVER_DIRECTORY/backup/gogsrepos ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3041. echo ' mkdir -p $SERVER_DIRECTORY/backup/gogsrepos' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3042. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3043. echo 'if [ ! -d $SERVER_DIRECTORY/backup/gogsssh ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3044. echo ' mkdir -p $SERVER_DIRECTORY/backup/gogsssh' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3045. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3046. echo "if [ ! -d /root/tempgogsdata ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3047. echo " mkdir -p /root/tempgogsdata" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3048. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3049. echo 'mysqldump --password=$DATABASE_PASSWORD gogs > /root/tempgogsdata/gogs.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3050. echo "if [ ! -s /root/tempgogsdata/gogs.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3051. echo ' echo "Gogs database could not be saved"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3052. echo ' if [ ! $DATABASE_PASSWORD ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3053. echo " echo 'No MariaDB password was given'" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3054. echo " fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3055. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3056. echo -n ' echo "Unable to export gogs database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3057. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3058. echo ' exit 6785' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3059. echo "fi" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3060. echo -n 'rsyncrypto -v -r /root/tempgogsdata $SERVER_DIRECTORY/backup/gogsdata $SERVER_DIRECTORY/backup/gogsdata.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3061. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3062. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3063. echo ' shred -zu /root/tempgogsdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3064. echo ' rm -rf /root/tempgogsdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3065. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3066. echo -n ' echo "Unable to encrypt gogs database" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3067. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3068. echo ' exit 3776' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3069. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3070. echo 'shred -zu /root/tempgogsdata/*' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3071. echo 'rm -rf /root/tempgogsdata' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3072. echo 'echo "Obtaining Gogs settings backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3073. echo -n 'rsyncrypto -v -r /home/git/go/src/github.com/gogits/gogs/custom $SERVER_DIRECTORY/backup/gogs $SERVER_DIRECTORY/backup/gogs.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3074. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3075. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3076. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3077. echo -n ' echo "Unable to encrypt gogs installation (/home/git/go/src/github.com/gogits/gogs/custom)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3078. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3079. echo ' exit 76547' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3080. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3081. echo 'echo "Obtaining Gogs repos backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3082. echo -n 'rsyncrypto -v -r /home/git/gogs-repositories $SERVER_DIRECTORY/backup/gogsrepos $SERVER_DIRECTORY/backup/gogsrepos.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3083. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3084. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3085. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3086. echo -n ' echo "Unable to encrypt gogs repos (/home/git/gogs-repositories)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3087. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3088. echo ' exit 454637' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3089. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3090. echo 'echo "Obtaining Gogs authorized_keys backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3091. echo -n 'rsyncrypto -v -r /home/git/.ssh $SERVER_DIRECTORY/backup/gogsssh $SERVER_DIRECTORY/backup/gogsssh.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3092. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3093. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3094. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3095. echo -n ' echo "Unable to encrypt gogs authorized_keys (/home/git/.ssh)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3096. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3097. echo ' exit 76864' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3098. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3099. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3100. fi
  3101. if grep -Fxq "install_wiki" $COMPLETION_FILE; then
  3102. echo 'if [ ! -d $SERVER_DIRECTORY/backup/wiki ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3103. echo ' mkdir -p $SERVER_DIRECTORY/backup/wiki' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3104. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3105. echo 'if [ ! -d $SERVER_DIRECTORY/backup/wiki2 ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3106. echo ' mkdir -p $SERVER_DIRECTORY/backup/wiki2' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3107. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3108. echo 'echo "Obtaining wiki data backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3109. echo -n 'rsyncrypto -v -r /var/lib/dokuwiki $SERVER_DIRECTORY/backup/wiki $SERVER_DIRECTORY/backup/wiki.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3110. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3111. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3112. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3113. echo -n ' echo "Unable to encrypt wiki installation (/var/lib/dokuwiki)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3114. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3115. echo ' exit 964' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3116. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3117. echo -n 'rsyncrypto -v -r /etc/dokuwiki $SERVER_DIRECTORY/backup/wiki2 $SERVER_DIRECTORY/backup/wiki2.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3118. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3119. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3120. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3121. echo -n ' echo "Unable to encrypt wiki installation (/etc/dokuwiki)" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3122. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3123. echo ' exit 964' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3124. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3125. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3126. fi
  3127. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  3128. echo 'if [ ! -d $SERVER_DIRECTORY/backup/blog ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3129. echo ' mkdir -p $SERVER_DIRECTORY/backup/blog' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3130. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3131. echo 'echo "Obtaining blog backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3132. echo -n "rsyncrypto -v -r /var/www/$FULLBLOG_DOMAIN_NAME/htdocs " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3133. echo -n '$SERVER_DIRECTORY/backup/blog $SERVER_DIRECTORY/backup/blog.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3134. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3135. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3136. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3137. echo -n ' echo "Unable to encrypt blog installation" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3138. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3139. echo ' exit 854' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3140. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3141. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3142. fi
  3143. if grep -Fxq "mesh_cjdns" $COMPLETION_FILE; then
  3144. echo 'if [ ! -d $SERVER_DIRECTORY/backup/cjdns ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3145. echo ' mkdir -p $SERVER_DIRECTORY/backup/cjdns' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3146. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3147. echo 'echo "Obtaining cjdns backup"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3148. echo -n "rsyncrypto -v -r /etc/cjdns " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3149. echo -n '$SERVER_DIRECTORY/backup/cjdns $SERVER_DIRECTORY/backup/cjdns.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3150. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3151. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3152. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3153. echo -n ' echo "Unable to encrypt cjdns installation" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3154. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3155. echo ' exit 854' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3156. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3157. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3158. fi
  3159. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3160. echo '# Backup certificates' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3161. echo "if [ -d /etc/ssl ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3162. echo ' echo "Backing up certificates"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3163. echo ' if [ ! -d $SERVER_DIRECTORY/backup/ssl ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3164. echo ' mkdir -p $SERVER_DIRECTORY/backup/ssl' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3165. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3166. echo -n ' rsyncrypto -v -r /etc/ssl $SERVER_DIRECTORY/backup/ssl $SERVER_DIRECTORY/backup/ssl.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3167. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3168. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3169. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3170. echo -n ' echo "Unable to encrypt ssl certificates" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3171. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3172. echo ' exit 343' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3173. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3174. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3175. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3176. echo '# Backup projects' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3177. echo "if [ -d /home/$MY_USERNAME/projects ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3178. echo ' echo "Backing up projects"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3179. echo ' if [ ! -d $SERVER_DIRECTORY/backup/projects ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3180. echo ' mkdir -p $SERVER_DIRECTORY/backup/projects' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3181. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3182. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/projects " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3183. echo -n '$SERVER_DIRECTORY/backup/projects $SERVER_DIRECTORY/backup/projects.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3184. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3185. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3186. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3187. echo -n ' echo "Unable to encrypt git projects" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3188. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3189. echo ' exit 873' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3190. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3191. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3192. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3193. echo '# Backup personal settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3194. echo "if [ -d /home/$MY_USERNAME/personal ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3195. echo ' echo "Backing up personal settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3196. echo ' if [ ! -d $SERVER_DIRECTORY/backup/personal ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3197. echo ' mkdir -p $SERVER_DIRECTORY/backup/personal' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3198. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3199. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/personal " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3200. echo -n '$SERVER_DIRECTORY/backup/personal $SERVER_DIRECTORY/backup/personal.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3201. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3202. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3203. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3204. echo -n ' echo "Unable to encrypt personal settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3205. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3206. echo ' exit 649' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3207. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3208. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3209. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3210. echo '# Backup the public mailing list' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3211. echo "if [ -d $PUBLIC_MAILING_LIST_DIRECTORY ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3212. echo ' echo "Backing up the public mailing list"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3213. echo ' if [ ! -d $SERVER_DIRECTORY/backup/mailinglist ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3214. echo ' mkdir -p $SERVER_DIRECTORY/backup/mailinglist' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3215. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3216. echo -n " rsyncrypto -v -r $PUBLIC_MAILING_LIST_DIRECTORY " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3217. echo -n '$SERVER_DIRECTORY/backup/mailinglist $SERVER_DIRECTORY/backup/mailinglist.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3218. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3219. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3220. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3221. echo -n ' echo "Unable to encrypt public mailing list" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3222. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3223. echo ' exit 938' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3224. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3225. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3226. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3227. echo '# Backup xmpp settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3228. echo "if [ -d $XMPP_DIRECTORY ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3229. echo ' echo "Backing up the XMPP settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3230. echo ' if [ ! -d $SERVER_DIRECTORY/backup/xmpp ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3231. echo ' mkdir -p $SERVER_DIRECTORY/backup/xmpp' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3232. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3233. echo -n " rsyncrypto -v -r $XMPP_DIRECTORY " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3234. echo -n '$SERVER_DIRECTORY/backup/xmpp $SERVER_DIRECTORY/backup/xmpp.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3235. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3236. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3237. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3238. echo -n ' echo "Unable to encrypt XMPP settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3239. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3240. echo ' exit 593' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3241. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3242. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3243. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3244. echo '# Backup gpg keys' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3245. echo "if [ -d /home/$MY_USERNAME/.gnupg ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3246. echo ' echo "Backing up gpg keys"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3247. echo ' if [ ! -d $SERVER_DIRECTORY/backup/gnupg ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3248. echo ' mkdir -p $SERVER_DIRECTORY/backup/gnupg' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3249. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3250. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/.gnupg " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3251. echo -n '$SERVER_DIRECTORY/backup/gnupg $SERVER_DIRECTORY/backup/gnupg.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3252. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3253. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3254. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3255. echo -n ' echo "Unable to encrypt gpg keys" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3256. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3257. echo ' exit 491' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3258. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3259. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3260. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3261. echo '# Backup ssh keys' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3262. echo "if [ -d /home/$MY_USERNAME/.ssh ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3263. echo ' echo "Backing up ssh keys"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3264. echo ' if [ ! -d $SERVER_DIRECTORY/backup/ssh ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3265. echo ' mkdir -p $SERVER_DIRECTORY/backup/ssh' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3266. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3267. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/.ssh " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3268. echo -n '$SERVER_DIRECTORY/backup/ssh $SERVER_DIRECTORY/backup/ssh.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3269. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3270. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3271. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3272. echo -n ' echo "Unable to encrypt ssh keys" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3273. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3274. echo ' exit 731' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3275. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3276. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3277. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3278. echo '# Backup web sites' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3279. echo "if [ -d /etc/nginx ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3280. echo ' echo "Backing up web settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3281. echo ' if [ ! -d $SERVER_DIRECTORY/backup/web ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3282. echo ' mkdir -p $SERVER_DIRECTORY/backup/web' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3283. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3284. 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
  3285. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3286. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3287. echo ' exit 848' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3288. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3289. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3290. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3291. echo '# Backup README file' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3292. echo "if [ -f /home/$MY_USERNAME/README ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3293. echo ' echo "Backing up README"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3294. echo ' if [ ! -d $SERVER_DIRECTORY/backup/readme ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3295. echo ' mkdir -p $SERVER_DIRECTORY/backup/readme' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3296. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3297. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3298. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3299. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3300. echo " cp -f /home/$MY_USERNAME/README /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3301. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3302. echo -n '$SERVER_DIRECTORY/backup/readme $SERVER_DIRECTORY/backup/readme.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3303. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3304. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3305. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3306. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3307. echo -n ' echo "Unable to encrypt README file" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3308. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3309. echo ' exit 848' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3310. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3311. echo " rm -rf /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3312. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3313. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3314. echo '# Backup Mutt settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3315. echo "if [ -f /home/$MY_USERNAME/.muttrc ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3316. echo ' echo "Backing up Mutt settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3317. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3318. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3319. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3320. echo " cp /home/$MY_USERNAME/.muttrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3321. echo ' if [ -f /etc/Muttrc ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3322. echo " cp /etc/Muttrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3323. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3324. echo ' if [ ! -d $SERVER_DIRECTORY/backup/mutt ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3325. echo ' mkdir -p $SERVER_DIRECTORY/backup/mutt' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3326. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3327. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3328. echo -n '$SERVER_DIRECTORY/backup/mutt $SERVER_DIRECTORY/backup/mutt.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3329. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3330. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3331. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3332. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3333. echo -n ' echo "Unable to encrypt Mutt settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3334. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3335. echo ' exit 492' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3336. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3337. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3338. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3339. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3340. echo '# Backup procmail settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3341. echo "if [ -f /home/$MY_USERNAME/.procmailrc ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3342. echo ' echo "Backing up procmail settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3343. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3344. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3345. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3346. echo " cp /home/$MY_USERNAME/.procmailrc /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3347. echo ' if [ ! -d $SERVER_DIRECTORY/backup/procmail ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3348. echo ' mkdir -p $SERVER_DIRECTORY/backup/procmail' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3349. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3350. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3351. echo -n '$SERVER_DIRECTORY/backup/procmail $SERVER_DIRECTORY/backup/procmail.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3352. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3353. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3354. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3355. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3356. echo -n ' echo "Unable to encrypt procmail settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3357. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3358. echo ' exit 492' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3359. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3360. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3361. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3362. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3363. echo '# Backup spamassassin settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3364. echo "if [ -d /home/$MY_USERNAME/.spamassassin ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3365. echo ' echo "Backing up spamassassin settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3366. echo ' if [ ! -d $SERVER_DIRECTORY/backup/spamassassin ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3367. echo ' mkdir -p $SERVER_DIRECTORY/backup/spamassassin' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3368. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3369. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/.spamassassin " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3370. echo -n '$SERVER_DIRECTORY/backup/spamassassin $SERVER_DIRECTORY/backup/spamassassin.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3371. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3372. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3373. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3374. echo -n ' echo "Unable to encrypt spamassassin settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3375. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3376. echo ' exit 492' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3377. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3378. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3379. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3380. echo '# Backup email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3381. echo "if [ -d /home/$MY_USERNAME/Maildir ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3382. echo ' echo "Creating an email archive"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3383. echo ' if [ ! -d /root/backupemail ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3384. echo " mkdir -p /root/backupemail" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3385. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3386. echo " tar -czvf /root/backupemail/maildir.tar.gz /home/$MY_USERNAME/Maildir" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3387. echo ' echo "Backing up emails"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3388. echo ' if [ ! -d $SERVER_DIRECTORY/backup/mail ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3389. echo ' mkdir -p $SERVER_DIRECTORY/backup/mail' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3390. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3391. echo -n ' rsyncrypto -v -r /root/backupemail ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3392. echo -n '$SERVER_DIRECTORY/backup/mail $SERVER_DIRECTORY/backup/mail.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3393. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3394. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3395. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3396. echo -n ' echo "Unable to encrypt emails" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3397. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3398. echo ' exit 396' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3399. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3400. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3401. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3402. echo '# Backup DLNA cache' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3403. echo "if [ -d /var/cache/minidlna ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3404. echo ' echo "Backing up DLNA cache"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3405. echo ' if [ ! -d $SERVER_DIRECTORY/backup/dlna ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3406. echo ' mkdir -p $SERVER_DIRECTORY/backup/dlna' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3407. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3408. echo -n ' rsyncrypto -v -r /var/cache/minidlna $SERVER_DIRECTORY/backup/dlna $SERVER_DIRECTORY/backup/dlna.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3409. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3410. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3411. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3412. echo -n ' echo "Unable to encrypt DLNA settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3413. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3414. echo ' exit 498' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3415. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3416. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3417. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3418. echo '# Backup VoIP settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3419. echo "if [ -f /etc/$VOIP_CONFIG_FILE ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3420. echo ' echo "Backing up VoIP settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3421. echo " if [ ! -d /home/$MY_USERNAME/tempbackup ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3422. echo " mkdir -p /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3423. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3424. echo " cp -f /etc/$VOIP_CONFIG_FILE /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3425. echo " cp -f /var/lib/mumble-server/$VOIP_DATABASE /home/$MY_USERNAME/tempbackup" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3426. echo ' if [ ! -d $SERVER_DIRECTORY/backup/voip ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3427. echo ' mkdir -p $SERVER_DIRECTORY/backup/voip' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3428. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3429. echo -n " rsyncrypto -v -r /home/$MY_USERNAME/tempbackup " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3430. echo -n '$SERVER_DIRECTORY/backup/voip $SERVER_DIRECTORY/backup/voip.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3431. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3432. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3433. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3434. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3435. echo -n ' echo "Unable to encrypt VoIP settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3436. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3437. echo ' exit 4923' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3438. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3439. echo ' rm -rf /home/$MY_USERNAME/tempbackup' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3440. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3441. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3442. if [[ $BACKUP_INCLUDES_DATABASES == "yes" ]]; then
  3443. echo '# Mysql settings' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3444. echo 'if [ ! -d $SERVER_DIRECTORY/backup/mariadb ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3445. echo ' mkdir -p $SERVER_DIRECTORY/backup/mariadb' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3446. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3447. echo 'if [ ! -d /root/tempmariadb ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3448. echo ' mkdir /root/tempmariadb' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3449. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3450. echo 'mysqldump --password=$DATABASE_PASSWORD mysql user > /root/tempmariadb/mysql.sql' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3451. echo "if [ ! -s /root/tempmariadb/mysql.sql ]; then" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3452. echo ' echo "Unable to backup mysql settings"' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3453. echo ' rm -rf /root/tempmariadb' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3454. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3455. echo -n ' echo "Unable to export database settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3456. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3457. echo ' exit 653' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3458. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3459. echo 'echo "$DATABASE_PASSWORD" > /root/tempmariadb/db' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3460. echo 'chmod 400 /root/tempmariadb/db' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3461. echo -n 'rsyncrypto -v -r /root/tempmariadb $SERVER_DIRECTORY/backup/mariadb $SERVER_DIRECTORY/backup/mariadb.keys ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3462. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3463. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3464. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3465. echo -n ' echo "Unable to encrypt database settings" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3466. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3467. echo ' exit 794' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3468. echo 'fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3469. echo 'rm -rf /root/tempmariadb' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3470. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3471. fi
  3472. # Now that we have the server directory updated with the encrypted backup
  3473. # we just need to rsync it to each friend
  3474. echo '# For each remote server' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3475. echo 'while read remote_server' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3476. echo 'do' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3477. echo ' # Get the server and its password' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3478. echo ' # Format is:' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3479. echo ' # username@domain:/home/username <port number> <ssh password>' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3480. echo -n ' REMOTE_SERVER=$(echo "${remote_server}" | ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3481. echo -n "awk -F ' ' '{print " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3482. echo -n '$1' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3483. echo "}')" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3484. echo ' if [ $REMOTE_SERVER ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3485. echo -n ' REMOTE_SSH_PORT=$(echo "${remote_server}" | ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3486. echo -n "awk -F ' ' '{print " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3487. echo -n '$2' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3488. echo "}')" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3489. echo -n ' REMOTE_PASSWORD=$(echo "${remote_server}" | ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3490. echo -n "awk -F ' ' '{print " >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3491. echo -n '$3' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3492. echo "}')" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3493. echo ' NOW=$(date +"%Y-%m-%d %H:%M:%S")' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3494. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3495. echo -n ' echo "$NOW Starting backup to $REMOTE_SERVER" >> ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3496. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3497. 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
  3498. echo '$SERVER_DIRECTORY/backup $REMOTE_SERVER' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3499. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3500. echo -n ' echo "$NOW Backup to $REMOTE_SERVER failed" >> ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3501. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3502. echo ' # Send a warning email' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3503. echo -n ' echo "Backup to $REMOTE_SERVER failed" | mail -s "Freedombone backup to friends" ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3504. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3505. echo ' else' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3506. echo -n ' echo "$NOW Backed up to $REMOTE_SERVER" >> ' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3507. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3508. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3509. echo ' fi' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3510. # End of the loop
  3511. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3512. echo "done < $FRIENDS_SERVERS_LIST" >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3513. echo '' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3514. echo 'exit 0' >> /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3515. chown root:root /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3516. chmod 400 /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3517. chmod +x /usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME
  3518. # update crontab
  3519. echo '#!/bin/bash' > /etc/cron.daily/backuptofriends
  3520. echo "/usr/bin/$BACKUP_TO_FRIENDS_SCRIPT_NAME" >> /etc/cron.daily/backuptofriends
  3521. chmod +x /etc/cron.daily/backuptofriends
  3522. echo 'backup_to_friends_servers' >> $COMPLETION_FILE
  3523. }
  3524. function restore_from_friend {
  3525. if grep -Fxq "restore_from_friend" $COMPLETION_FILE; then
  3526. return
  3527. fi
  3528. apt-get -y install rsyncrypto sshpass
  3529. get_mariadb_password
  3530. get_mariadb_gnusocial_admin_password
  3531. get_mariadb_redmatrix_admin_password
  3532. get_mariadb_owncloud_admin_password
  3533. get_mariadb_git_admin_password
  3534. if ! grep -q "restore from a friend's server" /home/$MY_USERNAME/README; then
  3535. echo '' >> /home/$MY_USERNAME/README
  3536. echo '' >> /home/$MY_USERNAME/README
  3537. echo 'Restoring from backups to friends servers' >> /home/$MY_USERNAME/README
  3538. echo '=========================================' >> /home/$MY_USERNAME/README
  3539. echo "To restore from a friend's server use the command:" >> /home/$MY_USERNAME/README
  3540. echo '' >> /home/$MY_USERNAME/README
  3541. echo " $RESTORE_FROM_FRIEND_SCRIPT_NAME [server]" >> /home/$MY_USERNAME/README
  3542. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  3543. fi
  3544. echo '#!/bin/bash' > /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3545. echo 'SERVER_NAME=$1' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3546. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3547. echo '# Temporary location for data to be backed up to other servers' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3548. echo 'SERVER_DIRECTORY=/root/remoterestore' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3549. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3550. echo 'if [ ! $SERVER_NAME ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3551. echo " echo '$RESTORE_FROM_FRIEND_SCRIPT_NAME [server]'" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3552. echo ' exit 1' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3553. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3554. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3555. echo "if [ ! -f $FRIENDS_SERVERS_LIST ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3556. echo " echo 'No friends list found at $FRIENDS_SERVERS_LIST'" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3557. echo ' exit 2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3558. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3559. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3560. echo -n 'if ! grep -q "$SERVER_NAME" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3561. echo "$FRIENDS_SERVERS_LIST; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3562. echo ' echo "Server not found within the friends list"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3563. echo ' exit 3' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3564. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3565. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3566. echo -n 'REMOTE_SERVER=$(grep -i "$SERVER_NAME" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3567. echo -n "$FRIENDS_SERVERS_LIST | awk -F ' ' '{print " >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3568. echo -n '$1' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3569. echo "}')" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3570. echo -n 'REMOTE_SSH_PORT=$(grep -i "$SERVER_NAME" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3571. echo -n "$FRIENDS_SERVERS_LIST | awk -F ' ' '{print " >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3572. echo -n '$2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3573. echo "}')" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3574. echo -n 'REMOTE_PASSWORD=$(grep -i "$SERVER_NAME" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3575. echo -n "$FRIENDS_SERVERS_LIST | awk -F ' ' '{print " >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3576. echo -n '$3' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3577. echo "}')" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3578. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3579. echo '# Check that a backup key exists' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3580. echo "if [ ! -f $BACKUP_CERTIFICATE ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3581. echo " echo 'No backup key was found in $BACKUP_CERTIFICATE'" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3582. echo ' exit 84' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3583. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3584. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3585. # Rsync from the remote server back to this server
  3586. echo 'NOW=$(date +"%Y-%m-%d %H:%M:%S")' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3587. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3588. echo -n 'echo "$NOW Starting restore from $REMOTE_SERVER" >> ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3589. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3590. 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
  3591. echo '$REMOTE_SERVER/backup $SERVER_DIRECTORY' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3592. echo 'if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3593. echo -n ' echo "$NOW Restore from $REMOTE_SERVER failed" >> ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3594. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3595. echo ' # Send a warning email' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3596. echo -n ' echo "Restore from $REMOTE_SERVER failed" | mail -s "Freedombone restore from friend" ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3597. echo "$MY_EMAIL_ADDRESS" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3598. echo ' exit 790' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3599. echo 'else' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3600. echo -n ' echo "$NOW Restored encrypted data from $REMOTE_SERVER" >> ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3601. echo "$REMOTE_BACKUPS_LOG" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3602. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3603. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3604. echo '# MariaDB password' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3605. echo -n 'DATABASE_PASSWORD=$(cat ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3606. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3607. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3608. echo 'if [ -d $SERVER_DIRECTORY/backup/mariadb ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3609. echo ' echo "Restoring mysql settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3610. echo ' if [ ! -d /root/tempmariadb ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3611. echo ' mkdir /root/tempmariadb' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3612. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3613. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/mariadb /root/tempmariadb $SERVER_DIRECTORY/backup/mariadb.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3614. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3615. echo ' echo "Get the MariaDB password from the backup"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3616. echo ' if [ ! -f /root/tempmariadb/remoterestore/backup/mariadb/tempmariadb/db ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3617. echo ' echo "MariaDB password file not found"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3618. echo ' exit 495' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3619. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3620. echo ' BACKUP_MARIADB_PASSWORD=$(cat /root/tempmariadb/remoterestore/backup/mariadb/tempmariadb/db)' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3621. echo ' if [[ $BACKUP_MARIADB_PASSWORD != $DATABASE_PASSWORD ]]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3622. echo ' echo "Restore the MariaDB user table"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3623. 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
  3624. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3625. echo ' echo "Try again using the password obtained from backup"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3626. 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
  3627. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3628. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3629. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3630. echo ' exit 962' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3631. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3632. echo ' echo "Restarting database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3633. echo ' service mysql restart' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3634. echo ' echo "Change the MariaDB password to the backup version"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3635. echo ' DATABASE_PASSWORD=$BACKUP_MARIADB_PASSWORD' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3636. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3637. echo ' shred -zu /root/tempmariadb/remoterestore/backup/mariadb/tempmariadb/db' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3638. echo ' rm -rf /root/tempmariadb' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3639. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3640. echo ' # Change database password file' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3641. echo -n ' echo "$DATABASE_PASSWORD" > ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3642. echo "$DATABASE_PASSWORD_FILE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3643. echo " chmod 600 $DATABASE_PASSWORD_FILE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3644. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3645. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3646. echo 'if [ -d $SERVER_DIRECTORY/backup/mutt ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3647. echo ' echo "Restoring Mutt settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3648. echo ' mkdir /root/tempmutt' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3649. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/mutt /root/tempmutt $SERVER_DIRECTORY/backup/mutt.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3650. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3651. echo " if [ -f /root/tempmutt/remoterestore/backup/mutt/$MY_USERNAME/tempbackup/.muttrc ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3652. echo " cp -f /root/tempmutt/remoterestore/backup/mutt/$MY_USERNAME/tempbackup/.muttrc /home/$MY_USERNAME/.muttrc" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3653. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3654. echo " if [ -f /root/tempmutt/remoterestore/backup/mutt/$MY_USERNAME/tempbackup/Muttrc ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3655. echo " cp -f /root/tempmutt/remoterestore/backup/mutt/$MY_USERNAME/tempbackup/Muttrc /etc/Muttrc" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3656. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3657. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3658. echo ' rm -rf /root/tempmutt' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3659. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3660. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3661. echo ' rm -rf /root/tempmutt' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3662. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3663. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3664. echo 'if [ -d $SERVER_DIRECTORY/backup/gnupg ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3665. echo ' echo "Restoring gnupg settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3666. echo ' mkdir /root/tempgnupg' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3667. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gnupg /root/tempgnupg $SERVER_DIRECTORY/backup/gnupg.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3668. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3669. echo " cp -r /root/tempgnupg/remoterestore/backup/gnupg/$MY_USERNAME/.gnupg /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3670. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3671. echo ' rm -rf /root/tempgnupg' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3672. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3673. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3674. echo ' rm -rf /root/tempgnupg' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3675. echo " cp -r /home/$MY_USERNAME/.gnupg /root" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3676. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3677. echo ' exit 283' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3678. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3679. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3680. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3681. echo 'if [ -d $SERVER_DIRECTORY/backup/procmail ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3682. echo ' echo "Restoring procmail settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3683. echo ' mkdir /root/tempprocmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3684. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/procmail /root/tempprocmail $SERVER_DIRECTORY/backup/procmail.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3685. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3686. echo " cp -f /root/tempprocmail/remoterestore/backup/procmail/$MY_USERNAME/tempbackup/.procmailrc /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3687. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3688. echo ' rm -rf /root/tempprocmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3689. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3690. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3691. echo ' rm -rf /root/tempprocmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3692. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3693. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3694. echo 'if [ -d $SERVER_DIRECTORY/backup/spamassassin ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3695. echo ' echo "Restoring spamassassin settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3696. echo ' mkdir /root/tempspamassassin' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3697. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/spamassassin /root/tempspamassassin $SERVER_DIRECTORY/backup/spamassassin.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3698. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3699. echo " cp -rf /root/tempspamassassin/remoterestore/backup/spamassassin/$MY_USERNAME/.spamassassin /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3700. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3701. echo ' rm -rf /root/tempspamassassin' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3702. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3703. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3704. echo ' rm -rf /root/tempspamassassin' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3705. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3706. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3707. echo 'if [ -d $SERVER_DIRECTORY/backup/readme ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3708. echo ' echo "Restoring README"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3709. echo ' mkdir /root/tempreadme' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3710. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/readme /root/tempreadme $SERVER_DIRECTORY/backup/readme.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3711. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3712. echo " cp -f /root/tempreadme/remoterestore/backup/readme/$MY_USERNAME/tempbackup/README /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3713. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3714. echo ' rm -rf /root/tempreadme' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3715. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3716. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3717. echo ' rm -rf /root/tempreadme' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3718. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3719. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3720. echo 'if [ -d $SERVER_DIRECTORY/backup/ssh ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3721. echo ' echo "Restoring ssh keys"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3722. echo ' mkdir /root/tempssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3723. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/ssh /root/tempssh $SERVER_DIRECTORY/backup/ssh.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3724. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3725. echo " cp -r /root/tempssh/remoterestore/backup/ssh/$MY_USERNAME/.ssh /home/$MY_USERNAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3726. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3727. echo ' rm -rf /root/tempssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3728. echo ' exit 664' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3729. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3730. echo ' rm -rf /root/tempssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3731. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3732. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3733. echo 'if [ -d $SERVER_DIRECTORY/backup/ssl ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3734. echo ' echo "Restoring certificates"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3735. echo ' mkdir /root/tempssl' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3736. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/ssl /root/tempssl $SERVER_DIRECTORY/backup/ssl.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3737. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3738. echo ' cp -r /root/tempssl/remoterestore/backup/ssl/ssl/* /etc/ssl' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3739. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3740. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3741. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3742. echo ' rm -rf /root/tempssl' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3743. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3744. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3745. echo 'if [ -d $SERVER_DIRECTORY/backup/projects ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3746. echo ' echo "Restoring projects"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3747. echo ' mkdir /root/tempprojects' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3748. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/projects /root/tempprojects $SERVER_DIRECTORY/backup/projects.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3749. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3750. echo " if [ -d /home/$MY_USERNAME/projects ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3751. echo " rm -rf /home/$MY_USERNAME/projects" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3752. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3753. echo " mv /root/tempprojects/remoterestore/backup/projects/$MY_USERNAME/projects /home/$MY_USERNAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3754. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3755. echo ' exit 166' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3756. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3757. echo ' rm -rf /root/tempprojects' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3758. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3759. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3760. echo 'if [ -d $SERVER_DIRECTORY/backup/personal ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3761. echo ' echo "Restoring personal settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3762. echo ' mkdir /root/temppersonal' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3763. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/personal /root/temppersonal $SERVER_DIRECTORY/backup/personal.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3764. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3765. echo " if [ -d /home/$MY_USERNAME/personal ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3766. echo " rm -rf /home/$MY_USERNAME/personal" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3767. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3768. echo " mv /root/temppersonal/remoterestore/backup/personal/$MY_USERNAME/personal /home/$MY_USERNAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3769. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3770. echo ' exit 184' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3771. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3772. echo ' rm -rf /root/temppersonal' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3773. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3774. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3775. echo "if [ -d $PUBLIC_MAILING_LIST_DIRECTORY ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3776. echo ' echo "Restoring public mailing list"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3777. echo ' mkdir /root/tempmailinglist' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3778. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/mailinglist /root/tempmailinglist $SERVER_DIRECTORY/backup/mailinglist.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3779. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3780. echo " cp -r /root/tempmailinglist/remoterestore/backup/mailinglist/spool/mlmmj/* $PUBLIC_MAILING_LIST_DIRECTORY" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3781. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3782. echo ' exit 526' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3783. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3784. echo ' rm -rf /root/tempmailinglist' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3785. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3786. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3787. echo "if [ -d $XMPP_DIRECTORY ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3788. echo ' echo "Restoring XMPP settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3789. echo ' mkdir /root/tempxmpp' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3790. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/xmpp /root/tempxmpp $SERVER_DIRECTORY/backup/xmpp.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3791. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3792. echo " cp -r /root/tempxmpp/remoterestore/backup/xmpp/lib/prosody/* $XMPP_DIRECTORY" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3793. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3794. echo ' exit 725' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3795. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3796. echo ' rm -rf /root/tempxmpp' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3797. echo ' service prosody restart' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3798. echo ' chown -R prosody:prosody /var/lib/prosody/*' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3799. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3800. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3801. BACKUP_INCLUDES_WEBSITES="no"
  3802. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  3803. BACKUP_INCLUDES_WEBSITES="yes"
  3804. echo 'if [ -d $SERVER_DIRECTORY/backup/gnusocial ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3805. echo ' echo "Restoring microblog database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3806. echo ' if [ ! -d /root/tempgnusocialdata ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3807. echo ' mkdir /root/tempgnusocialdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3808. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3809. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gnusocialdata /root/tempgnusocialdata $SERVER_DIRECTORY/backup/gnusocialdata.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3810. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3811. echo ' if [ ! -f /root/tempgnusocialdata/remoterestore/backup/gnusocialdata/tempgnusocialdata/gnusocial.sql ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3812. echo ' echo "Unable to restore microblog database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3813. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3814. echo ' exit 503' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3815. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3816. 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
  3817. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3818. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3819. echo ' exit 964' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3820. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3821. echo ' shred -zu /root/tempgnusocialdata/remoterestore/backup/gnusocialdata/tempgnusocialdata/*' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3822. echo ' rm -rf /root/tempgnusocialdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3823. echo ' echo "Restoring microblog installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3824. echo ' if [ ! -d /root/tempgnusocial ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3825. echo ' mkdir /root/tempgnusocial' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3826. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3827. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gnusocial /root/tempgnusocial $SERVER_DIRECTORY/backup/gnusocial.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3828. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3829. echo " rm -rf /var/www/$MICROBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3830. echo " mv /root/tempgnusocial/remoterestore/backup/gnusocial/www/$MICROBLOG_DOMAIN_NAME/htdocs /var/www/$MICROBLOG_DOMAIN_NAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3831. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3832. echo ' exit 683' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3833. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3834. echo ' rm -rf /root/tempgnusocial' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3835. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3836. echo " if [ -f /etc/ssl/certs/$MICROBLOG_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3837. echo " sed -i 's|$MICROBLOG_DOMAIN_NAME.crt|$MICROBLOG_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3838. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3839. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3840. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3841. fi
  3842. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  3843. BACKUP_INCLUDES_WEBSITES="yes"
  3844. echo 'if [ -d $SERVER_DIRECTORY/backup/redmatrix ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3845. echo ' echo "Restoring Red Matrix database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3846. echo ' if [ ! -d /root/tempredmatrixdata ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3847. echo ' mkdir /root/tempredmatrixdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3848. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3849. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/redmatrixdata /root/tempredmatrixdata $SERVER_DIRECTORY/backup/redmatrixdata.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3850. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3851. echo ' if [ ! -f /root/tempredmatrixdata/remoterestore/backup/redmatrixdata/tempredmatrixdata/redmatrix.sql ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3852. echo ' echo "Unable to restore Red Matrix database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3853. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3854. echo ' exit 504' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3855. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3856. 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
  3857. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3858. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3859. echo ' exit 965' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3860. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3861. echo ' shred -zu /root/tempredmatrixdata/remoterestore/backup/redmatrixdata/tempredmatrixdata/*' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3862. echo ' rm -rf /root/tempredmatrixdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3863. echo ' echo "Restoring Red Matrix installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3864. echo ' if [ ! -d /root/tempredmatrix ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3865. echo ' mkdir /root/tempredmatrix' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3866. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3867. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/redmatrix /root/tempredmatrix $SERVER_DIRECTORY/backup/redmatrix.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3868. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3869. echo " rm -rf /var/www/$REDMATRIX_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3870. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3871. 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
  3872. echo ' else' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3873. echo " mv /root/tempredmatrix/remoterestore/backup/redmatrix/www/$REDMATRIX_DOMAIN_NAME/htdocs /var/www/$REDMATRIX_DOMAIN_NAME/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3874. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3875. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3876. echo ' exit 759' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3877. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3878. echo ' rm -rf /root/tempredmatrix' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3879. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3880. echo " if [ -f /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3881. echo " sed -i 's|$REDMATRIX_DOMAIN_NAME.crt|$REDMATRIX_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3882. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3883. echo " chmod 777 /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3884. echo " chown -R www-data:www-data /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/*" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3885. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3886. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3887. fi
  3888. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  3889. BACKUP_INCLUDES_WEBSITES="yes"
  3890. echo 'if [ -d $SERVER_DIRECTORY/backup/owncloud ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3891. echo ' echo "Restoring owncloud database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3892. echo ' if [ ! -d /root/tempownclouddata ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3893. echo ' mkdir /root/tempownclouddata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3894. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3895. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/ownclouddata /root/tempownclouddata $SERVER_DIRECTORY/backup/ownclouddata.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3896. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3897. echo ' if [ ! -f /root/tempownclouddata/remoterestore/backup/ownclouddata/tempownclouddata/owncloud.sql ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3898. echo ' echo "Unable to restore Owncloud database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3899. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3900. echo ' exit 505' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3901. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3902. 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
  3903. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3904. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3905. echo ' exit 965' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3906. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3907. echo ' echo "Restoring Owncloud installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3908. echo ' if [ ! -d /root/tempowncloud ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3909. echo ' mkdir /root/tempowncloud' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3910. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3911. echo ' if [ ! -d /root/tempowncloud2 ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3912. echo ' mkdir /root/tempowncloud2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3913. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3914. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/owncloud /root/tempowncloud $SERVER_DIRECTORY/backup/owncloud.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3915. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3916. echo " cp -r /root/tempowncloud/remoterestore/backup/owncloud/lib/owncloud/* /var/lib/owncloud/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3917. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3918. echo ' exit 981' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3919. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3920. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/owncloud2 /root/tempowncloud2 $SERVER_DIRECTORY/backup/owncloud2.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3921. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3922. echo " cp -r /root/tempowncloud2/remoterestore/backup/owncloud2/owncloud/* /etc/owncloud/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3923. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3924. echo ' exit 982' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3925. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3926. echo ' rm -rf /root/tempowncloud' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3927. echo ' rm -rf /root/tempowncloud2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3928. echo ' rm -rf /root/tempownclouddata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3929. echo ' chown -R www-data:www-data /var/lib/owncloud/data' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3930. echo ' chown -R www-data:www-data /var/lib/owncloud/backup' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3931. echo ' chown -R www-data:www-data /var/lib/owncloud/assets' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3932. echo " occ files:scan $MY_USERNAME" >> /usr/bin/$RESTORE_SCRIPT_NAME
  3933. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3934. echo " if [ -f /etc/ssl/certs/$OWNCLOUD_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3935. echo " sed -i 's|$OWNCLOUD_DOMAIN_NAME.crt|$OWNCLOUD_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3936. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3937. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3938. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3939. fi
  3940. if grep -Fxq "install_gogs" $COMPLETION_FILE; then
  3941. BACKUP_INCLUDES_WEBSITES="yes"
  3942. echo 'if [ -d $SERVER_DIRECTORY/backup/gogs ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3943. echo ' echo "Restoring gogs database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3944. echo ' if [ ! -d /root/tempgogsdata ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3945. echo ' mkdir /root/tempgogsdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3946. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3947. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gogsdata /root/tempgogsdata $SERVER_DIRECTORY/backup/gogsdata.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3948. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3949. echo ' if [ ! -f /root/tempgogsdata/remoterestore/backup/gogsdata/tempgogsdata/gogs.sql ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3950. echo ' echo "Unable to restore Gogs database"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3951. echo ' rm -rf /root/tempgogsdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3952. echo ' exit 8548' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3953. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3954. echo ' mysqlsuccess=$(mysql -u root --password=$DATABASE_PASSWORD gogs -o < /root/tempgogsdata/remoterestore/backup/gogsdata/tempgogsdata/gogs.sql)' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3955. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3956. echo ' echo "$mysqlsuccess"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3957. echo ' exit 3695' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3958. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3959. echo ' echo "Restoring Gogs settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3960. echo ' if [ ! -d /root/tempgogs ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3961. echo ' mkdir /root/tempgogs' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3962. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3963. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gogs /root/tempgogs $SERVER_DIRECTORY/backup/gogs.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3964. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3965. echo ' if [ ! -d /home/git/go/src/github.com/gogits/gogs/custom ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3966. echo ' mkdir -p /home/git/go/src/github.com/gogits/gogs/custom' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3967. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3968. echo " cp -r /root/tempgogs/remoterestore/backup/gogs/git/go/src/github.com/gogits/gogs/custom/* /home/git/go/src/github.com/gogits/gogs/custom/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3969. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3970. echo ' exit 5885' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3971. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3972. echo ' echo "Restoring Gogs repos"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3973. echo ' if [ ! -d /root/tempgogsrepos ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3974. echo ' mkdir /root/tempgogsrepos' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3975. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3976. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gogsrepos /root/tempgogsrepos $SERVER_DIRECTORY/backup/gogsrepos.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3977. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3978. echo " cp -r /root/tempgogsrepos/remoterestore/backup/gogsrepos/git/gogs-repositories/* /home/git/gogs-repositories/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3979. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3980. echo ' exit 7649' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3981. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3982. echo ' echo "Restoring Gogs authorized_keys"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3983. echo ' if [ ! -d /root/tempgogsssh ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3984. echo ' mkdir /root/tempgogsssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3985. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3986. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/gogsssh /root/tempgogsssh $SERVER_DIRECTORY/backup/gogsssh.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3987. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3988. echo ' if [ ! -d /home/git/.ssh ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3989. echo ' mkdir /home/git/.ssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3990. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3991. echo " cp -r /root/tempgogsssh/remoterestore/backup/gogsssh/git/.ssh/* /home/git/.ssh/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3992. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3993. echo ' exit 74239' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3994. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3995. echo ' rm -rf /root/tempgogs' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3996. echo ' rm -rf /root/tempgogsdata' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3997. echo ' rm -rf /root/tempgogsrepos' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3998. echo ' rm -rf /root/tempgogsssh' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  3999. echo ' chown -R git:git /home/git' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4000. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4001. echo " if [ -f /etc/ssl/certs/$GIT_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4002. echo " sed -i 's|$GIT_DOMAIN_NAME.crt|$GIT_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$GIT_DOMAIN_NAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4003. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4004. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4005. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4006. fi
  4007. echo 'if [ -d $SERVER_DIRECTORY/backup/wiki ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4008. echo ' echo "Restoring Wiki installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4009. echo ' mkdir /root/tempwiki' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4010. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/wiki /root/tempwiki $SERVER_DIRECTORY/backup/wiki.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4011. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4012. echo " cp -r /root/tempwiki/remoterestore/backup/wiki/lib/dokuwiki/* /var/lib/dokuwiki/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4013. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4014. echo ' exit 868' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4015. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4016. echo ' mkdir /root/tempwiki2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4017. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/wiki2 /root/tempwiki2 $SERVER_DIRECTORY/backup/wiki2.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4018. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4019. echo " cp -r /root/tempwiki2/remoterestore/backup/wiki2/dokuwiki/* /etc/dokuwiki/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4020. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4021. echo ' exit 869' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4022. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4023. echo ' rm -rf /root/tempwiki' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4024. echo ' rm -rf /root/tempwiki2' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4025. echo ' chown -R www-data:www-data /var/lib/dokuwiki/*' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4026. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4027. echo " if [ -f /etc/ssl/certs/$WIKI_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4028. echo " sed -i 's|$WIKI_DOMAIN_NAME.crt|$WIKI_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$WIKI_DOMAIN_NAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4029. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4030. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4031. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4032. echo 'if [ -d $SERVER_DIRECTORY/backup/blog ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4033. echo ' echo "Restoring blog installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4034. echo ' mkdir /root/tempblog' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4035. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/blog /root/tempblog $SERVER_DIRECTORY/backup/blog.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4036. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4037. echo " rm -rf /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4038. 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
  4039. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4040. echo ' exit 593' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4041. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4042. echo ' rm -rf /root/tempblog' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4043. echo " if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/content ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4044. echo ' echo "No content directory found after restoring blog"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4045. echo ' exit 287' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4046. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4047. echo ' # Ensure that the bundled SSL cert is being used' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4048. echo " if [ -f /etc/ssl/certs/$FULLBLOG_DOMAIN_NAME.bundle.crt ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4049. echo " sed -i 's|$FULLBLOG_DOMAIN_NAME.crt|$FULLBLOG_DOMAIN_NAME.bundle.crt|g' /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4050. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4051. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4052. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4053. echo 'if [ -d $SERVER_DIRECTORY/backup/cjdns ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4054. echo ' echo "Restoring cjdns installation"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4055. echo ' mkdir /root/tempcjdns' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4056. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/cjdns /root/tempcjdns $SERVER_DIRECTORY/backup/cjdns.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4057. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4058. echo " rm -rf /etc/cjdns" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4059. echo " cp -r /root/tempcjdns/remoterestore/backup/cjdns/cjdns /etc/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4060. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4061. echo ' exit 7438' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4062. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4063. echo ' rm -rf /root/tempcjdns' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4064. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4065. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4066. echo 'if [ -d $SERVER_DIRECTORY/backup/voip ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4067. echo ' echo "Restoring VoIP settings"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4068. echo ' mkdir /root/tempvoip' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4069. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/voip /root/tempvoip $SERVER_DIRECTORY/backup/voip.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4070. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4071. echo " cp -f /root/tempvoip/remoterestore/backup/voip/$MY_USERNAME/tempbackup/$VOIP_CONFIG_FILE /etc/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4072. echo " cp -f /root/tempvoip/remoterestore/backup/voip/$MY_USERNAME/tempbackup/$VOIP_DATABASE /var/lib/mumble-server/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4073. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4074. echo ' rm -rf /root/tempvoip' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4075. echo ' exit 276' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4076. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4077. echo ' rm -rf /root/tempvoip' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4078. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4079. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4080. echo 'if [ -d $SERVER_DIRECTORY/backup/mail ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4081. echo ' echo "Restoring emails"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4082. echo ' mkdir /root/tempmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4083. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/mail /root/tempmail $SERVER_DIRECTORY/backup/mail.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4084. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4085. echo " if [ ! -d /home/$MY_USERNAME/Maildir ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4086. echo " mkdir /home/$MY_USERNAME/Maildir" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4087. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4088. echo ' tar -xzvf /root/tempmail/usb/backup/mail/backupemail/maildir.tar.gz' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4089. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4090. echo ' exit 927' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4091. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4092. echo ' rm -rf /root/tempmail' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4093. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4094. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4095. echo "if [ -d /var/cache/minidlna ]; then" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4096. echo ' if [ -d $SERVER_DIRECTORY/backup/dlna ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4097. echo ' echo "Restoring DLNA cache"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4098. echo ' mkdir /root/tempdlna' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4099. echo -n ' rsyncrypto -v -d -r $SERVER_DIRECTORY/backup/dlna /root/tempdlna $SERVER_DIRECTORY/backup/dlna.keys ' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4100. echo "$BACKUP_CERTIFICATE" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4101. echo " cp -r /root/tempdlna/remoterestore/backup/dlna/cache/minidlna/* /var/cache/minidlna/" >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4102. echo ' if [ ! "$?" = "0" ]; then' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4103. echo ' exit 982' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4104. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4105. echo ' rm -rf /root/tempdlna' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4106. echo ' fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4107. echo 'fi' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4108. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4109. echo 'echo "*** Remote restore was successful ***"' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4110. echo '' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4111. echo 'exit 0' >> /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4112. chmod 400 /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4113. chmod +x /usr/bin/$RESTORE_FROM_FRIEND_SCRIPT_NAME
  4114. echo 'restore_from_friend' >> $COMPLETION_FILE
  4115. }
  4116. function remove_default_user {
  4117. # make sure you don't use the default user account
  4118. if [[ $MY_USERNAME == "debian" ]]; then
  4119. echo 'Do not use the default debian user account. Create a different user with: adduser [username]'
  4120. exit 68
  4121. fi
  4122. # remove the default debian user to prevent it from becoming an attack vector
  4123. if [ -d /home/debian ]; then
  4124. userdel -r debian
  4125. echo 'Default debian user account removed'
  4126. fi
  4127. }
  4128. function enforce_good_passwords {
  4129. # because humans are generally bad at choosing passwords
  4130. if grep -Fxq "enforce_good_passwords" $COMPLETION_FILE; then
  4131. return
  4132. fi
  4133. apt-get -y install libpam-cracklib
  4134. 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
  4135. echo 'enforce_good_passwords' >> $COMPLETION_FILE
  4136. }
  4137. function change_login_message {
  4138. if grep -Fxq "change_login_message" $COMPLETION_FILE; then
  4139. return
  4140. fi
  4141. echo '' > /etc/motd
  4142. echo ".---. . . " >> /etc/motd
  4143. echo "| | | " >> /etc/motd
  4144. echo "|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-. " >> /etc/motd
  4145. echo "| | (.-' (.-' ( | ( )| | | | )( )| | (.-' " >> /etc/motd
  4146. echo "' ' --' --' -' - -' ' ' -' -' -' ' - --'" >> /etc/motd
  4147. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  4148. echo ' M A I L B O X E D I T I O N' >> /etc/motd
  4149. fi
  4150. if [[ $SYSTEM_TYPE == "$VARIANT_SOCIAL" ]]; then
  4151. echo ' S O C I A L E D I T I O N' >> /etc/motd
  4152. fi
  4153. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  4154. echo ' C H A T E D I T I O N' >> /etc/motd
  4155. fi
  4156. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  4157. echo ' C L O U D E D I T I O N' >> /etc/motd
  4158. fi
  4159. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" ]]; then
  4160. echo ' W R I T E R E D I T I O N ' >> /etc/motd
  4161. fi
  4162. if [[ $SYSTEM_TYPE == "$VARIANT_MEDIA" ]]; then
  4163. echo ' M E D I A E D I T I O N' >> /etc/motd
  4164. fi
  4165. if [[ $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  4166. echo ' D E V E L O P E R E D I T I O N' >> /etc/motd
  4167. fi
  4168. echo '' >> /etc/motd
  4169. echo ' Freedom in the Cloud' >> /etc/motd
  4170. echo '' >> /etc/motd
  4171. echo 'change_login_message' >> $COMPLETION_FILE
  4172. }
  4173. function search_for_attached_usb_drive {
  4174. # If a USB drive is attached then search for email,
  4175. # gpg, ssh keys and emacs configuration
  4176. if grep -Fxq "search_for_attached_usb_drive" $COMPLETION_FILE; then
  4177. return
  4178. fi
  4179. if [ -b $USB_DRIVE ]; then
  4180. if [ ! -d $USB_MOUNT ]; then
  4181. echo 'Mounting USB drive'
  4182. mkdir $USB_MOUNT
  4183. mount $USB_DRIVE $USB_MOUNT
  4184. fi
  4185. if ! [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  4186. if [ -d $USB_MOUNT/Maildir ]; then
  4187. echo 'Maildir found on USB drive'
  4188. IMPORT_MAILDIR=$USB_MOUNT/Maildir
  4189. fi
  4190. if [ -d $USB_MOUNT/.gnupg ]; then
  4191. echo 'Importing GPG keyring'
  4192. cp -r $USB_MOUNT/.gnupg /home/$MY_USERNAME
  4193. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.gnupg
  4194. GPG_KEYS_IMPORTED="yes"
  4195. if [ -f /home/$MY_USERNAME/.gnupg/secring.gpg ]; then
  4196. shred -zu $USB_MOUNT/.gnupg/secring.gpg
  4197. shred -zu $USB_MOUNT/.gnupg/random_seed
  4198. shred -zu $USB_MOUNT/.gnupg/trustdb.gpg
  4199. rm -rf $USB_MOUNT/.gnupg
  4200. else
  4201. echo 'GPG files did not copy'
  4202. exit 7
  4203. fi
  4204. fi
  4205. if [ -f $USB_MOUNT/.procmailrc ]; then
  4206. echo 'Importing procmail settings'
  4207. cp $USB_MOUNT/.procmailrc /home/$MY_USERNAME
  4208. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  4209. fi
  4210. if [ -f $USB_MOUNT/private_key.gpg ]; then
  4211. echo 'GPG private key found on USB drive'
  4212. MY_GPG_PRIVATE_KEY=$USB_MOUNT/private_key.gpg
  4213. fi
  4214. if [ -f $USB_MOUNT/public_key.gpg ]; then
  4215. echo 'GPG public key found on USB drive'
  4216. MY_GPG_PUBLIC_KEY=$USB_MOUNT/public_key.gpg
  4217. fi
  4218. fi
  4219. if [ -d $USB_MOUNT/prosody ]; then
  4220. if [ ! -d $XMPP_DIRECTORY ]; then
  4221. mkdir $XMPP_DIRECTORY
  4222. fi
  4223. cp -r $USB_MOUNT/prosody/* $XMPP_DIRECTORY
  4224. chown -R prosody:prosody $XMPP_DIRECTORY
  4225. fi
  4226. if [ -d $USB_MOUNT/.ssh ]; then
  4227. echo 'Importing ssh keys'
  4228. cp -r $USB_MOUNT/.ssh /home/$MY_USERNAME
  4229. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.ssh
  4230. # for security delete the ssh keys from the usb drive
  4231. if [ -f /home/$MY_USERNAME/.ssh/id_rsa ]; then
  4232. shred -zu $USB_MOUNT/.ssh/id_rsa
  4233. shred -zu $USB_MOUNT/.ssh/id_rsa.pub
  4234. shred -zu $USB_MOUNT/.ssh/known_hosts
  4235. rm -rf $USB_MOUNT/.ssh
  4236. else
  4237. echo 'ssh files did not copy'
  4238. exit 8
  4239. fi
  4240. fi
  4241. if [ -f $USB_MOUNT/.emacs ]; then
  4242. echo 'Importing .emacs file'
  4243. cp -f $USB_MOUNT/.emacs /home/$MY_USERNAME/.emacs
  4244. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs
  4245. fi
  4246. if [ -d $USB_MOUNT/.emacs.d ]; then
  4247. echo 'Importing .emacs.d directory'
  4248. cp -r $USB_MOUNT/.emacs.d /home/$MY_USERNAME
  4249. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs.d
  4250. fi
  4251. if [ -d $USB_MOUNT/ssl ]; then
  4252. echo 'Importing SSL certificates'
  4253. cp -r $USB_MOUNT/ssl/* /etc/ssl
  4254. chmod 640 /etc/ssl/certs/*
  4255. chmod 400 /etc/ssl/private/*
  4256. # change ownership of some certificates
  4257. if [ -d /etc/prosody ]; then
  4258. chown prosody:prosody /etc/ssl/private/xmpp.*
  4259. chown prosody:prosody /etc/ssl/certs/xmpp.*
  4260. fi
  4261. if [ -d /etc/dovecot ]; then
  4262. chown root:dovecot /etc/ssl/certs/dovecot.*
  4263. chown root:dovecot /etc/ssl/private/dovecot.*
  4264. fi
  4265. if [ -f /etc/ssl/private/exim.key ]; then
  4266. chown root:Debian-exim /etc/ssl/private/exim.key /etc/ssl/certs/exim.crt /etc/ssl/certs/exim.dhparam
  4267. fi
  4268. fi
  4269. if [ -d $USB_MOUNT/personal ]; then
  4270. echo 'Importing personal directory'
  4271. cp -r $USB_MOUNT/personal /home/$MY_USERNAME
  4272. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/personal
  4273. fi
  4274. else
  4275. if [ -d $USB_MOUNT ]; then
  4276. umount $USB_MOUNT
  4277. rm -rf $USB_MOUNT
  4278. fi
  4279. echo 'No USB drive attached'
  4280. fi
  4281. echo 'search_for_attached_usb_drive' >> $COMPLETION_FILE
  4282. }
  4283. function remove_proprietary_repos {
  4284. if grep -Fxq "remove_proprietary_repos" $COMPLETION_FILE; then
  4285. return
  4286. fi
  4287. sed -i 's/ non-free//g' /etc/apt/sources.list
  4288. echo 'remove_proprietary_repos' >> $COMPLETION_FILE
  4289. }
  4290. function change_debian_repos {
  4291. if grep -Fxq "change_debian_repos" $COMPLETION_FILE; then
  4292. return
  4293. fi
  4294. rm -rf /var/lib/apt/lists/*
  4295. apt-get clean
  4296. sed -i "s/ftp.us.debian.org/$DEBIAN_REPO/g" /etc/apt/sources.list
  4297. # ensure that there is a security repo
  4298. if ! grep -q "security" /etc/apt/sources.list; then
  4299. echo "deb http://security.debian.org/ $DEBIAN_VERSION/updates main contrib" >> /etc/apt/sources.list
  4300. echo "#deb-src http://security.debian.org/ $DEBIAN_VERSION/updates main contrib" >> /etc/apt/sources.list
  4301. fi
  4302. apt-get update
  4303. apt-get -y install apt-transport-https
  4304. echo 'change_debian_repos' >> $COMPLETION_FILE
  4305. }
  4306. function initial_setup {
  4307. if grep -Fxq "initial_setup" $COMPLETION_FILE; then
  4308. return
  4309. fi
  4310. apt-get -y remove --purge apache*
  4311. apt-get -y dist-upgrade
  4312. apt-get -y install ca-certificates emacs24 cpulimit
  4313. echo 'initial_setup' >> $COMPLETION_FILE
  4314. }
  4315. function install_editor {
  4316. if grep -Fxq "install_editor" $COMPLETION_FILE; then
  4317. return
  4318. fi
  4319. update-alternatives --set editor /usr/bin/emacs24
  4320. # A minimal emacs configuration
  4321. #echo -n "(add-to-list 'load-path " > /home/$MY_USERNAME/.emacs
  4322. #echo '"~/.emacs.d/")' >> /home/$MY_USERNAME/.emacs
  4323. #echo '' >> /home/$MY_USERNAME/.emacs
  4324. echo ';; ===== Remove trailing whitepace ======================================' >> /home/$MY_USERNAME/.emacs
  4325. echo '' >> /home/$MY_USERNAME/.emacs
  4326. echo ";;(add-hook 'before-save-hook 'delete-trailing-whitespace)" >> /home/$MY_USERNAME/.emacs
  4327. echo '' >> /home/$MY_USERNAME/.emacs
  4328. echo ';; Goto a line number with CTRL-l' >> /home/$MY_USERNAME/.emacs
  4329. echo -n '(global-set-key "\C-l" ' >> /home/$MY_USERNAME/.emacs
  4330. echo "'goto-line)" >> /home/$MY_USERNAME/.emacs
  4331. echo '' >> /home/$MY_USERNAME/.emacs
  4332. echo ';; ===== Show line numbers ==============================================' >> /home/$MY_USERNAME/.emacs
  4333. echo '' >> /home/$MY_USERNAME/.emacs
  4334. echo "(add-hook 'find-file-hook (lambda () (linum-mode 1)))" >> /home/$MY_USERNAME/.emacs
  4335. echo '' >> /home/$MY_USERNAME/.emacs
  4336. echo ';; ===== Enable line wrapping in org-mode ===============================' >> /home/$MY_USERNAME/.emacs
  4337. echo '' >> /home/$MY_USERNAME/.emacs
  4338. echo " (add-hook 'org-mode-hook" >> /home/$MY_USERNAME/.emacs
  4339. echo " '(lambda ()" >> /home/$MY_USERNAME/.emacs
  4340. echo " (visual-line-mode 1)))" >> /home/$MY_USERNAME/.emacs
  4341. echo '' >> /home/$MY_USERNAME/.emacs
  4342. echo ';; ===== Enable shift select in org mode ================================' >> /home/$MY_USERNAME/.emacs
  4343. echo '' >> /home/$MY_USERNAME/.emacs
  4344. echo '(setq org-support-shift-select t)' >> /home/$MY_USERNAME/.emacs
  4345. echo '' >> /home/$MY_USERNAME/.emacs
  4346. echo ';; ===== Set standard indent to 4 rather that 4 =========================' >> /home/$MY_USERNAME/.emacs
  4347. echo '' >> /home/$MY_USERNAME/.emacs
  4348. echo '(setq standard-indent 4)' >> /home/$MY_USERNAME/.emacs
  4349. echo '(setq-default tab-width 4)' >> /home/$MY_USERNAME/.emacs
  4350. echo '(setq c-basic-offset 4)' >> /home/$MY_USERNAME/.emacs
  4351. echo '' >> /home/$MY_USERNAME/.emacs
  4352. echo ';; ===== Support Wheel Mouse Scrolling ==================================' >> /home/$MY_USERNAME/.emacs
  4353. echo '' >> /home/$MY_USERNAME/.emacs
  4354. echo '(mouse-wheel-mode t)' >> /home/$MY_USERNAME/.emacs
  4355. echo '' >> /home/$MY_USERNAME/.emacs
  4356. echo ';; ===== Place Backup Files in Specific Directory =======================' >> /home/$MY_USERNAME/.emacs
  4357. echo '' >> /home/$MY_USERNAME/.emacs
  4358. echo '(setq make-backup-files t)' >> /home/$MY_USERNAME/.emacs
  4359. echo '(setq version-control t)' >> /home/$MY_USERNAME/.emacs
  4360. echo '(setq backup-directory-alist (quote ((".*" . "~/.emacs_backups/"))))' >> /home/$MY_USERNAME/.emacs
  4361. echo '' >> /home/$MY_USERNAME/.emacs
  4362. echo ';; ===== Make Text mode the default mode for new buffers ================' >> /home/$MY_USERNAME/.emacs
  4363. echo '' >> /home/$MY_USERNAME/.emacs
  4364. echo "(setq default-major-mode 'text-mode)" >> /home/$MY_USERNAME/.emacs
  4365. echo '' >> /home/$MY_USERNAME/.emacs
  4366. echo ';; ===== Line length ====================================================' >> /home/$MY_USERNAME/.emacs
  4367. echo '' >> /home/$MY_USERNAME/.emacs
  4368. echo '(setq-default fill-column 72)' >> /home/$MY_USERNAME/.emacs
  4369. echo '' >> /home/$MY_USERNAME/.emacs
  4370. echo ';; ===== Enable Line and Column Numbering ===============================' >> /home/$MY_USERNAME/.emacs
  4371. echo '' >> /home/$MY_USERNAME/.emacs
  4372. echo '(line-number-mode 1)' >> /home/$MY_USERNAME/.emacs
  4373. echo '(column-number-mode 1)' >> /home/$MY_USERNAME/.emacs
  4374. echo '' >> /home/$MY_USERNAME/.emacs
  4375. echo ';; ===== Turn on Auto Fill mode automatically in all modes ==============' >> /home/$MY_USERNAME/.emacs
  4376. echo '' >> /home/$MY_USERNAME/.emacs
  4377. echo ';; Auto-fill-mode the the automatic wrapping of lines and insertion of' >> /home/$MY_USERNAME/.emacs
  4378. echo ';; newlines when the cursor goes over the column limit.' >> /home/$MY_USERNAME/.emacs
  4379. echo '' >> /home/$MY_USERNAME/.emacs
  4380. echo ';; This should actually turn on auto-fill-mode by default in all major' >> /home/$MY_USERNAME/.emacs
  4381. echo ';; modes. The other way to do this is to turn on the fill for specific modes' >> /home/$MY_USERNAME/.emacs
  4382. echo ';; via hooks.' >> /home/$MY_USERNAME/.emacs
  4383. echo '' >> /home/$MY_USERNAME/.emacs
  4384. echo '(setq auto-fill-mode 1)' >> /home/$MY_USERNAME/.emacs
  4385. echo '' >> /home/$MY_USERNAME/.emacs
  4386. echo ';; ===== Enable GPG encryption =========================================' >> /home/$MY_USERNAME/.emacs
  4387. echo '' >> /home/$MY_USERNAME/.emacs
  4388. echo "(require 'epa)" >> /home/$MY_USERNAME/.emacs
  4389. echo '(epa-file-enable)' >> /home/$MY_USERNAME/.emacs
  4390. cp /home/$MY_USERNAME/.emacs /root/.emacs
  4391. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs
  4392. echo 'install_editor' >> $COMPLETION_FILE
  4393. }
  4394. function enable_backports {
  4395. if grep -Fxq "enable_backports" $COMPLETION_FILE; then
  4396. return
  4397. fi
  4398. if ! grep -Fxq "deb http://$DEBIAN_REPO/debian $DEBIAN_VERSION-backports main" /etc/apt/sources.list; then
  4399. echo "deb http://$DEBIAN_REPO/debian $DEBIAN_VERSION-backports main" >> /etc/apt/sources.list
  4400. fi
  4401. echo 'enable_backports' >> $COMPLETION_FILE
  4402. }
  4403. function update_the_kernel {
  4404. if grep -Fxq "update_the_kernel" $COMPLETION_FILE; then
  4405. return
  4406. fi
  4407. # if this is not a beaglebone or is a docker container
  4408. # then just use the standard kernel
  4409. if [[ $INSTALLED_WITHIN_DOCKER == "yes" || $INSTALLING_ON_BBB != "yes" ]]; then
  4410. return
  4411. fi
  4412. cd /opt/scripts/tools
  4413. ./update_kernel.sh --kernel $KERNEL_VERSION
  4414. echo 'update_the_kernel' >> $COMPLETION_FILE
  4415. }
  4416. function enable_zram {
  4417. if grep -Fxq "enable_zram" $COMPLETION_FILE; then
  4418. return
  4419. fi
  4420. if [[ $INSTALLED_WITHIN_DOCKER == "yes" || $INSTALLING_ON_BBB != "yes" ]]; then
  4421. return
  4422. fi
  4423. if ! grep -q "options zram num_devices=1" /etc/modprobe.d/zram.conf; then
  4424. echo 'options zram num_devices=1' >> /etc/modprobe.d/zram.conf
  4425. fi
  4426. echo '#!/bin/bash' > /etc/init.d/zram
  4427. echo '### BEGIN INIT INFO' >> /etc/init.d/zram
  4428. echo '# Provides: zram' >> /etc/init.d/zram
  4429. echo '# Required-Start:' >> /etc/init.d/zram
  4430. echo '# Required-Stop:' >> /etc/init.d/zram
  4431. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/zram
  4432. echo '# Default-Stop: 0 1 6' >> /etc/init.d/zram
  4433. echo '# Short-Description: Increased Performance In Linux With zRam (Virtual Swap Compressed in RAM)' >> /etc/init.d/zram
  4434. echo '# Description: Adapted from systemd scripts at https://github.com/mystilleef/FedoraZram' >> /etc/init.d/zram
  4435. echo '### END INIT INFO' >> /etc/init.d/zram
  4436. echo 'start() {' >> /etc/init.d/zram
  4437. echo ' # get the number of CPUs' >> /etc/init.d/zram
  4438. echo ' num_cpus=$(grep -c processor /proc/cpuinfo)' >> /etc/init.d/zram
  4439. echo ' # if something goes wrong, assume we have 1' >> /etc/init.d/zram
  4440. echo ' [ "$num_cpus" != 0 ] || num_cpus=1' >> /etc/init.d/zram
  4441. echo ' # set decremented number of CPUs' >> /etc/init.d/zram
  4442. echo ' decr_num_cpus=$((num_cpus - 1))' >> /etc/init.d/zram
  4443. echo ' # get the amount of memory in the machine' >> /etc/init.d/zram
  4444. echo ' mem_total_kb=$(grep MemTotal /proc/meminfo | grep -E --only-matching "[[:digit:]]+")' >> /etc/init.d/zram
  4445. echo ' mem_total=$((mem_total_kb * 1024))' >> /etc/init.d/zram
  4446. echo ' # load dependency modules' >> /etc/init.d/zram
  4447. echo ' modprobe zram num_devices=$num_cpus' >> /etc/init.d/zram
  4448. echo ' # initialize the devices' >> /etc/init.d/zram
  4449. echo ' for i in $(seq 0 $decr_num_cpus); do' >> /etc/init.d/zram
  4450. echo ' echo $((mem_total / num_cpus)) > /sys/block/zram$i/disksize' >> /etc/init.d/zram
  4451. echo ' done' >> /etc/init.d/zram
  4452. echo ' # Creating swap filesystems' >> /etc/init.d/zram
  4453. echo ' for i in $(seq 0 $decr_num_cpus); do' >> /etc/init.d/zram
  4454. echo ' mkswap /dev/zram$i' >> /etc/init.d/zram
  4455. echo ' done' >> /etc/init.d/zram
  4456. echo ' # Switch the swaps on' >> /etc/init.d/zram
  4457. echo ' for i in $(seq 0 $decr_num_cpus); do' >> /etc/init.d/zram
  4458. echo ' swapon -p 100 /dev/zram$i' >> /etc/init.d/zram
  4459. echo ' done' >> /etc/init.d/zram
  4460. echo '}' >> /etc/init.d/zram
  4461. echo 'stop() {' >> /etc/init.d/zram
  4462. echo ' # get the number of CPUs' >> /etc/init.d/zram
  4463. echo ' num_cpus=$(grep -c processor /proc/cpuinfo)' >> /etc/init.d/zram
  4464. echo ' # set decremented number of CPUs' >> /etc/init.d/zram
  4465. echo ' decr_num_cpus=$((num_cpus - 1))' >> /etc/init.d/zram
  4466. echo ' # Switching off swap' >> /etc/init.d/zram
  4467. echo ' for i in $(seq 0 $decr_num_cpus); do' >> /etc/init.d/zram
  4468. echo ' if [ "$(grep /dev/zram$i /proc/swaps)" != "" ]; then' >> /etc/init.d/zram
  4469. echo ' swapoff /dev/zram$i' >> /etc/init.d/zram
  4470. echo ' sleep 1' >> /etc/init.d/zram
  4471. echo ' fi' >> /etc/init.d/zram
  4472. echo ' done' >> /etc/init.d/zram
  4473. echo ' sleep 1' >> /etc/init.d/zram
  4474. echo ' rmmod zram' >> /etc/init.d/zram
  4475. echo '}' >> /etc/init.d/zram
  4476. echo 'case "$1" in' >> /etc/init.d/zram
  4477. echo ' start)' >> /etc/init.d/zram
  4478. echo ' start' >> /etc/init.d/zram
  4479. echo ' ;;' >> /etc/init.d/zram
  4480. echo ' stop)' >> /etc/init.d/zram
  4481. echo ' stop' >> /etc/init.d/zram
  4482. echo ' ;;' >> /etc/init.d/zram
  4483. echo ' restart)' >> /etc/init.d/zram
  4484. echo ' stop' >> /etc/init.d/zram
  4485. echo ' sleep 3' >> /etc/init.d/zram
  4486. echo ' start' >> /etc/init.d/zram
  4487. echo ' ;;' >> /etc/init.d/zram
  4488. echo ' *)' >> /etc/init.d/zram
  4489. echo ' echo "Usage: $0 {start|stop|restart}"' >> /etc/init.d/zram
  4490. echo ' RETVAL=1' >> /etc/init.d/zram
  4491. echo 'esac' >> /etc/init.d/zram
  4492. echo 'exit $RETVAL' >> /etc/init.d/zram
  4493. chmod +x /etc/init.d/zram
  4494. update-rc.d zram defaults
  4495. echo 'enable_zram' >> $COMPLETION_FILE
  4496. }
  4497. function check_onerng_verification {
  4498. if grep -Fxq "check_onerng_verification" $COMPLETION_FILE; then
  4499. return
  4500. fi
  4501. if [[ $HWRNG_TYPE != "onerng" ]]; then
  4502. return
  4503. fi
  4504. echo 'Checking OneRNG firmware verification'
  4505. last_onerng_validation=$(cat /var/log/syslog.1 | grep "OneRNG: firmware verification" | awk '/./{line=$0} END{print line}')
  4506. if [[ $last_onerng_validation != *"passed OK"* ]]; then
  4507. last_onerng_validation=$(cat /var/log/syslog | grep "OneRNG: firmware verification" | awk '/./{line=$0} END{print line}')
  4508. if [[ $last_onerng_validation != *"passed OK"* ]]; then
  4509. echo $last_onerng_validation
  4510. echo 'OneRNG firmware verification failed'
  4511. exit 735026
  4512. fi
  4513. fi
  4514. echo 'OneRNG firmware verification passed'
  4515. # if haveged was previously installed then remove it
  4516. apt-get -y remove haveged
  4517. echo 'check_onerng_verification' >> $COMPLETION_FILE
  4518. }
  4519. function install_onerng {
  4520. apt-get -y install rng-tools at python-gnupg
  4521. # Move to the installation directory
  4522. if [ ! -d $INSTALL_DIR ]; then
  4523. mkdir $INSTALL_DIR
  4524. fi
  4525. cd $INSTALL_DIR
  4526. # Download the package
  4527. if [ ! -f $ONERNG_PACKAGE ]; then
  4528. wget $ONERNG_PACKAGE_DOWNLOAD
  4529. mv "$ONERNG_PACKAGE?raw=true" $ONERNG_PACKAGE
  4530. fi
  4531. if [ ! -f $ONERNG_PACKAGE ]; then
  4532. echo "OneRNG package could not be downloaded"
  4533. exit 59249
  4534. fi
  4535. # Check the hash
  4536. hash=$(sha256sum $ONERNG_PACKAGE | awk -F ' ' '{print $1}')
  4537. if [[ $hash != $ONERNG_PACKAGE_HASH ]]; then
  4538. echo "OneRNG package: $ONERNG_PACKAGE"
  4539. echo "Hash does not match. This could indicate that the package has been tampered with."
  4540. echo "OneRNG expected package hash: $ONERNG_PACKAGE_HASH"
  4541. echo "OneRNG actual hash: $hash"
  4542. exit 25934
  4543. fi
  4544. # install the package
  4545. dpkg -i $ONERNG_PACKAGE
  4546. # check rng-tools configuration
  4547. if ! grep -q "/dev/$ONERNG_DEVICE" /etc/default/rng-tools; then
  4548. echo "HRNGDEVICE=/dev/$ONERNG_DEVICE" >> /etc/default/rng-tools
  4549. systemctl restart rng-tools
  4550. fi
  4551. # Check that the install worked
  4552. if [ ! -f /etc/onerng.conf ]; then
  4553. echo 'OneRNG configuration file not found. The package may not have installed successfully.'
  4554. exit 42904
  4555. fi
  4556. }
  4557. function random_number_generator {
  4558. if grep -Fxq "random_number_generator" $COMPLETION_FILE; then
  4559. return
  4560. fi
  4561. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4562. # it is assumed that docker uses the random number
  4563. # generator of the host system
  4564. return
  4565. fi
  4566. case $HWRNG_TYPE in
  4567. beaglebone)
  4568. apt-get -y install rng-tools
  4569. sed -i 's|#HRNGDEVICE=/dev/hwrng|HRNGDEVICE=/dev/hwrng|g' /etc/default/rng-tools
  4570. ;;
  4571. onerng)
  4572. install_onerng
  4573. ;;
  4574. *)
  4575. apt-get -y install haveged
  4576. ;;
  4577. esac
  4578. echo 'random_number_generator' >> $COMPLETION_FILE
  4579. }
  4580. function configure_ssh {
  4581. if grep -Fxq "configure_ssh" $COMPLETION_FILE; then
  4582. return
  4583. fi
  4584. sed -i "s/Port .*/Port $SSH_PORT/g" /etc/ssh/sshd_config
  4585. sed -i 's/PermitRootLogin.*/PermitRootLogin no/g' /etc/ssh/sshd_config
  4586. sed -i 's/X11Forwarding.*/X11Forwarding no/g' /etc/ssh/sshd_config
  4587. sed -i 's/ServerKeyBits.*/ServerKeyBits 4096/g' /etc/ssh/sshd_config
  4588. sed -i 's/TCPKeepAlive.*/TCPKeepAlive no/g' /etc/ssh/sshd_config
  4589. sed -i 's|HostKey /etc/ssh/ssh_host_dsa_key|#HostKey /etc/ssh/ssh_host_dsa_key|g' /etc/ssh/sshd_config
  4590. sed -i 's|HostKey /etc/ssh/ssh_host_ecdsa_key|#HostKey /etc/ssh/ssh_host_ecdsa_key|g' /etc/ssh/sshd_config
  4591. if grep -q 'ClientAliveInterval' /etc/ssh/sshd_config; then
  4592. sed -i 's/ClientAliveInterval.*/ClientAliveInterval 60/g' /etc/ssh/sshd_config
  4593. else
  4594. echo 'ClientAliveInterval 60' >> /etc/ssh/sshd_config
  4595. fi
  4596. if grep -q 'ClientAliveCountMax' /etc/ssh/sshd_config; then
  4597. sed -i 's/ClientAliveCountMax.*/ClientAliveCountMax 3/g' /etc/ssh/sshd_config
  4598. else
  4599. echo 'ClientAliveCountMax 3' >> /etc/ssh/sshd_config
  4600. fi
  4601. if grep -q 'Ciphers' /etc/ssh/sshd_config; then
  4602. sed -i "s|Ciphers.*|Ciphers $SSH_CIPHERS|g" /etc/ssh/sshd_config
  4603. else
  4604. echo "Ciphers $SSH_CIPHERS" >> /etc/ssh/sshd_config
  4605. fi
  4606. if grep -q 'MACs' /etc/ssh/sshd_config; then
  4607. sed -i "s|MACs.*|MACs $SSH_MACS|g" /etc/ssh/sshd_config
  4608. else
  4609. echo "MACs $SSH_MACS" >> /etc/ssh/sshd_config
  4610. fi
  4611. if grep -q 'KexAlgorithms' /etc/ssh/sshd_config; then
  4612. sed -i "s|KexAlgorithms.*|KexAlgorithms $SSH_KEX|g" /etc/ssh/sshd_config
  4613. else
  4614. echo "KexAlgorithms $SSH_KEX" >> /etc/ssh/sshd_config
  4615. fi
  4616. apt-get -y install fail2ban
  4617. echo 'configure_ssh' >> $COMPLETION_FILE
  4618. # Don't reboot if installing within docker
  4619. # random numbers will come from the host system
  4620. if [[ $INSTALLED_WITHIN_DOCKER == "yes" || $INSTALLING_ON_BBB != "yes" ]]; then
  4621. return
  4622. fi
  4623. echo ''
  4624. echo ''
  4625. echo ' *** Rebooting to initialise ssh settings and random number generator ***'
  4626. echo ''
  4627. echo " *** Reconnect via ssh on port $SSH_PORT, then run this script again ***"
  4628. echo ''
  4629. echo '## ' >> /etc/motd
  4630. echo '## Type "su" and enter your administrator password, then use the command:' >> /etc/motd
  4631. echo '## ' >> /etc/motd
  4632. echo '## freedombone -c freedombone.cfg' >> /etc/motd
  4633. echo '## ' >> /etc/motd
  4634. echo '## to continue the installation.' >> /etc/motd
  4635. reboot
  4636. }
  4637. # see https://stribika.github.io/2015/01/04/secure-secure-shell.html
  4638. function ssh_remove_small_moduli {
  4639. awk '$5 > 2000' /etc/ssh/moduli > ~/moduli
  4640. mv ~/moduli /etc/ssh/moduli
  4641. }
  4642. function configure_ssh_client {
  4643. if grep -Fxq "configure_ssh_client" $COMPLETION_FILE; then
  4644. return
  4645. fi
  4646. #sed -i 's/# PasswordAuthentication.*/ PasswordAuthentication no/g' /etc/ssh/ssh_config
  4647. #sed -i 's/# ChallengeResponseAuthentication.*/ ChallengeResponseAuthentication no/g' /etc/ssh/ssh_config
  4648. sed -i "s/# HostKeyAlgorithms.*/ HostKeyAlgorithms $SSH_HOST_KEY_ALGORITHMS/g" /etc/ssh/ssh_config
  4649. sed -i "s/# Ciphers.*/ Ciphers $SSH_CIPHERS/g" /etc/ssh/ssh_config
  4650. sed -i "s/# MACs.*/ MACs $SSH_MACS/g" /etc/ssh/ssh_config
  4651. if ! grep -q "HostKeyAlgorithms" /etc/ssh/ssh_config; then
  4652. echo " HostKeyAlgorithms $SSH_HOST_KEY_ALGORITHMS" >> /etc/ssh/ssh_config
  4653. fi
  4654. sed -i "s/Ciphers.*/Ciphers $SSH_CIPHERS/g" /etc/ssh/ssh_config
  4655. if ! grep -q "Ciphers " /etc/ssh/ssh_config; then
  4656. echo " Ciphers $SSH_CIPHERS" >> /etc/ssh/ssh_config
  4657. fi
  4658. sed -i "s/MACs.*/MACs $SSH_MACS/g" /etc/ssh/ssh_config
  4659. if ! grep -q "MACs " /etc/ssh/ssh_config; then
  4660. echo " MACs $SSH_MACS" >> /etc/ssh/ssh_config
  4661. fi
  4662. # Create ssh keys
  4663. if [ ! -f ~/.ssh/id_ed25519 ]; then
  4664. ssh-keygen -t ed25519 -o -a 100
  4665. fi
  4666. if [ ! -f ~/.ssh/id_rsa ]; then
  4667. ssh-keygen -t rsa -b 4096 -o -a 100
  4668. fi
  4669. ssh_remove_small_moduli
  4670. echo 'configure_ssh_client' >> $COMPLETION_FILE
  4671. }
  4672. function regenerate_ssh_keys {
  4673. if grep -Fxq "regenerate_ssh_keys" $COMPLETION_FILE; then
  4674. return
  4675. fi
  4676. rm -f /etc/ssh/ssh_host_*
  4677. dpkg-reconfigure openssh-server
  4678. ssh_remove_small_moduli
  4679. service ssh restart
  4680. echo 'regenerate_ssh_keys' >> $COMPLETION_FILE
  4681. }
  4682. function configure_dns {
  4683. if grep -Fxq "configure_dns" $COMPLETION_FILE; then
  4684. return
  4685. fi
  4686. echo 'domain localdomain' > /etc/resolv.conf
  4687. echo 'search localdomain' >> /etc/resolv.conf
  4688. echo "nameserver $NAMESERVER1" >> /etc/resolv.conf
  4689. echo "nameserver $NAMESERVER2" >> /etc/resolv.conf
  4690. echo 'configure_dns' >> $COMPLETION_FILE
  4691. }
  4692. function set_your_domain_name {
  4693. if grep -Fxq "set_your_domain_name" $COMPLETION_FILE; then
  4694. return
  4695. fi
  4696. echo "$DEFAULT_DOMAIN_NAME" > /etc/hostname
  4697. hostname $DEFAULT_DOMAIN_NAME
  4698. if grep -q "127.0.1.1" /etc/hosts; then
  4699. sed -i "s/127.0.1.1.*/127.0.1.1 $DEFAULT_DOMAIN_NAME/g" /etc/hosts
  4700. else
  4701. echo "127.0.1.1 $DEFAULT_DOMAIN_NAME" >> /etc/hosts
  4702. fi
  4703. echo 'set_your_domain_name' >> $COMPLETION_FILE
  4704. }
  4705. function time_synchronisation {
  4706. if grep -Fxq "time_synchronisation" $COMPLETION_FILE; then
  4707. return
  4708. fi
  4709. #apt-get -y install tlsdate
  4710. # building tlsdate from source is a workaround because of
  4711. # this bug https://github.com/ioerror/tlsdate/issues/130
  4712. apt-get -y install build-essential automake git pkg-config autoconf libtool libssl-dev libevent-dev
  4713. if [ ! -d $INSTALL_DIR ]; then
  4714. mkdir $INSTALL_DIR
  4715. fi
  4716. cd $INSTALL_DIR
  4717. git clone https://github.com/ioerror/tlsdate.git
  4718. cd $INSTALL_DIR/tlsdate
  4719. ./autogen.sh
  4720. ./configure
  4721. make
  4722. make install
  4723. cp /usr/local/bin/tlsdate* /usr/bin
  4724. cp /usr/local/sbin/tlsdate* /usr/bin
  4725. apt-get -y remove ntpdate
  4726. echo '#!/bin/bash' > /usr/bin/updatedate
  4727. echo "TIMESOURCE='TLS_TIME_SOURCE1'" >> /usr/bin/updatedate
  4728. echo "TIMESOURCE2='TLS_TIME_SOURCE2'" >> /usr/bin/updatedate
  4729. echo 'LOGFILE=/var/log/tlsdate.log' >> /usr/bin/updatedate
  4730. echo 'TIMEOUT=5' >> /usr/bin/updatedate
  4731. echo "EMAIL=$MY_EMAIL_ADDRESS" >> /usr/bin/updatedate
  4732. echo '# File which contains the previous date as a number' >> /usr/bin/updatedate
  4733. echo 'BEFORE_DATE_FILE=/var/log/tlsdateprevious.txt' >> /usr/bin/updatedate
  4734. echo '# File which contains the previous date as a string' >> /usr/bin/updatedate
  4735. echo 'BEFORE_FULLDATE_FILE=/var/log/tlsdate.txt' >> /usr/bin/updatedate
  4736. echo 'DATE_BEFORE=$(date)' >> /usr/bin/updatedate
  4737. echo 'BEFORE=$(date "+%s")' >> /usr/bin/updatedate
  4738. echo 'BACKWARDS_BETWEEN=0' >> /usr/bin/updatedate
  4739. echo 're="^[0-9]+$"' >> /usr/bin/updatedate
  4740. echo '# If the date was previously set' >> /usr/bin/updatedate
  4741. echo 'if [ -s "$BEFORE_DATE_FILE" ]; then' >> /usr/bin/updatedate
  4742. echo ' filesize=$(wc -c "$BEFORE_DATE_FILE" | cut -f 1 -d " ")' >> /usr/bin/updatedate
  4743. echo ' if [ $filesize -ge 5 ]; then' >> /usr/bin/updatedate
  4744. echo ' BEFORE_FILE=$(cat $BEFORE_DATE_FILE)' >> /usr/bin/updatedate
  4745. echo ' if [[ $BEFORE_FILE =~ $re ]]; then' >> /usr/bin/updatedate
  4746. echo ' BEFORE_FULLDATE=$(cat $BEFORE_FULLDATE_FILE)' >> /usr/bin/updatedate
  4747. echo ' # is the date going backwards?' >> /usr/bin/updatedate
  4748. echo ' if (( $BEFORE_FILE > $BEFORE )); then' >> /usr/bin/updatedate
  4749. echo ' echo -n "Date went backwards between tlsdate updates. " >> $LOGFILE' >> /usr/bin/updatedate
  4750. echo ' echo -n "$BEFORE_FILE > $BEFORE, " >> $LOGFILE' >> /usr/bin/updatedate
  4751. echo ' echo "$BEFORE_FULLDATE > $DATE_BEFORE" >> $LOGFILE' >> /usr/bin/updatedate
  4752. echo ' # Send a warning email' >> /usr/bin/updatedate
  4753. echo ' echo $(tail $LOGFILE -n 2) | mail -s "tlsdate anomaly" $EMAIL' >> /usr/bin/updatedate
  4754. echo ' # Try another time source' >> /usr/bin/updatedate
  4755. echo ' TIMESOURCE=$TIMESOURCE2' >> /usr/bin/updatedate
  4756. echo ' # try running without any parameters' >> /usr/bin/updatedate
  4757. echo ' tlsdate >> $LOGFILE' >> /usr/bin/updatedate
  4758. echo ' BACKWARDS_BETWEEN=1' >> /usr/bin/updatedate
  4759. echo ' fi' >> /usr/bin/updatedate
  4760. echo ' fi' >> /usr/bin/updatedate
  4761. echo ' fi' >> /usr/bin/updatedate
  4762. echo 'fi' >> /usr/bin/updatedate
  4763. echo '# Set the date' >> /usr/bin/updatedate
  4764. echo '/usr/bin/timeout $TIMEOUT tlsdate -l -t -H $TIMESOURCE -p 443 >> $LOGFILE' >> /usr/bin/updatedate
  4765. echo 'DATE_AFTER=$(date)' >> /usr/bin/updatedate
  4766. echo 'AFTER=$(date "+%s")' >> /usr/bin/updatedate
  4767. echo '# After setting the date did it go backwards?' >> /usr/bin/updatedate
  4768. echo 'if (( $AFTER < $BEFORE )); then' >> /usr/bin/updatedate
  4769. echo ' echo "Incorrect date: $DATE_BEFORE -> $DATE_AFTER" >> $LOGFILE' >> /usr/bin/updatedate
  4770. echo ' # Send a warning email' >> /usr/bin/updatedate
  4771. echo ' echo $(tail $LOGFILE -n 2) | mail -s "tlsdate anomaly" $EMAIL' >> /usr/bin/updatedate
  4772. echo ' # Try resetting the date from another time source' >> /usr/bin/updatedate
  4773. echo ' /usr/bin/timeout $TIMEOUT tlsdate -l -t -H $TIMESOURCE2 -p 443 >> $LOGFILE' >> /usr/bin/updatedate
  4774. echo ' DATE_AFTER=$(date)' >> /usr/bin/updatedate
  4775. echo ' AFTER=$(date "+%s")' >> /usr/bin/updatedate
  4776. echo 'else' >> /usr/bin/updatedate
  4777. echo ' echo -n $TIMESOURCE >> $LOGFILE' >> /usr/bin/updatedate
  4778. echo ' if [ -s "$BEFORE_DATE_FILE" ]; then' >> /usr/bin/updatedate
  4779. echo ' echo -n " " >> $LOGFILE' >> /usr/bin/updatedate
  4780. echo ' echo -n $BEFORE_FILE >> $LOGFILE' >> /usr/bin/updatedate
  4781. echo ' fi' >> /usr/bin/updatedate
  4782. echo ' echo -n " " >> $LOGFILE' >> /usr/bin/updatedate
  4783. echo ' echo -n $BEFORE >> $LOGFILE' >> /usr/bin/updatedate
  4784. echo ' echo -n " " >> $LOGFILE' >> /usr/bin/updatedate
  4785. echo ' echo -n $AFTER >> $LOGFILE' >> /usr/bin/updatedate
  4786. echo ' echo -n " " >> $LOGFILE' >> /usr/bin/updatedate
  4787. echo ' echo $DATE_AFTER >> $LOGFILE' >> /usr/bin/updatedate
  4788. echo 'fi' >> /usr/bin/updatedate
  4789. echo '# Log the last date' >> /usr/bin/updatedate
  4790. echo 'if [[ $BACKWARDS_BETWEEN == 0 ]]; then' >> /usr/bin/updatedate
  4791. echo ' echo "$AFTER" > $BEFORE_DATE_FILE' >> /usr/bin/updatedate
  4792. echo ' echo "$DATE_AFTER" > $BEFORE_FULLDATE_FILE' >> /usr/bin/updatedate
  4793. echo ' exit 0' >> /usr/bin/updatedate
  4794. echo 'else' >> /usr/bin/updatedate
  4795. echo ' exit 1' >> /usr/bin/updatedate
  4796. echo 'fi' >> /usr/bin/updatedate
  4797. chmod +x /usr/bin/updatedate
  4798. echo '*/15 * * * * root /usr/bin/updatedate' >> /etc/crontab
  4799. service cron restart
  4800. echo '#!/bin/bash' > /etc/init.d/tlsdate
  4801. echo '# /etc/init.d/tlsdate' >> /etc/init.d/tlsdate
  4802. echo '### BEGIN INIT INFO' >> /etc/init.d/tlsdate
  4803. echo '# Provides: tlsdate' >> /etc/init.d/tlsdate
  4804. echo '# Required-Start: $remote_fs $syslog' >> /etc/init.d/tlsdate
  4805. echo '# Required-Stop: $remote_fs $syslog' >> /etc/init.d/tlsdate
  4806. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/tlsdate
  4807. echo '# Default-Stop: 0 1 6' >> /etc/init.d/tlsdate
  4808. echo '# Short-Description: Initially calls tlsdate with the timewarp option' >> /etc/init.d/tlsdate
  4809. echo '# Description: Initially calls tlsdate with the timewarp option' >> /etc/init.d/tlsdate
  4810. echo '### END INIT INFO' >> /etc/init.d/tlsdate
  4811. echo '# Author: Bob Mottram <bob@robotics.uk.to>' >> /etc/init.d/tlsdate
  4812. echo 'PATH="/usr/local/sbin:/usr/local/bin:/usr/bin:/sbin:/usr/sbin:/bin"' >> /etc/init.d/tlsdate
  4813. echo 'LOGFILE="/var/log/tlsdate.log"' >> /etc/init.d/tlsdate
  4814. echo 'TLSDATECOMMAND="tlsdate --timewarp -l -H www.ptb.de -p 443 >> $LOGFILE"' >> /etc/init.d/tlsdate
  4815. echo '#Start-Stop here' >> /etc/init.d/tlsdate
  4816. echo 'case "$1" in' >> /etc/init.d/tlsdate
  4817. echo ' start)' >> /etc/init.d/tlsdate
  4818. echo ' echo "tlsdate started"' >> /etc/init.d/tlsdate
  4819. echo ' $TLSDATECOMMAND' >> /etc/init.d/tlsdate
  4820. echo ' ;;' >> /etc/init.d/tlsdate
  4821. echo ' stop)' >> /etc/init.d/tlsdate
  4822. echo ' echo "tlsdate stopped"' >> /etc/init.d/tlsdate
  4823. echo ' ;;' >> /etc/init.d/tlsdate
  4824. echo ' restart)' >> /etc/init.d/tlsdate
  4825. echo ' echo "tlsdate restarted"' >> /etc/init.d/tlsdate
  4826. echo ' $TLSDATECOMMAND' >> /etc/init.d/tlsdate
  4827. echo ' ;;' >> /etc/init.d/tlsdate
  4828. echo ' *)' >> /etc/init.d/tlsdate
  4829. echo ' echo "Usage: $0 {start|stop|restart}"' >> /etc/init.d/tlsdate
  4830. echo ' exit 1' >> /etc/init.d/tlsdate
  4831. echo ' ;;' >> /etc/init.d/tlsdate
  4832. echo 'esac' >> /etc/init.d/tlsdate
  4833. echo 'exit 0' >> /etc/init.d/tlsdate
  4834. chmod +x /etc/init.d/tlsdate
  4835. update-rc.d tlsdate defaults
  4836. echo 'time_synchronisation' >> $COMPLETION_FILE
  4837. }
  4838. function configure_firewall {
  4839. if grep -Fxq "configure_firewall" $COMPLETION_FILE; then
  4840. return
  4841. fi
  4842. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4843. # docker does its own firewalling
  4844. return
  4845. fi
  4846. iptables -P INPUT ACCEPT
  4847. ip6tables -P INPUT ACCEPT
  4848. iptables -F
  4849. ip6tables -F
  4850. iptables -t nat -F
  4851. ip6tables -t nat -F
  4852. iptables -X
  4853. ip6tables -X
  4854. iptables -P INPUT DROP
  4855. ip6tables -P INPUT DROP
  4856. iptables -A INPUT -i lo -j ACCEPT
  4857. iptables -A INPUT -i eth0 -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT
  4858. # Make sure incoming tcp connections are SYN packets
  4859. iptables -A INPUT -p tcp ! --syn -m state --state NEW -j DROP
  4860. # Drop packets with incoming fragments
  4861. iptables -A INPUT -f -j DROP
  4862. # Drop bogons
  4863. iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP
  4864. iptables -A INPUT -p tcp --tcp-flags ALL FIN,PSH,URG -j DROP
  4865. iptables -A INPUT -p tcp --tcp-flags ALL SYN,RST,ACK,FIN,URG -j DROP
  4866. # Incoming malformed NULL packets:
  4867. iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP
  4868. echo 'configure_firewall' >> $COMPLETION_FILE
  4869. }
  4870. function save_firewall_settings {
  4871. iptables-save > /etc/firewall.conf
  4872. ip6tables-save > /etc/firewall6.conf
  4873. printf '#!/bin/sh\n' > /etc/network/if-up.d/iptables
  4874. printf 'iptables-restore < /etc/firewall.conf\n' >> /etc/network/if-up.d/iptables
  4875. printf 'ip6tables-restore < /etc/firewall6.conf\n' >> /etc/network/if-up.d/iptables
  4876. chmod +x /etc/network/if-up.d/iptables
  4877. }
  4878. function configure_firewall_for_voip {
  4879. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  4880. return
  4881. fi
  4882. if grep -Fxq "configure_firewall_for_voip" $COMPLETION_FILE; then
  4883. return
  4884. fi
  4885. iptables -A INPUT -i eth0 -p udp --dport $VOIP_PORT -j ACCEPT
  4886. iptables -A INPUT -i eth0 -p tcp --dport $VOIP_PORT -j ACCEPT
  4887. save_firewall_settings
  4888. echo 'configure_firewall_for_voip' >> $COMPLETION_FILE
  4889. }
  4890. function configure_firewall_for_cjdns {
  4891. if grep -Fxq "configure_firewall_for_cjdns" $COMPLETION_FILE; then
  4892. return
  4893. fi
  4894. if [[ $ENABLE_CJDNS != "yes" ]]; then
  4895. return
  4896. fi
  4897. ip6tables -t nat -A POSTROUTING -o tun0 -j MASQUERADE
  4898. ip6tables -A FORWARD -i tun0 -o eth0 -m state --state RELATED,ESTABLISHED -j ACCEPT
  4899. save_firewall_settings
  4900. echo 'configure_firewall_for_cjdns' >> $COMPLETION_FILE
  4901. }
  4902. function configure_firewall_for_dlna {
  4903. if grep -Fxq "configure_firewall_for_dlna" $COMPLETION_FILE; then
  4904. return
  4905. fi
  4906. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4907. # docker does its own firewalling
  4908. return
  4909. fi
  4910. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" ]]; then
  4911. return
  4912. fi
  4913. iptables -A INPUT -i eth0 -p udp --dport 1900 -j ACCEPT
  4914. iptables -A INPUT -i eth0 -p tcp --dport 8200 -j ACCEPT
  4915. save_firewall_settings
  4916. echo 'configure_firewall_for_dlna' >> $COMPLETION_FILE
  4917. }
  4918. function configure_firewall_for_dns {
  4919. if grep -Fxq "configure_firewall_for_dns" $COMPLETION_FILE; then
  4920. return
  4921. fi
  4922. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4923. # docker does its own firewalling
  4924. return
  4925. fi
  4926. iptables -A INPUT -i eth0 -p udp -m udp --dport 1024:65535 --sport 53 -j ACCEPT
  4927. save_firewall_settings
  4928. echo 'configure_firewall_for_dns' >> $COMPLETION_FILE
  4929. }
  4930. function configure_firewall_for_xmpp {
  4931. if [ ! -d /etc/prosody ]; then
  4932. return
  4933. fi
  4934. if grep -Fxq "configure_firewall_for_xmpp" $COMPLETION_FILE; then
  4935. return
  4936. fi
  4937. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4938. # docker does its own firewalling
  4939. return
  4940. fi
  4941. iptables -A INPUT -i eth0 -p tcp --dport 5222:5223 -j ACCEPT
  4942. iptables -A INPUT -i eth0 -p tcp --dport 5269 -j ACCEPT
  4943. iptables -A INPUT -i eth0 -p tcp --dport 5280:5281 -j ACCEPT
  4944. save_firewall_settings
  4945. echo 'configure_firewall_for_xmpp' >> $COMPLETION_FILE
  4946. }
  4947. function configure_firewall_for_irc {
  4948. if [ ! -d /etc/ngircd ]; then
  4949. return
  4950. fi
  4951. if grep -Fxq "configure_firewall_for_irc" $COMPLETION_FILE; then
  4952. return
  4953. fi
  4954. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4955. # docker does its own firewalling
  4956. return
  4957. fi
  4958. iptables -A INPUT -i eth0 -p tcp --dport 6697 -j ACCEPT
  4959. iptables -I INPUT -i eth0 -p tcp --dport 1024:65535 --sport 6697 -j ACCEPT
  4960. iptables -A INPUT -i eth0 -p tcp --dport 9999 -j ACCEPT
  4961. save_firewall_settings
  4962. echo 'configure_firewall_for_irc' >> $COMPLETION_FILE
  4963. }
  4964. function configure_firewall_for_ftp {
  4965. if grep -Fxq "configure_firewall_for_ftp" $COMPLETION_FILE; then
  4966. return
  4967. fi
  4968. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4969. # docker does its own firewalling
  4970. return
  4971. fi
  4972. iptables -I INPUT -i eth0 -p tcp --dport 1024:65535 --sport 20:21 -j ACCEPT
  4973. save_firewall_settings
  4974. echo 'configure_firewall_for_ftp' >> $COMPLETION_FILE
  4975. }
  4976. function configure_firewall_for_web_access {
  4977. if grep -Fxq "configure_firewall_for_web_access" $COMPLETION_FILE; then
  4978. return
  4979. fi
  4980. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4981. # docker does its own firewalling
  4982. return
  4983. fi
  4984. iptables -A INPUT -i eth0 -p tcp --dport 32768:61000 --sport 80 -j ACCEPT
  4985. iptables -A INPUT -i eth0 -p tcp --dport 32768:61000 --sport 443 -j ACCEPT
  4986. save_firewall_settings
  4987. echo 'configure_firewall_for_web_access' >> $COMPLETION_FILE
  4988. }
  4989. function configure_firewall_for_web_server {
  4990. if grep -Fxq "configure_firewall_for_web_server" $COMPLETION_FILE; then
  4991. return
  4992. fi
  4993. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4994. # docker does its own firewalling
  4995. return
  4996. fi
  4997. iptables -A INPUT -i eth0 -p tcp --dport 80 -j ACCEPT
  4998. iptables -A INPUT -i eth0 -p tcp --dport 443 -j ACCEPT
  4999. save_firewall_settings
  5000. echo 'configure_firewall_for_web_server' >> $COMPLETION_FILE
  5001. }
  5002. function configure_firewall_for_ssh {
  5003. if grep -Fxq "configure_firewall_for_ssh" $COMPLETION_FILE; then
  5004. return
  5005. fi
  5006. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  5007. # docker does its own firewalling
  5008. return
  5009. fi
  5010. iptables -A INPUT -i eth0 -p tcp --dport 22 -j ACCEPT
  5011. iptables -A INPUT -i eth0 -p tcp --dport $SSH_PORT -j ACCEPT
  5012. save_firewall_settings
  5013. echo 'configure_firewall_for_ssh' >> $COMPLETION_FILE
  5014. }
  5015. function configure_firewall_for_git {
  5016. if grep -Fxq "configure_firewall_for_git" $COMPLETION_FILE; then
  5017. return
  5018. fi
  5019. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  5020. # docker does its own firewalling
  5021. return
  5022. fi
  5023. iptables -A INPUT -i eth0 -p tcp --dport 9418 -j ACCEPT
  5024. save_firewall_settings
  5025. echo 'configure_firewall_for_git' >> $COMPLETION_FILE
  5026. }
  5027. function configure_firewall_for_email {
  5028. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5029. return
  5030. fi
  5031. if grep -Fxq "configure_firewall_for_email" $COMPLETION_FILE; then
  5032. return
  5033. fi
  5034. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  5035. # docker does its own firewalling
  5036. return
  5037. fi
  5038. iptables -A INPUT -i eth0 -p tcp --dport 25 -j ACCEPT
  5039. iptables -A INPUT -i eth0 -p tcp --dport 587 -j ACCEPT
  5040. iptables -A INPUT -i eth0 -p tcp --dport 465 -j ACCEPT
  5041. iptables -A INPUT -i eth0 -p tcp --dport 993 -j ACCEPT
  5042. save_firewall_settings
  5043. echo 'configure_firewall_for_email' >> $COMPLETION_FILE
  5044. }
  5045. function configure_internet_protocol {
  5046. if grep -Fxq "configure_internet_protocol" $COMPLETION_FILE; then
  5047. return
  5048. fi
  5049. sed -i "s/#net.ipv4.tcp_syncookies=1/net.ipv4.tcp_syncookies=1/g" /etc/sysctl.conf
  5050. sed -i "s/#net.ipv4.conf.all.accept_redirects = 0/net.ipv4.conf.all.accept_redirects = 0/g" /etc/sysctl.conf
  5051. sed -i "s/#net.ipv6.conf.all.accept_redirects = 0/net.ipv6.conf.all.accept_redirects = 0/g" /etc/sysctl.conf
  5052. sed -i "s/#net.ipv4.conf.all.send_redirects = 0/net.ipv4.conf.all.send_redirects = 0/g" /etc/sysctl.conf
  5053. sed -i "s/#net.ipv4.conf.all.accept_source_route = 0/net.ipv4.conf.all.accept_source_route = 0/g" /etc/sysctl.conf
  5054. sed -i "s/#net.ipv6.conf.all.accept_source_route = 0/net.ipv6.conf.all.accept_source_route = 0/g" /etc/sysctl.conf
  5055. sed -i "s/#net.ipv4.conf.default.rp_filter=1/net.ipv4.conf.default.rp_filter=1/g" /etc/sysctl.conf
  5056. sed -i "s/#net.ipv4.conf.all.rp_filter=1/net.ipv4.conf.all.rp_filter=1/g" /etc/sysctl.conf
  5057. sed -i "s/#net.ipv4.ip_forward=1/net.ipv4.ip_forward=0/g" /etc/sysctl.conf
  5058. sed -i "s/#net.ipv6.conf.all.forwarding=1/net.ipv6.conf.all.forwarding=0/g" /etc/sysctl.conf
  5059. echo '# ignore pings' >> /etc/sysctl.conf
  5060. echo 'net.ipv4.icmp_echo_ignore_all = 1' >> /etc/sysctl.conf
  5061. echo 'net.ipv6.icmp_echo_ignore_all = 1' >> /etc/sysctl.conf
  5062. echo '# disable ipv6' >> /etc/sysctl.conf
  5063. echo 'net.ipv6.conf.all.disable_ipv6 = 1' >> /etc/sysctl.conf
  5064. echo 'net.ipv4.tcp_synack_retries = 2' >> /etc/sysctl.conf
  5065. echo 'net.ipv4.tcp_syn_retries = 1' >> /etc/sysctl.conf
  5066. echo '# keepalive' >> /etc/sysctl.conf
  5067. echo 'net.ipv4.tcp_keepalive_probes = 9' >> /etc/sysctl.conf
  5068. echo 'net.ipv4.tcp_keepalive_intvl = 75' >> /etc/sysctl.conf
  5069. echo 'net.ipv4.tcp_keepalive_time = 7200' >> /etc/sysctl.conf
  5070. echo 'configure_internet_protocol' >> $COMPLETION_FILE
  5071. }
  5072. function configure_email {
  5073. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" ]]; then
  5074. return
  5075. fi
  5076. if grep -Fxq "configure_email" $COMPLETION_FILE; then
  5077. return
  5078. fi
  5079. apt-get -y remove postfix
  5080. apt-get -y install exim4 sasl2-bin swaks libnet-ssleay-perl procmail
  5081. if [ ! -d /etc/exim4 ]; then
  5082. echo "ERROR: Exim does not appear to have installed. $CHECK_MESSAGE"
  5083. exit 48
  5084. fi
  5085. # configure for Maildir format
  5086. sed -i 's/MAIL_DIR/#MAIL_DIR/g' /etc/login.defs
  5087. sed -i 's|#MAIL_FILE.*|MAIL_FILE Maildir/|g' /etc/login.defs
  5088. if ! grep -q "export MAIL" /etc/profile; then
  5089. echo 'export MAIL=~/Maildir' >> /etc/profile
  5090. fi
  5091. sed -i 's|pam_mail.so standard|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/login
  5092. sed -i 's|pam_mail.so standard noenv|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/sshd
  5093. sed -i 's|pam_mail.so nopen|pam_mail.so dir=~/Maildir nopen|g' /etc/pam.d/su
  5094. echo 'dc_eximconfig_configtype="internet"' > /etc/exim4/update-exim4.conf.conf
  5095. echo "dc_other_hostnames='$DEFAULT_DOMAIN_NAME'" >> /etc/exim4/update-exim4.conf.conf
  5096. echo "dc_local_interfaces=''" >> /etc/exim4/update-exim4.conf.conf
  5097. echo "dc_readhost=''" >> /etc/exim4/update-exim4.conf.conf
  5098. echo "dc_relay_domains=''" >> /etc/exim4/update-exim4.conf.conf
  5099. echo "dc_minimaldns='false'" >> /etc/exim4/update-exim4.conf.conf
  5100. RELAY_NETS=$(echo $LOCAL_NETWORK_STATIC_IP_ADDRESS | awk -F '.' '{print $1 "." $2 "." $3 ".0/24"}')
  5101. echo "dc_relay_nets='$RELAY_NETS'" >> /etc/exim4/update-exim4.conf.conf
  5102. echo "dc_smarthost=''" >> /etc/exim4/update-exim4.conf.conf
  5103. echo "CFILEMODE='644'" >> /etc/exim4/update-exim4.conf.conf
  5104. echo "dc_use_split_config='false'" >> /etc/exim4/update-exim4.conf.conf
  5105. echo "dc_hide_mailname=''" >> /etc/exim4/update-exim4.conf.conf
  5106. echo "dc_mailname_in_oh='true'" >> /etc/exim4/update-exim4.conf.conf
  5107. echo "dc_localdelivery='maildir_home'" >> /etc/exim4/update-exim4.conf.conf
  5108. update-exim4.conf
  5109. sed -i "s/START=no/START=yes/g" /etc/default/saslauthd
  5110. /etc/init.d/saslauthd start
  5111. # make a tls certificate for email
  5112. if [ ! -f /etc/ssl/certs/exim.dhparam ]; then
  5113. freedombone-addcert -h exim
  5114. check_certificates exim
  5115. fi
  5116. cp /etc/ssl/private/exim.key /etc/exim4
  5117. cp /etc/ssl/certs/exim.crt /etc/exim4
  5118. cp /etc/ssl/certs/exim.dhparam /etc/exim4
  5119. chown root:Debian-exim /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  5120. chmod 640 /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  5121. sed -i '/login_saslauthd_server/,/.endif/ s/# *//' /etc/exim4/exim4.conf.template
  5122. sed -i "/.ifdef MAIN_HARDCODE_PRIMARY_HOSTNAME/i\MAIN_HARDCODE_PRIMARY_HOSTNAME = $DEFAULT_DOMAIN_NAME\nMAIN_TLS_ENABLE = true" /etc/exim4/exim4.conf.template
  5123. sed -i "s|SMTPLISTENEROPTIONS=''|SMTPLISTENEROPTIONS='-oX 465:25:587 -oP /var/run/exim4/exim.pid'|g" /etc/default/exim4
  5124. if ! grep -q "tls_on_connect_ports=465" /etc/exim4/exim4.conf.template; then
  5125. sed -i '/SSL configuration for exim/i\tls_on_connect_ports=465' /etc/exim4/exim4.conf.template
  5126. fi
  5127. adduser $MY_USERNAME sasl
  5128. addgroup Debian-exim sasl
  5129. /etc/init.d/exim4 restart
  5130. if [ ! -d /etc/skel/Maildir ]; then
  5131. mkdir -m 700 /etc/skel/Maildir
  5132. mkdir -m 700 /etc/skel/Maildir/Sent
  5133. mkdir -m 700 /etc/skel/Maildir/Sent/tmp
  5134. mkdir -m 700 /etc/skel/Maildir/Sent/cur
  5135. mkdir -m 700 /etc/skel/Maildir/Sent/new
  5136. mkdir -m 700 /etc/skel/Maildir/.learn-spam
  5137. mkdir -m 700 /etc/skel/Maildir/.learn-spam/cur
  5138. mkdir -m 700 /etc/skel/Maildir/.learn-spam/new
  5139. mkdir -m 700 /etc/skel/Maildir/.learn-spam/tmp
  5140. mkdir -m 700 /etc/skel/Maildir/.learn-ham
  5141. mkdir -m 700 /etc/skel/Maildir/.learn-ham/cur
  5142. mkdir -m 700 /etc/skel/Maildir/.learn-ham/new
  5143. mkdir -m 700 /etc/skel/Maildir/.learn-ham/tmp
  5144. ln -s /etc/skel/Maildir/.learn-spam /etc/skel/Maildir/spam
  5145. ln -s /etc/skel/Maildir/.learn-ham /etc/skel/Maildir/ham
  5146. fi
  5147. if [ ! -d /home/$MY_USERNAME/Maildir ]; then
  5148. mkdir -m 700 /home/$MY_USERNAME/Maildir
  5149. mkdir -m 700 /home/$MY_USERNAME/Maildir/cur
  5150. mkdir -m 700 /home/$MY_USERNAME/Maildir/tmp
  5151. mkdir -m 700 /home/$MY_USERNAME/Maildir/new
  5152. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent
  5153. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/cur
  5154. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/tmp
  5155. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/new
  5156. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam
  5157. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/cur
  5158. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/new
  5159. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/tmp
  5160. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham
  5161. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/cur
  5162. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/new
  5163. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/tmp
  5164. ln -s /home/$MY_USERNAME/Maildir/.learn-spam /home/$MY_USERNAME/Maildir/spam
  5165. ln -s /home/$MY_USERNAME/Maildir/.learn-ham /home/$MY_USERNAME/Maildir/ham
  5166. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  5167. fi
  5168. echo 'configure_email' >> $COMPLETION_FILE
  5169. }
  5170. function create_procmail {
  5171. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5172. return
  5173. fi
  5174. if grep -Fxq "create_procmail" $COMPLETION_FILE; then
  5175. return
  5176. fi
  5177. if [ ! -f /home/$MY_USERNAME/.procmailrc ]; then
  5178. echo 'MAILDIR=$HOME/Maildir' > /home/$MY_USERNAME/.procmailrc
  5179. echo 'DEFAULT=$MAILDIR/' >> /home/$MY_USERNAME/.procmailrc
  5180. echo 'LOGFILE=$HOME/log/procmail.log' >> /home/$MY_USERNAME/.procmailrc
  5181. echo 'LOGABSTRACT=all' >> /home/$MY_USERNAME/.procmailrc
  5182. fi
  5183. echo 'create_procmail' >> $COMPLETION_FILE
  5184. }
  5185. function spam_filtering {
  5186. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5187. return
  5188. fi
  5189. if grep -Fxq "spam_filtering" $COMPLETION_FILE; then
  5190. return
  5191. fi
  5192. apt-get -y install exim4-daemon-heavy
  5193. apt-get -y install spamassassin
  5194. sa-update -v
  5195. sed -i 's/ENABLED=0/ENABLED=1/g' /etc/default/spamassassin
  5196. sed -i 's/# spamd_address = 127.0.0.1 783/spamd_address = 127.0.0.1 783/g' /etc/exim4/exim4.conf.template
  5197. # This configuration is based on https://wiki.debian.org/DebianSpamAssassin
  5198. sed -i 's/local_parts = postmaster/local_parts = postmaster:abuse/g' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  5199. sed -i '/domains = +local_domains : +relay_to_domains/a\ set acl_m0 = rfcnames' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  5200. sed -i 's/accept/accept condition = ${if eq{$acl_m0}{rfcnames} {1}{0}}/g' /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5201. echo 'warn message = X-Spam-Score: $spam_score ($spam_bar)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5202. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5203. echo 'warn message = X-Spam-Flag: YES' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5204. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5205. echo 'warn message = X-Spam-Report: $spam_report' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5206. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5207. echo '# reject spam at high scores (> 12)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5208. echo 'deny message = This message scored $spam_score spam points.' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5209. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5210. echo ' condition = ${if >{$spam_score_int}{120}{1}{0}}' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  5211. # procmail configuration
  5212. echo '# get spamassassin to check emails' >> /home/$MY_USERNAME/.procmailrc
  5213. echo ':0fw: .spamassassin.lock' >> /home/$MY_USERNAME/.procmailrc
  5214. echo ' * < 256000' >> /home/$MY_USERNAME/.procmailrc
  5215. echo '| spamc' >> /home/$MY_USERNAME/.procmailrc
  5216. echo '# strong spam are discarded' >> /home/$MY_USERNAME/.procmailrc
  5217. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  5218. echo ' * ^X-Spam-Level: \*\*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  5219. echo '/dev/null' >> /home/$MY_USERNAME/.procmailrc
  5220. echo '# weak spam are kept just in case - clear this out every now and then' >> /home/$MY_USERNAME/.procmailrc
  5221. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  5222. echo ' * ^X-Spam-Level: \*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  5223. echo 'maybe-spam/' >> /home/$MY_USERNAME/.procmailrc
  5224. echo '# otherwise, marginal spam goes here for revision' >> /home/$MY_USERNAME/.procmailrc
  5225. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  5226. echo ' * ^X-Spam-Level: \*\*' >> /home/$MY_USERNAME/.procmailrc
  5227. echo 'spam/' >> /home/$MY_USERNAME/.procmailrc
  5228. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  5229. # filtering scripts
  5230. echo '#!/bin/bash' > /usr/bin/filterspam
  5231. echo 'USERNAME=$1' >> /usr/bin/filterspam
  5232. echo 'MAILDIR=/home/$USERNAME/Maildir/.learn-spam' >> /usr/bin/filterspam
  5233. echo 'if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterspam
  5234. echo ' exit' >> /usr/bin/filterspam
  5235. echo 'fi' >> /usr/bin/filterspam
  5236. echo 'for f in `ls $MAILDIR/cur`' >> /usr/bin/filterspam
  5237. echo 'do' >> /usr/bin/filterspam
  5238. echo ' spamc -L spam < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterspam
  5239. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterspam
  5240. echo 'done' >> /usr/bin/filterspam
  5241. echo 'for f in `ls $MAILDIR/new`' >> /usr/bin/filterspam
  5242. echo 'do' >> /usr/bin/filterspam
  5243. echo ' spamc -L spam < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterspam
  5244. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterspam
  5245. echo 'done' >> /usr/bin/filterspam
  5246. echo '#!/bin/bash' > /usr/bin/filterham
  5247. echo 'USERNAME=$1' >> /usr/bin/filterham
  5248. echo 'MAILDIR=/home/$USERNAME/Maildir/.learn-ham' >> /usr/bin/filterham
  5249. echo 'if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterham
  5250. echo ' exit' >> /usr/bin/filterham
  5251. echo 'fi' >> /usr/bin/filterham
  5252. echo 'for f in `ls $MAILDIR/cur`' >> /usr/bin/filterham
  5253. echo 'do' >> /usr/bin/filterham
  5254. echo ' spamc -L ham < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterham
  5255. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterham
  5256. echo 'done' >> /usr/bin/filterham
  5257. echo 'for f in `ls $MAILDIR/new`' >> /usr/bin/filterham
  5258. echo 'do' >> /usr/bin/filterham
  5259. echo ' spamc -L ham < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterham
  5260. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterham
  5261. echo 'done' >> /usr/bin/filterham
  5262. if ! grep -q "filterspam" /etc/crontab; then
  5263. echo "*/3 * * * * root /usr/bin/timeout 120 /usr/bin/filterspam $MY_USERNAME" >> /etc/crontab
  5264. fi
  5265. if ! grep -q "filterham" /etc/crontab; then
  5266. echo "*/3 * * * * root /usr/bin/timeout 120 /usr/bin/filterham $MY_USERNAME" >> /etc/crontab
  5267. fi
  5268. chmod 655 /usr/bin/filterspam /usr/bin/filterham
  5269. sed -i 's/# use_bayes 1/use_bayes 1/g' /etc/mail/spamassassin/local.cf
  5270. sed -i 's/# bayes_auto_learn 1/bayes_auto_learn 1/g' /etc/mail/spamassassin/local.cf
  5271. # user preferences
  5272. if [ ! -d /home/$MY_USERNAME/.spamassassin ]; then
  5273. mkdir /home/$MY_USERNAME/.spamassassin
  5274. echo '# How many points before a mail is considered spam.' > /home/$MY_USERNAME/.spamassassin/user_prefs
  5275. echo '# required_score 5' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5276. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5277. echo '# Whitelist and blacklist addresses are now file-glob-style patterns, so' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5278. echo '# "friend@somewhere.com", "*@isp.com", or "*.domain.net" will all work.' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5279. echo '# whitelist_from someone@somewhere.com' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5280. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5281. echo '# Add your own customised scores for some tests below. The default scores are' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5282. echo '# read from the installed spamassassin rules files, but you can override them' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5283. echo '# here. To see the list of tests and their default scores, go to' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5284. echo '# http://spamassassin.apache.org/tests.html .' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5285. echo '#' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5286. echo '# score SYMBOLIC_TEST_NAME n.nn' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5287. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5288. echo '# Speakers of Asian languages, like Chinese, Japanese and Korean, will almost' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5289. echo '# definitely want to uncomment the following lines. They will switch off some' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5290. echo '# rules that detect 8-bit characters, which commonly trigger on mails using CJK' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5291. echo '# character sets, or that assume a western-style charset is in use. ' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5292. echo '# ' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5293. echo '# score HTML_COMMENT_8BITS 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5294. echo '# score UPPERCASE_25_50 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5295. echo '# score UPPERCASE_50_75 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5296. echo '# score UPPERCASE_75_100 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5297. echo '# score OBSCURED_EMAIL 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5298. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5299. echo '# Speakers of any language that uses non-English, accented characters may wish' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5300. echo '# to uncomment the following lines. They turn off rules that fire on' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5301. echo '# misformatted messages generated by common mail apps in contravention of the' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5302. echo '# email RFCs.' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5303. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5304. echo '# score SUBJ_ILLEGAL_CHARS 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  5305. fi
  5306. # this must be accessible by root
  5307. chown -R $MY_USERNAME:root /home/$MY_USERNAME/.spamassassin
  5308. service spamassassin restart
  5309. service exim4 restart
  5310. service cron restart
  5311. echo 'spam_filtering' >> $COMPLETION_FILE
  5312. }
  5313. function configure_imap {
  5314. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5315. return
  5316. fi
  5317. if grep -Fxq "configure_imap" $COMPLETION_FILE; then
  5318. return
  5319. fi
  5320. dpkg -P dovecot-imapd
  5321. dpkg -P dovecot-core
  5322. apt-get -y install dovecot-imapd
  5323. if [ ! -d /etc/dovecot ]; then
  5324. echo "ERROR: Dovecot does not appear to have installed. $CHECK_MESSAGE"
  5325. exit 48
  5326. fi
  5327. if [ ! -f /etc/ssl/certs/dovecot.dhparam ]; then
  5328. freedombone-addcert -h dovecot
  5329. check_certificates dovecot
  5330. fi
  5331. chown root:dovecot /etc/ssl/certs/dovecot.*
  5332. chown root:dovecot /etc/ssl/private/dovecot.*
  5333. if [ ! -f /etc/dovecot/conf.d/10-ssl.conf ]; then
  5334. echo 'Unable to find /etc/dovecot/conf.d/10-ssl.conf'
  5335. exit 83629
  5336. fi
  5337. sed -i 's|#ssl =.*|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  5338. sed -i 's|ssl = no|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  5339. sed -i 's|ssl = yes|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  5340. sed -i 's|#ssl_cert =.*|ssl_cert = </etc/ssl/certs/dovecot.crt|g' /etc/dovecot/conf.d/10-ssl.conf
  5341. sed -i 's|ssl_cert =.*|ssl_cert = </etc/ssl/certs/dovecot.crt|g' /etc/dovecot/conf.d/10-ssl.conf
  5342. sed -i 's|#ssl_key =.*|ssl_key = </etc/ssl/private/dovecot.key|g' /etc/dovecot/conf.d/10-ssl.conf
  5343. sed -i 's|ssl_key =.*|ssl_key = </etc/ssl/private/dovecot.key|g' /etc/dovecot/conf.d/10-ssl.conf
  5344. sed -i 's|#ssl_dh_parameters_length.*|ssl_dh_parameters_length = 1024|g' /etc/dovecot/conf.d/10-ssl.conf
  5345. sed -i 's/#ssl_prefer_server_ciphers.*/ssl_prefer_server_ciphers = yes/g' /etc/dovecot/conf.d/10-ssl.conf
  5346. sed -i "s|#ssl_protocols =.*|ssl_protocols = '$SSL_PROTOCOLS'|g" /etc/dovecot/conf.d/10-ssl.conf
  5347. sed -i "s|ssl_protocols =.*|ssl_protocols = '$SSL_PROTOCOLS'|g" /etc/dovecot/conf.d/10-ssl.conf
  5348. echo "ssl_cipher_list = '$SSL_CIPHERS'" >> /etc/dovecot/conf.d/10-ssl.conf
  5349. if [ ! -f /etc/dovecot/conf.d/10-master.conf ]; then
  5350. echo 'Unable to find /etc/dovecot/conf.d/10-master.conf'
  5351. exit 49259
  5352. fi
  5353. sed -i 's/#process_limit =.*/process_limit = 100/g' /etc/dovecot/conf.d/10-master.conf
  5354. sed -i 's/#default_client_limit.*/default_client_limit = 100/g' /etc/dovecot/conf.d/10-master.conf
  5355. sed -i 's|#default_process_limit =.*|default_process_limit = 100|g' /etc/dovecot/conf.d/10-master.conf
  5356. if [ ! -f /etc/dovecot/conf.d/10-logging.conf ]; then
  5357. echo 'Unable to find /etc/dovecot/conf.d/10-logging.conf'
  5358. exit 48936
  5359. fi
  5360. sed -i 's/#auth_verbose.*/auth_verbose = yes/g' /etc/dovecot/conf.d/10-logging.conf
  5361. if [ ! -f /etc/dovecot/dovecot.conf ]; then
  5362. echo 'Unable to find /etc/dovecot/dovecot.conf'
  5363. exit 43890
  5364. fi
  5365. sed -i 's/#listen =.*/listen = */g' /etc/dovecot/dovecot.conf
  5366. if [ ! -f /etc/dovecot/conf.d/10-auth.conf ]; then
  5367. echo 'Unable to find /etc/dovecot/conf.d/10-auth.conf'
  5368. exit 843256
  5369. fi
  5370. sed -i 's/#disable_plaintext_auth =.*/disable_plaintext_auth = no/g' /etc/dovecot/conf.d/10-auth.conf
  5371. sed -i 's/auth_mechanisms =.*/auth_mechanisms = plain login/g' /etc/dovecot/conf.d/10-auth.conf
  5372. if [ ! -f /etc/dovecot/conf.d/10-mail.conf ]; then
  5373. echo 'Unable to find /etc/dovecot/conf.d/10-mail.conf'
  5374. exit 42036
  5375. fi
  5376. sed -i 's|mail_location =.*|mail_location = maildir:~/Maildir:LAYOUT=fs|g' /etc/dovecot/conf.d/10-mail.conf
  5377. service dovecot restart
  5378. echo 'configure_imap' >> $COMPLETION_FILE
  5379. }
  5380. function configure_imap_client_certs {
  5381. if grep -Fxq "configure_imap_client_certs" $COMPLETION_FILE; then
  5382. return
  5383. fi
  5384. # http://strange.systems/certificate-based-auth-with-dovecot-sendmail/
  5385. sed -i 's|#default_process_limit =.*|default_process_limit = 100|g' /etc/dovecot/conf.d/10-master.conf
  5386. sed -i 's/disable_plaintext_auth =.*/disable_plaintext_auth = yes/g' /etc/dovecot/conf.d/10-auth.conf
  5387. sed -i 's|#auth_ssl_require_client_cert =.*|auth_ssl_require_client_cert = yes|g' /etc/dovecot/conf.d/10-auth.conf
  5388. sed -i 's|#auth_ssl_username_from_cert =.*|auth_ssl_username_from_cert = yes|g' /etc/dovecot/conf.d/10-auth.conf
  5389. sed -i "s|#ssl_ca =.*|ssl_ca = /etc/ssl/certs/ca-$DEFAULT_DOMAIN_NAME.crt|g" /etc/dovecot/conf.d/10-ssl.conf
  5390. sed -i 's|#ssl_cert_username_field =.*|ssl_cert_username_field = commonName|g' /etc/dovecot/conf.d/10-ssl.conf
  5391. sed -i 's|#ssl_verify_client_cert =.*|ssl_verify_client_cert = yes|g' /etc/dovecot/conf.d/10-ssl.conf
  5392. if ! grep -q "passdb {" /etc/dovecot/conf.d/10-auth.conf; then
  5393. echo '' >> /etc/dovecot/conf.d/10-auth.conf
  5394. echo 'passdb {' >> /etc/dovecot/conf.d/10-auth.conf
  5395. echo ' driver = passwd-file' >> /etc/dovecot/conf.d/10-auth.conf
  5396. echo ' args = /etc/dovecot/passwd-file' >> /etc/dovecot/conf.d/10-auth.conf
  5397. echo ' deny = no' >> /etc/dovecot/conf.d/10-auth.conf
  5398. echo ' master = no' >> /etc/dovecot/conf.d/10-auth.conf
  5399. echo ' pass = no' >> /etc/dovecot/conf.d/10-auth.conf
  5400. echo '}' >> /etc/dovecot/conf.d/10-auth.conf
  5401. fi
  5402. # make a CA cert
  5403. if [ ! -f /etc/ssl/private/ca-$DEFAULT_DOMAIN_NAME.key ]; then
  5404. freedombone-addcert -h $DEFAULT_DOMAIN_NAME --ca ""
  5405. fi
  5406. # CA configuration
  5407. echo '[ ca ]' > /etc/ssl/dovecot-ca.cnf
  5408. echo "default_ca = dovecot-ca" >> /etc/ssl/dovecot-ca.cnf
  5409. echo '' >> /etc/ssl/dovecot-ca.cnf
  5410. echo '[ crl_ext ]' >> /etc/ssl/dovecot-ca.cnf
  5411. echo 'authorityKeyIdentifier=keyid:always' >> /etc/ssl/dovecot-ca.cnf
  5412. echo '' >> /etc/ssl/dovecot-ca.cnf
  5413. echo '[ dovecot-ca ]' >> /etc/ssl/dovecot-ca.cnf
  5414. echo 'new_certs_dir = .' >> /etc/ssl/dovecot-ca.cnf
  5415. echo 'unique_subject = no' >> /etc/ssl/dovecot-ca.cnf
  5416. echo "certificate = /etc/ssl/certs/ca-$DEFAULT_DOMAIN_NAME.crt" >> /etc/ssl/dovecot-ca.cnf
  5417. echo 'database = ssldb' >> /etc/ssl/dovecot-ca.cnf
  5418. echo "private_key = /etc/ssl/private/ca-$DEFAULT_DOMAIN_NAME.key" >> /etc/ssl/dovecot-ca.cnf
  5419. echo 'serial = sslserial' >> /etc/ssl/dovecot-ca.cnf
  5420. echo 'default_days = 3650' >> /etc/ssl/dovecot-ca.cnf
  5421. echo 'default_md = sha256' >> /etc/ssl/dovecot-ca.cnf
  5422. echo 'default_bits = 4096' >> /etc/ssl/dovecot-ca.cnf
  5423. echo 'policy = dovecot-ca_policy' >> /etc/ssl/dovecot-ca.cnf
  5424. echo 'x509_extensions = dovecot-ca_extensions' >> /etc/ssl/dovecot-ca.cnf
  5425. echo '' >> /etc/ssl/dovecot-ca.cnf
  5426. echo '[ dovecot-ca_policy ]' >> /etc/ssl/dovecot-ca.cnf
  5427. echo 'commonName = supplied' >> /etc/ssl/dovecot-ca.cnf
  5428. echo 'stateOrProvinceName = supplied' >> /etc/ssl/dovecot-ca.cnf
  5429. echo 'countryName = supplied' >> /etc/ssl/dovecot-ca.cnf
  5430. echo 'emailAddress = optional' >> /etc/ssl/dovecot-ca.cnf
  5431. echo 'organizationName = supplied' >> /etc/ssl/dovecot-ca.cnf
  5432. echo 'organizationalUnitName = optional' >> /etc/ssl/dovecot-ca.cnf
  5433. echo '' >> /etc/ssl/dovecot-ca.cnf
  5434. echo '[ dovecot-ca_extensions ]' >> /etc/ssl/dovecot-ca.cnf
  5435. echo 'basicConstraints = CA:false' >> /etc/ssl/dovecot-ca.cnf
  5436. echo 'subjectKeyIdentifier = hash' >> /etc/ssl/dovecot-ca.cnf
  5437. echo 'authorityKeyIdentifier = keyid:always' >> /etc/ssl/dovecot-ca.cnf
  5438. echo 'keyUsage = digitalSignature,keyEncipherment' >> /etc/ssl/dovecot-ca.cnf
  5439. echo 'extendedKeyUsage = clientAuth' >> /etc/ssl/dovecot-ca.cnf
  5440. if [ -f /etc/ssl/ssldb ]; then
  5441. rm /etc/ssl/ssldb
  5442. fi
  5443. if [ -f /etc/ssl/sslserial ]; then
  5444. rm /etc/ssl/sslserial
  5445. fi
  5446. touch /etc/ssl/ssldb
  5447. echo 0001 > /etc/ssl/sslserial
  5448. #freedombone-clientcert -u $MY_USERNAME
  5449. service dovecot restart
  5450. echo 'configure_imap_client_certs' >> $COMPLETION_FILE
  5451. }
  5452. function configure_gpg {
  5453. if grep -Fxq "configure_gpg" $COMPLETION_FILE; then
  5454. return
  5455. fi
  5456. apt-get -y install gnupg
  5457. # if gpg keys directory was previously imported from usb
  5458. if [[ $GPG_KEYS_IMPORTED == "yes" && -d /home/$MY_USERNAME/.gnupg ]]; then
  5459. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" /home/$MY_USERNAME/.gnupg/gpg.conf
  5460. 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}')
  5461. echo 'configure_gpg' >> $COMPLETION_FILE
  5462. return
  5463. fi
  5464. if [ ! -d /home/$MY_USERNAME/.gnupg ]; then
  5465. mkdir /home/$MY_USERNAME/.gnupg
  5466. echo 'keyserver hkp://keys.gnupg.net' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  5467. echo 'keyserver-options auto-key-retrieve' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  5468. fi
  5469. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" /home/$MY_USERNAME/.gnupg/gpg.conf
  5470. if ! grep -q "# default preferences" /home/$MY_USERNAME/.gnupg/gpg.conf; then
  5471. echo '' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  5472. echo '# default preferences' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  5473. echo 'personal-digest-preferences SHA256' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  5474. echo 'cert-digest-algo SHA256' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  5475. echo 'default-preference-list SHA512 SHA384 SHA256 SHA224 AES256 AES192 AES CAST5 ZLIB BZIP2 ZIP Uncompressed' >> /home/$MY_USERNAME/.gnupg/gpg.conf
  5476. fi
  5477. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.gnupg
  5478. if [[ $MY_GPG_PUBLIC_KEY && $MY_GPG_PRIVATE_KEY ]]; then
  5479. # use your existing GPG keys which were exported
  5480. if [ ! -f $MY_GPG_PUBLIC_KEY ]; then
  5481. echo "GPG public key file $MY_GPG_PUBLIC_KEY was not found"
  5482. exit 5
  5483. fi
  5484. if [ ! -f $MY_GPG_PRIVATE_KEY ]; then
  5485. echo "GPG private key file $MY_GPG_PRIVATE_KEY was not found"
  5486. exit 6
  5487. fi
  5488. su -c "gpg --import $MY_GPG_PUBLIC_KEY" - $MY_USERNAME
  5489. su -c "gpg --allow-secret-key-import --import $MY_GPG_PRIVATE_KEY" - $MY_USERNAME
  5490. # for security ensure that the private key file doesn't linger around
  5491. shred -zu $MY_GPG_PRIVATE_KEY
  5492. 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}')
  5493. else
  5494. # Generate a GPG key
  5495. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  5496. echo 'Key-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  5497. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  5498. echo 'Subkey-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  5499. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  5500. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  5501. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  5502. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  5503. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  5504. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  5505. 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}')
  5506. MY_GPG_PUBLIC_KEY=/tmp/public_key.gpg
  5507. su -c "gpg --output $MY_GPG_PUBLIC_KEY --armor --export $MY_GPG_PUBLIC_KEY_ID" - $MY_USERNAME
  5508. if grep -q "configure_email" $COMPLETION_FILE; then
  5509. if ! grep -q "Change your GPG password" /home/$MY_USERNAME/README; then
  5510. echo '' >> /home/$MY_USERNAME/README
  5511. echo '' >> /home/$MY_USERNAME/README
  5512. echo 'Change your GPG password' >> /home/$MY_USERNAME/README
  5513. echo '========================' >> /home/$MY_USERNAME/README
  5514. echo "It's very important to add a password to your GPG key so that" >> /home/$MY_USERNAME/README
  5515. echo "if anyone does get access to your email they still won't be able" >> /home/$MY_USERNAME/README
  5516. echo 'to read them without knowning the GPG password.' >> /home/$MY_USERNAME/README
  5517. echo 'You can change the it with:' >> /home/$MY_USERNAME/README
  5518. echo '' >> /home/$MY_USERNAME/README
  5519. echo " gpg --edit-key $MY_GPG_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  5520. echo ' passwd' >> /home/$MY_USERNAME/README
  5521. echo ' save' >> /home/$MY_USERNAME/README
  5522. echo ' quit' >> /home/$MY_USERNAME/README
  5523. fi
  5524. if ! grep -q "Publish your GPG public key" /home/$MY_USERNAME/README; then
  5525. echo '' >> /home/$MY_USERNAME/README
  5526. echo '' >> /home/$MY_USERNAME/README
  5527. echo 'Publish your GPG public key' >> /home/$MY_USERNAME/README
  5528. echo '===========================' >> /home/$MY_USERNAME/README
  5529. echo 'So that others can send emails to you securely you should' >> /home/$MY_USERNAME/README
  5530. echo 'publish your GPG public key with the command:' >> /home/$MY_USERNAME/README
  5531. echo '' >> /home/$MY_USERNAME/README
  5532. echo " gpg --send-keys $MY_GPG_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  5533. fi
  5534. fi
  5535. fi
  5536. echo 'configure_gpg' >> $COMPLETION_FILE
  5537. }
  5538. function encrypt_incoming_email {
  5539. # encrypts incoming mail using your GPG public key
  5540. # so even if an attacker gains access to the data at rest they still need
  5541. # to know your GPG key password to be able to read anything
  5542. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5543. return
  5544. fi
  5545. if grep -Fxq "encrypt_incoming_email" $COMPLETION_FILE; then
  5546. return
  5547. fi
  5548. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  5549. return
  5550. fi
  5551. if [ ! -f /usr/bin/gpgit.pl ]; then
  5552. apt-get -y install git libmail-gnupg-perl
  5553. cd $INSTALL_DIR
  5554. git clone https://github.com/mikecardwell/gpgit
  5555. cd gpgit
  5556. cp gpgit.pl /usr/bin
  5557. fi
  5558. # add a procmail rule
  5559. if ! grep -q "/usr/bin/gpgit.pl" /home/$MY_USERNAME/.procmailrc; then
  5560. echo '' >> /home/$MY_USERNAME/.procmailrc
  5561. echo ':0 f' >> /home/$MY_USERNAME/.procmailrc
  5562. echo "| /usr/bin/gpgit.pl --encrypt-mode prefer-inline --inline-flatten $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/.procmailrc
  5563. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  5564. fi
  5565. echo 'encrypt_incoming_email' >> $COMPLETION_FILE
  5566. }
  5567. function encrypt_outgoing_email {
  5568. # encrypts outgoing mail using your GPG public key
  5569. # so even if an attacker gains access to the data at rest they still need
  5570. # to know your GPG key password to be able to read sent mail
  5571. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5572. return
  5573. fi
  5574. if grep -Fxq "encrypt_outgoing_email" $COMPLETION_FILE; then
  5575. return
  5576. fi
  5577. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  5578. return
  5579. fi
  5580. if [ ! -d /home/$MY_USERNAME/.gnupg ]; then
  5581. return
  5582. fi
  5583. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  5584. return
  5585. fi
  5586. # obtain your public key ID
  5587. if [ ! $MY_GPG_PUBLIC_KEY_ID ]; then
  5588. 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}')
  5589. if [ ! $MY_GPG_PUBLIC_KEY_ID ]; then
  5590. return
  5591. fi
  5592. fi
  5593. if ! grep -q "pgp_encrypt_only_command" /home/$MY_USERNAME/.muttrc; then
  5594. echo '' >> /home/$MY_USERNAME/.muttrc
  5595. echo '# Encrypt items in the Sent folder' >> /home/$MY_USERNAME/.muttrc
  5596. echo "set pgp_encrypt_only_command=\"/usr/lib/mutt/pgpewrap gpg --batch --quiet --no-verbose --output - --encrypt --textmode --armor --always-trust --encrypt-to 0x$MY_GPG_PUBLIC_KEY_ID -- -r %r -- %f\"" >> /home/$MY_USERNAME/.muttrc
  5597. else
  5598. sed -i "s|set pgp_encrypt_only_command.*|set pgp_encrypt_only_command=\"/usr/lib/mutt/pgpewrap gpg --batch --quiet --no-verbose --output - --encrypt --textmode --armor --always-trust --encrypt-to 0x$MY_GPG_PUBLIC_KEY_ID -- -r %r -- %f\"|g" /home/$MY_USERNAME/.muttrc
  5599. fi
  5600. if ! grep -q "pgp_encrypt_sign_command" /home/$MY_USERNAME/.muttrc; then
  5601. echo "set pgp_encrypt_sign_command=\"/usr/lib/mutt/pgpewrap gpg %?p?--passphrase-fd 0? --batch --quiet --no-verbose --textmode --output - --encrypt --sign %?a?-u %a? --armor --always-trust --encrypt-to 0x$MY_GPG_PUBLIC_KEY_ID -- -r %r -- %f\"" >> /home/$MY_USERNAME/.muttrc
  5602. else
  5603. sed -i "s|set pgp_encrypt_sign_command.*|set pgp_encrypt_sign_command=\"/usr/lib/mutt/pgpewrap gpg %?p?--passphrase-fd 0? --batch --quiet --no-verbose --textmode --output - --encrypt --sign %?a?-u %a? --armor --always-trust --encrypt-to 0x$MY_GPG_PUBLIC_KEY_ID -- -r %r -- %f\"|g" /home/$MY_USERNAME/.muttrc
  5604. fi
  5605. echo 'encrypt_outgoing_email' >> $COMPLETION_FILE
  5606. }
  5607. function encrypt_all_email {
  5608. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5609. return
  5610. fi
  5611. if grep -Fxq "encrypt_all_email" $COMPLETION_FILE; then
  5612. return
  5613. fi
  5614. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  5615. return
  5616. fi
  5617. echo '#!/bin/bash' > /usr/bin/encmaildir
  5618. echo '#' >> /usr/bin/encmaildir
  5619. echo '# GPLv2' >> /usr/bin/encmaildir
  5620. echo '# GPG Encrypt a Maildir using gpgit.pl' >> /usr/bin/encmaildir
  5621. echo '# Oct 03, 2014' >> /usr/bin/encmaildir
  5622. echo '#' >> /usr/bin/encmaildir
  5623. echo '# Change log:' >> /usr/bin/encmaildir
  5624. echo '# Sep 03, 2011' >> /usr/bin/encmaildir
  5625. echo '# - Temporary file is based on file_owner to avoid' >> /usr/bin/encmaildir
  5626. echo '# issues with permission differences.' >> /usr/bin/encmaildir
  5627. echo '# - Temporary file is removed after run.' >> /usr/bin/encmaildir
  5628. echo '# - Optional arguments passed to "find".' >> /usr/bin/encmaildir
  5629. echo '# - Full paths to binaries.' >> /usr/bin/encmaildir
  5630. echo '# - Removed unneccessary need of "cat", "grep", etc.' >> /usr/bin/encmaildir
  5631. echo '# Sep 04, 2011' >> /usr/bin/encmaildir
  5632. echo '# - Dont remove Dovecot index/uid unless messages' >> /usr/bin/encmaildir
  5633. echo '# have been GPG encrypted.' >> /usr/bin/encmaildir
  5634. echo '# - Adjust file tests to not just use -e' >> /usr/bin/encmaildir
  5635. echo '# - Quote all file operations' >> /usr/bin/encmaildir
  5636. echo '# Sep 05, 2011' >> /usr/bin/encmaildir
  5637. echo '# - Dont arbitrarily copy files, only overwrite the file' >> /usr/bin/encmaildir
  5638. echo '# in ~/Maildir if it differs after calling gpgencmail.pl' >> /usr/bin/encmaildir
  5639. echo '# - Only rebuild the index if we have modified ~/Maildir' >> /usr/bin/encmaildir
  5640. echo '# Oct 03, 2014' >> /usr/bin/encmaildir
  5641. echo '# - Minor modifications for use with Freedombone' >> /usr/bin/encmaildir
  5642. echo '' >> /usr/bin/encmaildir
  5643. echo 'if [[ -z "$1" || -z "$2" || -z "$3" ]]; then' >> /usr/bin/encmaildir
  5644. echo ' echo "Usage is ./encmaildir.sh {optional arguments passed to find for messages such as -mtime 0}"' >> /usr/bin/encmaildir
  5645. echo ' exit 0' >> /usr/bin/encmaildir
  5646. echo 'fi' >> /usr/bin/encmaildir
  5647. echo '' >> /usr/bin/encmaildir
  5648. echo 'MAIL_DIR=$1' >> /usr/bin/encmaildir
  5649. echo 'EMAIL_ADDRESS=$2' >> /usr/bin/encmaildir
  5650. echo 'USERNAME=$3' >> /usr/bin/encmaildir
  5651. echo 'if [ ! -d "$MAIL_DIR" ]; then' >> /usr/bin/encmaildir
  5652. echo " MAIL_DIR='/home/$MY_USERNAME/Maildir'" >> /usr/bin/encmaildir
  5653. echo 'fi' >> /usr/bin/encmaildir
  5654. echo '' >> /usr/bin/encmaildir
  5655. echo 'if [ ! $EMAIL_ADDRESS ]; then' >> /usr/bin/encmaildir
  5656. echo " EMAIL_ADDRESS='$MY_EMAIL_ADDRESS'" >> /usr/bin/encmaildir
  5657. echo 'fi' >> /usr/bin/encmaildir
  5658. echo '' >> /usr/bin/encmaildir
  5659. echo 'if [ ! $USERNAME ]; then' >> /usr/bin/encmaildir
  5660. echo " USERNAME='$MY_USERNAME'" >> /usr/bin/encmaildir
  5661. echo 'fi' >> /usr/bin/encmaildir
  5662. echo '' >> /usr/bin/encmaildir
  5663. echo '# Does this key exist?' >> /usr/bin/encmaildir
  5664. echo 'gpg --list-keys "$EMAIL_ADDRESS" > /dev/null 2>&1' >> /usr/bin/encmaildir
  5665. echo 'if [ $? -gt 0 ]; then' >> /usr/bin/encmaildir
  5666. echo ' echo "A GPG key for $EMAIL_ADDRESS could not be found!"' >> /usr/bin/encmaildir
  5667. echo ' exit 0' >> /usr/bin/encmaildir
  5668. echo 'fi' >> /usr/bin/encmaildir
  5669. echo '' >> /usr/bin/encmaildir
  5670. echo '# Find all files in the Maildir specified.' >> /usr/bin/encmaildir
  5671. echo 'echo "Calling find"' >> /usr/bin/encmaildir
  5672. echo -n 'find "$MAIL_DIR" -type f -regex ' >> /usr/bin/encmaildir
  5673. echo -n "'.*/\(cur\|new\)/.*' " >> /usr/bin/encmaildir
  5674. echo '$4|while read line; do' >> /usr/bin/encmaildir
  5675. echo ' gpgit.pl --encrypt-mode prefer-inline "$EMAIL_ADDRESS" "/tmp/msg_$USERNAME"' >> /usr/bin/encmaildir
  5676. echo '' >> /usr/bin/encmaildir
  5677. echo ' # Check to see if there are differences between the existing' >> /usr/bin/encmaildir
  5678. echo ' # Maildir file and what was created by gpgit.pl' >> /usr/bin/encmaildir
  5679. echo ' diff -qa "$line" "/tmp/msg_$USERNAME" > /dev/null 2>&1;' >> /usr/bin/encmaildir
  5680. echo ' if [ $? -gt 0 ]; then' >> /usr/bin/encmaildir
  5681. echo ' # Preserve timestamps, set ownership.' >> /usr/bin/encmaildir
  5682. echo ' chown $USERNAME:$USERNAME "/tmp/msg_$USERNAME"' >> /usr/bin/encmaildir
  5683. echo ' chmod 600 "/tmp/msg_$USERNAME"' >> /usr/bin/encmaildir
  5684. echo ' touch "/tmp/msg_$USERNAME" --reference="$line"' >> /usr/bin/encmaildir
  5685. echo '' >> /usr/bin/encmaildir
  5686. echo ' # Unlink the original Maildir message' >> /usr/bin/encmaildir
  5687. echo ' unlink "$line"' >> /usr/bin/encmaildir
  5688. echo '' >> /usr/bin/encmaildir
  5689. echo ' # Strip message sizes, retain experimental flags' >> /usr/bin/encmaildir
  5690. echo ' # and status flags, and copy the file over.' >> /usr/bin/encmaildir
  5691. echo ' STRIPSIZES=$(/bin/echo "$line"|/bin/sed -e "s/W=[[:digit:]]*//" -e "s/S=[[:digit:]]*//" -e "s/,,//" -e "s/,:2/:2/")' >> /usr/bin/encmaildir
  5692. echo ' cp -av "/tmp/msg_$USERNAME" "$STRIPSIZES"' >> /usr/bin/encmaildir
  5693. echo '' >> /usr/bin/encmaildir
  5694. echo ' #Indexes must be rebuilt, weve modified Maildir.' >> /usr/bin/encmaildir
  5695. echo ' touch "/tmp/rebuild_index_$USERNAME"' >> /usr/bin/encmaildir
  5696. echo ' else' >> /usr/bin/encmaildir
  5697. echo ' echo "Not copying, no differences between /tmp/msg_$USERNAME and $line"' >> /usr/bin/encmaildir
  5698. echo ' fi' >> /usr/bin/encmaildir
  5699. echo '' >> /usr/bin/encmaildir
  5700. echo ' # Remove the temporary file' >> /usr/bin/encmaildir
  5701. echo ' unlink "/tmp/msg_$USERNAME"' >> /usr/bin/encmaildir
  5702. echo 'done' >> /usr/bin/encmaildir
  5703. echo '' >> /usr/bin/encmaildir
  5704. echo '# Remove Dovecot index and uids for regeneration.' >> /usr/bin/encmaildir
  5705. echo 'if [ -f "/tmp/rebuild_index_$USERNAME" ]; then' >> /usr/bin/encmaildir
  5706. echo ' echo "Removing Dovecot indexes and uids"' >> /usr/bin/encmaildir
  5707. echo -n ' find "$MAIL_DIR" -type f -regex ' >> /usr/bin/encmaildir
  5708. echo "'.*\(dovecot-\|dovecot\.\|\.uidvalidity\).*' -delete" >> /usr/bin/encmaildir
  5709. echo '' >> /usr/bin/encmaildir
  5710. echo ' # Remove the temporary file' >> /usr/bin/encmaildir
  5711. echo ' unlink "/tmp/rebuild_index_$USERNAME"' >> /usr/bin/encmaildir
  5712. echo 'else' >> /usr/bin/encmaildir
  5713. echo ' echo "No messages found needing GPG encryption, not' >> /usr/bin/encmaildir
  5714. echo ' echo "removing Dovecot indexes and UIDs."' >> /usr/bin/encmaildir
  5715. echo 'fi' >> /usr/bin/encmaildir
  5716. echo 'exit 0' >> /usr/bin/encmaildir
  5717. chmod +x /usr/bin/encmaildir
  5718. if [ ! /home/$MY_USERNAME/README ]; then
  5719. touch /home/$MY_USERNAME/README
  5720. fi
  5721. if ! grep -q "If you have imported legacy email" /home/$MY_USERNAME/README; then
  5722. echo '' >> /home/$MY_USERNAME/README
  5723. echo '' >> /home/$MY_USERNAME/README
  5724. echo 'Encrypting legacy email' >> /home/$MY_USERNAME/README
  5725. echo '=======================' >> /home/$MY_USERNAME/README
  5726. echo 'If you have imported legacy email which is not encrypted' >> /home/$MY_USERNAME/README
  5727. echo 'then it can be encrypted with the command:' >> /home/$MY_USERNAME/README
  5728. echo '' >> /home/$MY_USERNAME/README
  5729. echo ' encmaildir' >> /home/$MY_USERNAME/README
  5730. echo '' >> /home/$MY_USERNAME/README
  5731. echo 'But be warned that depending upon how much email you have' >> /home/$MY_USERNAME/README
  5732. echo 'this could take a seriously LONG time on the Beaglebone' >> /home/$MY_USERNAME/README
  5733. echo 'and may be better done on a faster machine.' >> /home/$MY_USERNAME/README
  5734. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5735. fi
  5736. echo 'encrypt_all_email' >> $COMPLETION_FILE
  5737. }
  5738. function email_client {
  5739. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5740. return
  5741. fi
  5742. if grep -Fxq "email_client" $COMPLETION_FILE; then
  5743. return
  5744. fi
  5745. apt-get -y install mutt-patched lynx abook
  5746. if [ ! -f /etc/Muttrc ]; then
  5747. echo "ERROR: Mutt does not appear to have installed. $CHECK_MESSAGE"
  5748. exit 49
  5749. fi
  5750. if [ ! -d /home/$MY_USERNAME/.mutt ]; then
  5751. mkdir /home/$MY_USERNAME/.mutt
  5752. fi
  5753. echo "text/html; lynx -dump -width=78 -nolist %s | sed ‘s/^ //’; copiousoutput; needsterminal; nametemplate=%s.html" > /home/$MY_USERNAME/.mutt/mailcap
  5754. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt
  5755. echo 'set mbox_type=Maildir' >> /etc/Muttrc
  5756. echo 'set folder="~/Maildir"' >> /etc/Muttrc
  5757. echo 'set mask="!^\\.[^.]"' >> /etc/Muttrc
  5758. echo 'set mbox="~/Maildir"' >> /etc/Muttrc
  5759. echo 'set record="+Sent"' >> /etc/Muttrc
  5760. echo 'set postponed="+Drafts"' >> /etc/Muttrc
  5761. echo 'set trash="+Trash"' >> /etc/Muttrc
  5762. echo 'set spoolfile="~/Maildir"' >> /etc/Muttrc
  5763. echo 'auto_view text/x-vcard text/html text/enriched' >> /etc/Muttrc
  5764. echo 'set editor="emacs -q --load ~/.emacs-mutt"' >> /etc/Muttrc
  5765. echo 'set header_cache="+.cache"' >> /etc/Muttrc
  5766. echo '' >> /etc/Muttrc
  5767. echo 'macro index S "<tag-prefix><save-message>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  5768. echo 'macro pager S "<save-message>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  5769. echo 'macro index H "<tag-prefix><copy-message>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  5770. echo 'macro pager H "<copy-message>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  5771. echo '' >> /etc/Muttrc
  5772. echo '# set up the sidebar' >> /etc/Muttrc
  5773. echo 'set sidebar_width=22' >> /etc/Muttrc
  5774. echo 'set sidebar_visible=yes' >> /etc/Muttrc
  5775. echo "set sidebar_delim='|'" >> /etc/Muttrc
  5776. echo 'set sidebar_sort=yes' >> /etc/Muttrc
  5777. echo '' >> /etc/Muttrc
  5778. echo 'set rfc2047_parameters' >> /etc/Muttrc
  5779. echo '' >> /etc/Muttrc
  5780. echo '# Show inbox and sent items' >> /etc/Muttrc
  5781. echo 'mailboxes = =Sent =maybe-spam =spam' >> /etc/Muttrc
  5782. echo '' >> /etc/Muttrc
  5783. echo '# Alter these colours as needed for maximum bling' >> /etc/Muttrc
  5784. echo 'color sidebar_new yellow default' >> /etc/Muttrc
  5785. echo 'color normal white default' >> /etc/Muttrc
  5786. echo 'color hdrdefault brightcyan default' >> /etc/Muttrc
  5787. echo 'color signature green default' >> /etc/Muttrc
  5788. echo 'color attachment brightyellow default' >> /etc/Muttrc
  5789. echo 'color quoted green default' >> /etc/Muttrc
  5790. echo 'color quoted1 white default' >> /etc/Muttrc
  5791. echo 'color tilde blue default' >> /etc/Muttrc
  5792. echo '' >> /etc/Muttrc
  5793. echo '# ctrl-n, ctrl-p to select next, prev folder' >> /etc/Muttrc
  5794. echo '# ctrl-o to open selected folder' >> /etc/Muttrc
  5795. echo 'bind index \Cp sidebar-prev' >> /etc/Muttrc
  5796. echo 'bind index \Cn sidebar-next' >> /etc/Muttrc
  5797. echo 'bind index \Co sidebar-open' >> /etc/Muttrc
  5798. echo 'bind pager \Cp sidebar-prev' >> /etc/Muttrc
  5799. echo 'bind pager \Cn sidebar-next' >> /etc/Muttrc
  5800. echo 'bind pager \Co sidebar-open' >> /etc/Muttrc
  5801. echo '' >> /etc/Muttrc
  5802. echo '# ctrl-b toggles sidebar visibility' >> /etc/Muttrc
  5803. echo "macro index,pager \Cb '<enter-command>toggle sidebar_visible<enter><redraw-screen>' 'toggle sidebar'" >> /etc/Muttrc
  5804. echo '' >> /etc/Muttrc
  5805. echo '# esc-m Mark new messages as read' >> /etc/Muttrc
  5806. echo 'macro index <esc>m "T~N<enter>;WNT~O<enter>;WO\CT~T<enter>" "mark all messages read"' >> /etc/Muttrc
  5807. echo '' >> /etc/Muttrc
  5808. echo '# Collapsing threads' >> /etc/Muttrc
  5809. echo 'macro index [ "<collapse-thread>" "collapse/uncollapse thread"' >> /etc/Muttrc
  5810. echo 'macro index ] "<collapse-all>" "collapse/uncollapse all threads"' >> /etc/Muttrc
  5811. echo '' >> /etc/Muttrc
  5812. echo '# threads containing new messages' >> /etc/Muttrc
  5813. echo 'uncolor index "~(~N)"' >> /etc/Muttrc
  5814. echo 'color index brightblue default "~(~N)"' >> /etc/Muttrc
  5815. echo '' >> /etc/Muttrc
  5816. echo '# new messages themselves' >> /etc/Muttrc
  5817. echo 'uncolor index "~N"' >> /etc/Muttrc
  5818. echo 'color index brightyellow default "~N"' >> /etc/Muttrc
  5819. echo '' >> /etc/Muttrc
  5820. echo '# GPG/PGP integration' >> /etc/Muttrc
  5821. echo '# this set the number of seconds to keep in memory the passphrase used to encrypt/sign' >> /etc/Muttrc
  5822. echo 'set pgp_timeout=1800' >> /etc/Muttrc
  5823. echo '' >> /etc/Muttrc
  5824. echo '# automatically sign and encrypt with PGP/MIME' >> /etc/Muttrc
  5825. echo 'set pgp_autosign # autosign all outgoing mails' >> /etc/Muttrc
  5826. echo 'set pgp_autoencrypt # Try to encrypt automatically' >> /etc/Muttrc
  5827. echo 'set pgp_replyencrypt # autocrypt replies to crypted' >> /etc/Muttrc
  5828. echo 'set pgp_replysign # autosign replies to signed' >> /etc/Muttrc
  5829. echo 'set pgp_auto_decode=yes # decode attachments' >> /etc/Muttrc
  5830. echo 'set fcc_clear=no # Keep encrypted copy of sent encrypted mail' >> /etc/Muttrc
  5831. echo 'unset smime_is_default' >> /etc/Muttrc
  5832. echo '' >> /etc/Muttrc
  5833. echo 'set alias_file=~/.mutt-alias' >> /etc/Muttrc
  5834. echo 'source ~/.mutt-alias' >> /etc/Muttrc
  5835. echo 'set query_command= "abook --mutt-query \"%s\""' >> /etc/Muttrc
  5836. echo 'macro index,pager A "<pipe-message>abook --add-email-quiet<return>" "add the sender address to abook"' >> /etc/Muttrc
  5837. # create an Emacs configuration specifically for use with Mutt, which
  5838. # has word wrap and spell checking on by default
  5839. echo "(add-hook 'before-save-hook 'delete-trailing-whitespace)" > /home/$MY_USERNAME/.emacs-mutt
  5840. echo '(setq org-support-shift-select t)' >> /home/$MY_USERNAME/.emacs-mutt
  5841. echo '(setq standard-indent 4)' >> /home/$MY_USERNAME/.emacs-mutt
  5842. echo '(setq-default tab-width 4)' >> /home/$MY_USERNAME/.emacs-mutt
  5843. echo '(setq c-basic-offset 4)' >> /home/$MY_USERNAME/.emacs-mutt
  5844. echo '(mouse-wheel-mode t)' >> /home/$MY_USERNAME/.emacs-mutt
  5845. echo '(setq make-backup-files t)' >> /home/$MY_USERNAME/.emacs-mutt
  5846. echo '(setq version-control t)' >> /home/$MY_USERNAME/.emacs-mutt
  5847. echo '(setq backup-directory-alist (quote ((".*" . "~/.emacs_backups/"))))' >> /home/$MY_USERNAME/.emacs-mutt
  5848. echo "(setq default-major-mode 'text-mode)" >> /home/$MY_USERNAME/.emacs-mutt
  5849. echo "(dolist (hook '(text-mode-hook))" >> /home/$MY_USERNAME/.emacs-mutt
  5850. echo ' (add-hook hook (lambda () (flyspell-mode 1))))' >> /home/$MY_USERNAME/.emacs-mutt
  5851. echo '(setq-default fill-column 72)' >> /home/$MY_USERNAME/.emacs-mutt
  5852. echo '(setq auto-fill-mode 0)' >> /home/$MY_USERNAME/.emacs-mutt
  5853. echo "(add-hook 'text-mode-hook 'turn-on-auto-fill)" >> /home/$MY_USERNAME/.emacs-mutt
  5854. echo "(setq-default auto-fill-function 'do-auto-fill)" >> /home/$MY_USERNAME/.emacs-mutt
  5855. cp -f /etc/Muttrc /home/$MY_USERNAME/.muttrc
  5856. touch /home/$MY_USERNAME/.mutt-alias
  5857. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs-mutt
  5858. cp /home/$MY_USERNAME/.emacs-mutt /etc/skel
  5859. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.muttrc
  5860. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt-alias
  5861. echo 'email_client' >> $COMPLETION_FILE
  5862. }
  5863. function email_archiving {
  5864. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5865. return
  5866. fi
  5867. if grep -Fxq "email_archiving" $COMPLETION_FILE; then
  5868. return
  5869. fi
  5870. if [ ! -d $INSTALL_DIR ]; then
  5871. mkdir $INSTALL_DIR
  5872. fi
  5873. cd $INSTALL_DIR
  5874. git clone https://github.com/bashrc/cleanup-maildir
  5875. cp $INSTALL_DIR/cleanup-maildir/cleanup-maildir /usr/bin
  5876. echo '#!/bin/bash' > /etc/cron.daily/archivemail
  5877. echo "MUTTRC=/home/$MY_USERNAME/.muttrc" >> /etc/cron.daily/archivemail
  5878. echo "python /usr/bin/cleanup-maildir --archive-folder='archive' --maildir-root='/home/$MY_USERNAME/Maildir' archive ''" >> /etc/cron.daily/archivemail
  5879. echo "chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir/archive-*" >> /etc/cron.daily/archivemail
  5880. echo 'if [ -f $MUTTRC ]; then' >> /etc/cron.daily/archivemail
  5881. echo ' MUTT_MAILBOXES=$(grep "mailboxes =" $MUTTRC)' >> /etc/cron.daily/archivemail
  5882. echo ' BACKUP_DIRECTORY=archive-$(date +"%Y")' >> /etc/cron.daily/archivemail
  5883. echo ' if [[ $MUTT_MAILBOXES != *$BACKUP_DIRECTORY* ]]; then' >> /etc/cron.daily/archivemail
  5884. echo ' sed -i "s|$MUTT_MAILBOXES|$MUTT_MAILBOXES =$BACKUP_DIRECTORY|g" $MUTTRC' >> /etc/cron.daily/archivemail
  5885. echo ' chown $MYUSERNAME:$MYUSERNAME $MUTTRC' >> /etc/cron.daily/archivemail
  5886. echo ' fi' >> /etc/cron.daily/archivemail
  5887. echo 'fi' >> /etc/cron.daily/archivemail
  5888. echo 'exit 0' >> /etc/cron.daily/archivemail
  5889. chmod +x /etc/cron.daily/archivemail
  5890. echo 'email_archiving' >> $COMPLETION_FILE
  5891. }
  5892. # Ensure that the from field is correct when sending email from Mutt
  5893. function email_from_address {
  5894. if grep -Fxq "email_from_address" $COMPLETION_FILE; then
  5895. return
  5896. fi
  5897. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  5898. return
  5899. fi
  5900. if grep -q "set from=" /home/$MY_USERNAME/.muttrc; then
  5901. sed -i "s|set from=.*|set from='$MY_NAME <$MY_EMAIL_ADDRESS>'|g" /home/$MY_USERNAME/.muttrc
  5902. else
  5903. echo "set from='$MY_NAME <$MY_EMAIL_ADDRESS>'" >> /home/$MY_USERNAME/.muttrc
  5904. fi
  5905. echo 'email_from_address' >> $COMPLETION_FILE
  5906. }
  5907. function create_public_mailing_list {
  5908. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5909. return
  5910. fi
  5911. if grep -Fxq "create_public_mailing_list" $COMPLETION_FILE; then
  5912. return
  5913. fi
  5914. if [ ! $PUBLIC_MAILING_LIST ]; then
  5915. return
  5916. fi
  5917. # does the mailing list have a separate domain name?
  5918. if [ ! $PUBLIC_MAILING_LIST_DOMAIN_NAME ]; then
  5919. PUBLIC_MAILING_LIST_DOMAIN_NAME=$DEFAULT_DOMAIN_NAME
  5920. fi
  5921. PUBLIC_MAILING_LIST_USER="mlmmj"
  5922. apt-get -y install mlmmj
  5923. adduser --system $PUBLIC_MAILING_LIST_USER
  5924. addgroup $PUBLIC_MAILING_LIST_USER
  5925. adduser $PUBLIC_MAILING_LIST_USER $PUBLIC_MAILING_LIST_USER
  5926. echo ''
  5927. echo "Creating the $PUBLIC_MAILING_LIST mailing list"
  5928. echo ''
  5929. # create the list
  5930. mlmmj-make-ml -a -L "$PUBLIC_MAILING_LIST" -c $PUBLIC_MAILING_LIST_USER
  5931. echo 'SYSTEM_ALIASES_PIPE_TRANSPORT = address_pipe' > /etc/exim4/conf.d/main/000_localmacros
  5932. echo "SYSTEM_ALIASES_USER = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  5933. echo "SYSTEM_ALIASES_GROUP = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  5934. # router
  5935. echo 'mlmmj_router:' > /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5936. echo ' debug_print = "R: mlmmj_router for $local_part@$domain"' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5937. echo ' driver = accept' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5938. echo ' domains = +mlmmj_domains' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5939. echo ' #require_files = MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5940. 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
  5941. echo ' # Exim will then spawn a new process running under the UID of "mlmmj".' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5942. echo ' require_files = mlmmj:MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5943. echo ' local_part_suffix = +*' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5944. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5945. echo ' headers_remove = Delivered-To' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5946. echo ' headers_add = Delivered-To: $local_part$local_part_suffix@$domain' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5947. echo ' transport = mlmmj_transport' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5948. # transport
  5949. echo 'mlmmj_transport:' > /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5950. echo ' debug_print = "T: mlmmj_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5951. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5952. echo ' return_path_add' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5953. echo ' user = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5954. echo ' group = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5955. echo ' home_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5956. echo ' current_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5957. echo ' command = /usr/bin/mlmmj-receive -F -L MLMMJ_HOME/${lc:$local_part}' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5958. if ! grep -q "MLMMJ_HOME=/var/spool/mlmmj" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5959. sed -i '/MAIN CONFIGURATION SETTINGS/a\MLMMJ_HOME=/var/spool/mlmmj' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5960. fi
  5961. if ! grep -q "domainlist mlmmj_domains =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5962. sed -i "/MLMMJ_HOME/a\domainlist mlmmj_domains = $PUBLIC_MAILING_LIST_DOMAIN_NAME" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5963. fi
  5964. if ! grep -q "delay_warning_condition =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5965. 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
  5966. fi
  5967. if ! grep -q ": +mlmmj_domains" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5968. 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
  5969. fi
  5970. if ! grep -q "! +mlmmj_domains" /etc/exim4/conf.d/router/200_exim4-config_primary; then
  5971. sed -i 's/domains = ! +local_domains/domains = ! +mlmmj_domains : ! +local_domains/g' /etc/exim4/conf.d/router/200_exim4-config_primary
  5972. fi
  5973. newaliases
  5974. update-exim4.conf.template -r
  5975. update-exim4.conf
  5976. service exim4 restart
  5977. if ! grep -q "$PUBLIC_MAILING_LIST mailing list" /home/$MY_USERNAME/README; then
  5978. echo '' >> /home/$MY_USERNAME/README
  5979. echo '' >> /home/$MY_USERNAME/README
  5980. echo 'Public mailing list' >> /home/$MY_USERNAME/README
  5981. echo '===================' >> /home/$MY_USERNAME/README
  5982. echo "To subscribe to the $PUBLIC_MAILING_LIST mailing list send a" >> /home/$MY_USERNAME/README
  5983. echo "cleartext email to $PUBLIC_MAILING_LIST+subscribe@$DEFAULT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  5984. fi
  5985. freedombone-addlist -u $MY_USERNAME -l "$PUBLIC_MAILING_LIST" -s "$PUBLIC_MAILING_LIST"
  5986. echo 'create_public_mailing_list' >> $COMPLETION_FILE
  5987. }
  5988. function create_private_mailing_list {
  5989. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  5990. return
  5991. fi
  5992. # This installation doesn't work, results in ruby errors
  5993. # There is currently no schleuder package for Debian jessie
  5994. if grep -Fxq "create_private_mailing_list" $COMPLETION_FILE; then
  5995. return
  5996. fi
  5997. if [ ! $PRIVATE_MAILING_LIST ]; then
  5998. return
  5999. fi
  6000. if [[ $PRIVATE_MAILING_LIST == $MY_USERNAME ]]; then
  6001. echo 'The name of the private mailing list should not be the'
  6002. echo 'same as your username'
  6003. exit 10
  6004. fi
  6005. if [ ! $MY_GPG_PUBLIC_KEY ]; then
  6006. echo 'To create a private mailing list you need to specify a file'
  6007. echo 'containing your exported GPG key within MY_GPG_PUBLIC_KEY at'
  6008. echo 'the top of the script'
  6009. exit 11
  6010. fi
  6011. apt-get -y install ruby ruby-dev ruby-gpgme libgpgme11-dev libmagic-dev
  6012. gem install schleuder
  6013. schleuder-fix-gem-dependencies
  6014. schleuder-init-setup --gem
  6015. # NOTE: this is version number sensitive and so might need changing
  6016. ln -s /var/lib/gems/2.1.0/gems/schleuder-2.2.4 /var/lib/schleuder
  6017. sed -i 's/#smtp_port: 25/smtp_port: 465/g' /etc/schleuder/schleuder.conf
  6018. sed -i 's/#superadminaddr: root@localhost/superadminaddr: root@localhost' /etc/schleuder/schleuder.conf
  6019. schleuder-newlist $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME -realname "$PRIVATE_MAILING_LIST" -adminaddress $MY_EMAIL_ADDRESS -initmember $MY_EMAIL_ADDRESS -initmemberkey $MY_GPG_PUBLIC_KEY -nointeractive
  6020. freedombone-addemail -u $MY_USERNAME -e $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME -l $PRIVATE_MAILING_LIST
  6021. echo 'schleuder:' > /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6022. echo ' debug_print = "R: schleuder for $local_part@$domain"' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6023. echo ' driver = accept' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6024. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6025. echo ' local_part_suffix = +* : -bounce : -sendkey' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6026. echo ' domains = +local_domains' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6027. echo ' user = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6028. echo ' group = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6029. echo ' require_files = schleuder:+/var/lib/schleuder/$domain/${local_part}' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6030. echo ' transport = schleuder_transport' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  6031. echo 'schleuder_transport:' > /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  6032. echo ' debug_print = "T: schleuder_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  6033. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  6034. echo ' home_directory = "/var/lib/schleuder/$domain/$local_part"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  6035. echo ' command = "/usr/bin/schleuder $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  6036. chown -R schleuder:schleuder /var/lib/schleuder
  6037. update-exim4.conf.template -r
  6038. update-exim4.conf
  6039. service exim4 restart
  6040. useradd -d /var/schleuderlists -s /bin/false schleuder
  6041. adduser Debian-exim schleuder
  6042. usermod -a -G mail schleuder
  6043. #exim -d -bt $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME
  6044. echo 'create_private_mailing_list' >> $COMPLETION_FILE
  6045. }
  6046. function import_email {
  6047. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  6048. return
  6049. fi
  6050. EMAIL_COMPLETE_MSG=' *** Freedombone mailbox installation is complete ***'
  6051. if grep -Fxq "import_email" $COMPLETION_FILE; then
  6052. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  6053. create_backup_script
  6054. create_restore_script
  6055. backup_to_friends_servers
  6056. intrusion_detection
  6057. echo ''
  6058. echo "$EMAIL_COMPLETE_MSG"
  6059. if [ -d $USB_MOUNT ]; then
  6060. umount $USB_MOUNT
  6061. rm -rf $USB_MOUNT
  6062. echo ' You can now remove the USB drive'
  6063. fi
  6064. exit 0
  6065. fi
  6066. return
  6067. fi
  6068. if [ $IMPORT_MAILDIR ]; then
  6069. if [ -d $IMPORT_MAILDIR ]; then
  6070. echo 'Transfering email files'
  6071. cp -r $IMPORT_MAILDIR /home/$MY_USERNAME
  6072. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  6073. else
  6074. echo "Email import directory $IMPORT_MAILDIR not found"
  6075. exit 9
  6076. fi
  6077. fi
  6078. echo 'import_email' >> $COMPLETION_FILE
  6079. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  6080. create_backup_script
  6081. create_restore_script
  6082. backup_to_friends_servers
  6083. intrusion_detection
  6084. # unmount any attached usb drive
  6085. echo ''
  6086. echo "$EMAIL_COMPLETE_MSG"
  6087. echo ''
  6088. if [ -d $USB_MOUNT ]; then
  6089. umount $USB_MOUNT
  6090. rm -rf $USB_MOUNT
  6091. echo ' You can now remove the USB drive'
  6092. fi
  6093. exit 0
  6094. fi
  6095. }
  6096. function install_web_server {
  6097. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  6098. return
  6099. fi
  6100. if grep -Fxq "install_web_server" $COMPLETION_FILE; then
  6101. return
  6102. fi
  6103. # remove apache
  6104. apt-get -y remove --purge apache2
  6105. if [ -d /etc/apache2 ]; then
  6106. rm -rf /etc/apache2
  6107. fi
  6108. # install nginx
  6109. apt-get -y install nginx php5-fpm git
  6110. # limit the number of php processes
  6111. sed -i 's/; process.max = 128/process.max = 32/g' /etc/php5/fpm/php-fpm.conf
  6112. sed -i 's/;process_control_timeout = 0/process_control_timeout = 300/g' /etc/php5/fpm/php-fpm.conf
  6113. if ! grep -q "pm.max_children" /etc/php5/fpm/php-fpm.conf; then
  6114. echo 'pm.max_children = 10' >> /etc/php5/fpm/php-fpm.conf
  6115. echo 'pm.start_servers = 2' >> /etc/php5/fpm/php-fpm.conf
  6116. echo 'pm.min_spare_servers = 2' >> /etc/php5/fpm/php-fpm.conf
  6117. echo 'pm.max_spare_servers = 5' >> /etc/php5/fpm/php-fpm.conf
  6118. echo 'pm.max_requests = 50' >> /etc/php5/fpm/php-fpm.conf
  6119. fi
  6120. if [ ! -d /etc/nginx ]; then
  6121. echo "ERROR: nginx does not appear to have installed. $CHECK_MESSAGE"
  6122. exit 51
  6123. fi
  6124. # Nginx settings
  6125. echo 'user www-data;' > /etc/nginx/nginx.conf
  6126. #echo "worker_processes; $CPU_CORES" >> /etc/nginx/nginx.conf
  6127. echo 'pid /run/nginx.pid;' >> /etc/nginx/nginx.conf
  6128. echo '' >> /etc/nginx/nginx.conf
  6129. echo 'events {' >> /etc/nginx/nginx.conf
  6130. echo ' worker_connections 50;' >> /etc/nginx/nginx.conf
  6131. echo ' # multi_accept on;' >> /etc/nginx/nginx.conf
  6132. echo '}' >> /etc/nginx/nginx.conf
  6133. echo '' >> /etc/nginx/nginx.conf
  6134. echo 'http {' >> /etc/nginx/nginx.conf
  6135. echo ' # limit the number of connections per single IP' >> /etc/nginx/nginx.conf
  6136. echo ' limit_conn_zone $binary_remote_addr zone=conn_limit_per_ip:10m;' >> /etc/nginx/nginx.conf
  6137. echo '' >> /etc/nginx/nginx.conf
  6138. echo ' # limit the number of requests for a given session' >> /etc/nginx/nginx.conf
  6139. echo ' # Note that the Owncloud web interface seems to require a rate of around 140r/s' >> /etc/nginx/nginx.conf
  6140. echo ' limit_req_zone $binary_remote_addr zone=req_limit_per_ip:10m rate=140r/s;' >> /etc/nginx/nginx.conf
  6141. echo '' >> /etc/nginx/nginx.conf
  6142. 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
  6143. echo ' client_body_buffer_size 128k;' >> /etc/nginx/nginx.conf
  6144. echo '' >> /etc/nginx/nginx.conf
  6145. echo ' # headerbuffer size for the request header from client, its set for testing purpose' >> /etc/nginx/nginx.conf
  6146. echo ' client_header_buffer_size 3m;' >> /etc/nginx/nginx.conf
  6147. echo '' >> /etc/nginx/nginx.conf
  6148. echo ' # maximum number and size of buffers for large headers to read from client request' >> /etc/nginx/nginx.conf
  6149. echo ' large_client_header_buffers 4 256k;' >> /etc/nginx/nginx.conf
  6150. echo '' >> /etc/nginx/nginx.conf
  6151. echo ' # read timeout for the request body from client, its set for testing purpose' >> /etc/nginx/nginx.conf
  6152. echo ' client_body_timeout 3m;' >> /etc/nginx/nginx.conf
  6153. echo '' >> /etc/nginx/nginx.conf
  6154. echo ' # how long to wait for the client to send a request header, its set for testing purpose' >> /etc/nginx/nginx.conf
  6155. echo ' client_header_timeout 3m;' >> /etc/nginx/nginx.conf
  6156. echo '' >> /etc/nginx/nginx.conf
  6157. echo ' ##' >> /etc/nginx/nginx.conf
  6158. echo ' # Basic Settings' >> /etc/nginx/nginx.conf
  6159. echo ' ##' >> /etc/nginx/nginx.conf
  6160. echo '' >> /etc/nginx/nginx.conf
  6161. echo ' sendfile on;' >> /etc/nginx/nginx.conf
  6162. echo ' tcp_nopush on;' >> /etc/nginx/nginx.conf
  6163. echo ' tcp_nodelay on;' >> /etc/nginx/nginx.conf
  6164. echo ' keepalive_timeout 65;' >> /etc/nginx/nginx.conf
  6165. echo ' types_hash_max_size 2048;' >> /etc/nginx/nginx.conf
  6166. echo ' server_tokens off;' >> /etc/nginx/nginx.conf
  6167. echo '' >> /etc/nginx/nginx.conf
  6168. echo ' # server_names_hash_bucket_size 64;' >> /etc/nginx/nginx.conf
  6169. echo ' # server_name_in_redirect off;' >> /etc/nginx/nginx.conf
  6170. echo '' >> /etc/nginx/nginx.conf
  6171. echo ' include /etc/nginx/mime.types;' >> /etc/nginx/nginx.conf
  6172. echo ' default_type application/octet-stream;' >> /etc/nginx/nginx.conf
  6173. echo '' >> /etc/nginx/nginx.conf
  6174. echo ' ##' >> /etc/nginx/nginx.conf
  6175. echo ' # Logging Settings' >> /etc/nginx/nginx.conf
  6176. echo ' ##' >> /etc/nginx/nginx.conf
  6177. echo '' >> /etc/nginx/nginx.conf
  6178. echo ' access_log /var/log/nginx/access.log;' >> /etc/nginx/nginx.conf
  6179. echo ' error_log /var/log/nginx/error.log;' >> /etc/nginx/nginx.conf
  6180. echo '' >> /etc/nginx/nginx.conf
  6181. echo ' ###' >> /etc/nginx/nginx.conf
  6182. echo ' # Gzip Settings' >> /etc/nginx/nginx.conf
  6183. echo ' ##' >> /etc/nginx/nginx.conf
  6184. echo ' gzip on;' >> /etc/nginx/nginx.conf
  6185. echo ' gzip_disable "msie6";' >> /etc/nginx/nginx.conf
  6186. echo '' >> /etc/nginx/nginx.conf
  6187. echo ' # gzip_vary on;' >> /etc/nginx/nginx.conf
  6188. echo ' # gzip_proxied any;' >> /etc/nginx/nginx.conf
  6189. echo ' # gzip_comp_level 6;' >> /etc/nginx/nginx.conf
  6190. echo ' # gzip_buffers 16 8k;' >> /etc/nginx/nginx.conf
  6191. echo ' # gzip_http_version 1.1;' >> /etc/nginx/nginx.conf
  6192. echo ' # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;' >> /etc/nginx/nginx.conf
  6193. echo '' >> /etc/nginx/nginx.conf
  6194. echo ' ##' >> /etc/nginx/nginx.conf
  6195. echo ' # Virtual Host Configs' >> /etc/nginx/nginx.conf
  6196. echo ' ##' >> /etc/nginx/nginx.conf
  6197. echo '' >> /etc/nginx/nginx.conf
  6198. echo ' include /etc/nginx/conf.d/*.conf;' >> /etc/nginx/nginx.conf
  6199. echo ' include /etc/nginx/sites-enabled/*;' >> /etc/nginx/nginx.conf
  6200. echo '}' >> /etc/nginx/nginx.conf
  6201. # install a script to easily enable and disable nginx virtual hosts
  6202. if [ ! -d $INSTALL_DIR ]; then
  6203. mkdir $INSTALL_DIR
  6204. fi
  6205. cd $INSTALL_DIR
  6206. git clone https://github.com/perusio/nginx_ensite
  6207. cd $INSTALL_DIR/nginx_ensite
  6208. cp nginx_* /usr/sbin
  6209. nginx_dissite default
  6210. echo 'install_web_server' >> $COMPLETION_FILE
  6211. }
  6212. function configure_php {
  6213. sed -i "s/memory_limit = 128M/memory_limit = ${MAX_PHP_MEMORY}M/g" /etc/php5/fpm/php.ini
  6214. sed -i 's/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/g' /etc/php5/fpm/php.ini
  6215. sed -i "s/memory_limit = -1/memory_limit = ${MAX_PHP_MEMORY}M/g" /etc/php5/cli/php.ini
  6216. sed -i "s/upload_max_filesize = 2M/upload_max_filesize = 50M/g" /etc/php5/fpm/php.ini
  6217. sed -i "s/post_max_size = 8M/post_max_size = 50M/g" /etc/php5/fpm/php.ini
  6218. }
  6219. function install_mariadb {
  6220. if grep -Fxq "install_mariadb" $COMPLETION_FILE; then
  6221. return
  6222. fi
  6223. apt-get -y install python-software-properties debconf-utils
  6224. apt-get -y install software-properties-common
  6225. apt-get -y update
  6226. get_mariadb_password
  6227. if [ ! $MARIADB_PASSWORD ]; then
  6228. MARIADB_PASSWORD=$(openssl rand -base64 32)
  6229. echo "$MARIADB_PASSWORD" > $DATABASE_PASSWORD_FILE
  6230. chmod 600 $DATABASE_PASSWORD_FILE
  6231. echo '' >> /home/$MY_USERNAME/README
  6232. echo '' >> /home/$MY_USERNAME/README
  6233. echo 'MariaDB / MySql' >> /home/$MY_USERNAME/README
  6234. echo '===============' >> /home/$MY_USERNAME/README
  6235. echo "Your MariaDB password is: $MARIADB_PASSWORD" >> /home/$MY_USERNAME/README
  6236. echo '' >> /home/$MY_USERNAME/README
  6237. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6238. fi
  6239. debconf-set-selections <<< "mariadb-server mariadb-server/root_password password $MARIADB_PASSWORD"
  6240. debconf-set-selections <<< "mariadb-server mariadb-server/root_password_again password $MARIADB_PASSWORD"
  6241. apt-get -y install mariadb-server
  6242. apt-get -y remove --purge apache*
  6243. if [ -d /etc/apache2 ]; then
  6244. rm -rf /etc/apache2
  6245. echo 'Removed Apache installation after MariaDB install'
  6246. fi
  6247. if [ ! -d /etc/mysql ]; then
  6248. echo "ERROR: mariadb-server does not appear to have installed. $CHECK_MESSAGE"
  6249. exit 54
  6250. fi
  6251. mysqladmin -u root password "$MARIADB_PASSWORD"
  6252. echo 'install_mariadb' >> $COMPLETION_FILE
  6253. }
  6254. function backup_databases_script_header {
  6255. if [ ! -f /usr/bin/backupdatabases ]; then
  6256. # daily
  6257. echo '#!/bin/sh' > /usr/bin/backupdatabases
  6258. echo '' >> /usr/bin/backupdatabases
  6259. echo "EMAIL='$MY_EMAIL_ADDRESS'" >> /usr/bin/backupdatabases
  6260. echo '' >> /usr/bin/backupdatabases
  6261. echo -n 'MYSQL_PASSWORD=$(cat ' >> /usr/bin/backupdatabases
  6262. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/backupdatabases
  6263. echo 'umask 0077' >> /usr/bin/backupdatabases
  6264. echo '' >> /usr/bin/backupdatabases
  6265. echo '# exit if we are backing up to friends servers' >> /usr/bin/backupdatabases
  6266. echo "if [ -f $FRIENDS_SERVERS_LIST ]; then" >> /usr/bin/backupdatabases
  6267. echo ' exit 1' >> /usr/bin/backupdatabases
  6268. echo 'fi' >> /usr/bin/backupdatabases
  6269. chmod 600 /usr/bin/backupdatabases
  6270. chmod +x /usr/bin/backupdatabases
  6271. echo '#!/bin/sh' > /etc/cron.daily/backupdatabasesdaily
  6272. echo '/usr/bin/backupdatabases' >> /etc/cron.daily/backupdatabasesdaily
  6273. chmod 600 /etc/cron.daily/backupdatabasesdaily
  6274. chmod +x /etc/cron.daily/backupdatabasesdaily
  6275. # weekly
  6276. echo '#!/bin/sh' > /etc/cron.weekly/backupdatabasesweekly
  6277. echo '' >> /etc/cron.weekly/backupdatabasesweekly
  6278. echo 'umask 0077' >> /etc/cron.weekly/backupdatabasesweekly
  6279. chmod 600 /etc/cron.weekly/backupdatabasesweekly
  6280. chmod +x /etc/cron.weekly/backupdatabasesweekly
  6281. # monthly
  6282. echo '#!/bin/sh' > /etc/cron.monthly/backupdatabasesmonthly
  6283. echo '' >> /etc/cron.monthly/backupdatabasesmonthly
  6284. echo 'umask 0077' >> /etc/cron.monthly/backupdatabasesmonthly
  6285. chmod 600 /etc/cron.monthly/backupdatabasesmonthly
  6286. chmod +x /etc/cron.monthly/backupdatabasesmonthly
  6287. fi
  6288. }
  6289. function repair_databases_script {
  6290. if grep -Fxq "repair_databases_script" $COMPLETION_FILE; then
  6291. return
  6292. fi
  6293. if [ ! -f $DATABASE_PASSWORD_FILE ]; then
  6294. return
  6295. fi
  6296. echo '#!/bin/bash' > /usr/bin/repairdatabase
  6297. echo '' >> /usr/bin/repairdatabase
  6298. echo 'DATABASE=$1' >> /usr/bin/repairdatabase
  6299. echo "EMAIL=$MY_EMAIL_ADDRESS" >> /usr/bin/repairdatabase
  6300. echo '' >> /usr/bin/repairdatabase
  6301. echo -n 'MYSQL_ROOT_PASSWORD=$(cat ' >> /usr/bin/repairdatabase
  6302. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/repairdatabase
  6303. echo 'TEMPFILE=/root/repairdatabase_$DATABASE' >> /usr/bin/repairdatabase
  6304. echo '' >> /usr/bin/repairdatabase
  6305. echo 'umask 0077' >> /usr/bin/repairdatabase
  6306. echo '' >> /usr/bin/repairdatabase
  6307. echo '# check the database' >> /usr/bin/repairdatabase
  6308. echo 'mysqlcheck -c -u root --password=$MYSQL_ROOT_PASSWORD $DATABASE > $TEMPFILE' >> /usr/bin/repairdatabase
  6309. echo '' >> /usr/bin/repairdatabase
  6310. echo '# Attempt to repair the database if it contains errors' >> /usr/bin/repairdatabase
  6311. echo 'if grep -q "Error" "$TEMPFILE"; then' >> /usr/bin/repairdatabase
  6312. echo ' mysqlcheck -u root --password=$MYSQL_ROOT_PASSWORD --auto-repair $DATABASE' >> /usr/bin/repairdatabase
  6313. echo 'else' >> /usr/bin/repairdatabase
  6314. echo ' # No errors were found, so exit' >> /usr/bin/repairdatabase
  6315. echo ' rm -f $TEMPFILE' >> /usr/bin/repairdatabase
  6316. echo ' exit 0' >> /usr/bin/repairdatabase
  6317. echo 'fi' >> /usr/bin/repairdatabase
  6318. echo 'rm -f $TEMPFILE' >> /usr/bin/repairdatabase
  6319. echo '' >> /usr/bin/repairdatabase
  6320. echo '# Check the database again' >> /usr/bin/repairdatabase
  6321. echo 'mysqlcheck -c -u root --password=$MYSQL_ROOT_PASSWORD $DATABASE > $TEMPFILE' >> /usr/bin/repairdatabase
  6322. echo '' >> /usr/bin/repairdatabase
  6323. echo '# If it still contains errors then restore from backup' >> /usr/bin/repairdatabase
  6324. echo 'if grep -q "Error" "$TEMPFILE"; then' >> /usr/bin/repairdatabase
  6325. echo ' mysql -u root --password=$MYSQL_ROOT_PASSWORD $DATABASE -o < /var/backups/${DATABASE}_daily.sql' >> /usr/bin/repairdatabase
  6326. echo '' >> /usr/bin/repairdatabase
  6327. echo ' # Send a warning email' >> /usr/bin/repairdatabase
  6328. echo ' echo "$DATABASE database corruption could not be repaired. Restored from backup." | mail -s "Freedombone database maintenance" $EMAIL' >> /usr/bin/repairdatabase
  6329. echo ' rm -f $TEMPFILE' >> /usr/bin/repairdatabase
  6330. echo '' >> /usr/bin/repairdatabase
  6331. echo ' exit 1' >> /usr/bin/repairdatabase
  6332. echo 'fi' >> /usr/bin/repairdatabase
  6333. echo 'rm -f $TEMPFILE' >> /usr/bin/repairdatabase
  6334. echo '' >> /usr/bin/repairdatabase
  6335. echo 'exit 0' >> /usr/bin/repairdatabase
  6336. chmod 600 /usr/bin/repairdatabase
  6337. chmod +x /usr/bin/repairdatabase
  6338. echo '#!/bin/bash' > /etc/cron.hourly/repair
  6339. echo '' >> /etc/cron.hourly/repair
  6340. chmod 600 /etc/cron.hourly/repair
  6341. chmod +x /etc/cron.hourly/repair
  6342. echo 'repair_databases_script' >> $COMPLETION_FILE
  6343. }
  6344. function install_owncloud_music_app {
  6345. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  6346. return
  6347. fi
  6348. if grep -Fxq "install_owncloud_music_app" $COMPLETION_FILE; then
  6349. return
  6350. fi
  6351. if ! grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  6352. echo 'Tried to install the Owncloud music app, but Owncloud installation was not found'
  6353. exit 9823
  6354. fi
  6355. cd /usr/share/owncloud/apps
  6356. git clone https://github.com/owncloud/music music
  6357. if grep -q "Music player in Owncloud" /home/$MY_USERNAME/README; then
  6358. echo '' >> /home/$MY_USERNAME/README
  6359. echo '' >> /home/$MY_USERNAME/README
  6360. echo 'Music player in Owncloud' >> /home/$MY_USERNAME/README
  6361. echo '========================' >> /home/$MY_USERNAME/README
  6362. echo 'To enable the music app within ouwncloud log in to the Owncloud' >> /home/$MY_USERNAME/README
  6363. echo 'administrator account then go to Apps on the left hand dropdown' >> /home/$MY_USERNAME/README
  6364. echo 'menu and enable the music app. You can then log out and log back' >> /home/$MY_USERNAME/README
  6365. echo 'in as your Owncloud user and select music from the left hand' >> /home/$MY_USERNAME/README
  6366. echo 'dropdown menu.' >> /home/$MY_USERNAME/README
  6367. fi
  6368. echo 'install_owncloud_music_app' >> $COMPLETION_FILE
  6369. }
  6370. function add_ddns_domain {
  6371. if [ ! $CURRENT_DDNS_DOMAIN ]; then
  6372. echo 'ddns domain not specified'
  6373. exit 5638
  6374. fi
  6375. if [ ! -f /etc/inadyn.conf ]; then
  6376. echo 'Unable to find inadyn configuration file /etc/inadyn.conf'
  6377. exit 5745
  6378. fi
  6379. if ! grep -q "$DDNS_PROVIDER" /etc/inadyn.conf; then
  6380. echo '' >> /etc/inadyn.conf
  6381. echo "system $DDNS_PROVIDER" >> /etc/inadyn.conf
  6382. echo ' ssl' >> /etc/inadyn.conf
  6383. echo " checkip-url $GET_IP_ADDRESS_URL /" >> /etc/inadyn.conf
  6384. if [ $DDNS_USERNAME ]; then
  6385. echo " username $DDNS_USERNAME" >> /etc/inadyn.conf
  6386. fi
  6387. if [ $DDNS_PASSWORD ]; then
  6388. echo " password $DDNS_PASSWORD" >> /etc/inadyn.conf
  6389. fi
  6390. fi
  6391. if ! grep -q "$CURRENT_DDNS_DOMAIN" /etc/inadyn.conf; then
  6392. echo " alias $CURRENT_DDNS_DOMAIN" >> /etc/inadyn.conf
  6393. fi
  6394. chmod 600 /etc/inadyn.conf
  6395. service inadyn restart
  6396. systemctl daemon-reload
  6397. # clear the arguments
  6398. CURRENT_DDNS_DOMAIN=
  6399. }
  6400. function install_owncloud {
  6401. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  6402. return
  6403. fi
  6404. OWNCLOUD_COMPLETION_MSG1=" *** Freedombone $SYSTEM_TYPE is now installed ***"
  6405. OWNCLOUD_COMPLETION_MSG2="Open $OWNCLOUD_DOMAIN_NAME in a web browser to complete the setup"
  6406. if grep -Fxq "install_owncloud" $COMPLETION_FILE; then
  6407. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  6408. install_owncloud_music_app
  6409. create_backup_script
  6410. create_restore_script
  6411. backup_to_friends_servers
  6412. intrusion_detection
  6413. # unmount any attached usb drive
  6414. if [ -d $USB_MOUNT ]; then
  6415. umount $USB_MOUNT
  6416. rm -rf $USB_MOUNT
  6417. fi
  6418. echo ''
  6419. echo "$OWNCLOUD_COMPLETION_MSG1"
  6420. echo "$OWNCLOUD_COMPLETION_MSG2"
  6421. exit 0
  6422. fi
  6423. return
  6424. fi
  6425. # if this is exclusively a cloud setup
  6426. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  6427. if [ ! $DEFAULT_DOMAIN_NAME ]; then
  6428. echo 'No default domain name when installing cloud variant'
  6429. exit 5380
  6430. fi
  6431. fi
  6432. if [ ! $OWNCLOUD_DOMAIN_NAME ]; then
  6433. echo 'No Owncloud domain name was specified'
  6434. exit 3095
  6435. fi
  6436. if [[ $SYSTEM_TYPE != "$VARIANT_CLOUD" ]]; then
  6437. if [[ $SYSTEM_TYPE != "$VARIANT_FULL" ]]; then
  6438. echo "Owncloud install did not recognise the system type $SYSTEM_TYPE"
  6439. exit 6746
  6440. fi
  6441. fi
  6442. apt-get -y install owncloud
  6443. apt-get -y remove --purge apache*
  6444. if [ -d /etc/apache2 ]; then
  6445. rm -rf /etc/apache2
  6446. echo 'Removed Apache installation after Owncloud install'
  6447. fi
  6448. install_mariadb
  6449. get_mariadb_password
  6450. get_mariadb_owncloud_admin_password
  6451. if [ ! $OWNCLOUD_ADMIN_PASSWORD ]; then
  6452. OWNCLOUD_ADMIN_PASSWORD=$(openssl rand -base64 32)
  6453. fi
  6454. if ! grep -q "Owncloud database user" /home/$MY_USERNAME/README; then
  6455. echo '' >> /home/$MY_USERNAME/README
  6456. echo '' >> /home/$MY_USERNAME/README
  6457. echo 'Owncloud' >> /home/$MY_USERNAME/README
  6458. echo '========' >> /home/$MY_USERNAME/README
  6459. echo 'Owncloud database user: owncloudadmin' >> /home/$MY_USERNAME/README
  6460. echo "Owncloud database password: $OWNCLOUD_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  6461. echo 'Owncloud database name: owncloud' >> /home/$MY_USERNAME/README
  6462. echo '' >> /home/$MY_USERNAME/README
  6463. echo 'After creating an administrator account then create a user account via' >> /home/$MY_USERNAME/README
  6464. echo "the Users dropdown menu entry. The username should be '$MY_USERNAME'." >> /home/$MY_USERNAME/README
  6465. echo '' >> /home/$MY_USERNAME/README
  6466. echo 'On mobile devices you can download the Owncloud client via F-Droid.' >> /home/$MY_USERNAME/README
  6467. echo '' >> /home/$MY_USERNAME/README
  6468. echo 'To synchronise calendar entries with Android "install CalDAV Sync Adapter"' >> /home/$MY_USERNAME/README
  6469. echo 'using F-Droid then go to settings/accounts and add a CalDav account with' >> /home/$MY_USERNAME/README
  6470. echo "the URL https://$OWNCLOUD_DOMAIN_NAME/remote.php/caldav/principals/$MY_USERNAME" >> /home/$MY_USERNAME/README
  6471. echo 'and the username and password shown above.' >> /home/$MY_USERNAME/README
  6472. fi
  6473. echo "create database owncloud;
  6474. CREATE USER 'owncloudadmin'@'localhost' IDENTIFIED BY '$OWNCLOUD_ADMIN_PASSWORD';
  6475. GRANT ALL PRIVILEGES ON owncloud.* TO 'owncloudadmin'@'localhost';
  6476. quit" > $INSTALL_DIR/batch.sql
  6477. chmod 600 $INSTALL_DIR/batch.sql
  6478. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  6479. shred -zu $INSTALL_DIR/batch.sql
  6480. if [ ! -d /var/www/$OWNCLOUD_DOMAIN_NAME ]; then
  6481. mkdir /var/www/$OWNCLOUD_DOMAIN_NAME
  6482. fi
  6483. if [ -d /var/www/$OWNCLOUD_DOMAIN_NAME/htdocs ]; then
  6484. rm -rf /var/www/$OWNCLOUD_DOMAIN_NAME/htdocs
  6485. fi
  6486. ln -s /usr/share/owncloud /var/www/$OWNCLOUD_DOMAIN_NAME/htdocs
  6487. echo 'server {' > /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6488. echo ' listen 80;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6489. echo " server_name $OWNCLOUD_DOMAIN_NAME;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6490. echo ' access_log off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6491. echo " error_log /var/log/nginx/$OWNCLOUD_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6492. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6493. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6494. echo ' rewrite ^ https://$server_name$request_uri? permanent;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6495. echo '}' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6496. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6497. echo 'server {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6498. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6499. echo " root /var/www/$OWNCLOUD_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6500. echo " server_name $OWNCLOUD_DOMAIN_NAME;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6501. echo ' access_log off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6502. echo " error_log /var/log/nginx/$OWNCLOUD_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6503. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6504. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6505. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6506. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6507. echo ' ssl on;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6508. echo " ssl_certificate /etc/ssl/certs/$OWNCLOUD_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6509. echo " ssl_certificate_key /etc/ssl/private/$OWNCLOUD_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6510. echo " ssl_dhparam /etc/ssl/certs/$OWNCLOUD_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6511. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6512. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6513. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6514. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6515. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6516. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6517. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6518. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6519. echo ' # if you want to be able to access the site via HTTP' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6520. echo ' # then replace the above with the following:' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6521. echo ' # add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6522. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6523. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6524. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6525. echo ' allow all;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6526. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6527. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6528. echo ' client_max_body_size 10G; # set max upload size' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6529. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6530. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6531. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6532. echo ' rewrite ^/caldav(.*)$ /remote.php/caldav$1 redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6533. echo ' rewrite ^/carddav(.*)$ /remote.php/carddav$1 redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6534. echo ' rewrite ^/webdav(.*)$ /remote.php/webdav$1 redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6535. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6536. echo ' index index.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6537. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6538. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6539. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6540. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6541. echo ' allow all;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6542. echo ' log_not_found off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6543. echo ' access_log off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6544. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6545. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6546. echo ' location ~ ^/(data|config|\.ht|db_structure\.xml|README) {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6547. echo ' deny all;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6548. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6549. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6550. echo ' location / {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6551. echo ' # The following 2 rules are only needed with webfinger' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6552. echo ' rewrite ^/.well-known/host-meta /public.php?service=host-meta last;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6553. echo ' rewrite ^/.well-known/host-meta.json /public.php?service=host-meta-json last;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6554. echo ' rewrite ^/.well-known/carddav /remote.php/carddav/ redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6555. echo ' rewrite ^/.well-known/caldav /remote.php/caldav/ redirect;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6556. echo ' rewrite ^(/core/doc/[^\/]+/)$ $1/index.html;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6557. echo ' try_files $uri $uri/ index.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6558. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6559. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6560. echo ' location ~ ^(.+?\.php)(/.*)?$ {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6561. echo ' try_files $1 =404;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6562. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6563. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6564. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6565. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6566. echo ' fastcgi_param SCRIPT_FILENAME $document_root$1;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6567. echo ' fastcgi_param PATH_INFO $2;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6568. echo ' fastcgi_param HTTPS on;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6569. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6570. echo '' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6571. echo ' # Optional: set long EXPIRES header on static assets' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6572. echo ' location ~* ^.+\.(jpg|jpeg|gif|bmp|ico|png|css|js|swf)$ {' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6573. echo ' expires 30d;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6574. echo " # Optional: Don't log access to assets" >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6575. echo ' access_log off;' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6576. echo ' }' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6577. echo '}' >> /etc/nginx/sites-available/$OWNCLOUD_DOMAIN_NAME
  6578. configure_php
  6579. if [ ! -f /etc/ssl/certs/$OWNCLOUD_DOMAIN_NAME.dhparam ]; then
  6580. freedombone-addcert -h $OWNCLOUD_DOMAIN_NAME
  6581. check_certificates $OWNCLOUD_DOMAIN_NAME
  6582. fi
  6583. # Ensure that the database gets backed up locally, if remote
  6584. # backups are not being used
  6585. backup_databases_script_header
  6586. echo '' >> /usr/bin/backupdatabases
  6587. echo '# Backup Owncloud database' >> /usr/bin/backupdatabases
  6588. echo 'TEMPFILE=/root/owncloud.sql' >> /usr/bin/backupdatabases
  6589. echo 'DAILYFILE=/var/backups/owncloud_daily.sql' >> /usr/bin/backupdatabases
  6590. echo 'mysqldump --password="$MYSQL_PASSWORD" owncloud > $TEMPFILE' >> /usr/bin/backupdatabases
  6591. echo 'FILESIZE=$(stat -c%s $TEMPFILE)' >> /usr/bin/backupdatabases
  6592. echo 'if [ "$FILESIZE" -eq "0" ]; then' >> /usr/bin/backupdatabases
  6593. echo ' if [ -f $DAILYFILE ]; then' >> /usr/bin/backupdatabases
  6594. echo ' cp $DAILYFILE $TEMPFILE' >> /usr/bin/backupdatabases
  6595. echo '' >> /usr/bin/backupdatabases
  6596. echo ' # try to restore yesterdays database' >> /usr/bin/backupdatabases
  6597. echo ' mysql -u root --password="$MYSQL_PASSWORD" owncloud -o < $DAILYFILE' >> /usr/bin/backupdatabases
  6598. echo '' >> /usr/bin/backupdatabases
  6599. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  6600. 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
  6601. echo ' else' >> /usr/bin/backupdatabases
  6602. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  6603. echo ' echo "Unable to create a backup of the Owncloud database." | mail -s "Owncloud backup" $EMAIL' >> /usr/bin/backupdatabases
  6604. echo ' fi' >> /usr/bin/backupdatabases
  6605. echo 'else' >> /usr/bin/backupdatabases
  6606. echo ' chmod 600 $TEMPFILE' >> /usr/bin/backupdatabases
  6607. echo ' mv $TEMPFILE $DAILYFILE' >> /usr/bin/backupdatabases
  6608. echo '' >> /usr/bin/backupdatabases
  6609. echo ' # Make the backup readable only by root' >> /usr/bin/backupdatabases
  6610. echo ' chmod 600 $DAILYFILE' >> /usr/bin/backupdatabases
  6611. echo 'fi' >> /usr/bin/backupdatabases
  6612. nginx_ensite $OWNCLOUD_DOMAIN_NAME
  6613. service php5-fpm restart
  6614. service nginx restart
  6615. # update the dynamic DNS
  6616. CURRENT_DDNS_DOMAIN=$OWNCLOUD_DOMAIN_NAME
  6617. add_ddns_domain
  6618. echo 'install_owncloud' >> $COMPLETION_FILE
  6619. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  6620. install_owncloud_music_app
  6621. create_backup_script
  6622. create_restore_script
  6623. backup_to_friends_servers
  6624. intrusion_detection
  6625. # unmount any attached usb drive
  6626. if [ -d $USB_MOUNT ]; then
  6627. umount $USB_MOUNT
  6628. rm -rf $USB_MOUNT
  6629. fi
  6630. echo ''
  6631. echo "$OWNCLOUD_COMPLETION_MSG1"
  6632. echo "$OWNCLOUD_COMPLETION_MSG2"
  6633. exit 0
  6634. fi
  6635. }
  6636. function install_gogs {
  6637. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  6638. return
  6639. fi
  6640. if grep -Fxq "install_gogs" $COMPLETION_FILE; then
  6641. return
  6642. fi
  6643. if [ ! $GIT_DOMAIN_NAME ]; then
  6644. return
  6645. fi
  6646. # http://gogs.io/docs/installation/install_from_source.md
  6647. # add a gogs user account
  6648. adduser --disabled-login --gecos 'Gogs' git
  6649. # install Go
  6650. apt-get -y install golang
  6651. if ! grep -q "export GOPATH=/home/git/go" ~/.bashrc; then
  6652. echo 'export GOPATH=/home/git/go' >> ~/.bashrc
  6653. echo 'systemctl set-environment GOPATH=/home/git/go' >> ~/.bashrc
  6654. fi
  6655. . ~/.bashrc
  6656. export GOPATH=/home/git/go
  6657. if [ ! -d $GOPATH ]; then
  6658. mkdir -p $GOPATH
  6659. fi
  6660. go get -u github.com/gpmgo/gopm
  6661. if [ ! "$?" = "0" ]; then
  6662. exit 479832
  6663. fi
  6664. # clone the repo
  6665. if [ ! -d $GOPATH/src/github.com/gogits ]; then
  6666. mkdir -p $GOPATH/src/github.com/gogits
  6667. fi
  6668. cd $GOPATH/src/github.com/gogits
  6669. git clone $GIT_DOMAIN_REPO
  6670. cd gogs
  6671. # install
  6672. go get ./...
  6673. go build
  6674. if [ ! "$?" = "0" ]; then
  6675. exit 546750
  6676. fi
  6677. install_mariadb
  6678. get_mariadb_password
  6679. get_mariadb_git_admin_password
  6680. if [ ! $GIT_ADMIN_PASSWORD ]; then
  6681. GIT_ADMIN_PASSWORD=$(openssl rand -base64 32)
  6682. fi
  6683. if ! grep -q "Gogs admin user password" /home/$MY_USERNAME/README; then
  6684. echo '' >> /home/$MY_USERNAME/README
  6685. echo '' >> /home/$MY_USERNAME/README
  6686. echo 'Gogs' >> /home/$MY_USERNAME/README
  6687. echo '====' >> /home/$MY_USERNAME/README
  6688. echo 'Database type: MySql' >> /home/$MY_USERNAME/README
  6689. echo 'Database host: 127.0.0.1:3306' >> /home/$MY_USERNAME/README
  6690. echo 'Database user: root' >> /home/$MY_USERNAME/README
  6691. echo "Database password: $MARIADB_PASSWORD" >> /home/$MY_USERNAME/README
  6692. echo 'Database name: gogs' >> /home/$MY_USERNAME/README
  6693. echo 'Gogs admin user: gogsadmin' >> /home/$MY_USERNAME/README
  6694. echo "Gogs admin user password: $GIT_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  6695. echo "Gogs admin user email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/README
  6696. echo '' >> /home/$MY_USERNAME/README
  6697. echo 'Install Steps For First-time Run:' >> /home/$MY_USERNAME/README
  6698. echo 'Leave email service settings empty' >> /home/$MY_USERNAME/README
  6699. echo 'Check "Enable Register Confirmation"' >> /home/$MY_USERNAME/README
  6700. echo 'Check "Enable Mail Notification"' >> /home/$MY_USERNAME/README
  6701. echo '' >> /home/$MY_USERNAME/README
  6702. echo 'After the initial install edit /home/git/go/src/github.com/gogits/gogs/custom/conf/app.ini' >> /home/$MY_USERNAME/README
  6703. echo 'and within the [server] section set:' >> /home/$MY_USERNAME/README
  6704. echo " DOMAIN = $GIT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  6705. echo " ROOT_URL = http://$GIT_DOMAIN_NAME/" >> /home/$MY_USERNAME/README
  6706. echo " SSH_PORT = $SSH_PORT" >> /home/$MY_USERNAME/README
  6707. echo 'If you want to disable new account registrations then append the following:' >> /home/$MY_USERNAME/README
  6708. echo ' [service]' >> /home/$MY_USERNAME/README
  6709. echo ' DISABLE_REGISTRATION = true' >> /home/$MY_USERNAME/README
  6710. echo 'Then restart with:' >> /home/$MY_USERNAME/README
  6711. echo ' systemctl restart gogs' >> /home/$MY_USERNAME/README
  6712. echo '' >> /home/$MY_USERNAME/README
  6713. echo "Note that there's a usability/security trade-off made here." >> /home/$MY_USERNAME/README
  6714. echo "In order to allow git clone via http we don't redirect everything" >> /home/$MY_USERNAME/README
  6715. echo 'over https. Instead only critical things such as user login,' >> /home/$MY_USERNAME/README
  6716. echo 'settings and admin are encrypted.' >> /home/$MY_USERNAME/README
  6717. echo 'There are also potential security issues with cloning/pulling/pushing' >> /home/$MY_USERNAME/README
  6718. echo 'code over http, since a determined adversary could inject malware' >> /home/$MY_USERNAME/README
  6719. echo 'into the stream as it passes, so beware.' >> /home/$MY_USERNAME/README
  6720. echo 'If you have a bought domain and a non-self signed cert then you' >> /home/$MY_USERNAME/README
  6721. echo "should change /etc/nginx/sites-available/$GIT_DOMAIN_NAME to redirect everything over https." >> /home/$MY_USERNAME/README
  6722. fi
  6723. echo "create database gogs;
  6724. CREATE USER 'gogsadmin'@'localhost' IDENTIFIED BY '$GOGS_ADMIN_PASSWORD';
  6725. GRANT ALL PRIVILEGES ON gogs.* TO 'gogsadmin'@'localhost';
  6726. quit" > $INSTALL_DIR/batch.sql
  6727. chmod 600 $INSTALL_DIR/batch.sql
  6728. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  6729. shred -zu $INSTALL_DIR/batch.sql
  6730. chmod 600 /home/git/go/src/github.com/gogits/gogs/custom/conf/app.ini
  6731. chown -R git:git /home/git
  6732. cp $GOPATH/src/github.com/gogits/gogs/scripts/systemd/gogs.service /etc/systemd/system
  6733. sed -i 's|#After=mysqld.service|After=mysqld.service|g' /etc/systemd/system/gogs.service
  6734. sed -i "s|WorkingDirectory=.*|WorkingDirectory=$GOPATH/src/github.com/gogits/gogs|g" /etc/systemd/system/gogs.service
  6735. sed -i "s|ExecStart=.*|ExecStart=$GOPATH/src/github.com/gogits/gogs/gogs web|g" /etc/systemd/system/gogs.service
  6736. sed -i "s|Environment.*|Environment=\"USER=git\" \"HOME=/home/git\" \"GOPATH=/home/git/go\"|g" /etc/systemd/system/gogs.service
  6737. systemctl enable gogs
  6738. systemctl daemon-reload
  6739. systemctl restart gogs
  6740. if [ ! -d /var/www/$GIT_DOMAIN_NAME ]; then
  6741. mkdir /var/www/$GIT_DOMAIN_NAME
  6742. fi
  6743. if [ -d /var/www/$GIT_DOMAIN_NAME/htdocs ]; then
  6744. rm -rf /var/www/$GIT_DOMAIN_NAME/htdocs
  6745. fi
  6746. echo 'server {' > /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6747. echo ' listen 80;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6748. echo " server_name $GIT_DOMAIN_NAME;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6749. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6750. echo " error_log /var/log/nginx/$GIT_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6751. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6752. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6753. echo ' location / {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6754. echo ' proxy_pass http://localhost:3000;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6755. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6756. echo ' location ^~ /user/ {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6757. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6758. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6759. echo ' location ^~ /admin/ {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6760. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6761. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6762. echo '}' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6763. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6764. echo 'server {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6765. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6766. echo " root /var/www/$GIT_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6767. echo " server_name $GIT_DOMAIN_NAME;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6768. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6769. echo " error_log /var/log/nginx/$GIT_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6770. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6771. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6772. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6773. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6774. echo ' ssl on;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6775. echo " ssl_certificate /etc/ssl/certs/$GIT_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6776. echo " ssl_certificate_key /etc/ssl/private/$GIT_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6777. echo " ssl_dhparam /etc/ssl/certs/$GIT_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6778. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6779. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6780. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6781. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6782. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6783. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6784. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6785. echo ' add_header Strict-Transport-Security max-age=0;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6786. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6787. echo ' location / {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6788. echo ' proxy_pass http://localhost:3000;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6789. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6790. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6791. echo ' client_max_body_size 10G; # set max upload size' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6792. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6793. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6794. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6795. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6796. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6797. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6798. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6799. echo ' allow all;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6800. echo ' log_not_found off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6801. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6802. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6803. echo '}' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6804. configure_php
  6805. if [ ! -f /etc/ssl/certs/$GIT_DOMAIN_NAME.dhparam ]; then
  6806. freedombone-addcert -h $GIT_DOMAIN_NAME
  6807. check_certificates $GIT_DOMAIN_NAME
  6808. fi
  6809. nginx_ensite $GIT_DOMAIN_NAME
  6810. service php5-fpm restart
  6811. service nginx restart
  6812. # update the dynamic DNS
  6813. CURRENT_DDNS_DOMAIN=$GIT_DOMAIN_NAME
  6814. add_ddns_domain
  6815. echo 'install_gogs' >> $COMPLETION_FILE
  6816. }
  6817. function install_xmpp {
  6818. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  6819. return
  6820. fi
  6821. if grep -Fxq "install_xmpp" $COMPLETION_FILE; then
  6822. return
  6823. fi
  6824. apt-get -y install lua-sec
  6825. apt-get -y install prosody
  6826. if [ ! -d /etc/prosody ]; then
  6827. echo "ERROR: prosody does not appear to have installed. $CHECK_MESSAGE"
  6828. exit 52
  6829. fi
  6830. if [ ! -f /etc/ssl/certs/xmpp.dhparam ]; then
  6831. freedombone-addcert -h xmpp
  6832. check_certificates xmpp
  6833. fi
  6834. chown prosody:prosody /etc/ssl/private/xmpp.key
  6835. chown prosody:prosody /etc/ssl/certs/xmpp.*
  6836. cp -a /etc/prosody/conf.avail/example.com.cfg.lua /etc/prosody/conf.avail/xmpp.cfg.lua
  6837. sed -i 's|/etc/prosody/certs/example.com.key|/etc/ssl/private/xmpp.key|g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6838. sed -i 's|/etc/prosody/certs/example.com.crt|/etc/ssl/certs/xmpp.crt|g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6839. if ! grep -q "xmpp.dhparam" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6840. sed -i '/certificate =/a\ dhparam = "/etc/ssl/certs/xmpp.dhparam";' /etc/prosody/conf.avail/xmpp.cfg.lua
  6841. fi
  6842. if ! grep -q 'options = {"no_sslv2", "no_sslv3" }' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6843. sed -i '/certificate =/a\ options = {"no_sslv2", "no_sslv3" };' /etc/prosody/conf.avail/xmpp.cfg.lua
  6844. fi
  6845. if ! grep -q 'ciphers =' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6846. sed -i "/certificate =/a\ ciphers = $XMPP_CIPHERS;" /etc/prosody/conf.avail/xmpp.cfg.lua
  6847. fi
  6848. if ! grep -q 'depth = "1";' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6849. sed -i '/certificate =/a\ depth = "1";' /etc/prosody/conf.avail/xmpp.cfg.lua
  6850. fi
  6851. if ! grep -q 'curve =' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6852. sed -i "/certificate =/a\ curve = $XMPP_ECC_CURVE;" /etc/prosody/conf.avail/xmpp.cfg.lua
  6853. fi
  6854. sed -i "s/example.com/$DEFAULT_DOMAIN_NAME/g" /etc/prosody/conf.avail/xmpp.cfg.lua
  6855. sed -i 's/enabled = false -- Remove this line to enable this host//g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6856. if ! grep -q "modules_enabled" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6857. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6858. echo 'modules_enabled = {' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6859. echo ' "bosh"; -- Enable mod_bosh' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6860. echo ' "tls"; -- Enable mod_tls' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6861. echo ' "saslauth"; -- Enable mod_saslauth' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6862. echo '}' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6863. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6864. echo 'c2s_require_encryption = true' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6865. echo 's2s_require_encryption = true' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6866. echo 'allow_unencrypted_plain_auth = false' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6867. fi
  6868. ln -sf /etc/prosody/conf.avail/xmpp.cfg.lua /etc/prosody/conf.d/xmpp.cfg.lua
  6869. sed -i 's|/etc/prosody/certs/localhost.key|/etc/ssl/private/xmpp.key|g' /etc/prosody/prosody.cfg.lua
  6870. sed -i 's|/etc/prosody/certs/localhost.crt|/etc/ssl/certs/xmpp.crt|g' /etc/prosody/prosody.cfg.lua
  6871. if ! grep -q "xmpp.dhparam" /etc/prosody/prosody.cfg.lua; then
  6872. sed -i '/certificate =/a\ dhparam = "/etc/ssl/certs/xmpp.dhparam";' /etc/prosody/prosody.cfg.lua
  6873. fi
  6874. if ! grep -q 'options = {"no_sslv2", "no_sslv3" }' /etc/prosody/prosody.cfg.lua; then
  6875. sed -i '/certificate =/a\ options = {"no_sslv2", "no_sslv3" };' /etc/prosody/prosody.cfg.lua
  6876. fi
  6877. if ! grep -q 'ciphers =' /etc/prosody/prosody.cfg.lua; then
  6878. sed -i "/certificate =/a\ ciphers = $XMPP_CIPHERS;" /etc/prosody/prosody.cfg.lua
  6879. fi
  6880. if ! grep -q 'depth = "1";' /etc/prosody/prosody.cfg.lua; then
  6881. sed -i '/certificate =/a\ depth = "1";' /etc/prosody/prosody.cfg.lua
  6882. fi
  6883. if ! grep -q 'curve =' /etc/prosody/prosody.cfg.lua; then
  6884. sed -i "/certificate =/a\ curve = $XMPP_ECC_CURVE;" /etc/prosody/prosody.cfg.lua
  6885. fi
  6886. sed -i 's/c2s_require_encryption = false/c2s_require_encryption = true/g' /etc/prosody/prosody.cfg.lua
  6887. if ! grep -q "s2s_require_encryption" /etc/prosody/prosody.cfg.lua; then
  6888. sed -i '/c2s_require_encryption/a\s2s_require_encryption = true' /etc/prosody/prosody.cfg.lua
  6889. fi
  6890. if ! grep -q "allow_unencrypted_plain_auth" /etc/prosody/prosody.cfg.lua; then
  6891. echo 'allow_unencrypted_plain_auth = false' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6892. fi
  6893. sed -i 's/--"bosh";/"bosh";/g' /etc/prosody/prosody.cfg.lua
  6894. sed -i 's/authentication = "internal_plain"/authentication = "internal_hashed"/g' /etc/prosody/prosody.cfg.lua
  6895. sed -i 's/enabled = false -- Remove this line to enable this host//g' /etc/prosody/prosody.cfg.lua
  6896. sed -i 's|key = "/etc/prosody/certs/example.com.key"|key = "/etc/ssl/private/xmpp.key"|g' /etc/prosody/prosody.cfg.lua
  6897. sed -i 's|certificate = "/etc/prosody/certs/example.com.crt"|certificate = "/etc/ssl/certs/xmpp.crt"|g' /etc/prosody/prosody.cfg.lua
  6898. sed -i "s/example.com/$DEFAULT_DOMAIN_NAME/g" /etc/prosody/prosody.cfg.lua
  6899. service prosody restart
  6900. touch /home/$MY_USERNAME/README
  6901. if ! grep -q "Your XMPP password is" /home/$MY_USERNAME/README; then
  6902. XMPP_PASSWORD=$(openssl rand -base64 8)
  6903. prosodyctl register $MY_USERNAME $DEFAULT_DOMAIN_NAME $XMPP_PASSWORD
  6904. echo '' >> /home/$MY_USERNAME/README
  6905. echo '' >> /home/$MY_USERNAME/README
  6906. echo 'XMPP' >> /home/$MY_USERNAME/README
  6907. echo '====' >> /home/$MY_USERNAME/README
  6908. echo "Your XMPP password is: $XMPP_PASSWORD" >> /home/$MY_USERNAME/README
  6909. echo 'You can change it with: ' >> /home/$MY_USERNAME/README
  6910. echo '' >> /home/$MY_USERNAME/README
  6911. echo " prosodyctl passwd $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/README
  6912. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6913. fi
  6914. echo 'install_xmpp' >> $COMPLETION_FILE
  6915. }
  6916. function install_watchdog_script {
  6917. if grep -Fxq "install_watchdog_script" $COMPLETION_FILE; then
  6918. return
  6919. fi
  6920. echo '#!/bin/bash' > /usr/bin/$WATCHDOG_SCRIPT_NAME
  6921. echo 'LOGFILE=/var/log/keepon.log' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6922. echo 'CURRENT_DATE=$(date)' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6923. # application specific stuff is added later
  6924. chmod +x /usr/bin/$WATCHDOG_SCRIPT_NAME
  6925. if ! grep -q "/usr/bin/$WATCHDOG_SCRIPT_NAME" /etc/crontab; then
  6926. echo "*/1 * * * * root /usr/bin/$WATCHDOG_SCRIPT_NAME" >> /etc/crontab
  6927. fi
  6928. echo 'install_watchdog_script' >> $COMPLETION_FILE
  6929. }
  6930. function install_irc_server {
  6931. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  6932. return
  6933. fi
  6934. if grep -Fxq "install_irc_server" $COMPLETION_FILE; then
  6935. return
  6936. fi
  6937. apt-get -y install ngircd
  6938. if [ ! -d /etc/ngircd ]; then
  6939. echo "ERROR: ngircd does not appear to have installed. $CHECK_MESSAGE"
  6940. exit 53
  6941. fi
  6942. if [ ! -f /etc/ssl/certs/ngircd.dhparam ]; then
  6943. freedombone-addcert -h ngircd
  6944. check_certificates ngircd
  6945. fi
  6946. echo '**************************************************' > /etc/ngircd/motd
  6947. echo '* F R E E D O M B O N E I R C *' >> /etc/ngircd/motd
  6948. echo '* *' >> /etc/ngircd/motd
  6949. echo '* Freedom in the Cloud *' >> /etc/ngircd/motd
  6950. echo '**************************************************' >> /etc/ngircd/motd
  6951. sed -i 's|MotdFile = /etc/ngircd/ngircd.motd|MotdFile = /etc/ngircd/motd|g' /etc/ngircd/ngircd.conf
  6952. sed -i "s/irc@irc.example.com/$MY_EMAIL_ADDRESS/g" /etc/ngircd/ngircd.conf
  6953. sed -i "s/irc.example.net/$DEFAULT_DOMAIN_NAME/g" /etc/ngircd/ngircd.conf
  6954. sed -i "s|Yet another IRC Server running on Debian GNU/Linux|IRC Server of $DEFAULT_DOMAIN_NAME|g" /etc/ngircd/ngircd.conf
  6955. sed -i 's/;Password = wealllikedebian/Password =/g' /etc/ngircd/ngircd.conf
  6956. sed -i 's|;CertFile = /etc/ssl/certs/server.crt|CertFile = /etc/ssl/certs/ngircd.crt|g' /etc/ngircd/ngircd.conf
  6957. sed -i 's|;DHFile = /etc/ngircd/dhparams.pem|DHFile = /etc/ssl/certs/ngircd.dhparam|g' /etc/ngircd/ngircd.conf
  6958. sed -i 's|;KeyFile = /etc/ssl/private/server.key|KeyFile = /etc/ssl/private/ngircd.key|g' /etc/ngircd/ngircd.conf
  6959. sed -i 's/;Ports = 6697, 9999/Ports = 6697, 9999/g' /etc/ngircd/ngircd.conf
  6960. sed -i 's/;Name = #ngircd/Name = #freedombone/g' /etc/ngircd/ngircd.conf
  6961. sed -i 's/;Topic = Our ngircd testing channel/Topic = Freedombone chat channel/g' /etc/ngircd/ngircd.conf
  6962. sed -i 's/;MaxUsers = 23/MaxUsers = 23/g' /etc/ngircd/ngircd.conf
  6963. sed -i 's|;KeyFile = /etc/ngircd/#chan.key|KeyFile = /etc/ngircd/#freedombone.key|g' /etc/ngircd/ngircd.conf
  6964. sed -i 's/;CloakHost = cloaked.host/CloakHost = freedombone/g' /etc/ngircd/ngircd.conf
  6965. IRC_SALT=$(openssl rand -base64 32)
  6966. IRC_OPERATOR_PASSWORD=$(openssl rand -base64 8)
  6967. sed -i "s|;CloakHostSalt = abcdefghijklmnopqrstuvwxyz|CloakHostSalt = $IRC_SALT|g" /etc/ngircd/ngircd.conf
  6968. sed -i 's/;ConnectIPv4 = yes/ConnectIPv4 = yes/g' /etc/ngircd/ngircd.conf
  6969. sed -i 's/;MorePrivacy = no/MorePrivacy = yes/g' /etc/ngircd/ngircd.conf
  6970. sed -i 's/;RequireAuthPing = no/RequireAuthPing = no/g' /etc/ngircd/ngircd.conf
  6971. sed -i "s/;Name = TheOper/Name = $MY_USERNAME/g" /etc/ngircd/ngircd.conf
  6972. sed -i "s/;Password = ThePwd/Password = $IRC_OPERATOR_PASSWORD/g" /etc/ngircd/ngircd.conf
  6973. service ngircd start
  6974. # keep the daemon running
  6975. echo '' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6976. echo '# keep irc daemon running' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6977. echo 'IRC_RUNNING=$(pgrep ngircd > /dev/null && echo Running)' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6978. echo 'if [ ! $IRC_RUNNING ]; then' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6979. echo ' service ngircd start' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6980. echo ' echo -n $CURRENT_DATE >> $LOGFILE' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6981. echo ' echo " IRC daemon restarted" >> $LOGFILE' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6982. echo 'fi' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6983. if ! grep -q "IRC Server" /home/$MY_USERNAME/README; then
  6984. echo '' >> /home/$MY_USERNAME/README
  6985. echo '' >> /home/$MY_USERNAME/README
  6986. echo 'IRC Server' >> /home/$MY_USERNAME/README
  6987. echo '==========' >> /home/$MY_USERNAME/README
  6988. echo 'To connect to your IRC server in irssi:' >> /home/$MY_USERNAME/README
  6989. echo '' >> /home/$MY_USERNAME/README
  6990. echo " /server add -auto -ssl $DEFAULT_DOMAIN_NAME 6697" >> /home/$MY_USERNAME/README
  6991. echo " /connect $DEFAULT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  6992. echo ' /join #freedombone' >> /home/$MY_USERNAME/README
  6993. fi
  6994. echo 'install_irc_server' >> $COMPLETION_FILE
  6995. }
  6996. function get_wiki_admin_password {
  6997. if [ -f /home/$MY_USERNAME/README ]; then
  6998. if grep -q "Wiki password" /home/$MY_USERNAME/README; then
  6999. WIKI_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Wiki password:" | awk -F ':' '{print $2}' | sed 's/^ *//')
  7000. fi
  7001. fi
  7002. }
  7003. function install_wiki {
  7004. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  7005. return
  7006. fi
  7007. if grep -Fxq "install_wiki" $COMPLETION_FILE; then
  7008. return
  7009. fi
  7010. if [ ! $WIKI_DOMAIN_NAME ]; then
  7011. return
  7012. fi
  7013. apt-get -y install dokuwiki
  7014. apt-get -y remove --purge apache*
  7015. if [ -d /etc/apache2 ]; then
  7016. rm -rf /etc/apache2
  7017. echo 'Removed Apache installation after Dokuwiki install'
  7018. fi
  7019. if [ ! -d /var/www/$WIKI_DOMAIN_NAME ]; then
  7020. mkdir /var/www/$WIKI_DOMAIN_NAME
  7021. fi
  7022. if [ -d /var/www/$WIKI_DOMAIN_NAME/htdocs ]; then
  7023. rm -rf /var/www/$WIKI_DOMAIN_NAME/htdocs
  7024. fi
  7025. if [ ! -f /etc/ssl/certs/$WIKI_DOMAIN_NAME.dhparam ]; then
  7026. freedombone-addcert -h $WIKI_DOMAIN_NAME
  7027. check_certificates $WIKI_DOMAIN_NAME
  7028. fi
  7029. ln -s /usr/share/dokuwiki /var/www/$WIKI_DOMAIN_NAME/htdocs
  7030. mkdir /var/lib/dokuwiki/custom
  7031. cp /etc/dokuwiki/local.php.dist /var/lib/dokuwiki/custom/local.php
  7032. ln -s /var/lib/dokuwiki/custom/local.php /etc/dokuwiki/local.php
  7033. chown www-data /var/lib/dokuwiki/custom
  7034. chown www-data /var/lib/dokuwiki/custom/local.php
  7035. chown -R www-data /etc/dokuwiki
  7036. chown -R www-data /usr/share/dokuwiki/lib/
  7037. chmod 600 /var/lib/dokuwiki/custom/local.php
  7038. chmod -R 755 /usr/share/dokuwiki/lib
  7039. sed -i 's|//$conf|$conf|g' /var/lib/dokuwiki/custom/local.php
  7040. sed -i "s|joe|$MY_USERNAME|g" /var/lib/dokuwiki/custom/local.php
  7041. sed -i "s|Debian DokuWiki|$WIKI_TITLE|g" /etc/dokuwiki/local.php
  7042. # set the admin user
  7043. sed -i "s/@admin/$MY_USERNAME/g" /etc/dokuwiki/local.php
  7044. # disallow registration of new users
  7045. if ! grep -q "disableactions" /etc/dokuwiki/local.php; then
  7046. echo "\$conf['disableactions'] = 'register';" >> /etc/dokuwiki/local.php
  7047. fi
  7048. if ! grep -q "disableactions" /var/lib/dokuwiki/custom/local.php; then
  7049. echo "\$conf['disableactions'] = 'register';" >> /var/lib/dokuwiki/custom/local.php
  7050. fi
  7051. if ! grep -q "authtype" /var/lib/dokuwiki/custom/local.php; then
  7052. echo "\$conf['authtype'] = 'authplain';" >> /var/lib/dokuwiki/custom/local.php
  7053. fi
  7054. if ! grep -q "authtype" /etc/dokuwiki/local.php; then
  7055. echo "\$conf['authtype'] = 'authplain';" >> /etc/dokuwiki/local.php
  7056. fi
  7057. get_wiki_admin_password
  7058. if [ ! $WIKI_ADMIN_PASSWORD ]; then
  7059. WIKI_ADMIN_PASSWORD=$(openssl rand -base64 16)
  7060. fi
  7061. HASHED_WIKI_PASSWORD=$(echo -n "$WIKI_ADMIN_PASSWORD" | md5sum | awk -F ' ' '{print $1}')
  7062. echo -n "$MY_USERNAME:$HASHED_WIKI_PASSWORD:$MY_NAME:$MY_EMAIL:admin,user,upload" > /var/lib/dokuwiki/acl/users.auth.php
  7063. chmod 640 /var/lib/dokuwiki/acl/users.auth.php
  7064. if ! grep -q "video/ogg" /etc/dokuwiki/mime.conf; then
  7065. echo 'ogv video/ogg' >> /etc/dokuwiki/mime.conf
  7066. fi
  7067. if ! grep -q "video/mp4" /etc/dokuwiki/mime.conf; then
  7068. echo 'mp4 video/mp4' >> /etc/dokuwiki/mime.conf
  7069. fi
  7070. if ! grep -q "video/webm" /etc/dokuwiki/mime.conf; then
  7071. echo 'webm video/webm' >> /etc/dokuwiki/mime.conf
  7072. fi
  7073. echo 'server {' > /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7074. echo ' listen 80;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7075. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7076. echo " server_name $WIKI_DOMAIN_NAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7077. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7078. echo " error_log /var/log/nginx/$WIKI_DOMAIN_NAME_error.log;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7079. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7080. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7081. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7082. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7083. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7084. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7085. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7086. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7087. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7088. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7089. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7090. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7091. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7092. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7093. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7094. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7095. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7096. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7097. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7098. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7099. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7100. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7101. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7102. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7103. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7104. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7105. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7106. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7107. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7108. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7109. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7110. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7111. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7112. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7113. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7114. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7115. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7116. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7117. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7118. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7119. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7120. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7121. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7122. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7123. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7124. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7125. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7126. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7127. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7128. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7129. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7130. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7131. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7132. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7133. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7134. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7135. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7136. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7137. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7138. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7139. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7140. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7141. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7142. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7143. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7144. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7145. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7146. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7147. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7148. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7149. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7150. echo 'server {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7151. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7152. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7153. echo " server_name $WIKI_DOMAIN_NAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7154. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7155. echo " error_log /var/log/nginx/$WIKI_DOMAIN_NAME_error_ssl.log;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7156. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7157. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7158. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7159. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7160. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7161. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7162. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7163. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7164. echo ' ssl on;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7165. echo " ssl_certificate /etc/ssl/certs/$WIKI_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7166. echo " ssl_certificate_key /etc/ssl/private/$WIKI_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7167. echo " ssl_dhparam /etc/ssl/certs/$WIKI_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7168. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7169. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7170. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7171. echo ' ssl_session_cache builtin:1000 shared:SSL:10m;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7172. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7173. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7174. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7175. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7176. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7177. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7178. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7179. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7180. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7181. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7182. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7183. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7184. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7185. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7186. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7187. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7188. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7189. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7190. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7191. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7192. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7193. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7194. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7195. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7196. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7197. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7198. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7199. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7200. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7201. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7202. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7203. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7204. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7205. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7206. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7207. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7208. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7209. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7210. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7211. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7212. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7213. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7214. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7215. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7216. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7217. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7218. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7219. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7220. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7221. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7222. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7223. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7224. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7225. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7226. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7227. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7228. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7229. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7230. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7231. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7232. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7233. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7234. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7235. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7236. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7237. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7238. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7239. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7240. configure_php
  7241. nginx_ensite $WIKI_DOMAIN_NAME
  7242. service php5-fpm restart
  7243. service nginx restart
  7244. # update the dynamic DNS
  7245. CURRENT_DDNS_DOMAIN=$WIKI_DOMAIN_NAME
  7246. add_ddns_domain
  7247. # add some post-install instructions
  7248. if ! grep -q "Wiki password" /home/$MY_USERNAME/README; then
  7249. echo '' >> /home/$MY_USERNAME/README
  7250. echo '' >> /home/$MY_USERNAME/README
  7251. echo 'Wiki' >> /home/$MY_USERNAME/README
  7252. echo '====' >> /home/$MY_USERNAME/README
  7253. echo "Wiki username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  7254. echo "Wiki password: $WIKI_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7255. echo '' >> /home/$MY_USERNAME/README
  7256. echo 'Once you have set up the wiki then remove the install file:' >> /home/$MY_USERNAME/README
  7257. echo '' >> /home/$MY_USERNAME/README
  7258. echo " rm /var/www/$WIKI_DOMAIN_NAME/htdocs/install.php" >> /home/$MY_USERNAME/README
  7259. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7260. fi
  7261. echo 'install_wiki' >> $COMPLETION_FILE
  7262. }
  7263. function get_blog_admin_password {
  7264. if [ -f /home/$MY_USERNAME/README ]; then
  7265. if grep -q "Your blog password is" /home/$MY_USERNAME/README; then
  7266. FULLBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Your blog password is" | awk -F ':' '{print $2}' | sed 's/^ *//')
  7267. fi
  7268. fi
  7269. }
  7270. function install_blog {
  7271. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  7272. return
  7273. fi
  7274. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  7275. return
  7276. fi
  7277. if [ ! $FULLBLOG_DOMAIN_NAME ]; then
  7278. echo 'The blog domain name was not specified'
  7279. exit 5062
  7280. fi
  7281. if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME ]; then
  7282. mkdir /var/www/$FULLBLOG_DOMAIN_NAME
  7283. fi
  7284. cd /var/www/$FULLBLOG_DOMAIN_NAME
  7285. git clone https://github.com/danpros/htmly htdocs
  7286. # This is a workaround until a better solution
  7287. git checkout 4842796 -b tempbranch
  7288. chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs
  7289. if [ ! -f /etc/ssl/certs/$FULLBLOG_DOMAIN_NAME.dhparam ]; then
  7290. freedombone-addcert -h $FULLBLOG_DOMAIN_NAME
  7291. check_certificates $FULLBLOG_DOMAIN_NAME
  7292. fi
  7293. echo 'server {' > /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7294. echo ' listen 80;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7295. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7296. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7297. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7298. echo " error_log /var/log/nginx/$FULLBLOG_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7299. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7300. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7301. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7302. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7303. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7304. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7305. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7306. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7307. echo ' # Always redirect the login page to https' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7308. echo ' location /login {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7309. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7310. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7311. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7312. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7313. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7314. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7315. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7316. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7317. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7318. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7319. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7320. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7321. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7322. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7323. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7324. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7325. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7326. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7327. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7328. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7329. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7330. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7331. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7332. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7333. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7334. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7335. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7336. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7337. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7338. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7339. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7340. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7341. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7342. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7343. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7344. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7345. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7346. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7347. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7348. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7349. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7350. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7351. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7352. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7353. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7354. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7355. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7356. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7357. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7358. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7359. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7360. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7361. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7362. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7363. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7364. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7365. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7366. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7367. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7368. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7369. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7370. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7371. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7372. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7373. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7374. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7375. echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7376. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7377. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7378. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7379. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7380. echo " error_log /var/log/nginx/$FULLBLOG_DOMAIN_NAME_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7381. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7382. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7383. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7384. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7385. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7386. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7387. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7388. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7389. echo ' ssl on;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7390. echo " ssl_certificate /etc/ssl/certs/$FULLBLOG_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7391. echo " ssl_certificate_key /etc/ssl/private/$FULLBLOG_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7392. echo " ssl_dhparam /etc/ssl/certs/$FULLBLOG_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7393. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7394. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7395. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7396. echo ' ssl_session_cache builtin:1000 shared:SSL:10m;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7397. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7398. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7399. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7400. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7401. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7402. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7403. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7404. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7405. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7406. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7407. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7408. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7409. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7410. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7411. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7412. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7413. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7414. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7415. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7416. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7417. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7418. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7419. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7420. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7421. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7422. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7423. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7424. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7425. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7426. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7427. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7428. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7429. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7430. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7431. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7432. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7433. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7434. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7435. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7436. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7437. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7438. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7439. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7440. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7441. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7442. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7443. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7444. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7445. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7446. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7447. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7448. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7449. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7450. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7451. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7452. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7453. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7454. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7455. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7456. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7457. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7458. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7459. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7460. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7461. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7462. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7463. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7464. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7465. configure_php
  7466. # blog settings
  7467. cp /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini.example /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7468. sed -i "s|site.url.*|site.url = 'https://$FULLBLOG_DOMAIN_NAME'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7469. sed -i "s|blog.title.*|blog.title = '$MY_BLOG_TITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7470. sed -i "s|blog.tagline.*|blog.tagline = '$MY_BLOG_SUBTITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7471. sed -i 's|timezone.*|timezone = "Europe/London"|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7472. sed -i "s|Your name|$MY_NAME|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7473. # create a user password
  7474. get_blog_admin_password
  7475. if [ ! $FULLBLOG_ADMIN_PASSWORD ]; then
  7476. FULLBLOG_ADMIN_PASSWORD=$(openssl rand -base64 16)
  7477. echo '' >> /home/$MY_USERNAME/README
  7478. echo '' >> /home/$MY_USERNAME/README
  7479. echo 'HTMLy Blog' >> /home/$MY_USERNAME/README
  7480. echo '==========' >> /home/$MY_USERNAME/README
  7481. echo "Your blog username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  7482. echo "Your blog password is: $FULLBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7483. echo "Log into your blog at https://$FULLBLOG_DOMAIN_NAME/login" >> /home/$MY_USERNAME/README
  7484. echo 'Edit your blog title and time zone at:' >> /home/$MY_USERNAME/README
  7485. echo " /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini" >> /home/$MY_USERNAME/README
  7486. echo '' >> /home/$MY_USERNAME/README
  7487. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7488. fi
  7489. # create a user
  7490. cp /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/username.ini.example /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7491. HASHED_BLOG_PASSWORD="$(echo -n $FULLBLOG_ADMIN_PASSWORD | sha256sum | awk -F ' ' '{print $1}')"
  7492. sed -i "s|yourpassword|$HASHED_BLOG_PASSWORD|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7493. sed -i 's/encryption = clear/encryption = "sha256"/g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7494. nginx_ensite $FULLBLOG_DOMAIN_NAME
  7495. service php5-fpm restart
  7496. service nginx restart
  7497. # update the dynamic DNS
  7498. CURRENT_DDNS_DOMAIN=$FULLBLOG_DOMAIN_NAME
  7499. add_ddns_domain
  7500. echo 'install_blog' >> $COMPLETION_FILE
  7501. }
  7502. function install_gnu_social {
  7503. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  7504. return
  7505. fi
  7506. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  7507. return
  7508. fi
  7509. if [ ! $MICROBLOG_DOMAIN_NAME ]; then
  7510. echo 'No domain name was given for the microblog'
  7511. exit 7359
  7512. fi
  7513. install_mariadb
  7514. get_mariadb_password
  7515. repair_databases_script
  7516. apt-get -y install php-gettext php5-curl php5-gd php5-mysql git curl php-xml-parser
  7517. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME ]; then
  7518. mkdir /var/www/$MICROBLOG_DOMAIN_NAME
  7519. fi
  7520. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs ]; then
  7521. mkdir /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7522. fi
  7523. cd $INSTALL_DIR
  7524. git clone $MICROBLOG_REPO gnusocial
  7525. rm -rf /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7526. mv gnusocial /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7527. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7528. chown www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7529. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/avatar
  7530. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/background
  7531. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/file
  7532. chmod +x /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php
  7533. get_mariadb_gnusocial_admin_password
  7534. if [ ! $MICROBLOG_ADMIN_PASSWORD ]; then
  7535. MICROBLOG_ADMIN_PASSWORD=$(openssl rand -base64 32)
  7536. echo '' >> /home/$MY_USERNAME/README
  7537. echo '' >> /home/$MY_USERNAME/README
  7538. echo 'GNU Social' >> /home/$MY_USERNAME/README
  7539. echo '==========' >> /home/$MY_USERNAME/README
  7540. echo "Your MariaDB gnusocial admin password is: $MICROBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7541. echo '' >> /home/$MY_USERNAME/README
  7542. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7543. fi
  7544. echo "create database gnusocial;
  7545. CREATE USER 'gnusocialadmin'@'localhost' IDENTIFIED BY '$MICROBLOG_ADMIN_PASSWORD';
  7546. GRANT ALL PRIVILEGES ON gnusocial.* TO 'gnusocialadmin'@'localhost';
  7547. quit" > $INSTALL_DIR/batch.sql
  7548. chmod 600 $INSTALL_DIR/batch.sql
  7549. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  7550. shred -zu $INSTALL_DIR/batch.sql
  7551. if [ ! -f "/etc/aliases" ]; then
  7552. touch /etc/aliases
  7553. fi
  7554. if grep -q "www-data: root" /etc/aliases; then
  7555. echo 'www-data: root' >> /etc/aliases
  7556. fi
  7557. if grep -q "/var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php" /etc/aliases; then
  7558. echo "*: /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php" >> /etc/aliases
  7559. fi
  7560. newaliases
  7561. # update the dynamic DNS
  7562. CURRENT_DDNS_DOMAIN=$MICROBLOG_DOMAIN_NAME
  7563. add_ddns_domain
  7564. echo 'server {' > /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7565. echo ' listen 80;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7566. echo " server_name $MICROBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7567. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7568. echo ' access_log off;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7569. echo " error_log /var/log/nginx/$MICROBLOG_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7570. echo ' index index.php;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7571. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7572. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7573. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7574. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7575. echo ' rewrite ^ https://$server_name$request_uri? permanent;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7576. echo '}' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7577. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7578. echo 'server {' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7579. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7580. echo " server_name $MICROBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7581. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7582. echo ' index index.php index.html index.htm;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7583. echo ' access_log off;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7584. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7585. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7586. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7587. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7588. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7589. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7590. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7591. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7592. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7593. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7594. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7595. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7596. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7597. echo ' fastcgi_read_timeout 300;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7598. echo ' }' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7599. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7600. echo ' ssl on;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7601. echo " ssl_certificate /etc/ssl/certs/$MICROBLOG_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7602. echo " ssl_certificate_key /etc/ssl/private/$MICROBLOG_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7603. echo " ssl_dhparam /etc/ssl/certs/$MICROBLOG_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7604. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7605. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7606. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7607. echo ' ssl_session_cache builtin:1000 shared:SSL:10m;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7608. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7609. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7610. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7611. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7612. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7613. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7614. echo ' location / {' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7615. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7616. echo ' break;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7617. echo ' }' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7618. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7619. echo ' location ~* ^/(.*)\.(ico|css|js|gif|png|jpg|bmp|JPG|jpeg)$ {' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7620. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7621. echo ' rewrite ^/(.*)$ /$1 break;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7622. echo ' access_log off;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7623. echo ' expires max;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7624. echo ' }' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7625. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7626. echo ' client_max_body_size 15m;' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7627. echo '' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7628. echo " error_log /var/log/nginx/$MICROBLOG_DOMAIN_NAME_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7629. echo '}' >> /etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7630. configure_php
  7631. if [ ! -f /etc/ssl/certs/$MICROBLOG_DOMAIN_NAME.dhparam ]; then
  7632. freedombone-addcert -h $MICROBLOG_DOMAIN_NAME
  7633. check_certificates $MICROBLOG_DOMAIN_NAME
  7634. fi
  7635. # Ensure that the database gets backed up locally, if remote
  7636. # backups are not being used
  7637. backup_databases_script_header
  7638. echo '' >> /usr/bin/backupdatabases
  7639. echo '# Backup the GNU Social database' >> /usr/bin/backupdatabases
  7640. echo 'TEMPFILE=/root/gnusocial.sql' >> /usr/bin/backupdatabases
  7641. echo 'DAILYFILE=/var/backups/gnusocial_daily.sql' >> /usr/bin/backupdatabases
  7642. echo 'mysqldump --password="$MYSQL_PASSWORD" gnusocial > $TEMPFILE' >> /usr/bin/backupdatabases
  7643. echo 'FILESIZE=$(stat -c%s $TEMPFILE)' >> /usr/bin/backupdatabases
  7644. echo 'if [ "$FILESIZE" -eq "0" ]; then' >> /usr/bin/backupdatabases
  7645. echo ' if [ -f $DAILYFILE ]; then' >> /usr/bin/backupdatabases
  7646. echo ' cp $DAILYFILE $TEMPFILE' >> /usr/bin/backupdatabases
  7647. echo '' >> /usr/bin/backupdatabases
  7648. echo ' # try to restore yesterdays database' >> /usr/bin/backupdatabases
  7649. echo ' mysql -u root --password="$MYSQL_PASSWORD" gnusocial -o < $DAILYFILE' >> /usr/bin/backupdatabases
  7650. echo '' >> /usr/bin/backupdatabases
  7651. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  7652. 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
  7653. echo ' else' >> /usr/bin/backupdatabases
  7654. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  7655. echo ' echo "Unable to create a backup of the GNU Social database." | mail -s "GNU Social backup" $EMAIL' >> /usr/bin/backupdatabases
  7656. echo ' fi' >> /usr/bin/backupdatabases
  7657. echo 'else' >> /usr/bin/backupdatabases
  7658. echo ' chmod 600 $TEMPFILE' >> /usr/bin/backupdatabases
  7659. echo ' mv $TEMPFILE $DAILYFILE' >> /usr/bin/backupdatabases
  7660. echo '' >> /usr/bin/backupdatabases
  7661. echo ' # Make the backup readable only by root' >> /usr/bin/backupdatabases
  7662. echo ' chmod 600 $DAILYFILE' >> /usr/bin/backupdatabases
  7663. echo 'fi' >> /usr/bin/backupdatabases
  7664. echo '' >> /etc/cron.weekly/backupdatabasesweekly
  7665. echo '# GNU Social' >> /etc/cron.weekly/backupdatabasesweekly
  7666. echo 'if [ -f /var/backups/gnusocial_weekly.sql ]; then' >> /etc/cron.weekly/backupdatabasesweekly
  7667. echo ' cp -f /var/backups/gnusocial_weekly.sql /var/backups/gnusocial_2weekly.sql' >> /etc/cron.weekly/backupdatabasesweekly
  7668. echo 'fi' >> /etc/cron.weekly/backupdatabasesweekly
  7669. echo 'if [ -f /var/backups/gnusocial_daily.sql ]; then' >> /etc/cron.weekly/backupdatabasesweekly
  7670. echo ' cp -f /var/backups/gnusocial_daily.sql /var/backups/gnusocial_weekly.sql' >> /etc/cron.weekly/backupdatabasesweekly
  7671. echo 'fi' >> /etc/cron.weekly/backupdatabasesweekly
  7672. echo '' >> /etc/cron.monthly/backupdatabasesmonthly
  7673. echo '# GNU Social' >> /etc/cron.monthly/backupdatabasesmonthly
  7674. echo 'if [ -f /var/backups/gnusocial_monthly.sql ]; then' >> /etc/cron.monthly/backupdatabasesmonthly
  7675. echo ' cp -f /var/backups/gnusocial_monthly.sql /var/backups/gnusocial_2monthly.sql' >> /etc/cron.monthly/backupdatabasesmonthly
  7676. echo 'fi' >> /etc/cron.monthly/backupdatabasesmonthly
  7677. echo 'if [ -f /var/backups/gnusocial_weekly.sql ]; then' >> /etc/cron.monthly/backupdatabasesmonthly
  7678. echo ' cp -f /var/backups/gnusocial_weekly.sql /var/backups/gnusocial_monthly.sql' >> /etc/cron.monthly/backupdatabasesmonthly
  7679. echo 'fi' >> /etc/cron.monthly/backupdatabasesmonthly
  7680. echo '/usr/bin/repairdatabase gnusocial' >> /etc/cron.hourly/repair
  7681. nginx_ensite $MICROBLOG_DOMAIN_NAME
  7682. service php5-fpm restart
  7683. service nginx restart
  7684. # some post-install instructions for the user
  7685. if ! grep -q "To set up your microblog" /home/$MY_USERNAME/README; then
  7686. echo '' >> /home/$MY_USERNAME/README
  7687. echo '' >> /home/$MY_USERNAME/README
  7688. echo 'Microblog' >> /home/$MY_USERNAME/README
  7689. echo '=========' >> /home/$MY_USERNAME/README
  7690. echo "To set up your microblog go to" >> /home/$MY_USERNAME/README
  7691. echo "https://$MICROBLOG_DOMAIN_NAME/install.php" >> /home/$MY_USERNAME/README
  7692. echo 'and enter the following settings:' >> /home/$MY_USERNAME/README
  7693. echo ' - Set a name for the site' >> /home/$MY_USERNAME/README
  7694. echo ' - Server SSL: enable' >> /home/$MY_USERNAME/README
  7695. echo ' - Hostname: localhost' >> /home/$MY_USERNAME/README
  7696. echo ' - Type: MySql/MariaDB' >> /home/$MY_USERNAME/README
  7697. echo ' - Name: gnusocial' >> /home/$MY_USERNAME/README
  7698. echo ' - DB username: root' >> /home/$MY_USERNAME/README
  7699. echo " - DB Password; $MARIADB_PASSWORD" >> /home/$MY_USERNAME/README
  7700. echo " - Administrator nickname: $MY_USERNAME" >> /home/$MY_USERNAME/README
  7701. echo " - Administrator password: $MICROBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7702. echo ' - Subscribe to announcements: ticked' >> /home/$MY_USERNAME/README
  7703. echo ' - Site profile: Community' >> /home/$MY_USERNAME/README
  7704. echo '' >> /home/$MY_USERNAME/README
  7705. echo 'When the install is complete you will see a lot of warnings' >> /home/$MY_USERNAME/README
  7706. echo 'but just ignore those and navigate to ' >> /home/$MY_USERNAME/README
  7707. echo "https://$MICROBLOG_DOMAIN_NAME and you can then " >> /home/$MY_USERNAME/README
  7708. echo 'complete the configuration via the *Admin* section on the header' >> /home/$MY_USERNAME/README
  7709. echo 'bar. Some recommended admin settings are:' >> /home/$MY_USERNAME/README
  7710. echo '' >> /home/$MY_USERNAME/README
  7711. echo 'Under the *Site* settings:' >> /home/$MY_USERNAME/README
  7712. echo ' Text limit: 140' >> /home/$MY_USERNAME/README
  7713. echo ' Dupe Limit: 60000' >> /home/$MY_USERNAME/README
  7714. echo '' >> /home/$MY_USERNAME/README
  7715. echo 'Under the *User* settings:' >> /home/$MY_USERNAME/README
  7716. echo ' Bio limit: 1000' >> /home/$MY_USERNAME/README
  7717. echo '' >> /home/$MY_USERNAME/README
  7718. echo 'Under the *Access* settings:' >> /home/$MY_USERNAME/README
  7719. echo ' /Invite only/ ticked' >> /home/$MY_USERNAME/README
  7720. echo '' >> /home/$MY_USERNAME/README
  7721. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7722. fi
  7723. echo 'install_gnu_social' >> $COMPLETION_FILE
  7724. }
  7725. function install_redmatrix {
  7726. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  7727. return
  7728. fi
  7729. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  7730. return
  7731. fi
  7732. if [ ! $REDMATRIX_DOMAIN_NAME ]; then
  7733. return
  7734. fi
  7735. install_mariadb
  7736. get_mariadb_password
  7737. repair_databases_script
  7738. apt-get -y install php5-common php5-cli php5-curl php5-gd php5-mysql php5-mcrypt git
  7739. if [ ! -d /var/www/$REDMATRIX_DOMAIN_NAME ]; then
  7740. mkdir /var/www/$REDMATRIX_DOMAIN_NAME
  7741. fi
  7742. if [ ! -d /var/www/$REDMATRIX_DOMAIN_NAME/htdocs ]; then
  7743. mkdir /var/www/$REDMATRIX_DOMAIN_NAME/htdocs
  7744. fi
  7745. if [ ! -f /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/index.php ]; then
  7746. cd $INSTALL_DIR
  7747. git clone $REDMATRIX_REPO redmatrix
  7748. rm -rf /var/www/$REDMATRIX_DOMAIN_NAME/htdocs
  7749. mv redmatrix /var/www/$REDMATRIX_DOMAIN_NAME/htdocs
  7750. chown -R www-data:www-data /var/www/$REDMATRIX_DOMAIN_NAME/htdocs
  7751. git clone $REDMATRIX_ADDONS_REPO /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/addon
  7752. # some extra themes
  7753. git clone https://github.com/DeadSuperHero/redmatrix-themes /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/redmatrix-themes1
  7754. cp -r /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/redmatrix-themes1/* view/theme/
  7755. fi
  7756. get_mariadb_redmatrix_admin_password
  7757. if [ ! $REDMATRIX_ADMIN_PASSWORD ]; then
  7758. REDMATRIX_ADMIN_PASSWORD=$(openssl rand -base64 32)
  7759. echo '' >> /home/$MY_USERNAME/README
  7760. echo '' >> /home/$MY_USERNAME/README
  7761. echo 'Red Matrix' >> /home/$MY_USERNAME/README
  7762. echo '==========' >> /home/$MY_USERNAME/README
  7763. echo "Your MariaDB Red Matrix admin password is: $REDMATRIX_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7764. echo '' >> /home/$MY_USERNAME/README
  7765. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7766. fi
  7767. echo "create database redmatrix;
  7768. CREATE USER 'redmatrixadmin'@'localhost' IDENTIFIED BY '$REDMATRIX_ADMIN_PASSWORD';
  7769. GRANT ALL PRIVILEGES ON redmatrix.* TO 'redmatrixadmin'@'localhost';
  7770. quit" > $INSTALL_DIR/batch.sql
  7771. chmod 600 $INSTALL_DIR/batch.sql
  7772. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  7773. shred -zu $INSTALL_DIR/batch.sql
  7774. if ! grep -q "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs" /etc/crontab; then
  7775. 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
  7776. fi
  7777. # update the dynamic DNS
  7778. CURRENT_DDNS_DOMAIN=$REDMATRIX_DOMAIN_NAME
  7779. add_ddns_domain
  7780. echo 'server {' > /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7781. echo ' listen 80;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7782. echo " server_name $REDMATRIX_DOMAIN_NAME;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7783. echo " root /var/www/$REDMATRIX_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7784. echo ' access_log off;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7785. echo " error_log /var/log/nginx/$REDMATRIX_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7786. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7787. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7788. echo ' index index.php;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7789. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7790. echo ' rewrite ^ https://$server_name$request_uri? permanent;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7791. echo '}' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7792. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7793. echo 'server {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7794. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7795. echo " root /var/www/$REDMATRIX_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7796. echo " server_name $REDMATRIX_DOMAIN_NAME;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7797. echo " error_log /var/log/nginx/$REDMATRIX_DOMAIN_NAME_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7798. echo ' index index.php;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7799. echo ' charset utf-8;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7800. echo ' client_max_body_size 20m;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7801. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7802. echo ' access_log off;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7803. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7804. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7805. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7806. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7807. echo ' ssl on;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7808. echo " ssl_certificate /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7809. echo " ssl_certificate_key /etc/ssl/private/$REDMATRIX_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7810. echo " ssl_dhparam /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7811. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7812. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7813. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7814. echo ' ssl_session_cache builtin:1000 shared:SSL:10m;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7815. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7816. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7817. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7818. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7819. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7820. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7821. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7822. echo ' location / {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7823. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7824. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7825. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7826. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7827. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7828. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7829. echo ' allow all;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7830. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7831. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7832. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7833. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7834. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7835. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7836. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7837. echo ' expires 30d;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7838. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7839. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7840. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7841. echo ' # block these file types' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7842. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7843. echo ' deny all;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7844. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7845. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7846. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7847. echo ' # or a unix socket' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7848. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7849. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7850. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7851. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7852. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7853. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7854. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7855. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7856. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7857. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7858. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7859. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7860. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7861. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7862. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7863. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7864. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7865. echo ' fastcgi_read_timeout 300;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7866. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7867. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7868. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7869. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7870. echo ' deny all;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7871. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7872. echo '' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7873. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7874. echo ' deny all;' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7875. echo ' }' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7876. echo '}' >> /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME
  7877. configure_php
  7878. if [ ! -f /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.dhparam ]; then
  7879. freedombone-addcert -h $REDMATRIX_DOMAIN_NAME
  7880. check_certificates $REDMATRIX_DOMAIN_NAME
  7881. fi
  7882. if [ ! -d /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/view/tpl/smarty3 ]; then
  7883. mkdir /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/view/tpl/smarty3
  7884. fi
  7885. if [ ! -d "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store" ]; then
  7886. mkdir "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store"
  7887. fi
  7888. if [ ! -d "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]" ]; then
  7889. mkdir "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]"
  7890. fi
  7891. if [ ! -d "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3" ]; then
  7892. mkdir "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3"
  7893. chmod 777 "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store/[data]/smarty3"
  7894. fi
  7895. chmod 777 /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/view/tpl
  7896. chown -R www-data:www-data "/var/www/$REDMATRIX_DOMAIN_NAME/htdocs/store"
  7897. chmod 777 /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/view/tpl/smarty3
  7898. # Ensure that the database gets backed up locally, if remote
  7899. # backups are not being used
  7900. backup_databases_script_header
  7901. echo '' >> /usr/bin/backupdatabases
  7902. echo '# Backup the Red Matrix database' >> /usr/bin/backupdatabases
  7903. echo 'TEMPFILE=/root/redmatrix.sql' >> /usr/bin/backupdatabases
  7904. echo 'DAILYFILE=/var/backups/redmatrix_daily.sql' >> /usr/bin/backupdatabases
  7905. echo 'mysqldump --password="$MYSQL_PASSWORD" redmatrix > $TEMPFILE' >> /usr/bin/backupdatabases
  7906. echo 'FILESIZE=$(stat -c%s $TEMPFILE)' >> /usr/bin/backupdatabases
  7907. echo 'if [ "$FILESIZE" -eq "0" ]; then' >> /usr/bin/backupdatabases
  7908. echo ' if [ -f $DAILYFILE ]; then' >> /usr/bin/backupdatabases
  7909. echo ' cp $DAILYFILE $TEMPFILE' >> /usr/bin/backupdatabases
  7910. echo '' >> /usr/bin/backupdatabases
  7911. echo ' # try to restore yesterdays database' >> /usr/bin/backupdatabases
  7912. echo ' mysql -u root --password="$MYSQL_PASSWORD" redmatrix -o < $DAILYFILE' >> /usr/bin/backupdatabases
  7913. echo '' >> /usr/bin/backupdatabases
  7914. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  7915. 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
  7916. echo ' else' >> /usr/bin/backupdatabases
  7917. echo ' # Send a warning email' >> /usr/bin/backupdatabases
  7918. echo ' echo "Unable to create a backup of the Red Matrix database." | mail -s "Red Matrix backup" $EMAIL' >> /usr/bin/backupdatabases
  7919. echo ' fi' >> /usr/bin/backupdatabases
  7920. echo 'else' >> /usr/bin/backupdatabases
  7921. echo ' chmod 600 $TEMPFILE' >> /usr/bin/backupdatabases
  7922. echo ' mv $TEMPFILE $DAILYFILE' >> /usr/bin/backupdatabases
  7923. echo '' >> /usr/bin/backupdatabases
  7924. echo ' # Make the backup readable only by root' >> /usr/bin/backupdatabases
  7925. echo ' chmod 600 $DAILYFILE' >> /usr/bin/backupdatabases
  7926. echo 'fi' >> /usr/bin/backupdatabases
  7927. echo '' >> /etc/cron.weekly/backupdatabasesweekly
  7928. echo '# Red Matrix' >> /etc/cron.weekly/backupdatabasesweekly
  7929. echo 'if [ -f /var/backups/redmatrix_weekly.sql ]; then' >> /etc/cron.weekly/backupdatabasesweekly
  7930. echo ' cp -f /var/backups/redmatrix_weekly.sql /var/backups/redmatrix_2weekly.sql' >> /etc/cron.weekly/backupdatabasesweekly
  7931. echo 'fi' >> /etc/cron.weekly/backupdatabasesweekly
  7932. echo 'if [ -f /var/backups/redmatrix_daily.sql ]; then' >> /etc/cron.weekly/backupdatabasesweekly
  7933. echo ' cp -f /var/backups/redmatrix_daily.sql /var/backups/redmatrix_weekly.sql' >> /etc/cron.weekly/backupdatabasesweekly
  7934. echo 'fi' >> /etc/cron.weekly/backupdatabasesweekly
  7935. echo '' >> /etc/cron.monthly/backupdatabasesmonthly
  7936. echo '# Red Matrix' >> /etc/cron.monthly/backupdatabasesmonthly
  7937. echo 'if [ -f /var/backups/redmatrix_monthly.sql ]; then' >> /etc/cron.monthly/backupdatabasesmonthly
  7938. echo ' cp -f /var/backups/redmatrix_monthly.sql /var/backups/redmatrix_2monthly.sql' >> /etc/cron.monthly/backupdatabasesmonthly
  7939. echo 'fi' >> /etc/cron.monthly/backupdatabasesmonthly
  7940. echo 'if [ -f /var/backups/redmatrix_weekly.sql ]; then' >> /etc/cron.monthly/backupdatabasesmonthly
  7941. echo ' cp -f /var/backups/redmatrix_weekly.sql /var/backups/redmatrix_monthly.sql' >> /etc/cron.monthly/backupdatabasesmonthly
  7942. echo 'fi' >> /etc/cron.monthly/backupdatabasesmonthly
  7943. echo '/usr/bin/repairdatabase redmatrix' >> /etc/cron.hourly/repair
  7944. nginx_ensite $REDMATRIX_DOMAIN_NAME
  7945. service php5-fpm restart
  7946. service nginx restart
  7947. service cron restart
  7948. # some post-install instructions for the user
  7949. if ! grep -q "To set up your Red Matrix" /home/$MY_USERNAME/README; then
  7950. echo '' >> /home/$MY_USERNAME/README
  7951. echo "To set up your Red Matrix site go to" >> /home/$MY_USERNAME/README
  7952. echo "https://$REDMATRIX_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  7953. echo 'You will need to have a non self-signed SSL certificate in order' >> /home/$MY_USERNAME/README
  7954. echo "to use Red Matrix. Put the public certificate in /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.crt" >> /home/$MY_USERNAME/README
  7955. echo "and the private certificate in /etc/ssl/private/$REDMATRIX_DOMAIN_NAME.key." >> /home/$MY_USERNAME/README
  7956. echo 'If there is an intermediate certificate needed (such as with StartSSL) then' >> /home/$MY_USERNAME/README
  7957. echo 'this will need to be concatenated onto the end of the crt file, like this:' >> /home/$MY_USERNAME/README
  7958. echo '' >> /home/$MY_USERNAME/README
  7959. 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
  7960. echo '' >> /home/$MY_USERNAME/README
  7961. echo "Then change ssl_certificate to /etc/ssl/certs/$REDMATRIX_DOMAIN_NAME.bundle.crt" >> /home/$MY_USERNAME/README
  7962. echo "within /etc/nginx/sites-available/$REDMATRIX_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  7963. echo '' >> /home/$MY_USERNAME/README
  7964. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7965. fi
  7966. echo 'install_redmatrix' >> $COMPLETION_FILE
  7967. }
  7968. function script_for_attaching_usb_drive {
  7969. if grep -Fxq "script_for_attaching_usb_drive" $COMPLETION_FILE; then
  7970. return
  7971. fi
  7972. echo '#!/bin/bash' > /usr/bin/attach-music
  7973. echo 'remove-music' >> /usr/bin/attach-music
  7974. echo "if [ ! -d $USB_MOUNT ]; then" >> /usr/bin/attach-music
  7975. echo " mkdir $USB_MOUNT" >> /usr/bin/attach-music
  7976. echo 'fi' >> /usr/bin/attach-music
  7977. echo "mount /dev/sda1 $USB_MOUNT" >> /usr/bin/attach-music
  7978. echo "chown root:root $USB_MOUNT" >> /usr/bin/attach-music
  7979. echo "chown -R minidlna:minidlna $USB_MOUNT/*" >> /usr/bin/attach-music
  7980. echo 'service minidlna restart' >> /usr/bin/attach-music
  7981. echo 'minidlnad -R' >> /usr/bin/attach-music
  7982. chmod +x /usr/bin/attach-music
  7983. ln -s /usr/bin/attach-music /usr/bin/attach-usb
  7984. ln -s /usr/bin/attach-music /usr/bin/attach-videos
  7985. ln -s /usr/bin/attach-music /usr/bin/attach-pictures
  7986. ln -s /usr/bin/attach-music /usr/bin/attach-media
  7987. echo '#!/bin/bash' > /usr/bin/remove-music
  7988. echo "if [ -d $USB_MOUNT ]; then" >> /usr/bin/remove-music
  7989. echo " umount $USB_MOUNT" >> /usr/bin/remove-music
  7990. echo " rm -rf $USB_MOUNT" >> /usr/bin/remove-music
  7991. echo 'fi' >> /usr/bin/remove-music
  7992. chmod +x /usr/bin/remove-music
  7993. ln -s /usr/bin/remove-music /usr/bin/detach-music
  7994. ln -s /usr/bin/remove-music /usr/bin/detach-usb
  7995. ln -s /usr/bin/remove-music /usr/bin/remove-usb
  7996. ln -s /usr/bin/remove-music /usr/bin/detach-media
  7997. ln -s /usr/bin/remove-music /usr/bin/remove-media
  7998. ln -s /usr/bin/remove-music /usr/bin/detach-videos
  7999. ln -s /usr/bin/remove-music /usr/bin/remove-videos
  8000. ln -s /usr/bin/remove-music /usr/bin/detach-pictures
  8001. ln -s /usr/bin/remove-music /usr/bin/remove-pictures
  8002. echo 'script_for_attaching_usb_drive' >> $COMPLETION_FILE
  8003. }
  8004. function install_dlna_server {
  8005. if grep -Fxq "install_dlna_server" $COMPLETION_FILE; then
  8006. return
  8007. fi
  8008. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  8009. return
  8010. fi
  8011. apt-get -y install minidlna
  8012. if [ ! -f /etc/minidlna.conf ]; then
  8013. echo "ERROR: minidlna does not appear to have installed. $CHECK_MESSAGE"
  8014. exit 55
  8015. fi
  8016. sed -i "s|media_dir=/var/lib/minidlna|media_dir=A,/home/$MY_USERNAME/Music|g" /etc/minidlna.conf
  8017. if ! grep -q "/home/$MY_USERNAME/Pictures" /etc/minidlna.conf; then
  8018. echo "media_dir=P,/home/$MY_USERNAME/Pictures" >> /etc/minidlna.conf
  8019. fi
  8020. if ! grep -q "/home/$MY_USERNAME/Videos" /etc/minidlna.conf; then
  8021. echo "media_dir=V,/home/$MY_USERNAME/Videos" >> /etc/minidlna.conf
  8022. fi
  8023. if ! grep -q "$USB_MOUNT/Music" /etc/minidlna.conf; then
  8024. echo "media_dir=A,$USB_MOUNT/Music" >> /etc/minidlna.conf
  8025. fi
  8026. if ! grep -q "$USB_MOUNT/Pictures" /etc/minidlna.conf; then
  8027. echo "media_dir=P,$USB_MOUNT/Pictures" >> /etc/minidlna.conf
  8028. fi
  8029. if ! grep -q "$USB_MOUNT/Videos" /etc/minidlna.conf; then
  8030. echo "media_dir=V,$USB_MOUNT/Videos" >> /etc/minidlna.conf
  8031. fi
  8032. sed -i 's/#root_container=./root_container=B/g' /etc/minidlna.conf
  8033. sed -i 's/#network_interface=/network_interface=eth0/g' /etc/minidlna.conf
  8034. sed -i 's/#friendly_name=/friendly_name="Freedombone Media"/g' /etc/minidlna.conf
  8035. sed -i 's|#db_dir=/var/cache/minidlna|db_dir=/var/cache/minidlna|g' /etc/minidlna.conf
  8036. sed -i 's/#inotify=yes/inotify=yes/g' /etc/minidlna.conf
  8037. sed -i 's/#notify_interval=895/notify_interval=300/g' /etc/minidlna.conf
  8038. sed -i "s|#presentation_url=/|presentation_url=http://localhost:8200|g" /etc/minidlna.conf
  8039. service minidlna force-reload
  8040. service minidlna reload
  8041. sed -i 's/fs.inotify.max_user_watches*/fs.inotify.max_user_watches=65536/g' /etc/sysctl.conf
  8042. if ! grep -q "max_user_watches" $COMPLETION_FILE; then
  8043. echo 'fs.inotify.max_user_watches=65536' >> /etc/sysctl.conf
  8044. fi
  8045. /sbin/sysctl -p
  8046. echo 'install_dlna_server' >> $COMPLETION_FILE
  8047. }
  8048. function install_mediagoblin {
  8049. return
  8050. if grep -Fxq "install_mediagoblin" $COMPLETION_FILE; then
  8051. return
  8052. fi
  8053. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  8054. return
  8055. fi
  8056. if [ ! $MEDIAGOBLIN_DOMAIN_NAME ]; then
  8057. return
  8058. fi
  8059. apt-get -y install git-core python python-dev python-lxml python-imaging python-virtualenv
  8060. apt-get -y install postgresql postgresql-client python-psycopg2
  8061. apt-get -y install python-gst-1.0 libjpeg62-turbo-dev gstreamer1.0-plugins-base python-gobject
  8062. apt-get -y install gstreamer1.0-plugins-good gstreamer1.0-libav libav-tools gstreamer0.10-tools
  8063. apt-get -y install python-numpy python-scipy libsndfile1-dev python-gst0.10-dev
  8064. apt-get -y install gstreamer0.10-plugins-base gstreamer0.10-plugins-good gstreamer1.0-tools
  8065. su -c "createuser -A -D mediagoblin" - postgres
  8066. su -c "createdb -E UNICODE -O mediagoblin mediagoblin" - postgres
  8067. adduser --disabled-login --gecos 'Mediagoblin' mediagoblin
  8068. MEDIAGOBLIN_DOMAIN_ROOT="/home/mediagoblin"
  8069. MEDIAGOBLIN_PATH="$MEDIAGOBLIN_DOMAIN_ROOT/mediagoblin"
  8070. MEDIAGOBLIN_PATH_BIN="$MEDIAGOBLIN_PATH/mediagoblin/bin"
  8071. mkdir -p $MEDIAGOBLIN_DOMAIN_ROOT
  8072. chown -hR mediagoblin: $MEDIAGOBLIN_DOMAIN_ROOT
  8073. su -c "cd $MEDIAGOBLIN_DOMAIN_ROOT; git clone $MEDIAGOBLIN_REPO" - mediagoblin
  8074. cd $MEDIAGOBLIN_DOMAIN_ROOT
  8075. git checkout -q v0.7.1
  8076. su -c "cd $MEDIAGOBLIN_PATH; git submodule init" - mediagoblin
  8077. su -c "cd $MEDIAGOBLIN_PATH; git submodule update" - mediagoblin
  8078. su -c "cd $MEDIAGOBLIN_PATH; (virtualenv --python=python2 --system-site-packages . || cd $MEDIAGOBLIN_PATH; virtualenv --python=python2 .) && ./bin/python setup.py develop" - mediagoblin
  8079. su -c "cd $MEDIAGOBLIN_PATH; ./bin/easy_install flup" - mediagoblin
  8080. if [ -f $MEDIAGOBLIN_PATH/lib/python2.7/no-global-site-packages.txt ]; then
  8081. virtualenv deactivate
  8082. rm -f $MEDIAGOBLIN_PATH/lib/python2.7/no-global-site-packages.txt
  8083. su -c "cd $MEDIAGOBLIN_PATH; source bin/activate" - mediagoblin
  8084. fi
  8085. if [ -f $MEDIAGOBLIN_PATH/mediagoblin.example.ini ]; then
  8086. # this is for versions > 0.7.1
  8087. su -c "cp $MEDIAGOBLIN_PATH/mediagoblin.example.ini $MEDIAGOBLIN_PATH/mediagoblin_local.ini" - mediagoblin
  8088. sed -i 's|# data_basedir.*|data_basedir = "/var/lib/mediagoblin"|g' $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  8089. else
  8090. su -c "cp $MEDIAGOBLIN_PATH/mediagoblin.ini $MEDIAGOBLIN_PATH/mediagoblin_local.ini" - mediagoblin
  8091. fi
  8092. sed -i 's|# sql_engine.*|sql_engine = postgresql:///mediagoblin|g' $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  8093. sed -i "s/email_sender_address.*/email_sender_address = \"$MY_EMAIL_ADDRESS\"/g" $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  8094. sed -i 's|email_debug_mode.*|email_debug_mode = false|g' $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  8095. # add extra media types
  8096. if ! grep -q "media_types.stl" $MEDIAGOBLIN_PATH/mediagoblin_local.ini; then
  8097. echo '[[mediagoblin.media_types.stl]]' >> $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  8098. fi
  8099. if ! grep -q "media_types.audio" $MEDIAGOBLIN_PATH/mediagoblin_local.ini; then
  8100. echo '[[mediagoblin.media_types.audio]]' >> $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  8101. fi
  8102. if ! grep -q "media_types.video" $MEDIAGOBLIN_PATH/mediagoblin_local.ini; then
  8103. echo '[[mediagoblin.media_types.video]]' >> $MEDIAGOBLIN_PATH/mediagoblin_local.ini
  8104. fi
  8105. #su -c 'cd $MEDIAGOBLIN_PATH; ./bin/pip install scikits.audiolab' - mediagoblin
  8106. #su -c "cd $MEDIAGOBLIN_PATH; git submodule update && ./bin/python setup.py develop --upgrade && ./bin/gmg dbupdate" - mediagoblin
  8107. su -c "cd $MEDIAGOBLIN_PATH; ./bin/gmg dbupdate" - mediagoblin
  8108. echo 'server {' > /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8109. echo ' listen 80;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8110. echo " server_name $MEDIAGOBLIN_DOMAIN_NAME;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8111. echo ' access_log off;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8112. echo " error_log /var/log/nginx/$MEDIAGOBLIN_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8113. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8114. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8115. echo ' location / {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8116. echo ' proxy_pass http://localhost:6543;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8117. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8118. echo ' location ^~ /auth/ {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8119. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8120. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8121. echo ' location ^~ /u/ {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8122. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8123. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8124. echo ' location ^~ /submit/ {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8125. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8126. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8127. echo '}' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8128. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8129. echo 'server {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8130. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8131. echo " root /var/www/$MEDIAGOBLIN_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8132. echo " server_name $MEDIAGOBLIN_DOMAIN_NAME;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8133. echo ' access_log off;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8134. echo " error_log /var/log/nginx/$MEDIAGOBLIN_DOMAIN_NAME_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8135. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8136. echo ' limit_conn conn_limit_per_ip 10;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8137. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8138. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8139. echo ' ssl on;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8140. echo " ssl_certificate /etc/ssl/certs/$MEDIAGOBLIN_DOMAIN_NAME.crt;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8141. echo " ssl_certificate_key /etc/ssl/private/$MEDIAGOBLIN_DOMAIN_NAME.key;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8142. echo " ssl_dhparam /etc/ssl/certs/$MEDIAGOBLIN_DOMAIN_NAME.dhparam;" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8143. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8144. echo ' ssl_session_timeout 5m;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8145. echo ' ssl_prefer_server_ciphers on;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8146. echo " ssl_protocols $SSL_PROTOCOLS; # not possible to do exclusive" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8147. echo " ssl_ciphers '$SSL_CIPHERS';" >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8148. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8149. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8150. echo ' add_header Strict-Transport-Security max-age=0;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8151. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8152. echo ' location / {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8153. echo ' proxy_pass http://localhost:6543;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8154. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8155. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8156. echo ' client_max_body_size 10G; # set max upload size' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8157. echo ' client_body_buffer_size 128k;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8158. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8159. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8160. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8161. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8162. echo '' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8163. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8164. echo ' allow all;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8165. echo ' log_not_found off;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8166. echo ' access_log off;' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8167. echo ' }' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8168. echo '}' >> /etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8169. if [ ! -f /etc/ssl/certs/$MEDIAGOBLIN_DOMAIN_NAME.dhparam ]; then
  8170. freedombone-addcert -h $MEDIAGOBLIN_DOMAIN_NAME
  8171. check_certificates $MEDIAGOBLIN_DOMAIN_NAME
  8172. fi
  8173. nginx_ensite $MEDIAGOBLIN_DOMAIN_NAME
  8174. service php5-fpm restart
  8175. service nginx restart
  8176. /usr/sbin/nginx -s reload
  8177. # update the dynamic DNS
  8178. CURRENT_DDNS_DOMAIN=$MEDIAGOBLIN_DOMAIN_NAME
  8179. add_ddns_domain
  8180. # init with systemd
  8181. echo '[Unit]' > /etc/systemd/system/mediagoblin.service
  8182. echo 'Description=Mediagoblin (Media Server)' >> /etc/systemd/system/mediagoblin.service
  8183. echo 'After=syslog.target' >> /etc/systemd/system/mediagoblin.service
  8184. echo 'After=network.target' >> /etc/systemd/system/mediagoblin.service
  8185. echo 'After=postgresql.service' >> /etc/systemd/system/mediagoblin.service
  8186. echo '' >> /etc/systemd/system/mediagoblin.service
  8187. echo '[Service]' >> /etc/systemd/system/mediagoblin.service
  8188. echo 'Type=simple' >> /etc/systemd/system/mediagoblin.service
  8189. echo 'User=mediagoblin' >> /etc/systemd/system/mediagoblin.service
  8190. echo 'Group=mediagoblin' >> /etc/systemd/system/mediagoblin.service
  8191. echo 'WorkingDirectory=/home/mediagoblin/mediagoblin' >> /etc/systemd/system/mediagoblin.service
  8192. echo 'ExecStart=/home/mediagoblin/mediagoblin/lazyserver.sh --server-name=broadcast' >> /etc/systemd/system/mediagoblin.service
  8193. echo 'Restart=always' >> /etc/systemd/system/mediagoblin.service
  8194. echo 'Environment="USER=mediagoblin","HOME=/home/mediagoblin"' >> /etc/systemd/system/mediagoblin.service
  8195. echo '' >> /etc/systemd/system/mediagoblin.service
  8196. echo '[Install]' >> /etc/systemd/system/mediagoblin.service
  8197. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/mediagoblin.service
  8198. systemctl enable mediagoblin
  8199. systemctl restart mediagoblin
  8200. echo 'install_mediagoblin' >> $COMPLETION_FILE
  8201. }
  8202. function create_upgrade_script {
  8203. if grep -Fxq "create_upgrade_script" $COMPLETION_FILE; then
  8204. return
  8205. fi
  8206. echo '#!/bin/bash' > /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8207. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8208. echo 'apt-get -y update' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8209. echo 'apt-get -y upgrade' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8210. if grep -Fxq "install_redmatrix" $COMPLETION_FILE; then
  8211. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8212. echo '# Red Matrix' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8213. echo "cd /var/www/$REDMATRIX_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8214. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8215. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8216. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8217. echo "cd /var/www/$REDMATRIX_DOMAIN_NAME/htdocs/addon" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8218. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8219. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8220. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8221. echo "chown -R www-data:www-data /var/www/$REDMATRIX_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8222. fi
  8223. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  8224. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8225. echo '# GNU Social' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8226. echo "cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8227. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8228. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8229. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8230. echo "chown -R www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8231. fi
  8232. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  8233. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8234. echo '# Blog' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8235. echo "cd /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8236. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8237. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8238. echo '#git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8239. echo "#chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8240. fi
  8241. if grep -Fxq "install_owncloud_music_app" $COMPLETION_FILE; then
  8242. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8243. echo '# Owncloud music app' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8244. echo "cd /usr/share/owncloud/apps/music" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8245. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8246. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8247. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8248. fi
  8249. if grep -Fxq "mesh_cjdns" $COMPLETION_FILE; then
  8250. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8251. echo '# cjdns' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8252. echo "cd /etc/cjdns" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8253. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8254. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8255. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8256. fi
  8257. if grep -Fxq "install_gogs" $COMPLETION_FILE; then
  8258. echo '' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8259. echo '# gogs' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8260. echo 'cd /home/git/go/src/github.com/gogits/gogs' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8261. echo 'git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8262. echo 'git stash drop' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8263. echo 'git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8264. echo 'chown -R git:git /home/git' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8265. echo 'chmod 600 /home/git/go/src/github.com/gogits/gogs/custom/conf/app.ini' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8266. echo 'export GOPATH=/home/git/go' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8267. echo 'go build' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8268. echo 'systemctl restart gogs' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8269. echo 'systemctl daemon-reload' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8270. fi
  8271. echo '# update email encryption script' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8272. echo "if [ -d $INSTALL_DIR/gpgit ]; then" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8273. echo " cd $INSTALL_DIR/gpgit" >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8274. echo ' git stash' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8275. echo ' git pull' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8276. echo ' cp gpgit.pl /usr/bin' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8277. echo 'fi' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8278. echo 'exit 0' >> /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8279. chmod +x /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8280. echo 'create_upgrade_script' >> $COMPLETION_FILE
  8281. }
  8282. function intrusion_detection {
  8283. if grep -Fxq "intrusion_detection" $COMPLETION_FILE; then
  8284. return
  8285. fi
  8286. apt-get -y install tripwire
  8287. apt-get -y autoremove
  8288. cd /etc/tripwire
  8289. cp site.key $DEFAULT_DOMAIN_NAME-site.key
  8290. echo ''
  8291. echo ''
  8292. echo '*** Installing intrusion detection. Press Enter when asked for the local and site passphrases. ***'
  8293. echo ''
  8294. echo ''
  8295. tripwire --init
  8296. # make a script for easy resetting of the tripwire
  8297. echo '#!/bin/sh' > /usr/bin/reset-tripwire
  8298. echo 'tripwire --update-policy --secure-mode low /etc/tripwire/twpol.txt' >> /usr/bin/reset-tripwire
  8299. chmod +x /usr/bin/reset-tripwire
  8300. reset-tripwire
  8301. sed -i 's/SYSLOGREPORTING.*/SYSLOGREPORTING =false/g' /etc/tripwire/twcfg.txt
  8302. sed -i '/# These files change the behavior of the root account/,/}/ s/.*//g' /etc/tripwire/twpol.txt
  8303. sed -i 's|/etc/rc.boot.*||g' /etc/tripwire/twpol.txt
  8304. # Don't show any changes to /proc
  8305. sed -i 's|/proc.*||g' /etc/tripwire/twpol.txt
  8306. # Don't report log changes
  8307. sed -i 's|/var/log.*||g' /etc/tripwire/twpol.txt
  8308. # Ignore /etc/tripwire
  8309. if ! grep -q "!/etc/tripwire" /etc/tripwire/twpol.txt; then
  8310. sed -i '\|/etc\t\t->.*|a\ !/etc/tripwire;' /etc/tripwire/twpol.txt
  8311. fi
  8312. # Avoid logging the changed database
  8313. sed -i 's|$(TWETC)/tw.pol.*||g' /etc/tripwire/twpol.txt
  8314. reset-tripwire
  8315. echo 'intrusion_detection' >> $COMPLETION_FILE
  8316. }
  8317. # see https://trac.torproject.org/projects/tor/wiki/doc/TransparentProxy
  8318. # Local Redirection and Anonymizing Middlebox
  8319. function route_outgoing_traffic_through_tor {
  8320. if grep -Fxq "route_outgoing_traffic_through_tor" $COMPLETION_FILE; then
  8321. return
  8322. fi
  8323. if [[ $ROUTE_THROUGH_TOR != "yes" ]]; then
  8324. return
  8325. fi
  8326. apt-get -y install tor tor-arm
  8327. ### set variables
  8328. # Destinations you don't want routed through Tor
  8329. _non_tor="192.168.1.0/24 192.168.0.0/24"
  8330. # The user that Tor runs as
  8331. _tor_uid="debian-tor"
  8332. # Tor's TransPort
  8333. _trans_port="9040"
  8334. # Your internal interface
  8335. _int_if="eth0"
  8336. ### Set iptables *nat
  8337. iptables -t nat -A OUTPUT -o lo -j RETURN
  8338. iptables -t nat -A OUTPUT -m owner --uid-owner $_tor_uid -j RETURN
  8339. iptables -t nat -A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 53
  8340. # Allow clearnet access for hosts in $_non_tor
  8341. for _clearnet in $_non_tor; do
  8342. iptables -t nat -A OUTPUT -d $_clearnet -j RETURN
  8343. iptables -t nat -A PREROUTING -i $_int_if -d $_clearnet -j RETURN
  8344. done
  8345. # Redirect all other pre-routing and output to Tor
  8346. iptables -t nat -A OUTPUT -p tcp --syn -j REDIRECT --to-ports $_trans_port
  8347. iptables -t nat -A PREROUTING -i $_int_if -p udp --dport 53 -j REDIRECT --to-ports 53
  8348. iptables -t nat -A PREROUTING -i $_int_if -p tcp --syn -j REDIRECT --to-ports $_trans_port
  8349. ### set iptables *filter
  8350. iptables -A OUTPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
  8351. # Allow clearnet access for hosts in $_non_tor
  8352. for _clearnet in $_non_tor 127.0.0.0/8; do
  8353. iptables -A OUTPUT -d $_clearnet -j ACCEPT
  8354. done
  8355. # Allow only Tor output
  8356. iptables -A OUTPUT -m owner --uid-owner $_tor_uid -j ACCEPT
  8357. iptables -A OUTPUT -j REJECT
  8358. save_firewall_settings
  8359. if ! grep -q "fs.file-max" /etc/sysctl.conf; then
  8360. echo "fs.file-max=100000" >> /etc/sysctl.conf
  8361. /sbin/sysctl -p
  8362. fi
  8363. echo 'domain localdomain' > /etc/resolv.conf
  8364. echo 'search localdomain' >> /etc/resolv.conf
  8365. echo 'nameserver 127.0.0.1' >> /etc/resolv.conf
  8366. if ! grep -q "VirtualAddrNetworkIPv4" /etc/tor/torrc; then
  8367. echo 'VirtualAddrNetworkIPv4 10.192.0.0/10' >> /etc/tor/torrc
  8368. fi
  8369. if ! grep -q "AutomapHostsOnResolve" /etc/tor/torrc; then
  8370. echo 'AutomapHostsOnResolve 1' >> /etc/tor/torrc
  8371. fi
  8372. if ! grep -q "TransPort" /etc/tor/torrc; then
  8373. echo 'TransPort 9040' >> /etc/tor/torrc
  8374. fi
  8375. if ! grep -q "TransListenAddress 127.0.0.1" /etc/tor/torrc; then
  8376. echo 'TransListenAddress 127.0.0.1' >> /etc/tor/torrc
  8377. fi
  8378. if ! grep -q "TransListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" /etc/tor/torrc; then
  8379. echo "TransListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/tor/torrc
  8380. fi
  8381. if ! grep -q "DNSPort" /etc/tor/torrc; then
  8382. echo 'DNSPort 53' >> /etc/tor/torrc
  8383. fi
  8384. if ! grep -q "DNSListenAddress 127.0.0.1" /etc/tor/torrc; then
  8385. echo 'DNSListenAddress 127.0.0.1' >> /etc/tor/torrc
  8386. fi
  8387. if ! grep -q "DNSListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" /etc/tor/torrc; then
  8388. echo "DNSListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/tor/torrc
  8389. fi
  8390. echo 'route_outgoing_traffic_through_tor' >> $COMPLETION_FILE
  8391. }
  8392. # A command to create a git repository for a project
  8393. function create_git_project {
  8394. if grep -Fxq "create_git_project" $COMPLETION_FILE; then
  8395. return
  8396. fi
  8397. apt-get -y install git
  8398. echo '#!/bin/bash' > /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8399. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8400. echo 'GIT_PROJECT_NAME=$1' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8401. echo 'if [ ! $GIT_PROJECT_NAME ]; then' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8402. echo ' echo "Please specify a project name, without any spaces"' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8403. echo ' exit 1' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8404. echo 'fi' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8405. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8406. echo 'if [ ! -d /home/$USER/projects/$GIT_PROJECT_NAME ]; then' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8407. echo ' mkdir -p /home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8408. echo 'fi' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8409. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8410. echo 'cd /home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8411. echo 'git init --bare' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8412. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8413. echo -n 'echo "Your project has been created, ' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8414. echo 'use the following command to clone the repository"' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8415. echo -n " git clone ssh://$MY_USERNAME@$DEFAULT_DOMAIN_NAME:$SSH_PORT" >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8416. echo '/home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8417. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8418. echo 'exit 0' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8419. chmod +x /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8420. echo 'create_git_project' >> $COMPLETION_FILE
  8421. }
  8422. # Create daily backups of any projects on Github
  8423. # Then if Github goes away, turns evil, is censored or has
  8424. # outages then you still have access to your projects
  8425. function backup_github_projects {
  8426. if grep -Fxq "backup_github_projects" $COMPLETION_FILE; then
  8427. return
  8428. fi
  8429. if [ ! $GITHUB_USERNAME ]; then
  8430. return 731
  8431. fi
  8432. if [ ! $GITHUB_BACKUP_DIRECTORY ]; then
  8433. return 732
  8434. fi
  8435. apt-get -y install git
  8436. # create a github backups directory if needed
  8437. if [ ! -d $GITHUB_BACKUP_DIRECTORY ]; then
  8438. mkdir -p $GITHUB_BACKUP_DIRECTORY
  8439. fi
  8440. # get the backup utility
  8441. cd $INSTALL_DIR
  8442. git clone https://github.com/josegonzalez/python-github-backup
  8443. # install it
  8444. cd $INSTALL_DIR/python-github-backup
  8445. python setup.py install
  8446. # add a daily cron entry
  8447. echo '#!/bin/bash' > /etc/cron.daily/github
  8448. echo "github-backup $GITHUB_USERNAME -o $GITHUB_BACKUP_DIRECTORY --repositories" >> /etc/cron.daily/github
  8449. echo 'exit 0' >> /etc/cron.daily/github
  8450. chmod +x /etc/cron.daily/github
  8451. # do an initial backup
  8452. /etc/cron.daily/github
  8453. echo 'backup_github_projects' >> $COMPLETION_FILE
  8454. }
  8455. function install_dynamicdns {
  8456. if grep -Fxq "install_dynamicdns" $COMPLETION_FILE; then
  8457. return
  8458. fi
  8459. # Here we compile from source because the current package
  8460. # doesn't support https, which could result in passwords
  8461. # being leaked
  8462. apt-get -y install build-essential curl libgnutls28-dev automake1.11
  8463. git clone https://github.com/bashrc/inadyn $INSTALL_DIR/inadyn
  8464. if [ ! -d $INSTALL_DIR/inadyn ]; then
  8465. echo 'inadyn repo not cloned'
  8466. exit 6785
  8467. fi
  8468. cd $INSTALL_DIR/inadyn
  8469. ./configure
  8470. if [ ! "$?" = "0" ]; then
  8471. exit 74890
  8472. fi
  8473. USE_OPENSSL=1 make
  8474. if [ ! "$?" = "0" ]; then
  8475. exit 74858
  8476. fi
  8477. make install
  8478. if [ ! "$?" = "0" ]; then
  8479. exit 3785
  8480. fi
  8481. # create an unprivileged user
  8482. #useradd -r -s /bin/false debian-inadyn
  8483. # create a configuration file
  8484. echo 'background' > /etc/inadyn.conf
  8485. echo 'verbose 1' >> /etc/inadyn.conf
  8486. echo 'period 300' >> /etc/inadyn.conf
  8487. echo 'startup-delay 60' >> /etc/inadyn.conf
  8488. echo 'cache-dir /run/inadyn' >> /etc/inadyn.conf
  8489. chmod 600 /etc/inadyn.conf
  8490. echo '[Unit]' > /etc/systemd/system/inadyn.service
  8491. echo 'Description=inadyn (DynDNS updater)' >> /etc/systemd/system/inadyn.service
  8492. echo 'After=network.target' >> /etc/systemd/system/inadyn.service
  8493. echo '' >> /etc/systemd/system/inadyn.service
  8494. echo '[Service]' >> /etc/systemd/system/inadyn.service
  8495. echo 'ExecStart=/usr/local/sbin/inadyn --config /etc/inadyn.conf' >> /etc/systemd/system/inadyn.service
  8496. echo 'Restart=always' >> /etc/systemd/system/inadyn.service
  8497. echo 'Type=forking' >> /etc/systemd/system/inadyn.service
  8498. echo '' >> /etc/systemd/system/inadyn.service
  8499. echo '[Install]' >> /etc/systemd/system/inadyn.service
  8500. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/inadyn.service
  8501. systemctl enable inadyn
  8502. systemctl restart inadyn
  8503. systemctl daemon-reload
  8504. echo 'install_dynamicdns' >> $COMPLETION_FILE
  8505. }
  8506. function get_voip_server_password {
  8507. if [ -f /home/$MY_USERNAME/README ]; then
  8508. if grep -q "VoIP server password" /home/$MY_USERNAME/README; then
  8509. if [ ! $VOIP_SERVER_PASSWORD ]; then
  8510. VOIP_SERVER_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "VoIP server password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  8511. fi
  8512. fi
  8513. fi
  8514. }
  8515. function install_voip {
  8516. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  8517. return
  8518. fi
  8519. if grep -Fxq "install_voip" $COMPLETION_FILE; then
  8520. return
  8521. fi
  8522. apt-get -y install mumble-server
  8523. get_voip_server_password
  8524. if [ ! $VOIP_SERVER_PASSWORD ]; then
  8525. VOIP_SERVER_PASSWORD=$(openssl rand -base64 16)
  8526. fi
  8527. if [ ${#VOIP_SERVER_PASSWORD} -lt $MINIMUM_PASSWORD_LENGTH ]; then
  8528. VOIP_SERVER_PASSWORD=$(openssl rand -base64 16)
  8529. fi
  8530. # Make an ssl cert for the server
  8531. if [ ! -f /etc/ssl/certs/mumble.dhparam ]; then
  8532. freedombone-addcert -h mumble
  8533. check_certificates mumble
  8534. fi
  8535. # Check that the cert was created
  8536. if [ ! -f /etc/ssl/certs/mumble.crt ]; then
  8537. echo 'VoIP server certificate not created'
  8538. exit 57892
  8539. fi
  8540. if [ ! -f /etc/ssl/private/mumble.key ]; then
  8541. echo 'VoIP server key not created'
  8542. exit 57893
  8543. fi
  8544. sed -i "s|welcometext=.*|welcometext=\"<br />Welcome to $DEFAULT_DOMAIN_NAME <b>VoIP</b>.<br />Chat freely!<br />\"|g" /etc/mumble-server.ini
  8545. if [ $VOIP_SERVER_PASSWORD ]; then
  8546. sed -i "s|serverpassword=.*|serverpassword=$VOIP_SERVER_PASSWORD|g" /etc/mumble-server.ini
  8547. fi
  8548. sed -i 's|#autobanAttempts.*|autobanAttempts = 10|g' /etc/mumble-server.ini
  8549. sed -i 's|#autobanTimeframe.*|autobanTimeframe = 120|g' /etc/mumble-server.ini
  8550. sed -i 's|#autobanTime.*|autobanTime = 300|g' /etc/mumble-server.ini
  8551. sed -i 's|#sendversion=.*|sendversion=False|g' /etc/mumble-server.ini
  8552. sed -i 's|sendversion=.*|sendversion=False|g' /etc/mumble-server.ini
  8553. if ! grep -q "allowping" /etc/mumble-server.ini; then
  8554. echo 'allowping=False' >> /etc/mumble-server.ini
  8555. fi
  8556. sed -i 's|allowping=.*|allowping=False|g' /etc/mumble-server.ini
  8557. sed -i 's|#sslCert=.*|sslCert=/etc/ssl/certs/mumble.crt|g' /etc/mumble-server.ini
  8558. sed -i 's|#sslKey=.*|sslKey=/etc/ssl/privare/mumble.key|g' /etc/mumble-server.ini
  8559. sed -i 's|#certrequired=.*|certrequired=True|g' /etc/mumble-server.ini
  8560. sed -i 's|users=100|users=10|g' /etc/mumble-server.ini
  8561. sed -i 's|#channelnestinglimit=10|channelnestinglimit=10|g' /etc/mumble-server.ini
  8562. sed -i 's|#textmessagelength=.*|textmessagelength=1000|g' /etc/mumble-server.ini
  8563. sed -i 's|textmessagelength=.*|textmessagelength=1000|g' /etc/mumble-server.ini
  8564. sed -i 's|#imagemessagelength=.*|imagemessagelength=131072|g' /etc/mumble-server.ini
  8565. sed -i 's|#allowhtml=.*|allowhtml=False|g' /etc/mumble-server.ini
  8566. sed -i 's|allowhtml=.*|allowhtml=False|g' /etc/mumble-server.ini
  8567. sed -i "s|port=.*|port=$VOIP_PORT|g" /etc/mumble-server.ini
  8568. service mumble-server restart
  8569. if ! grep -q "VoIP Server" /home/$MY_USERNAME/README; then
  8570. echo '' >> /home/$MY_USERNAME/README
  8571. echo '' >> /home/$MY_USERNAME/README
  8572. echo 'VoIP Server' >> /home/$MY_USERNAME/README
  8573. echo '===========' >> /home/$MY_USERNAME/README
  8574. echo 'VoIP server username: mumble-server' >> /home/$MY_USERNAME/README
  8575. echo "VoIP server password: $VOIP_SERVER_PASSWORD" >> /home/$MY_USERNAME/README
  8576. echo '' >> /home/$MY_USERNAME/README
  8577. echo 'To connect to the VoIP server use your username and the server password shown above.' >> /home/$MY_USERNAME/README
  8578. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  8579. fi
  8580. echo 'install_voip' >> $COMPLETION_FILE
  8581. }
  8582. function install_final {
  8583. if grep -Fxq "install_final" $COMPLETION_FILE; then
  8584. return
  8585. fi
  8586. # unmount any attached usb drive
  8587. if [ -d $USB_MOUNT ]; then
  8588. umount $USB_MOUNT
  8589. rm -rf $USB_MOUNT
  8590. fi
  8591. echo 'install_final' >> $COMPLETION_FILE
  8592. echo ''
  8593. echo ' *** Freedombone installation is complete. Rebooting... ***'
  8594. echo ''
  8595. if [ -f "/home/$MY_USERNAME/README" ]; then
  8596. echo "See /home/$MY_USERNAME/README for post-installation instructions."
  8597. echo ''
  8598. fi
  8599. reboot
  8600. }
  8601. read_configuration
  8602. parse_args
  8603. check_domains
  8604. install_not_on_BBB
  8605. remove_default_user
  8606. configure_firewall
  8607. configure_firewall_for_ssh
  8608. configure_firewall_for_dns
  8609. configure_firewall_for_ftp
  8610. configure_firewall_for_web_access
  8611. configure_firewall_for_cjdns
  8612. configure_firewall_for_voip
  8613. remove_proprietary_repos
  8614. change_debian_repos
  8615. enable_backports
  8616. configure_dns
  8617. install_dynamicdns
  8618. randomize_cron
  8619. create_freedns_updater
  8620. initial_setup
  8621. enforce_good_passwords
  8622. install_editor
  8623. change_login_message
  8624. update_the_kernel
  8625. enable_zram
  8626. random_number_generator
  8627. set_your_domain_name
  8628. time_synchronisation
  8629. configure_internet_protocol
  8630. create_git_project
  8631. mesh_cjdns
  8632. mesh_cjdns_tools
  8633. backup_github_projects
  8634. configure_ssh
  8635. remove_instructions_from_motd
  8636. check_hwrng
  8637. search_for_attached_usb_drive
  8638. regenerate_ssh_keys
  8639. create_upgrade_script
  8640. route_outgoing_traffic_through_tor
  8641. install_watchdog_script
  8642. configure_email
  8643. create_procmail
  8644. spam_filtering
  8645. configure_imap
  8646. #configure_imap_client_certs
  8647. configure_gpg
  8648. encrypt_incoming_email
  8649. encrypt_outgoing_email
  8650. email_client
  8651. email_archiving
  8652. email_from_address
  8653. configure_firewall_for_email
  8654. create_public_mailing_list
  8655. #create_private_mailing_list
  8656. encrypt_all_email
  8657. import_email
  8658. script_for_attaching_usb_drive
  8659. install_web_server
  8660. configure_firewall_for_web_server
  8661. install_owncloud
  8662. install_owncloud_music_app
  8663. install_gogs
  8664. install_xmpp
  8665. configure_firewall_for_xmpp
  8666. install_irc_server
  8667. configure_firewall_for_irc
  8668. install_voip
  8669. install_wiki
  8670. install_blog
  8671. install_gnu_social
  8672. install_redmatrix
  8673. install_dlna_server
  8674. configure_firewall_for_dlna
  8675. install_mediagoblin
  8676. repair_databases_script
  8677. create_backup_script
  8678. create_restore_script
  8679. backup_to_friends_servers
  8680. restore_from_friend
  8681. intrusion_detection
  8682. install_final
  8683. echo 'Freedombone installation is complete'
  8684. exit 0