freedombone 538KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484
  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-2016 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 Affero 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 Affero General Public License for more details.
  27. #
  28. # You should have received a copy of the GNU Affero General Public License
  29. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  30. NO_OF_ARGS=$#
  31. PROJECT_NAME='freedombone'
  32. export TEXTDOMAIN=$PROJECT_NAME
  33. export TEXTDOMAINDIR="/usr/share/locale"
  34. DEFAULT_LANGUAGE=$(echo $LANG)
  35. # username created by default within a debian image
  36. GENERIC_IMAGE_USERNAME='fbone'
  37. # Web site
  38. PROJECT_WEBSITE="http://${PROJECT_NAME}.uk.to"
  39. # Repo
  40. PROJECT_REPO="https://github.com/bashrc/${PROJECT_NAME}"
  41. # default search engine for command line browser
  42. DEFAULT_SEARCH='https://searx.laquadrature.net'
  43. # Are we installing on a Beaglebone Black (BBB) or some other system?
  44. INSTALLING_ON_BBB="no"
  45. # Version number of this script
  46. VERSION="1.01"
  47. # if yes then this minimises the number of descisions presented during install
  48. MINIMAL_INSTALL="yes"
  49. # Whether web sites will be .onion addresses only
  50. ONION_ONLY="no"
  51. # Different system variants which may be specified within
  52. # the SYSTEM_TYPE option
  53. VARIANT_FULL="full"
  54. VARIANT_WRITER="writer"
  55. VARIANT_CLOUD="cloud"
  56. VARIANT_CHAT="chat"
  57. VARIANT_MAILBOX="mailbox"
  58. VARIANT_NONMAILBOX="nonmailbox"
  59. VARIANT_SOCIAL="social"
  60. VARIANT_MEDIA="media"
  61. VARIANT_DEVELOPER="developer"
  62. VARIANT_MESH="mesh"
  63. DEFAULT_DOMAIN_NAME=
  64. DEFAULT_DOMAIN_CODE=
  65. MY_USERNAME=
  66. SYSTEM_TYPE=$VARIANT_FULL
  67. # whether the system is being installed from a pre-created configuration file
  68. INSTALLING_FROM_CONFIGURATION_FILE="no"
  69. # An optional configuration file which overrides some of these variables
  70. CONFIGURATION_FILE="${PROJECT_NAME}.cfg"
  71. SSH_PORT=2222
  72. IRC_PORT=6697
  73. IRC_ONION_PORT=6697
  74. GO_VERSION=1.5
  75. # password used for accessing your repo mirrors
  76. MY_MIRRORS_PASSWORD=
  77. # friend's repo mirrors
  78. FRIENDS_MIRRORS_PASSWORD=
  79. FRIENDS_MIRRORS_SERVER=
  80. FRIENDS_MIRRORS_SSH_PORT=2222
  81. # This isn't used here, but is included for mirrors creation purposes
  82. LETSENCRYPT_REPO="https://github.com/letsencrypt/letsencrypt"
  83. # An optional password to log into IRC. This applies to all users
  84. IRC_PASSWORD=
  85. # If this file exists it contains a global password used with
  86. # disk image installs. This simplifies password management for
  87. # deployment at scale
  88. IMAGE_PASSWORD_FILE=/root/login.txt
  89. # parameters used when adding a new domain
  90. DDNS_PROVIDER="default@freedns.afraid.org"
  91. DDNS_USERNAME=
  92. DDNS_PASSWORD=
  93. EXIM_ONION_REPO="https://github.com/petterreinholdtsen/exim4-smtorp"
  94. NGINX_ENSITE_REPO="https://github.com/perusio/nginx_ensite"
  95. NGINX_ENSITE_COMMIT='fa4d72ce1c0a490442c8474e9c8dc21ed52c93d0'
  96. CLEANUP_MAILDIR_REPO="https://github.com/bashrc/cleanup-maildir"
  97. CLEANUP_MAILDIR_COMMIT='33241d2e3861f901ba17f5c77ada007e1ec06a86'
  98. INADYN_REPO="https://github.com/bashrc/inadyn"
  99. INADYN_COMMIT='fadbe17f520d337dfb8d69ee4bf1fcaa23fce0d6'
  100. # Minimum number of characters in a password
  101. MINIMUM_PASSWORD_LENGTH=10
  102. # number of CPU cores
  103. CPU_CORES=1
  104. # If the system is on an IPv6 network
  105. IPV6_NETWORK='2001:470:26:307'
  106. # The static IP address of the system within the local network
  107. # By default the IP address is dynamic within your LAN
  108. LOCAL_NETWORK_STATIC_IP_ADDRESS=
  109. # IP address of the router (gateway)
  110. ROUTER_IP_ADDRESS="192.168.1.254"
  111. # DNS
  112. NAMESERVER1='213.73.91.35'
  113. NAMESERVER2='85.214.20.141'
  114. # whether to route outgoing traffic through Tor
  115. ROUTE_THROUGH_TOR="no"
  116. # Why use Google as a time source?
  117. # The thinking here is that it's likely to be reliable and fast.
  118. # The ping doesn't reveal any information other than that the server
  119. # is running, and if anyone maliciously alters the time on Google's
  120. # servers then that would certainly be newsworthy and they'd be
  121. # likely to do something about it quickly.
  122. # If you have better time sources then change them here.
  123. TLS_TIME_SOURCE1="google.com"
  124. TLS_TIME_SOURCE2="www.ptb.de"
  125. # The type of hardware random number generator being used
  126. # This can be empty, "beaglebone" or "onerng"
  127. HWRNG_TYPE=
  128. # Download location for OneRNG driver
  129. ONERNG_PACKAGE="onerng_3.4-1_all.deb"
  130. ONERNG_PACKAGE_DOWNLOAD="https://github.com/OneRNG/onerng.github.io/blob/master/sw/$ONERNG_PACKAGE?raw=true"
  131. # Hash for OneRNG driver
  132. ONERNG_PACKAGE_HASH='78f1c2f52ae573e3b398a695ece7ab9f41868252657ea269f0d5cf0bd4f2eb59'
  133. # device name for OneRNG
  134. ONERNG_DEVICE='ttyACM0'
  135. # Whether this system is being installed within a docker container
  136. INSTALLED_WITHIN_DOCKER="no"
  137. # If you want to run a public mailing list specify its name here.
  138. # There should be no spaces in the name
  139. PUBLIC_MAILING_LIST=
  140. # Optional different domain name for the public mailing list
  141. PUBLIC_MAILING_LIST_DOMAIN_NAME=
  142. # Directory where the public mailing list data is stored
  143. PUBLIC_MAILING_LIST_DIRECTORY="/var/spool/mlmmj"
  144. # If you want to run an encrypted mailing list specify its name here.
  145. # There should be no spaces in the name
  146. PRIVATE_MAILING_LIST=
  147. # Domain name for mediagoblin installation
  148. MEDIAGOBLIN_DOMAIN_NAME=
  149. MEDIAGOBLIN_CODE=
  150. MEDIAGOBLIN_REPO="git://git.savannah.gnu.org/mediagoblin.git"
  151. MEDIAGOBLIN_COMMIT='d1ac2d52fd8859c3f32fa38e4836ffe9615e5bba'
  152. MEDIAGOBLIN_ADMIN_PASSWORD=
  153. MEDIAGOBLIN_ONION_PORT=8096
  154. #mediadrop
  155. MEDIA_SERVER_DOMAIN_NAME=
  156. MEDIA_SERVER_CODE=
  157. MEDIA_SERVER_BASE_DIRECTORY=/var/www/media
  158. MEDIA_SERVER_WORKING_DIRECTORY=${MEDIA_SERVER_BASE_DIRECTORY}/mediadrop
  159. MEDIA_SERVER_REPO="https://github.com/mediadrop/mediadrop"
  160. MEDIA_SERVER_COMMIT='ad44f47d99b5d57d3396a3afb80d68a4a182dadd'
  161. MEDIA_SERVER_ONION_PORT=8098
  162. MEDIA_SERVER_ADMIN_PASSWORD=
  163. # Domain name for microblog installation
  164. MICROBLOG_DOMAIN_NAME=
  165. MICROBLOG_CODE=
  166. MICROBLOG_ONION_PORT=8087
  167. MICROBLOG_REPO="https://git.gnu.io/gnu/gnu-social.git"
  168. MICROBLOG_COMMIT='c67b89e56bf0f90730a9e22beca7e1bd41fc26c3'
  169. MICROBLOG_ADMIN_PASSWORD=
  170. MICROBLOG_THEME_REPO="https://git.gnu.io/h2p/Qvitter.git"
  171. MICROBLOG_THEME_COMMIT='34510bcf37c727f91afad789fb0a531a45171ccf'
  172. MICROBLOG_WELCOME_MESSAGE=$'<h1>Welcome to GNU Social – a federated microblog</h1><p>Another Freedombone site</p>'
  173. MICROBLOG_BACKGROUND_IMAGE_URL=
  174. MICROBLOG_MARKDOWN_REPO="https://git.gnu.io/chimo/markdown.git"
  175. MICROBLOG_MARKDOWN_COMMIT='03c53942f94b3376f0946e6e1fe566cc21ccf232'
  176. # Sharings plugin for the microblog
  177. SHARINGS_REPO="http://git.lasindias.club/bashrc/Sharings"
  178. SHARINGS_COMMIT='d5c6c7f855d9afff9086c09ea706f38c859bc0d4'
  179. SHARINGS_THEME_REPO="http://git.lasindias.club/manuel/SharingsTheme"
  180. SHARINGS_THEME_COMMIT='7106c7ef03'
  181. # Domain name for hubzilla installation
  182. HUBZILLA_DOMAIN_NAME=
  183. HUBZILLA_CODE=
  184. HUBZILLA_ONION_PORT=8085
  185. HUBZILLA_REPO="https://github.com/redmatrix/hubzilla.git"
  186. HUBZILLA_THEMES_REPO="https://github.com/DeadSuperHero/redmatrix-themes"
  187. HUBZILLA_ADDONS_REPO="https://github.com/redmatrix/hubzilla-addons.git"
  188. HUBZILLA_ADMIN_PASSWORD=
  189. HUBZILLA_COMMIT='2d79e75788aa71664a379c4cea0b6bfe3ab87ad0'
  190. HUBZILLA_ADDONS_COMMIT='67b40c7a40f328a93ee030eb15e9e1261f3cba64'
  191. # roundcube webmail
  192. WEBMAIL_REPO="https://github.com/roundcube/roundcubemail"
  193. WEBMAIL_COMMIT='78cf9c2e5cff2d78cd8beb647d60570f195a2a9c'
  194. WEBMAIL_ONION_HOSTNAME=
  195. WEBMAIL_ONION_PORT=8097
  196. WEBMAIL_ADMIN_PASSWORD=
  197. # Domain name for git hosting installation
  198. GIT_DOMAIN_NAME=
  199. GIT_CODE=
  200. GIT_ONION_PORT=8090
  201. GIT_DOMAIN_REPO="https://github.com/gogits/gogs"
  202. GIT_ADMIN_PASSWORD=
  203. GOGS_COMMIT='3fb4f7f4980b4339fd9ef6a3ba5b0acab83d264d'
  204. GO_PACKAGE_MANAGER_REPO="https://github.com/gpmgo/gopm"
  205. GVM_HOME=/home/git/gvm
  206. GVM_REPO="https://github.com/moovweb/gvm"
  207. GVM_COMMIT='25ea8ae158e2861c92e2b22c458e60840157832f'
  208. # Syncthing
  209. SYNCTHING_ID=
  210. SYNCTHING_CONFIG_PATH=/root/.config/syncthing
  211. SYNCTHING_CONFIG_FILE=$SYNCTHING_CONFIG_PATH/config.xml
  212. SYNCTHING_RELAY_SERVER='https://relays.syncthing.net/endpoint'
  213. SYNCTHING_RELEASES='https://api.github.com/repos/syncthing/syncthing/releases?per_page=30'
  214. SYNCTHING_PORT=22000
  215. SYNCTHING_SHARED_DATA=/var/lib/syncthing/SyncShared
  216. SYNCTHING_USER_IDS_FILE='.syncthingids'
  217. # Domain name for your wiki
  218. WIKI_DOMAIN_NAME=
  219. WIKI_ADMIN_PASSWORD=
  220. WIKI_TITLE="${PROJECT_NAME} Wiki"
  221. WIKI_CODE=
  222. WIKI_ONION_PORT=8089
  223. # Domain name for your blog
  224. FULLBLOG_DOMAIN_NAME=
  225. FULLBLOG_CODE=
  226. FULLBLOG_ONION_PORT=8086
  227. FULLBLOG_REPO="https://github.com/danpros/htmly"
  228. FULLBLOG_COMMIT='bf5fe9486160be4da86d8987d3e5c977e1dc6d32'
  229. MY_BLOG_TITLE="My Blog"
  230. MY_BLOG_SUBTITLE="Another ${PROJECT_NAME} Blog"
  231. # search engine
  232. SEARCH_ENGINE_REPO="https://github.com/asciimoo/searx"
  233. SEARCH_ENGINE_COMMIT='fee556c9904637051a9ba874ba7e71cd9f10789f'
  234. SEARCH_ENGINE_PATH=/etc
  235. SEARCH_ENGINE_ONION_PORT=8094
  236. SEARCH_ENGINE_ONION_HOSTNAME=
  237. SEARCH_ENGINE_LOGIN_TEXT=$"Search engine login"
  238. SEARCH_ENGINE_PASSWORD=
  239. GPG_KEYSERVER="hkp://keys.gnupg.net"
  240. # whether to encrypt all incoming email with your public key
  241. GPG_ENCRYPT_STORED_EMAIL="yes"
  242. # gets set to yes if gpg keys are imported from usb
  243. GPG_KEYS_IMPORTED="no"
  244. # optionally you can provide your exported GPG key pair here
  245. # Note that the private key file will be deleted after use
  246. # If these are unspecified then a new GPG key will be created
  247. MY_GPG_PUBLIC_KEY=
  248. MY_GPG_PRIVATE_KEY=
  249. # optionally specify your public key ID
  250. MY_GPG_PUBLIC_KEY_ID=
  251. # If you have existing mail within a Maildir
  252. # you can specify the directory here and the files
  253. # will be imported
  254. IMPORT_MAILDIR=
  255. # The Debian package repository to use.
  256. DEBIAN_REPO="ftp.us.debian.org"
  257. DEBIAN_VERSION="jessie"
  258. # Directory where source code is downloaded and compiled
  259. INSTALL_DIR=$HOME/build
  260. # device name for an attached usb drive
  261. USB_DRIVE=/dev/sda1
  262. # Location where the USB drive is mounted to
  263. USB_MOUNT=/mnt/usb
  264. # name of a script used to upgrade the system
  265. UPGRADE_SCRIPT_NAME="${PROJECT_NAME}-upgrade"
  266. # name of a script which keeps running processes going even if they crash
  267. WATCHDOG_SCRIPT_NAME="keepon"
  268. # Number of days to keep backups for
  269. BACKUP_MAX_DAYS=30
  270. # memory limit for php in MB
  271. MAX_PHP_MEMORY=64
  272. # default MariaDB password
  273. MARIADB_PASSWORD=
  274. # Directory where XMPP settings are stored
  275. XMPP_DIRECTORY="/var/lib/prosody"
  276. XMPP_PASSWORD=
  277. # file containing a list of remote locations to backup to
  278. # Format: [username@friendsdomain//home/username] [ssh_password]
  279. # With the only space character being between the server and the password
  280. FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
  281. # list of encryption protocols
  282. SSL_PROTOCOLS="TLSv1 TLSv1.1 TLSv1.2"
  283. # list of ciphers to use. See bettercrypto.org recommendations
  284. SSL_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"
  285. # ssh (from https://stribika.github.io/2015/01/04/secure-secure-shell.html)
  286. SSH_CIPHERS="chacha20-poly1305@openssh.com,aes256-gcm@openssh.com,aes128-gcm@openssh.com,aes256-ctr,aes192-ctr,aes128-ctr"
  287. 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"
  288. SSH_KEX="curve25519-sha256@libssh.org,diffie-hellman-group-exchange-sha256"
  289. 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"
  290. # xmpp ciphers and curve
  291. 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"'
  292. XMPP_ECC_CURVE='"secp384r1"'
  293. # the default email address
  294. MY_EMAIL_ADDRESS=$MY_USERNAME@$DEFAULT_DOMAIN_NAME
  295. # optionally specify your name to appear on the blog
  296. MY_NAME=$DEFAULT_DOMAIN_NAME
  297. export DEBIAN_FRONTEND=noninteractive
  298. # logging level for Nginx
  299. WEBSERVER_LOG_LEVEL='warn'
  300. # used to limit CPU usage
  301. CPULIMIT='/usr/bin/cpulimit -l 20 -e'
  302. # command to create a git repository
  303. CREATE_GIT_PROJECT_COMMAND='create-project'
  304. # File which keeps track of what has already been installed
  305. COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt
  306. # Used to indicate whether the backup contains MariaDB databases or not
  307. BACKUP_INCLUDES_DATABASES="no"
  308. # contains the mysql root password which
  309. # is used for backups and repair
  310. DATABASE_PASSWORD_FILE=/root/dbpass
  311. # log file where details of remote backups are stored
  312. REMOTE_BACKUPS_LOG=/var/log/remotebackups.log
  313. # message if something fails to install
  314. 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."
  315. # web site used to obtain the external IP address of the system
  316. GET_IP_ADDRESS_URL="checkip.two-dns.de"
  317. # Password used for VoIP server
  318. VOIP_SERVER_PASSWORD=
  319. # Port on which VoIP server listens
  320. VOIP_PORT=64738
  321. SIP_SERVER_PASSWORD=
  322. SIP_PORT=5060
  323. SIP_TLS_PORT=5061
  324. VOIP_TURN_PORT=3478
  325. VOIP_TURN_TLS_PORT=5349
  326. VOIP_TURN_NONCE=
  327. # Location of VoIP database and configuration
  328. VOIP_DATABASE="mumble-server.sqlite"
  329. VOIP_CONFIG_FILE="mumble-server.ini"
  330. # other possible services to obtain the external IP address
  331. EXTERNAL_IP_SERVICES=( \
  332. 'https://check.torproject.org/' \
  333. 'https://www.whatsmydns.net/whats-my-ip-address.html' \
  334. 'https://www.privateinternetaccess.com/pages/whats-my-ip/' \
  335. 'http://checkip.two-dns.de' \
  336. 'http://ip.dnsexit.com' \
  337. 'http://ifconfig.me/ip' \
  338. 'http://ipecho.net/plain' \
  339. 'http://checkip.dyndns.org/plain' \
  340. 'http://ipogre.com/linux.php' \
  341. 'http://whatismyipaddress.com/' \
  342. 'http://ip.my-proxy.com/' \
  343. 'http://websiteipaddress.com/WhatIsMyIp' \
  344. 'http://getmyipaddress.org/' \
  345. 'http://www.my-ip-address.net/' \
  346. 'http://myexternalip.com/raw' \
  347. 'http://www.canyouseeme.org/' \
  348. 'http://www.trackip.net/' \
  349. 'http://icanhazip.com/' \
  350. 'http://www.iplocation.net/' \
  351. 'http://www.howtofindmyipaddress.com/' \
  352. 'http://www.ipchicken.com/' \
  353. 'http://whatsmyip.net/' \
  354. 'http://www.ip-adress.com/' \
  355. 'http://checkmyip.com/' \
  356. 'http://www.tracemyip.org/' \
  357. 'http://checkmyip.net/' \
  358. 'http://www.lawrencegoetz.com/programs/ipinfo/' \
  359. 'http://www.findmyip.co/' \
  360. 'http://ip-lookup.net/' \
  361. 'http://www.dslreports.com/whois' \
  362. 'http://www.mon-ip.com/en/my-ip/' \
  363. 'http://www.myip.ru' \
  364. 'http://ipgoat.com/' \
  365. 'http://www.myipnumber.com/my-ip-address.asp' \
  366. 'http://www.whatsmyipaddress.net/' \
  367. 'http://formyip.com/' \
  368. 'http://www.displaymyip.com/' \
  369. 'http://www.bobborst.com/tools/whatsmyip/' \
  370. 'http://www.geoiptool.com/' \
  371. 'http://checkip.dyndns.com/' \
  372. 'http://myexternalip.com/' \
  373. 'http://www.ip-adress.eu/' \
  374. 'http://www.infosniper.net/' \
  375. 'http://wtfismyip.com/' \
  376. 'http://ipinfo.io/' \
  377. 'http://httpbin.org/ip')
  378. WIFI_CHANNEL=2
  379. WIFI_INTERFACE=wlan0
  380. WIFI_TYPE='wpa2-psk'
  381. WIFI_SSID=
  382. WIFI_PASSPHRASE=
  383. WIFI_HOTSPOT='no'
  384. WIFI_NETWORKS_FILE=~/${PROJECT_NAME}-wifi.cfg
  385. # cjdns settings
  386. ENABLE_CJDNS="no"
  387. CJDNS_PRIVATE_KEY=
  388. CJDNS_PUBLIC_KEY=
  389. CJDNS_IPV6=
  390. CJDNS_PASSWORD=
  391. CJDNS_PORT=
  392. CJDNS_REPO="https://github.com/cjdelisle/cjdns.git"
  393. CJDNS_COMMIT='13189fde111d0500427a7a0ce06a970753527bca'
  394. CJDCMD_REPO="https://github.com/inhies/cjdcmd"
  395. CJDCMD_COMMIT='973cca6ed0eecf9041c3403a40193c0b1291b808'
  396. # B.A.T.M.A.N settings
  397. ENABLE_BATMAN="no"
  398. BATMAN_CELLID='any'
  399. # Babel mesh
  400. ENABLE_BABEL="no"
  401. BABEL_PORT=6696
  402. # social key management
  403. ENABLE_SOCIAL_KEY_MANAGEMENT="no"
  404. TOX_PORT=33445
  405. TOXCORE_REPO="git://github.com/irungentoo/toxcore.git"
  406. TOXCORE_COMMIT='532629d486e3361c7d8d95b38293cc7d61dc4ee5'
  407. TOXID_REPO="https://github.com/bashrc/toxid"
  408. TOX_BOOTSTRAP_ID_FILE=/var/lib/tox-bootstrapd/pubkey.txt
  409. # These are some default nodes, but you can replace them with trusted nodes
  410. # as you prefer. See https://wiki.tox.im/Nodes
  411. TOX_NODES=
  412. #TOX_NODES=(
  413. # '192.254.75.102,2607:5600:284::2,33445,951C88B7E75C867418ACDB5D273821372BB5BD652740BCDF623A4FA293E75D2F,Tox RELENG,US'
  414. # '144.76.60.215,2a01:4f8:191:64d6::1,33445,04119E835DF3E78BACF0F84235B300546AF8B936F035185E2A8E9E0A67C8924F,sonOfRa,DE'
  415. #)
  416. TOXIC_REPO="https://github.com/Tox/toxic"
  417. TOXIC_COMMIT='cf16849b374e484a33a4dffa3dfb937b59d537f2'
  418. TOXIC_FILE=/usr/local/bin/toxic
  419. ZERONET_REPO="https://github.com/HelloZeroNet/ZeroNet.git"
  420. ZERONET_COMMIT='675bd462556c541d65e2d95f91f899146a373aad'
  421. ZERONET_BLOG_REPO="https://github.com/HelloZeroNet/ZeroBlog"
  422. ZERONET_BLOG_COMMIT='bbb0d6c36465fed2e6df71f1aab45fcc9c6ad609'
  423. ZERONET_MAIL_REPO="https://github.com/HelloZeroNet/ZeroMail"
  424. ZERONET_MAIL_COMMIT='955af09d643c72b02e4983d71eca5c0c93a6c131'
  425. ZERONET_FORUM_REPO="https://github.com/HelloZeroNet/ZeroTalk"
  426. ZERONET_FORUM_COMMIT='e2d2c9cb1cfbfef91b244935efb5c14c2ad95faa'
  427. ZERONET_URL=http://127.0.0.1:43110
  428. ZERONET_PORT=15441
  429. TRACKER_PORT=6969
  430. ZERONET_DEFAULT_BLOG_TAGLINE="Blogging on the Mesh"
  431. ZERONET_DEFAULT_FORUM_TAGLINE="A decentralized discussion group"
  432. ZERONET_DEFAULT_MAIL_TAGLINE="Mail for the Mesh"
  433. # https://github.com/ipfs/go-ipfs
  434. IPFS_GO_REPO="https://github.com/ipfs/go-ipfs"
  435. IPFS_COMMIT='20b06a4cbce8884f5b194da6e98cb11f2c77f166'
  436. IPFS_PORT=4001
  437. GPGIT_REPO="https://github.com/mikecardwell/gpgit"
  438. GPGIT_COMMIT='583dc76119f19420f8a33f606744faa7c8922738'
  439. # Default diffie-hellman key length in bits
  440. DH_KEYLENGTH=2048
  441. # repo for atheros AR9271 wifi driver
  442. ATHEROS_WIFI_REPO="https://github.com/qca/open-ath9k-htc-firmware.git"
  443. # Whether Let's Encrypt is enabled for all sites
  444. LETSENCRYPT_ENABLED="no"
  445. LETSENCRYPT_SERVER='https://acme-v01.api.letsencrypt.org/directory'
  446. RSS_READER_REPO="https://tt-rss.org/git/tt-rss.git"
  447. RSS_READER_COMMIT='9e84bab449f9ed55e02e60378b0af1521026f3b8'
  448. RSS_READER_ADMIN_PASSWORD=
  449. RSS_READER_ONION_PORT=8092
  450. RSS_MOBILE_READER_ONION_PORT=8095
  451. RSS_READER_DOMAIN_NAME=ttrss
  452. RSS_MOBILE_READER_REPO="https://github.com/mboinet/ttrss-mobile"
  453. RSS_MOBILE_READER_COMMIT='d5242e1c269e9480ab3b66b7a38da3c892dfb326'
  454. RSS_READER_PATH=/etc/share/tt-rss
  455. RSS_READER_GNUSOCIAL_REPO="https://github.com/bashrc/ttrss-gnusocial"
  456. RSS_READER_GNUSOCIAL_COMMIT='8b92b8f5db7b0d12459c7bd86a50f48815efe642'
  457. # refresh gpg keys every few hours
  458. REFRESH_GPG_KEYS_HOURS=2
  459. function show_help {
  460. echo ''
  461. echo $"${PROJECT_NAME} -c [configuration file]"
  462. echo ''
  463. echo $' -h --help Show help'
  464. echo $' menuconfig Easy interactive installation'
  465. echo $' menuconfig-full Full interactive installation'
  466. echo $' menuconfig-onion Interactive installation for onion-only sites'
  467. echo $' -c --config Installing from a configuration file'
  468. echo $' --bbb Installing on Beaglebone Black'
  469. echo $' -u --user User to install the system as'
  470. echo $' -d --domain Default domain name'
  471. echo $' -s --system System type'
  472. echo $' --ip Static LAN IP address of the system'
  473. echo $' --iprouter LAN IP address of the internet router'
  474. echo $' --ddns Dynamic DNS provider domain'
  475. echo $' --ddnsuser Dynamic DNS provider username'
  476. echo $' --ddnspass Dynamic DNS provider password'
  477. echo ''
  478. echo $' --microblogdomain Microblog domain name'
  479. echo $' --wikidomain Wiki domain name'
  480. echo $' --blogdomain Blog domain name'
  481. echo $' --hubzilladomain Hubzilla domain name'
  482. echo $' --gitdomain Git hosting domain name'
  483. echo $' -t --time Domain used as a TLS time source'
  484. echo $' --ssh ssh port number'
  485. echo $' --list Public mailing list name'
  486. echo $' --cores Number of CPU cores'
  487. echo $' --name Your name'
  488. echo $' --email Your email address'
  489. echo $' --usb Path for the USB drive (eg. /dev/sdb1)'
  490. echo $' --cjdns Enable CJDNS'
  491. echo $' --vpass VoIP server password'
  492. echo $' --vport VoIP server port'
  493. echo $' --ns1 First DNS nameserver'
  494. echo $' --ns2 Second DNS nameserver'
  495. echo $' --repo Debian repository'
  496. echo ''
  497. echo $'system types'
  498. echo '------------'
  499. echo $'This can either be blank if you wish to install the full system,'
  500. echo $"or for more specialised variants you can specify '$VARIANT_MAILBOX', '$VARIANT_CLOUD',"
  501. echo $"'$VARIANT_CHAT', '$VARIANT_SOCIAL', '$VARIANT_MEDIA', '$VARIANT_WRITER', '$VARIANT_DEVELOPER'"
  502. echo $"or '$VARIANT_MESH'."
  503. echo ''
  504. echo $"If you wish to install everything except email then use the '$VARIANT_NONMAILBOX' variaint."
  505. echo ''
  506. exit 0
  507. }
  508. function git_clone {
  509. repo_url="$1"
  510. destination_dir="$2"
  511. if [[ "$repo_url" == "ssh:"* ]]; then
  512. if [ "${FRIENDS_MIRRORS_SERVER}" ]; then
  513. if [ ${#FRIENDS_MIRRORS_SERVER} -gt 2 ]; then
  514. if [ "$FRIENDS_MIRRORS_PASSWORD" ]; then
  515. if [ ${#FRIENDS_MIRRORS_PASSWORD} -gt 2 ]; then
  516. echo "sshpass -p \"$FRIENDS_MIRRORS_PASSWORD\" git clone $repo_url $destination_dir"
  517. sshpass -p "$FRIENDS_MIRRORS_PASSWORD" git clone "$repo_url" "$destination_dir"
  518. return
  519. fi
  520. fi
  521. fi
  522. fi
  523. fi
  524. echo "git clone $repo_url $destination_dir"
  525. git clone "$repo_url" "$destination_dir"
  526. }
  527. function git_pull {
  528. if [ ! $1 ]; then
  529. echo $'git_pull no repo specified'
  530. fi
  531. git stash
  532. git remote set-url origin $1
  533. git checkout master
  534. if [ "${FRIENDS_MIRRORS_SERVER}" ]; then
  535. if [ ${#FRIENDS_MIRRORS_SERVER} -gt 2 ]; then
  536. if [ "$FRIENDS_MIRRORS_PASSWORD" ]; then
  537. if [ ${#FRIENDS_MIRRORS_PASSWORD} -gt 2 ]; then
  538. sshpass -p "$FRIENDS_MIRRORS_PASSWORD" git pull
  539. if [ $2 ]; then
  540. git checkout $2 -b $2
  541. fi
  542. return
  543. fi
  544. fi
  545. fi
  546. fi
  547. git pull
  548. if [ $2 ]; then
  549. # delete any existing branch
  550. git branch -D $2
  551. # check out the new branch
  552. git checkout $2 -b $2
  553. if [ ! "$?" = "0" ]; then
  554. echo $"Unable to checkout $1 $2"
  555. exit 72357
  556. fi
  557. fi
  558. }
  559. function remove_database {
  560. app_name="$1"
  561. if [ ! -d $INSTALL_DIR ]; then
  562. mkdir $INSTALL_DIR
  563. fi
  564. echo "drop database ${app_name};
  565. quit" > $INSTALL_DIR/batch.sql
  566. chmod 600 $INSTALL_DIR/batch.sql
  567. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  568. shred -zu $INSTALL_DIR/batch.sql
  569. }
  570. function create_database {
  571. app_name="$1"
  572. app_admin_password="$2"
  573. app_admin_username=$3
  574. if [ ! -d $INSTALL_DIR ]; then
  575. mkdir $INSTALL_DIR
  576. fi
  577. if [ ! $app_admin_username ]; then
  578. app_admin_username=${app_name}admin
  579. fi
  580. echo "create database ${app_name};
  581. CREATE USER '$app_admin_username@localhost' IDENTIFIED BY '${app_admin_password}';
  582. GRANT ALL PRIVILEGES ON ${app_name}.* TO '$app_admin_username@localhost';
  583. quit" > $INSTALL_DIR/batch.sql
  584. chmod 600 $INSTALL_DIR/batch.sql
  585. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  586. shred -zu $INSTALL_DIR/batch.sql
  587. }
  588. function locale_setup {
  589. if grep -Fxq "locale_setup" $COMPLETION_FILE; then
  590. return
  591. fi
  592. apt-get -y install locales locales-all debconf
  593. if [ ! "$DEFAULT_LANGUAGE" ]; then
  594. DEFAULT_LANGUAGE='en_GB.UTF-8'
  595. fi
  596. if [ ${#DEFAULT_LANGUAGE} -lt 2 ]; then
  597. DEFAULT_LANGUAGE='en_GB.UTF-8'
  598. fi
  599. update-locale LANG=${DEFAULT_LANGUAGE}
  600. update-locale LANGUAGE=${DEFAULT_LANGUAGE}
  601. update-locale LC_MESSAGES=${DEFAULT_LANGUAGE}
  602. update-locale LC_ALL=${DEFAULT_LANGUAGE}
  603. update-locale LC_CTYPE=${DEFAULT_LANGUAGE}
  604. echo 'locale_setup' >> $COMPLETION_FILE
  605. }
  606. function interactive_configuration_remote_backups {
  607. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  608. return
  609. fi
  610. if [ ! -f /usr/local/bin/${PROJECT_NAME}-remote ]; then
  611. if [ ! -f /usr/bin/${PROJECT_NAME}-remote ]; then
  612. echo $"The command ${PROJECT_NAME}-remote was not found"
  613. exit 87354
  614. fi
  615. fi
  616. ${PROJECT_NAME}-remote -u $MY_USERNAME -l $FRIENDS_SERVERS_LIST -m $MINIMUM_PASSWORD_LENGTH -r yes
  617. if [ ! "$?" = "0" ]; then
  618. echo $'Command failed:'
  619. echo ''
  620. echo $" ${PROJECT_NAME}-remote -u $MY_USERNAME -l $FRIENDS_SERVERS_LIST -m $MINIMUM_PASSWORD_LENGTH -r yes"
  621. echo ''
  622. exit 65892
  623. fi
  624. }
  625. # test a domain name to see if it's valid
  626. function validate_domain_name {
  627. # count the number of dots in the domain name
  628. dots=${TEST_DOMAIN_NAME//[^.]}
  629. no_of_dots=${#dots}
  630. if (( $no_of_dots > 3 )); then
  631. 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"
  632. fi
  633. if (( $no_of_dots == 0 )); then
  634. 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"
  635. fi
  636. }
  637. function interactive_configuration {
  638. if [ ! -f /usr/local/bin/${PROJECT_NAME}-config ]; then
  639. if [ ! -f /usr/bin/${PROJECT_NAME}-config ]; then
  640. echo $"The command ${PROJECT_NAME}-config was not found"
  641. exit 63935
  642. fi
  643. fi
  644. if [ -f /tmp/meshuserdevice ]; then
  645. rm -f /tmp/meshuserdevice
  646. fi
  647. if [[ $ONION_ONLY == "no" ]]; then
  648. if [[ $MINIMAL_INSTALL == "no" ]]; then
  649. ${PROJECT_NAME}-config \
  650. -f $CONFIGURATION_FILE \
  651. -w $PROJECT_WEBSITE \
  652. -m $MINIMUM_PASSWORD_LENGTH
  653. else
  654. ${PROJECT_NAME}-config \
  655. -f $CONFIGURATION_FILE \
  656. -w $PROJECT_WEBSITE \
  657. -m $MINIMUM_PASSWORD_LENGTH \
  658. --minimal "yes"
  659. fi
  660. else
  661. ${PROJECT_NAME}-config \
  662. -f $CONFIGURATION_FILE \
  663. -w $PROJECT_WEBSITE \
  664. -m $MINIMUM_PASSWORD_LENGTH \
  665. --onion "yes"
  666. fi
  667. if [ -f /tmp/meshuserdevice ]; then
  668. # mesh network user device installation
  669. rm -f /tmp/meshuserdevice
  670. exit 0
  671. fi
  672. if [ ! "$?" = "0" ]; then
  673. echo $'Command failed:'
  674. echo ''
  675. echo $" ${PROJECT_NAME}-config -u $MY_USERNAME -f $CONFIGURATION_FILE -w $PROJECT_WEBSITE -b $PROJECT_BITMESSAGE -m $MINIMUM_PASSWORD_LENGTH --minimal [yes|no]"
  676. echo ''
  677. exit 73594
  678. fi
  679. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  680. FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
  681. dialog --title $"Encrypted backup to other servers" \
  682. --backtitle $"${PROJECT_NAME} Configuration" \
  683. --defaultno \
  684. --yesno $"\nDo you wish to configure some remote backup locations?" 7 60
  685. sel=$?
  686. case $sel in
  687. 0) interactive_configuration_remote_backups;;
  688. esac
  689. fi
  690. }
  691. command_options=$1
  692. if [[ $command_options == "menuconfig-full" ]]; then
  693. MINIMAL_INSTALL="no"
  694. command_options="menuconfig"
  695. fi
  696. if [[ $command_options == "menuconfig-onion" ]]; then
  697. MINIMAL_INSTALL="yes"
  698. ONION_ONLY="yes"
  699. command_options="menuconfig"
  700. fi
  701. if [[ $command_options == "menuconfig" ]]; then
  702. interactive_configuration
  703. else
  704. while [[ $# > 1 ]]
  705. do
  706. key="$1"
  707. case $key in
  708. -h|--help)
  709. show_help
  710. ;;
  711. # load a configuration file
  712. -c|--config)
  713. shift
  714. CONFIGURATION_FILE="$1"
  715. INSTALLING_FROM_CONFIGURATION_FILE="yes"
  716. break
  717. ;;
  718. # username within /home
  719. -u|--user)
  720. shift
  721. MY_USERNAME="$1"
  722. ;;
  723. # microblog domain name
  724. --microblogdomain)
  725. shift
  726. MICROBLOG_DOMAIN_NAME="$1"
  727. ;;
  728. # wiki domain name
  729. --wikidomain)
  730. shift
  731. WIKI_DOMAIN_NAME="$1"
  732. ;;
  733. # blog domain name
  734. --blogdomain)
  735. shift
  736. FULLBLOG_DOMAIN_NAME="$1"
  737. ;;
  738. # hubzilla domain name
  739. --hubzilladomain)
  740. shift
  741. HUBZILLA_DOMAIN_NAME="$1"
  742. ;;
  743. # git hosting domain name
  744. --gitdomain)
  745. shift
  746. GIT_DOMAIN_NAME="$1"
  747. ;;
  748. # default domain name
  749. -d|--domain)
  750. shift
  751. DEFAULT_DOMAIN_NAME="$1"
  752. ;;
  753. # The type of system
  754. -s|--system)
  755. shift
  756. SYSTEM_TYPE="$1"
  757. ;;
  758. # The dynamic DNS provider
  759. --ddns)
  760. shift
  761. DDNS_PROVIDER="$1"
  762. ;;
  763. # Username for the synamic DNS provider
  764. --ddnsuser)
  765. shift
  766. DDNS_USERNAME="$1"
  767. ;;
  768. # Password for the synamic DNS provider
  769. --ddnspass)
  770. shift
  771. DDNS_PASSWORD="$1"
  772. ;;
  773. # Whether this installation is on a Beaglebone Black
  774. --bbb)
  775. INSTALLING_ON_BBB="yes"
  776. ;;
  777. # Domain name to use as a TLS time source
  778. -t|--time)
  779. shift
  780. TLS_TIME_SOURCE1="$1"
  781. ;;
  782. # Static IP address for the system
  783. --ip)
  784. shift
  785. LOCAL_NETWORK_STATIC_IP_ADDRESS=$1
  786. ;;
  787. # IP address for the internet router
  788. --iprouter)
  789. shift
  790. ROUTER_IP_ADDRESS=$1
  791. ;;
  792. # ssh port
  793. --ssh)
  794. shift
  795. SSH_PORT=$1
  796. ;;
  797. # public mailing list name
  798. --list)
  799. shift
  800. PUBLIC_MAILING_LIST="$1"
  801. ;;
  802. # Number of CPU cores
  803. --cores)
  804. shift
  805. CPU_CORES=$1
  806. ;;
  807. # my name
  808. --name)
  809. shift
  810. MY_NAME="$1"
  811. ;;
  812. # my email address
  813. --email)
  814. shift
  815. MY_EMAIL_ADDRESS="$1"
  816. ;;
  817. # USB drive
  818. --usb)
  819. shift
  820. USB_DRIVE=$1
  821. ;;
  822. # Enable CJDNS
  823. --cjdns)
  824. shift
  825. ENABLE_CJDNS="yes"
  826. ;;
  827. # Enable B.A.T.M.A.N
  828. --batman)
  829. shift
  830. ENABLE_BATMAN="yes"
  831. ;;
  832. # Enable Babel
  833. --babel)
  834. shift
  835. ENABLE_BABEL="yes"
  836. ;;
  837. # VoIP server password
  838. --vpass)
  839. shift
  840. VOIP_SERVER_PASSWORD=$1
  841. ;;
  842. # VoIP server port
  843. --vport)
  844. shift
  845. VOIP_PORT=$1
  846. ;;
  847. # DNS Nameserver 1
  848. --ns1)
  849. shift
  850. NAMESERVER1=$1
  851. ;;
  852. # DNS Nameserver 2
  853. --ns2)
  854. shift
  855. NAMESERVER2=$1
  856. ;;
  857. # Debian repository
  858. --repo)
  859. shift
  860. DEBIAN_REPO=$1
  861. ;;
  862. # minimal install
  863. --minimal)
  864. shift
  865. MINIMAL_INSTALL=$1
  866. ;;
  867. *)
  868. # unknown option
  869. ;;
  870. esac
  871. shift
  872. done
  873. fi
  874. function parse_args {
  875. if [[ $NO_OF_ARGS == 0 ]]; then
  876. echo 'no_of_args = 0'
  877. show_help
  878. exit 0
  879. fi
  880. if [ ! -d /home/$MY_USERNAME ]; then
  881. echo $"There is no user '$MY_USERNAME' on the system. Use 'adduser $MY_USERNAME' to create the user."
  882. exit 1
  883. fi
  884. if [ ! "$DEFAULT_DOMAIN_NAME" ]; then
  885. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  886. echo 'No default domain specified'
  887. show_help
  888. exit 2
  889. fi
  890. fi
  891. if [ ! $MY_USERNAME ]; then
  892. echo 'No username specified'
  893. show_help
  894. exit 3
  895. fi
  896. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  897. if [[ $ONION_ONLY == "no" ]]; then
  898. if [ ! $DDNS_USERNAME ]; then
  899. echo $'Please provide the username for your dynamic DNS provider with the --ddnsuser option'
  900. exit 7823
  901. fi
  902. if [ ! $DDNS_PASSWORD ]; then
  903. echo $'Please provide the password for your dynamic DNS provider with the --ddnspass option'
  904. exit 6382
  905. fi
  906. fi
  907. fi
  908. if [ ! $SYSTEM_TYPE ]; then
  909. SYSTEM_TYPE=$VARIANT_FULL
  910. fi
  911. 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_MESH && $SYSTEM_TYPE != $VARIANT_FULL ]]; then
  912. echo $"'$SYSTEM_TYPE' is an unrecognised ${PROJECT_NAME} variant."
  913. exit 30
  914. fi
  915. }
  916. function read_repo_servers {
  917. if [ -f $CONFIGURATION_FILE ]; then
  918. if grep -q "FRIENDS_MIRRORS_SERVER" $CONFIGURATION_FILE; then
  919. FRIENDS_MIRRORS_SERVER=$(grep "FRIENDS_MIRRORS_SERVER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  920. fi
  921. if grep -q "FRIENDS_MIRRORS_SSH_PORT" $CONFIGURATION_FILE; then
  922. FRIENDS_MIRRORS_SSH_PORT=$(grep "FRIENDS_MIRRORS_SSH_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  923. fi
  924. if grep -q "MY_MIRRORS_PASSWORD" $CONFIGURATION_FILE; then
  925. MY_MIRRORS_PASSWORD=$(grep "MY_MIRRORS_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  926. fi
  927. if grep -q "FRIENDS_MIRRORS_PASSWORD" $CONFIGURATION_FILE; then
  928. FRIENDS_MIRRORS_PASSWORD=$(grep "FRIENDS_MIRRORS_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  929. fi
  930. fi
  931. if [ ! $FRIENDS_MIRRORS_SERVER ]; then
  932. return
  933. fi
  934. if [ ${#FRIENDS_MIRRORS_SERVER} -lt 2 ]; then
  935. return
  936. fi
  937. MAIN_COMMAND=/usr/local/bin/${PROJECT_NAME}
  938. if [ ! -f $MAIN_COMMAND ]; then
  939. MAIN_COMMAND=/usr/bin/${PROJECT_NAME}
  940. fi
  941. REPOS=($(cat ${MAIN_COMMAND} | grep "_REPO=\"" | uniq -u | sed 's|${PROJECT_NAME}|'"${PROJECT_NAME}"'|g'))
  942. for line in "${REPOS[@]}"
  943. do
  944. repo_name=$(echo "$line" | awk -F '=' '{print $1}')
  945. mirrors_name=$(echo "$repo_name" | sed "s|_REPO||g" | awk '{print tolower($0)}')
  946. friends_repo_url="ssh://mirrors@${FRIENDS_MIRRORS_SERVER}:${FRIENDS_MIRRORS_SSH_PORT}/home/mirrors/${mirrors_name}"
  947. ${repo_name}="${friends_repo_url}"
  948. done
  949. }
  950. function read_configuration {
  951. # if not installing on a Beaglebone then use sdb as the USB drive by default
  952. if [ ! $INSTALLING_ON_BBB ]; then
  953. if [[ $USB_DRIVE == /dev/sda1 ]]; then
  954. USB_DRIVE=/dev/sdb1
  955. fi
  956. fi
  957. if [[ $INSTALLING_FROM_CONFIGURATION_FILE == "yes" ]]; then
  958. if [ ! -f $CONFIGURATION_FILE ]; then
  959. echo $"The configuration file $CONFIGURATION_FILE was not found"
  960. exit 8935
  961. fi
  962. fi
  963. if [ -f $CONFIGURATION_FILE ]; then
  964. read_repo_servers
  965. # Ensure that a copy of the config exists for upgrade purposes
  966. if [[ $CONFIGURATION_FILE != "/root/${PROJECT_NAME}.cfg" ]]; then
  967. cp $CONFIGURATION_FILE /root/${PROJECT_NAME}.cfg
  968. fi
  969. if grep -q "REFRESH_GPG_KEYS_HOURS" $CONFIGURATION_FILE; then
  970. REFRESH_GPG_KEYS_HOURS=$(grep "REFRESH_GPG_KEYS_HOURS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  971. fi
  972. if grep -q "WEBMAIL_REPO" $CONFIGURATION_FILE; then
  973. WEBMAIL_REPO=$(grep "WEBMAIL_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  974. fi
  975. if grep -q "WEBMAIL_COMMIT" $CONFIGURATION_FILE; then
  976. WEBMAIL_COMMIT=$(grep "WEBMAIL_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  977. fi
  978. if grep -q "WIFI_INTERFACE" $CONFIGURATION_FILE; then
  979. WIFI_INTERFACE=$(grep "WIFI_INTERFACE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  980. fi
  981. if grep -q "WIFI_SSID" $CONFIGURATION_FILE; then
  982. WIFI_SSID=$(grep "WIFI_SSID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  983. fi
  984. if grep -q "WIFI_TYPE" $CONFIGURATION_FILE; then
  985. WIFI_TYPE=$(grep "WIFI_TYPE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  986. fi
  987. if grep -q "WIFI_PASSPHRASE" $CONFIGURATION_FILE; then
  988. WIFI_PASSPHRASE=$(grep "WIFI_PASSPHRASE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  989. fi
  990. if grep -q "WIFI_HOTSPOT" $CONFIGURATION_FILE; then
  991. WIFI_HOTSPOT=$(grep "WIFI_HOTSPOT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  992. fi
  993. if grep -q "WIFI_NETWORKS_FILE" $CONFIGURATION_FILE; then
  994. WIFI_NETWORKS_FILE=$(grep "WIFI_NETWORKS_FILE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  995. fi
  996. if grep -q "SYNCTHING_ID" $CONFIGURATION_FILE; then
  997. SYNCTHING_ID=$(grep "SYNCTHING_ID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  998. fi
  999. if grep -q "SYNCTHING_CONFIG_PATH" $CONFIGURATION_FILE; then
  1000. SYNCTHING_CONFIG_PATH=$(grep "SYNCTHING_CONFIG_PATH" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1001. fi
  1002. if grep -q "SYNCTHING_CONFIG_FILE" $CONFIGURATION_FILE; then
  1003. SYNCTHING_CONFIG_FILE=$(grep "SYNCTHING_CONFIG_FILE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1004. fi
  1005. if grep -q "SYNCTHING_RELAY_SERVER" $CONFIGURATION_FILE; then
  1006. SYNCTHING_RELAY_SERVER=$(grep "SYNCTHING_RELAY_SERVER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1007. fi
  1008. if grep -q "SYNCTHING_RELEASES" $CONFIGURATION_FILE; then
  1009. SYNCTHING_RELEASES=$(grep "SYNCTHING_RELEASES" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1010. fi
  1011. if grep -q "SYNCTHING_PORT" $CONFIGURATION_FILE; then
  1012. SYNCTHING_PORT=$(grep "SYNCTHING_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1013. fi
  1014. if grep -q "SYNCTHING_SHARED_DATA" $CONFIGURATION_FILE; then
  1015. SYNCTHING_SHARED_DATA=$(grep "SYNCTHING_SHARED_DATA" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1016. fi
  1017. if grep -q "VOIP_TURN_PORT" $CONFIGURATION_FILE; then
  1018. VOIP_TURN_PORT=$(grep "VOIP_TURN_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1019. fi
  1020. if grep -q "VOIP_TURN_TLS_PORT" $CONFIGURATION_FILE; then
  1021. VOIP_TURN_TLS_PORT=$(grep "VOIP_TURN_TLS_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1022. fi
  1023. if grep -q "VOIP_TURN_NONCE" $CONFIGURATION_FILE; then
  1024. VOIP_TURN_NONCE=$(grep "VOIP_TURN_NONCE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1025. fi
  1026. if grep -q "DEFAULT_SEARCH" $CONFIGURATION_FILE; then
  1027. DEFAULT_SEARCH=$(grep "DEFAULT_SEARCH" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1028. fi
  1029. if grep -q "SEARCH_ENGINE_PASSWORD" $CONFIGURATION_FILE; then
  1030. SEARCH_ENGINE_PASSWORD=$(grep "SEARCH_ENGINE_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1031. fi
  1032. if grep -q "XMPP_PASSWORD" $CONFIGURATION_FILE; then
  1033. XMPP_PASSWORD=$(grep "XMPP_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1034. fi
  1035. if grep -q "RSS_READER_REPO" $CONFIGURATION_FILE; then
  1036. RSS_READER_REPO=$(grep "RSS_READER_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1037. fi
  1038. if grep -q "RSS_MOBILE_READER_REPO" $CONFIGURATION_FILE; then
  1039. RSS_MOBILE_READER_REPO=$(grep "RSS_MOBILE_READER_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1040. fi
  1041. if grep -q "RSS_READER_COMMIT" $CONFIGURATION_FILE; then
  1042. RSS_READER_COMMIT=$(grep "RSS_READER_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1043. fi
  1044. if grep -q "RSS_MOBILE_READER_COMMIT" $CONFIGURATION_FILE; then
  1045. RSS_MOBILE_READER_COMMIT=$(grep "RSS_MOBILE_READER_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1046. fi
  1047. if grep -q "RSS_READER_ADMIN_PASSWORD" $CONFIGURATION_FILE; then
  1048. RSS_READER_ADMIN_PASSWORD=$(grep "RSS_READER_ADMIN_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1049. fi
  1050. if grep -q "RSS_READER_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1051. RSS_READER_DOMAIN_NAME=$(grep "RSS_READER_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1052. fi
  1053. if grep -q "MICROBLOG_BACKGROUND_IMAGE_URL" $CONFIGURATION_FILE; then
  1054. MICROBLOG_BACKGROUND_IMAGE_URL=$(grep "MICROBLOG_BACKGROUND_IMAGE_URL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1055. fi
  1056. if grep -q "MICROBLOG_WELCOME_MESSAGE" $CONFIGURATION_FILE; then
  1057. MICROBLOG_WELCOME_MESSAGE=$(grep "MICROBLOG_WELCOME_MESSAGE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1058. fi
  1059. if grep -q "PROJECT_WEBSITE" $CONFIGURATION_FILE; then
  1060. PROJECT_WEBSITE=$(grep "PROJECT_WEBSITE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1061. fi
  1062. if grep -q "PROJECT_REPO" $CONFIGURATION_FILE; then
  1063. PROJECT_REPO=$(grep "PROJECT_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1064. fi
  1065. if grep -q "ONION_ONLY" $CONFIGURATION_FILE; then
  1066. ONION_ONLY=$(grep "ONION_ONLY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1067. fi
  1068. if grep -q "IRC_PASSWORD" $CONFIGURATION_FILE; then
  1069. IRC_PASSWORD=$(grep "IRC_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1070. fi
  1071. if grep -q "DEFAULT_LANGUAGE" $CONFIGURATION_FILE; then
  1072. DEFAULT_LANGUAGE=$(grep "DEFAULT_LANGUAGE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1073. fi
  1074. if grep -q "MINIMAL_INSTALL" $CONFIGURATION_FILE; then
  1075. MINIMAL_INSTALL=$(grep "MINIMAL_INSTALL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1076. fi
  1077. if grep -q "LETSENCRYPT_SERVER" $CONFIGURATION_FILE; then
  1078. LETSENCRYPT_SERVER=$(grep "LETSENCRYPT_SERVER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1079. fi
  1080. if grep -q "FULLBLOG_REPO" $CONFIGURATION_FILE; then
  1081. FULLBLOG_REPO=$(grep "FULLBLOG_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1082. fi
  1083. if grep -q "FULLBLOG_COMMIT" $CONFIGURATION_FILE; then
  1084. FULLBLOG_COMMIT=$(grep "FULLBLOG_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1085. fi
  1086. if grep -q "GOGS_COMMIT" $CONFIGURATION_FILE; then
  1087. GOGS_COMMIT=$(grep "GOGS_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1088. fi
  1089. if grep -q "TOXCORE_COMMIT" $CONFIGURATION_FILE; then
  1090. TOXCORE_COMMIT=$(grep "TOXCORE_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1091. fi
  1092. if grep -q "TOXIC_COMMIT" $CONFIGURATION_FILE; then
  1093. TOXIC_COMMIT=$(grep "TOXIC_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1094. fi
  1095. if grep -q "GPGIT_REPO" $CONFIGURATION_FILE; then
  1096. GPGIT_REPO=$(grep "GPGIT_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1097. fi
  1098. if grep -q "GPGIT_COMMIT" $CONFIGURATION_FILE; then
  1099. GPGIT_COMMIT=$(grep "GPGIT_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1100. fi
  1101. if grep -q "HUBZILLA_REPO" $CONFIGURATION_FILE; then
  1102. HUBZILLA_REPO=$(grep "HUBZILLA_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1103. fi
  1104. if grep -q "HUBZILLA_COMMIT" $CONFIGURATION_FILE; then
  1105. HUBZILLA_COMMIT=$(grep "HUBZILLA_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1106. fi
  1107. if grep -q "IPFS_COMMIT" $CONFIGURATION_FILE; then
  1108. IPFS_COMMIT=$(grep "IPFS_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1109. fi
  1110. if grep -q "ZERONET_BLOG_COMMIT" $CONFIGURATION_FILE; then
  1111. ZERONET_BLOG_COMMIT=$(grep "ZERONET_BLOG_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1112. fi
  1113. if grep -q "ZERONET_MAIL_COMMIT" $CONFIGURATION_FILE; then
  1114. ZERONET_MAIL_COMMIT=$(grep "ZERONET_MAIL_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1115. fi
  1116. if grep -q "ZERONET_FORUM_COMMIT" $CONFIGURATION_FILE; then
  1117. ZERONET_FORUM_COMMIT=$(grep "ZERONET_FORUM_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1118. fi
  1119. if grep -q "MICROBLOG_COMMIT" $CONFIGURATION_FILE; then
  1120. MICROBLOG_COMMIT=$(grep "MICROBLOG_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1121. fi
  1122. if grep -q "NGINX_ENSITE_REPO" $CONFIGURATION_FILE; then
  1123. NGINX_ENSITE_REPO=$(grep "NGINX_ENSITE_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1124. fi
  1125. if grep -q "NGINX_ENSITE_COMMIT" $CONFIGURATION_FILE; then
  1126. NGINX_ENSITE_COMMIT=$(grep "NGINX_ENSITE_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1127. fi
  1128. if grep -q "CLEANUP_MAILDIR_COMMIT" $CONFIGURATION_FILE; then
  1129. CLEANUP_MAILDIR_COMMIT=$(grep "CLEANUP_MAILDIR_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1130. fi
  1131. if grep -q "CLEANUP_MAILDIR_REPO" $CONFIGURATION_FILE; then
  1132. CLEANUP_MAILDIR_REPO=$(grep "CLEANUP_MAILDIR_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1133. fi
  1134. if grep -q "ZERONET_COMMIT" $CONFIGURATION_FILE; then
  1135. ZERONET_COMMIT=$(grep "ZERONET_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1136. fi
  1137. if grep -q "INADYN_REPO" $CONFIGURATION_FILE; then
  1138. INADYN_REPO=$(grep "INADYN_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1139. fi
  1140. if grep -q "INADYN_COMMIT" $CONFIGURATION_FILE; then
  1141. INADYN_COMMIT=$(grep "INADYN_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1142. fi
  1143. if grep -q "GPG_KEYSERVER" $CONFIGURATION_FILE; then
  1144. GPG_KEYSERVER=$(grep "GPG_KEYSERVER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1145. fi
  1146. if grep -q "IPFS_PORT" $CONFIGURATION_FILE; then
  1147. IPFS_PORT=$(grep "IPFS_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1148. fi
  1149. if grep -q "TRACKER_PORT" $CONFIGURATION_FILE; then
  1150. TRACKER_PORT=$(grep "TRACKER_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1151. fi
  1152. if grep -q "ZERONET_PORT" $CONFIGURATION_FILE; then
  1153. ZERONET_PORT=$(grep "ZERONET_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1154. fi
  1155. if grep -q "DH_KEYLENGTH" $CONFIGURATION_FILE; then
  1156. DH_KEYLENGTH=$(grep "DH_KEYLENGTH" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1157. fi
  1158. if grep -q "IRC_PORT" $CONFIGURATION_FILE; then
  1159. IRC_PORT=$(grep "IRC_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1160. fi
  1161. if grep -q "WIFI_CHANNEL" $CONFIGURATION_FILE; then
  1162. WIFI_CHANNEL=$(grep "WIFI_CHANNEL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1163. fi
  1164. if grep -q "BATMAN_CELLID" $CONFIGURATION_FILE; then
  1165. BATMAN_CELLID=$(grep "BATMAN_CELLID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1166. fi
  1167. if grep -q "TOX_PORT" $CONFIGURATION_FILE; then
  1168. TOX_PORT=$(grep "TOX_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1169. fi
  1170. if grep -q "TOX_NODES" $CONFIGURATION_FILE; then
  1171. TOX_NODES=$(grep "TOX_NODES" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1172. fi
  1173. if grep -q "TOXCORE_REPO" $CONFIGURATION_FILE; then
  1174. TOXCORE_REPO=$(grep "TOXCORE_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1175. fi
  1176. if grep -q "ENABLE_SOCIAL_KEY_MANAGEMENT" $CONFIGURATION_FILE; then
  1177. ENABLE_SOCIAL_KEY_MANAGEMENT=$(grep "ENABLE_SOCIAL_KEY_MANAGEMENT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1178. fi
  1179. if grep -q "IPV6_NETWORK" $CONFIGURATION_FILE; then
  1180. IPV6_NETWORK=$(grep "IPV6_NETWORK" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1181. fi
  1182. if grep -q "HWRNG_TYPE" $CONFIGURATION_FILE; then
  1183. HWRNG_TYPE=$(grep "HWRNG_TYPE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1184. fi
  1185. if grep -q "MEDIA_SERVER_ADMIN_PASSWORD" $CONFIGURATION_FILE; then
  1186. MEDIA_SERVER_ADMIN_PASSWORD=$(grep "MEDIA_SERVER_ADMIN_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1187. fi
  1188. if grep -q "MEDIA_SERVER_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1189. MEDIA_SERVER_DOMAIN_NAME=$(grep "MEDIA_SERVER_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1190. fi
  1191. if grep -q "MEDIA_SERVER_CODE" $CONFIGURATION_FILE; then
  1192. MEDIA_SERVER_CODE=$(grep "MEDIA_SERVER_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1193. fi
  1194. if grep -q "MEDIA_SERVER_REPO" $CONFIGURATION_FILE; then
  1195. MEDIA_SERVER_REPO=$(grep "MEDIA_SERVER_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1196. fi
  1197. if grep -q "MEDIA_SERVER_COMMIT" $CONFIGURATION_FILE; then
  1198. MEDIA_SERVER_COMMIT=$(grep "MEDIA_SERVER_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1199. fi
  1200. if grep -q "MEDIAGOBLIN_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1201. MEDIAGOBLIN_DOMAIN_NAME=$(grep "MEDIAGOBLIN_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1202. fi
  1203. if grep -q "MEDIAGOBLIN_CODE" $CONFIGURATION_FILE; then
  1204. MEDIAGOBLIN_CODE=$(grep "MEDIAGOBLIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1205. fi
  1206. if grep -q "MEDIAGOBLIN_REPO" $CONFIGURATION_FILE; then
  1207. MEDIAGOBLIN_REPO=$(grep "MEDIAGOBLIN_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1208. fi
  1209. if grep -q "MEDIAGOBLIN_COMMIT" $CONFIGURATION_FILE; then
  1210. MEDIAGOBLIN_COMMIT=$(grep "MEDIAGOBLIN_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1211. fi
  1212. if grep -q "GIT_ADMIN_PASSWORD" $CONFIGURATION_FILE; then
  1213. GIT_ADMIN_PASSWORD=$(grep "GIT_ADMIN_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1214. fi
  1215. if grep -q "GIT_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1216. GIT_DOMAIN_NAME=$(grep "GIT_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1217. fi
  1218. if grep -q "GIT_CODE" $CONFIGURATION_FILE; then
  1219. GIT_CODE=$(grep "GIT_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1220. fi
  1221. if grep -q "SYSTEM_TYPE" $CONFIGURATION_FILE; then
  1222. SYSTEM_TYPE=$(grep "SYSTEM_TYPE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1223. fi
  1224. if grep -q "SSL_PROTOCOLS" $CONFIGURATION_FILE; then
  1225. SSL_PROTOCOLS=$(grep "SSL_PROTOCOLS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1226. fi
  1227. if grep -q "SSL_CIPHERS" $CONFIGURATION_FILE; then
  1228. SSL_CIPHERS=$(grep "SSL_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1229. fi
  1230. if grep -q "SSH_CIPHERS" $CONFIGURATION_FILE; then
  1231. SSH_CIPHERS=$(grep "SSH_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1232. fi
  1233. if grep -q "SSH_MACS" $CONFIGURATION_FILE; then
  1234. SSH_MACS=$(grep "SSH_MACS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1235. fi
  1236. if grep -q "SSH_KEX" $CONFIGURATION_FILE; then
  1237. SSH_KEX=$(grep "SSH_KEX" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1238. fi
  1239. if grep -q "SSH_HOST_KEY_ALGORITHMS" $CONFIGURATION_FILE; then
  1240. SSH_HOST_KEY_ALGORITHMS=$(grep "SSH_HOST_KEY_ALGORITHMS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1241. fi
  1242. if grep -q "SSH_PASSWORDS" $CONFIGURATION_FILE; then
  1243. SSH_PASSWORDS=$(grep "SSH_PASSWORDS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1244. fi
  1245. if grep -q "XMPP_CIPHERS" $CONFIGURATION_FILE; then
  1246. XMPP_CIPHERS=$(grep "XMPP_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1247. fi
  1248. if grep -q "XMPP_ECC_CURVE" $CONFIGURATION_FILE; then
  1249. XMPP_ECC_CURVE=$(grep "XMPP_ECC_CURVE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1250. fi
  1251. if grep -q "MY_USERNAME" $CONFIGURATION_FILE; then
  1252. MY_USERNAME=$(grep "MY_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1253. fi
  1254. if grep -q "DOMAIN_NAME" $CONFIGURATION_FILE; then
  1255. # for backwards compatability
  1256. DEFAULT_DOMAIN_NAME=$(grep "DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1257. fi
  1258. if grep -q "DEFAULT_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1259. DEFAULT_DOMAIN_NAME=$(grep "DEFAULT_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1260. fi
  1261. if grep -q "DEFAULT_DOMAIN_CODE" $CONFIGURATION_FILE; then
  1262. DEFAULT_DOMAIN_CODE=$(grep "DEFAULT_DOMAIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1263. fi
  1264. if grep -q "NAMESERVER1" $CONFIGURATION_FILE; then
  1265. NAMESERVER1=$(grep "NAMESERVER1" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1266. fi
  1267. if grep -q "NAMESERVER2" $CONFIGURATION_FILE; then
  1268. NAMESERVER2=$(grep "NAMESERVER2" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1269. fi
  1270. if grep -q "DEBIAN_REPO" $CONFIGURATION_FILE; then
  1271. DEBIAN_REPO=$(grep "DEBIAN_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1272. 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."
  1273. fi
  1274. if grep -q "VOIP_PORT" $CONFIGURATION_FILE; then
  1275. VOIP_PORT=$(grep "VOIP_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1276. fi
  1277. if grep -q "VOIP_SERVER_PASSWORD" $CONFIGURATION_FILE; then
  1278. VOIP_SERVER_PASSWORD=$(grep "VOIP_SERVER_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1279. fi
  1280. if grep -q "SIP_PORT" $CONFIGURATION_FILE; then
  1281. SIP_PORT=$(grep "SIP_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1282. fi
  1283. if grep -q "SIP_TLS_PORT" $CONFIGURATION_FILE; then
  1284. SIP_TLS_PORT=$(grep "SIP_TLS_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1285. fi
  1286. if grep -q "SIP_SERVER_PASSWORD" $CONFIGURATION_FILE; then
  1287. SIP_SERVER_PASSWORD=$(grep "SIP_SERVER_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1288. fi
  1289. if grep -q "GET_IP_ADDRESS_URL" $CONFIGURATION_FILE; then
  1290. GET_IP_ADDRESS_URL=$(grep "GET_IP_ADDRESS_URL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1291. fi
  1292. if grep -q "DDNS_PROVIDER" $CONFIGURATION_FILE; then
  1293. DDNS_PROVIDER=$(grep "DDNS_PROVIDER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1294. fi
  1295. if grep -q "DDNS_USERNAME" $CONFIGURATION_FILE; then
  1296. DDNS_USERNAME=$(grep "DDNS_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1297. fi
  1298. if grep -q "DDNS_PASSWORD" $CONFIGURATION_FILE; then
  1299. DDNS_PASSWORD=$(grep "DDNS_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1300. fi
  1301. if grep -q "LOCAL_NETWORK_STATIC_IP_ADDRESS" $CONFIGURATION_FILE; then
  1302. LOCAL_NETWORK_STATIC_IP_ADDRESS=$(grep "LOCAL_NETWORK_STATIC_IP_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1303. fi
  1304. if grep -q "ENABLE_BABEL" $CONFIGURATION_FILE; then
  1305. ENABLE_BABEL=$(grep "ENABLE_BABEL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1306. fi
  1307. if grep -q "ENABLE_BATMAN" $CONFIGURATION_FILE; then
  1308. ENABLE_BATMAN=$(grep "ENABLE_BATMAN" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1309. fi
  1310. if grep -q "ENABLE_CJDNS" $CONFIGURATION_FILE; then
  1311. ENABLE_CJDNS=$(grep "ENABLE_CJDNS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1312. fi
  1313. if grep -q "CJDNS_COMMIT" $CONFIGURATION_FILE; then
  1314. CJDNS_COMMIT=$(grep "CJDNS_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1315. fi
  1316. if grep -q "CJDNS_IPV6" $CONFIGURATION_FILE; then
  1317. CJDNS_IPV6=$(grep "CJDNS_IPV6" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1318. fi
  1319. if grep -q "CJDNS_PUBLIC_KEY" $CONFIGURATION_FILE; then
  1320. CJDNS_PUBLIC_KEY=$(grep "CJDNS_PUBLIC_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1321. fi
  1322. if grep -q "CJDNS_PRIVATE_KEY" $CONFIGURATION_FILE; then
  1323. CJDNS_PRIVATE_KEY=$(grep "CJDNS_PRIVATE_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1324. fi
  1325. if grep -q "ROUTER_IP_ADDRESS" $CONFIGURATION_FILE; then
  1326. ROUTER_IP_ADDRESS=$(grep "ROUTER_IP_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1327. fi
  1328. if grep -q "CPU_CORES" $CONFIGURATION_FILE; then
  1329. CPU_CORES=$(grep "CPU_CORES" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1330. fi
  1331. if grep -q "WEBSERVER_LOG_LEVEL" $CONFIGURATION_FILE; then
  1332. WEBSERVER_LOG_LEVEL=$(grep "WEBSERVER_LOG_LEVEL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1333. fi
  1334. if grep -q "ROUTE_THROUGH_TOR" $CONFIGURATION_FILE; then
  1335. ROUTE_THROUGH_TOR=$(grep "ROUTE_THROUGH_TOR" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1336. fi
  1337. if grep -q "WIKI_TITLE" $CONFIGURATION_FILE; then
  1338. WIKI_TITLE=$(grep "WIKI_TITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1339. fi
  1340. if grep -q "MY_NAME" $CONFIGURATION_FILE; then
  1341. MY_NAME=$(grep "MY_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1342. fi
  1343. if grep -q "MY_EMAIL_ADDRESS" $CONFIGURATION_FILE; then
  1344. MY_EMAIL_ADDRESS=$(grep "MY_EMAIL_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1345. fi
  1346. if grep -q "INSTALLING_ON_BBB" $CONFIGURATION_FILE; then
  1347. INSTALLING_ON_BBB=$(grep "INSTALLING_ON_BBB" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1348. fi
  1349. if grep -q "SSH_PORT" $CONFIGURATION_FILE; then
  1350. SSH_PORT=$(grep "SSH_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1351. fi
  1352. if grep -q "INSTALLED_WITHIN_DOCKER" $CONFIGURATION_FILE; then
  1353. INSTALLED_WITHIN_DOCKER=$(grep "INSTALLED_WITHIN_DOCKER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1354. fi
  1355. if grep -q "PUBLIC_MAILING_LIST" $CONFIGURATION_FILE; then
  1356. PUBLIC_MAILING_LIST=$(grep "PUBLIC_MAILING_LIST" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1357. fi
  1358. if grep -q "MICROBLOG_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1359. MICROBLOG_DOMAIN_NAME=$(grep "MICROBLOG_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1360. fi
  1361. if grep -q "MICROBLOG_CODE" $CONFIGURATION_FILE; then
  1362. MICROBLOG_CODE=$(grep "MICROBLOG_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1363. fi
  1364. if grep -q "HUBZILLA_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1365. HUBZILLA_DOMAIN_NAME=$(grep "HUBZILLA_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1366. fi
  1367. if grep -q "HUBZILLA_CODE" $CONFIGURATION_FILE; then
  1368. HUBZILLA_CODE=$(grep "HUBZILLA_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1369. fi
  1370. if grep -q "WIKI_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1371. WIKI_DOMAIN_NAME=$(grep "WIKI_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1372. fi
  1373. if grep -q "WIKI_CODE" $CONFIGURATION_FILE; then
  1374. WIKI_CODE=$(grep "WIKI_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1375. fi
  1376. if grep -q "FULLBLOG_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1377. FULLBLOG_DOMAIN_NAME=$(grep "FULLBLOG_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1378. fi
  1379. if grep -q "FULLBLOG_CODE" $CONFIGURATION_FILE; then
  1380. FULLBLOG_CODE=$(grep "FULLBLOG_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1381. fi
  1382. if grep -q "MY_BLOG_TITLE" $CONFIGURATION_FILE; then
  1383. MY_BLOG_TITLE=$(grep "MY_BLOG_TITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1384. fi
  1385. if grep -q "MY_BLOG_SUBTITLE" $CONFIGURATION_FILE; then
  1386. MY_BLOG_SUBTITLE=$(grep "MY_BLOG_SUBTITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1387. fi
  1388. if grep -q "GPG_ENCRYPT_STORED_EMAIL" $CONFIGURATION_FILE; then
  1389. GPG_ENCRYPT_STORED_EMAIL=$(grep "GPG_ENCRYPT_STORED_EMAIL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1390. fi
  1391. if grep -q "MY_GPG_PUBLIC_KEY" $CONFIGURATION_FILE; then
  1392. MY_GPG_PUBLIC_KEY=$(grep "MY_GPG_PUBLIC_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1393. fi
  1394. if grep -q "MY_GPG_PRIVATE_KEY" $CONFIGURATION_FILE; then
  1395. MY_GPG_PRIVATE_KEY=$(grep "MY_GPG_PRIVATE_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1396. fi
  1397. if grep -q "MY_GPG_PUBLIC_KEY_ID" $CONFIGURATION_FILE; then
  1398. MY_GPG_PUBLIC_KEY_ID=$(grep "MY_GPG_PUBLIC_KEY_ID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1399. fi
  1400. if grep -q "USB_DRIVE" $CONFIGURATION_FILE; then
  1401. USB_DRIVE=$(grep "USB_DRIVE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1402. fi
  1403. if grep -q "MAX_PHP_MEMORY" $CONFIGURATION_FILE; then
  1404. MAX_PHP_MEMORY=$(grep "MAX_PHP_MEMORY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1405. fi
  1406. if grep -q "TLS_TIME_SOURCE1" $CONFIGURATION_FILE; then
  1407. TLS_TIME_SOURCE1=$(grep "TLS_TIME_SOURCE1" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1408. fi
  1409. if grep -q "TLS_TIME_SOURCE2" $CONFIGURATION_FILE; then
  1410. TLS_TIME_SOURCE2=$(grep "TLS_TIME_SOURCE2" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1411. fi
  1412. fi
  1413. echo "System type: $SYSTEM_TYPE"
  1414. }
  1415. function set_default_onion_domains {
  1416. # If sites are only visible via Tor then for installation
  1417. # purposes assign them some default domain names
  1418. if [[ $ONION_ONLY == "no" ]]; then
  1419. return
  1420. fi
  1421. if [ ${#MICROBLOG_DOMAIN_NAME} -gt 1 ]; then
  1422. MICROBLOG_DOMAIN_NAME='microblog.local'
  1423. fi
  1424. if [ ${#FULLBLOG_DOMAIN_NAME} -gt 1 ]; then
  1425. FULLBLOG_DOMAIN_NAME='blog.local'
  1426. fi
  1427. if [ ${#WIKI_DOMAIN_NAME} -gt 1 ]; then
  1428. WIKI_DOMAIN_NAME='wiki.local'
  1429. fi
  1430. if [ ${#DEFAULT_DOMAIN_NAME} -gt 1 ]; then
  1431. DEFAULT_DOMAIN_NAME="${PROJECT_NAME}.local"
  1432. fi
  1433. if [ ${#GIT_DOMAIN_NAME} -gt 1 ]; then
  1434. GIT_DOMAIN_NAME='git.local'
  1435. fi
  1436. if [ ${#MEDIAGOBLIN_DOMAIN_NAME} -gt 1 ]; then
  1437. MEDIAGOBLIN_DOMAIN_NAME='media.local'
  1438. fi
  1439. }
  1440. function nginx_disable_sniffing {
  1441. domain_name=$1
  1442. filename=/etc/nginx/sites-available/$domain_name
  1443. echo ' add_header X-Frame-Options DENY;' >> $filename
  1444. echo ' add_header X-Content-Type-Options nosniff;' >> $filename
  1445. echo '' >> $filename
  1446. }
  1447. function nginx_limits {
  1448. domain_name=$1
  1449. max_body='20m'
  1450. if [ $2 ]; then
  1451. max_body=$2
  1452. fi
  1453. filename=/etc/nginx/sites-available/$domain_name
  1454. echo " client_max_body_size ${max_body};" >> $filename
  1455. echo ' client_body_buffer_size 128k;' >> $filename
  1456. echo '' >> $filename
  1457. echo ' limit_conn conn_limit_per_ip 10;' >> $filename
  1458. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> $filename
  1459. echo '' >> $filename
  1460. }
  1461. function nginx_http_redirect {
  1462. # redirect port 80 to https
  1463. domain_name=$1
  1464. filename=/etc/nginx/sites-available/$domain_name
  1465. echo 'server {' > $filename
  1466. echo ' listen 80;' >> $filename
  1467. echo ' listen [::]:80;' >> $filename
  1468. echo " server_name ${domain_name};" >> $filename
  1469. echo " root /var/www/${domain_name}/htdocs;" >> $filename
  1470. echo ' access_log off;' >> $filename
  1471. echo " error_log /var/log/nginx/${domain_name}_error.log $WEBSERVER_LOG_LEVEL;" >> $filename
  1472. nginx_limits $domain_name
  1473. echo ' rewrite ^ https://$server_name$request_uri? permanent;' >> $filename
  1474. echo '}' >> $filename
  1475. echo '' >> $filename
  1476. }
  1477. function nginx_ssl {
  1478. # creates the SSL/TLS section for a website
  1479. domain_name=$1
  1480. filename=/etc/nginx/sites-available/$domain_name
  1481. echo ' ssl on;' >> $filename
  1482. echo " ssl_certificate /etc/ssl/certs/${domain_name}.crt;" >> $filename
  1483. echo " ssl_certificate_key /etc/ssl/private/${domain_name}.key;" >> $filename
  1484. echo " ssl_dhparam /etc/ssl/certs/${domain_name}.dhparam;" >> $filename
  1485. echo '' >> $filename
  1486. echo ' ssl_session_timeout 60m;' >> $filename
  1487. echo ' ssl_prefer_server_ciphers on;' >> $filename
  1488. echo " ssl_protocols $SSL_PROTOCOLS;" >> $filename
  1489. echo " ssl_ciphers '$SSL_CIPHERS';" >> $filename
  1490. }
  1491. function rss_reader_modifications {
  1492. # modify the rss reader to use a socks5 proxy rather than a http proxy
  1493. if [ ! -d $RSS_READER_PATH ]; then
  1494. return
  1495. fi
  1496. # ensure that socks5 proxy is used
  1497. if ! grep -q "CURLOPT_PROXYTYPE" $RSS_READER_PATH/plugins/af_unburn/init.php; then
  1498. sed -i '/curl_setopt($ch, CURLOPT_PROXY, _CURL_HTTP_PROXY);/a \\t\t\t\t\tcurl_setopt($ch, CURLOPT_PROXYTYPE, CURLPROXY_SOCKS5);' $RSS_READER_PATH/plugins/af_unburn/init.php
  1499. fi
  1500. if ! grep -q "CURLOPT_PROXYTYPE" $RSS_READER_PATH/include/functions.php; then
  1501. sed -i '/curl_setopt($ch, CURLOPT_PROXY, _CURL_HTTP_PROXY);/a \\t\t\t\tcurl_setopt($ch, CURLOPT_PROXYTYPE, CURLPROXY_SOCKS5);' $RSS_READER_PATH/include/functions.php
  1502. fi
  1503. chown -R www-data:www-data $RSS_READER_PATH
  1504. chmod a+x $RSS_READER_PATH
  1505. }
  1506. function set_repo_commit {
  1507. repo_dir=$1
  1508. repo_commit_name=$2
  1509. repo_commit=$3
  1510. repo_url=$4
  1511. if [ -d $repo_dir ]; then
  1512. if grep -q "$repo_commit_name" $COMPLETION_FILE; then
  1513. CURRENT_REPO_COMMIT=$(grep "$repo_commit_name" $COMPLETION_FILE | awk -F ':' '{print $2}')
  1514. if [[ "$CURRENT_REPO_COMMIT" != "$repo_commit" ]]; then
  1515. cd $repo_dir
  1516. git_pull $repo_url $repo_commit
  1517. sed -i "s/${repo_commit_name}.*/${repo_commit_name}:$repo_commit/g" $COMPLETION_FILE
  1518. # application specific stuff after updating the repo
  1519. if [[ $repo_dir == *"www"* ]]; then
  1520. chown -R www-data:www-data $repo_dir
  1521. fi
  1522. if [[ $repo_dir == *"cjdns" ]]; then
  1523. ./do
  1524. fi
  1525. if [[ $repo_dir == *"gpgit" ]]; then
  1526. cp gpgit.pl /usr/bin/gpgit.pl
  1527. fi
  1528. if [[ $repo_dir == *"cleanup-maildir" ]]; then
  1529. cp $INSTALL_DIR/cleanup-maildir/cleanup-maildir /usr/bin
  1530. fi
  1531. if [[ $repo_dir == *"nginx_ensite" ]]; then
  1532. make install
  1533. fi
  1534. if [[ $repo_dir == *"gogs" ]]; then
  1535. git checkout master
  1536. go get -u ./...
  1537. if [ ! "$?" = "0" ]; then
  1538. echo $'Failed to get gogs'
  1539. exit 52792
  1540. fi
  1541. git checkout $repo_commit
  1542. go build
  1543. if [ ! "$?" = "0" ]; then
  1544. echo $'Failed to build gogs'
  1545. exit 36226
  1546. fi
  1547. systemctl restart gogs
  1548. fi
  1549. if [[ $repo_dir == *"toxcore" ]]; then
  1550. sed -i 's|ExecStart=.*|ExecStart=/usr/local/bin/tox-bootstrapd --config /etc/tox-bootstrapd.conf|g' $rootdir/etc/systemd/system/tox-bootstrapd.service
  1551. autoreconf -i
  1552. ./configure --enable-daemon
  1553. make
  1554. make install
  1555. systemctl daemon-reload
  1556. systemctl restart tox-bootstrapd.service
  1557. fi
  1558. if [[ $repo_dir == *"toxic" ]]; then
  1559. make
  1560. make install
  1561. fi
  1562. if [[ $repo_dir == $RSS_READER_PATH ]]; then
  1563. rss_reader_modifications
  1564. fi
  1565. if [[ $repo_dir == *"inadyn" ]]; then
  1566. ./configure
  1567. USE_OPENSSL=1 make
  1568. make install
  1569. systemctl restart inadyn
  1570. fi
  1571. if [[ $repo_dir == *"ipfs" ]]; then
  1572. chown -R git:git /home/git
  1573. systemctl restart ipfs
  1574. systemctl daemon-reload
  1575. fi
  1576. fi
  1577. else
  1578. echo "${repo_commit_name}:${repo_commit}" >> $COMPLETION_FILE
  1579. fi
  1580. fi
  1581. }
  1582. function wait_for_onion_service {
  1583. onion_service_name="$1"
  1584. sleep_ctr=0
  1585. while [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; do
  1586. sleep 1
  1587. sleep_ctr=$((sleep_ctr + 1))
  1588. if [ $sleep_ctr -gt 10 ]; then
  1589. break
  1590. fi
  1591. done
  1592. if [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  1593. # restart and try a second time
  1594. systemctl restart tor
  1595. sleep_ctr=0
  1596. while [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; do
  1597. sleep 1
  1598. sleep_ctr=$((sleep_ctr + 1))
  1599. if [ $sleep_ctr -gt 10 ]; then
  1600. break
  1601. fi
  1602. done
  1603. fi
  1604. }
  1605. function add_onion_service {
  1606. onion_service_name="$1"
  1607. onion_service_port_from=$2
  1608. onion_service_port_to=$3
  1609. if [ -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  1610. echo $(cat /var/lib/tor/hidden_service_${onion_service_name}/hostname)
  1611. return
  1612. fi
  1613. if [ ! -d /var/lib/tor ]; then
  1614. echo $"No Tor installation found. ${onion_service_name} onion site cannot be configured."
  1615. exit 877367
  1616. fi
  1617. if ! grep -q "hidden_service_${onion_service_name}" /etc/tor/torrc; then
  1618. echo "HiddenServiceDir /var/lib/tor/hidden_service_${onion_service_name}/" >> /etc/tor/torrc
  1619. echo "HiddenServicePort ${onion_service_port_from} 127.0.0.1:${onion_service_port_to}" >> /etc/tor/torrc
  1620. fi
  1621. systemctl restart tor
  1622. wait_for_onion_service ${onion_service_name}
  1623. if [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  1624. echo $"${onion_service_name} onion site hostname not found"
  1625. exit 76362
  1626. fi
  1627. echo $(cat /var/lib/tor/hidden_service_${onion_service_name}/hostname)
  1628. }
  1629. function setup_wifi {
  1630. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  1631. return
  1632. fi
  1633. if [ ! $WIFI_SSID ]; then
  1634. return
  1635. fi
  1636. if [ ${#WIFI_SSID} -lt 2 ]; then
  1637. return
  1638. fi
  1639. if grep -Fxq "setup_wifi" $COMPLETION_FILE; then
  1640. return
  1641. fi
  1642. HOTSPOT='no'
  1643. if [[ $WIFI_HOTSPOT != 'no' ]]; then
  1644. HOTSPOT='yes'
  1645. fi
  1646. if [ -f $WIFI_NETWORKS_FILE ]; then
  1647. ${PROJECT_NAME}-wifi -i $WIFI_INTERFACE --networks $WIFI_NETWORKS_FILE
  1648. echo 'setup_wifi' >> $COMPLETION_FILE
  1649. return
  1650. fi
  1651. if [[ $WIFI_TYPE != 'none' ]]; then
  1652. if [ ! $WIFI_PASSPHRASE ]; then
  1653. echo $'No wifi passphrase was given'
  1654. return
  1655. fi
  1656. if [ ${#WIFI_PASSPHRASE} -lt 2 ]; then
  1657. echo $'Wifi passphrase was too short'
  1658. return
  1659. fi
  1660. ${PROJECT_NAME}-wifi -i $WIFI_INTERFACE -s $WIFI_SSID -t $WIFI_TYPE -p $WIFI_PASSPHRASE --hotspot $HOTSPOT --networks $WIFI_NETWORKS_FILE
  1661. else
  1662. ${PROJECT_NAME}-wifi -i $WIFI_INTERFACE -s $WIFI_SSID -t $WIFI_TYPE --hotspot $HOTSPOT --networks $WIFI_NETWORKS_FILE
  1663. fi
  1664. echo 'setup_wifi' >> $COMPLETION_FILE
  1665. }
  1666. function create_avahi_onion_domains {
  1667. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  1668. return
  1669. fi
  1670. if [ ! -d /etc/avahi/services ]; then
  1671. return
  1672. fi
  1673. if [ $MICROBLOG_DOMAIN_NAME ]; then
  1674. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/microblog.service
  1675. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/microblog.service
  1676. echo '<service-group>' >> /etc/avahi/services/microblog.service
  1677. echo ' <name replace-wildcards="yes">%h HTTP</name>' >> /etc/avahi/services/microblog.service
  1678. echo ' <service>' >> /etc/avahi/services/microblog.service
  1679. echo ' <type>_http._tcp</type>' >> /etc/avahi/services/microblog.service
  1680. echo " <port>$MICROBLOG_ONION_PORT</port>" >> /etc/avahi/services/microblog.service
  1681. echo ' </service>' >> /etc/avahi/services/microblog.service
  1682. echo '</service-group>' >> /etc/avahi/services/microblog.service
  1683. fi
  1684. if [ $FULLBLOG_DOMAIN_NAME ]; then
  1685. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/blog.service
  1686. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/blog.service
  1687. echo '<service-group>' >> /etc/avahi/services/blog.service
  1688. echo ' <name replace-wildcards="yes">%h HTTP</name>' >> /etc/avahi/services/blog.service
  1689. echo ' <service>' >> /etc/avahi/services/blog.service
  1690. echo ' <type>_http._tcp</type>' >> /etc/avahi/services/blog.service
  1691. echo " <port>$BLOG_ONION_PORT</port>" >> /etc/avahi/services/blog.service
  1692. echo ' </service>' >> /etc/avahi/services/blog.service
  1693. echo '</service-group>' >> /etc/avahi/services/blog.service
  1694. fi
  1695. if [ $GIT_DOMAIN_NAME ]; then
  1696. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/git.service
  1697. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/git.service
  1698. echo '<service-group>' >> /etc/avahi/services/git.service
  1699. echo ' <name replace-wildcards="yes">%h HTTP</name>' >> /etc/avahi/services/git.service
  1700. echo ' <service>' >> /etc/avahi/services/git.service
  1701. echo ' <type>_http._tcp</type>' >> /etc/avahi/services/git.service
  1702. echo " <port>$GIT_ONION_PORT</port>" >> /etc/avahi/services/git.service
  1703. echo ' </service>' >> /etc/avahi/services/git.service
  1704. echo '</service-group>' >> /etc/avahi/services/git.service
  1705. fi
  1706. if [ $WIKI_DOMAIN_NAME ]; then
  1707. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/wiki.service
  1708. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/wiki.service
  1709. echo '<service-group>' >> /etc/avahi/services/wiki.service
  1710. echo ' <name replace-wildcards="yes">%h HTTP</name>' >> /etc/avahi/services/wiki.service
  1711. echo ' <service>' >> /etc/avahi/services/wiki.service
  1712. echo ' <type>_http._tcp</type>' >> /etc/avahi/services/wiki.service
  1713. echo " <port>$WIKI_ONION_PORT</port>" >> /etc/avahi/services/wiki.service
  1714. echo ' </service>' >> /etc/avahi/services/wiki.service
  1715. echo '</service-group>' >> /etc/avahi/services/wiki.service
  1716. fi
  1717. }
  1718. # check an individual domain name
  1719. function test_domain_name {
  1720. if [ $1 ]; then
  1721. TEST_DOMAIN_NAME=$1
  1722. validate_domain_name
  1723. if [[ $TEST_DOMAIN_NAME != $1 ]]; then
  1724. echo $TEST_DOMAIN_NAME
  1725. exit 8528
  1726. fi
  1727. fi
  1728. }
  1729. # check that domain names are sensible
  1730. function check_domains {
  1731. if [ ${#WIKI_DOMAIN_NAME} -gt 1 ]; then
  1732. test_domain_name "$WIKI_DOMAIN_NAME"
  1733. if [[ "$test_domain_name" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  1734. echo $'Wiki domain name is the same as blog domain name. They must be different'
  1735. exit 97326
  1736. fi
  1737. if [[ "$test_domain_name" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  1738. echo $'Wiki domain name is the same as microblog domain name. They must be different'
  1739. exit 36827
  1740. fi
  1741. if [[ "$test_domain_name" == "$HUBZILLA_DOMAIN_NAME" ]]; then
  1742. echo $'Wiki domain name is the same as hubzilla domain name. They must be different'
  1743. exit 65848
  1744. fi
  1745. if [ ${#GIT_DOMAIN_NAME} -gt 1 ]; then
  1746. if [[ "$test_domain_name" == "$GIT_DOMAIN_NAME" ]]; then
  1747. echo $'Wiki domain name is the same as Gogs domain name. They must be different'
  1748. exit 73529
  1749. fi
  1750. fi
  1751. fi
  1752. if [ ${#FULLBLOG_DOMAIN_NAME} -gt 1 ]; then
  1753. test_domain_name "$FULLBLOG_DOMAIN_NAME"
  1754. if [[ "$test_domain_name" == "$WIKI_DOMAIN_NAME" ]]; then
  1755. echo $'Blog domain name is the same as wiki domain name. They must be different'
  1756. exit 62348
  1757. fi
  1758. if [[ "$test_domain_name" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  1759. echo $'Blog domain name is the same as microblog domain name. They must be different'
  1760. exit 38236
  1761. fi
  1762. if [[ "$test_domain_name" == "$HUBZILLA_DOMAIN_NAME" ]]; then
  1763. echo $'Blog domain name is the same as hubzilla domain name. They must be different'
  1764. exit 35483
  1765. fi
  1766. if [ $GIT_DOMAIN_NAME ]; then
  1767. if [[ "$test_domain_name" == "$GIT_DOMAIN_NAME" ]]; then
  1768. echo $'Blog domain name is the same as Gogs domain name. They must be different'
  1769. exit 84695
  1770. fi
  1771. fi
  1772. fi
  1773. if [ ${#MICROBLOG_DOMAIN_NAME} -gt 1 ]; then
  1774. test_domain_name "$MICROBLOG_DOMAIN_NAME"
  1775. if [[ "$test_domain_name" == "$WIKI_DOMAIN_NAME" ]]; then
  1776. echo $'Microblog domain name is the same as wiki domain name. They must be different'
  1777. exit 73924
  1778. fi
  1779. if [[ "$test_domain_name" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  1780. echo $'Microblog domain name is the same as blog domain name. They must be different'
  1781. exit 26832
  1782. fi
  1783. if [[ "$test_domain_name" == "$HUBZILLA_DOMAIN_NAME" ]]; then
  1784. echo $'Microblog domain name is the same as hubzilla domain name. They must be different'
  1785. exit 678382
  1786. fi
  1787. if [ $GIT_DOMAIN_NAME ]; then
  1788. if [[ "$test_domain_name" == "$GIT_DOMAIN_NAME" ]]; then
  1789. echo $'Microblog domain name is the same as Gogs domain name. They must be different'
  1790. exit 684325
  1791. fi
  1792. fi
  1793. fi
  1794. if [ $HUBZILLA_DOMAIN_NAME ]; then
  1795. test_domain_name "$HUBZILLA_DOMAIN_NAME"
  1796. if [[ "$test_domain_name" == "$WIKI_DOMAIN_NAME" ]]; then
  1797. echo $'Hubzilla domain name is the same as wiki domain name. They must be different'
  1798. exit 83682
  1799. fi
  1800. if [[ "$test_domain_name" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  1801. echo $'Hubzilla domain name is the same as blog domain name. They must be different'
  1802. exit 74817
  1803. fi
  1804. if [[ "$test_domain_name" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  1805. echo $'Hubzilla domain name is the same as microblog domain name. They must be different'
  1806. exit 83683
  1807. fi
  1808. if [ ${#GIT_DOMAIN_NAME} -gt 1 ]; then
  1809. if [[ "$test_domain_name" == "$GIT_DOMAIN_NAME" ]]; then
  1810. echo $'Hubzilla domain name is the same as Gogs domain name. They must be different'
  1811. exit 135523
  1812. fi
  1813. fi
  1814. fi
  1815. if [ ${#GIT_DOMAIN_NAME} -gt 1 ]; then
  1816. test_domain_name "$GIT_DOMAIN_NAME"
  1817. if [[ "$test_domain_name" == "$WIKI_DOMAIN_NAME" ]]; then
  1818. echo $'Hubzilla domain name is the same as wiki domain name. They must be different'
  1819. exit 83682
  1820. fi
  1821. if [[ "$test_domain_name" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  1822. echo $'Hubzilla domain name is the same as blog domain name. They must be different'
  1823. exit 74817
  1824. fi
  1825. if [[ "$test_domain_name" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  1826. echo $'Hubzilla domain name is the same as microblog domain name. They must be different'
  1827. exit 83683
  1828. fi
  1829. if [[ "$test_domain_name" == "$HUBZILLA_DOMAIN_NAME" ]]; then
  1830. echo $'Microblog domain name is the same as hubzilla domain name. They must be different'
  1831. exit 678382
  1832. fi
  1833. fi
  1834. }
  1835. # Checks whether certificates were generated for the given hostname
  1836. function check_certificates {
  1837. if [ ! $1 ]; then
  1838. return
  1839. fi
  1840. USE_LETSENCRYPT='no'
  1841. if [ $2 ]; then
  1842. USE_LETSENCRYPT=$2
  1843. fi
  1844. if [[ $USE_LETSENCRYPT == 'no' ]]; then
  1845. if [ ! -f /etc/ssl/private/$1.key ]; then
  1846. echo $"Private certificate for $CHECK_HOSTNAME was not created"
  1847. exit 63959
  1848. fi
  1849. if [ ! -f /etc/ssl/certs/$1.crt ]; then
  1850. echo $"Public certificate for $CHECK_HOSTNAME was not created"
  1851. exit 7679
  1852. fi
  1853. else
  1854. if [ ! -f /etc/letsencrypt/live/${1}/privkey.pem ]; then
  1855. echo $"Private certificate for $CHECK_HOSTNAME was not created"
  1856. exit 6282
  1857. fi
  1858. if [ ! -f /etc/letsencrypt/live/${1}/fullchain.pem ]; then
  1859. echo $"Public certificate for $CHECK_HOSTNAME was not created"
  1860. exit 5328
  1861. fi
  1862. fi
  1863. if [ ! -f /etc/ssl/certs/$1.dhparam ]; then
  1864. echo $"Diffie–Hellman parameters for $CHECK_HOSTNAME were not created"
  1865. exit 5989
  1866. fi
  1867. }
  1868. function create_site_certificate {
  1869. SITE_DOMAIN_NAME="$1"
  1870. # if yes then only "valid" certs are allowed, not self-signed
  1871. NO_SELF_SIGNED='no'
  1872. if [ $2 ]; then
  1873. NO_SELF_SIGNED="$2"
  1874. fi
  1875. if [[ $ONION_ONLY == "no" ]]; then
  1876. if [ ! -f /etc/ssl/certs/$SITE_DOMAIN_NAME.dhparam ]; then
  1877. if [[ $LETSENCRYPT_ENABLED != "yes" ]]; then
  1878. ${PROJECT_NAME}-addcert -h $SITE_DOMAIN_NAME --dhkey $DH_KEYLENGTH
  1879. check_certificates $SITE_DOMAIN_NAME
  1880. else
  1881. ${PROJECT_NAME}-addcert -e $SITE_DOMAIN_NAME -s $LETSENCRYPT_SERVER --dhkey $DH_KEYLENGTH --email $MY_EMAIL_ADDRESS
  1882. if [ ! "$?" = "0" ]; then
  1883. if [[ $NO_SELF_SIGNED == 'no' ]]; then
  1884. echo $"Lets Encrypt failed for $SITE_DOMAIN_NAME, so try making a self-signed cert"
  1885. ${PROJECT_NAME}-addcert -h $SITE_DOMAIN_NAME --dhkey $DH_KEYLENGTH
  1886. check_certificates $SITE_DOMAIN_NAME
  1887. else
  1888. echo $"Lets Encrypt failed for $SITE_DOMAIN_NAME"
  1889. exit 682529
  1890. fi
  1891. else
  1892. check_certificates $SITE_DOMAIN_NAME 'yes'
  1893. fi
  1894. fi
  1895. fi
  1896. fi
  1897. }
  1898. function backup_database_local {
  1899. # Makes local backups of databases which can then be automatically rolled
  1900. # back if corruption is detected
  1901. database_name=$1
  1902. backup_databases_script=/usr/bin/backupdatabases
  1903. echo '' >> $backup_databases_script
  1904. echo "# Backup the ${database_name} database" >> $backup_databases_script
  1905. echo "TEMPFILE=/root/${database_name}.sql" >> $backup_databases_script
  1906. echo 'DAILYFILE=/var/backups/${database_name}_daily.sql' >> $backup_databases_script
  1907. echo "mysqldump --password=\"\$MYSQL_PASSWORD\" ${database_name} > \$TEMPFILE" >> $backup_databases_script
  1908. echo 'FILESIZE=$(stat -c%s $TEMPFILE)' >> $backup_databases_script
  1909. echo 'if [ "$FILESIZE" -eq "0" ]; then' >> $backup_databases_script
  1910. echo ' if [ -f $DAILYFILE ]; then' >> $backup_databases_script
  1911. echo ' cp $DAILYFILE $TEMPFILE' >> $backup_databases_script
  1912. echo '' >> $backup_databases_script
  1913. echo ' # try to restore yesterdays database' >> $backup_databases_script
  1914. echo " mysql -u root --password=\"\$MYSQL_PASSWORD\" ${database_name} -o < \$DAILYFILE" >> $backup_databases_script
  1915. echo '' >> $backup_databases_script
  1916. echo ' # Send a warning email' >> $backup_databases_script
  1917. echo " echo \"Unable to create a backup of the ${database_name} database. Attempted to restore from yesterdays backup\" | mail -s \"${database_name} backup\" \$EMAIL" >> $backup_databases_script
  1918. echo ' else' >> $backup_databases_script
  1919. echo ' # Send a warning email' >> $backup_databases_script
  1920. echo " echo \"Unable to create a backup of the ${database_name} database.\" | mail -s \"${database_name} backup\" \$EMAIL" >> $backup_databases_script
  1921. echo ' fi' >> $backup_databases_script
  1922. echo 'else' >> $backup_databases_script
  1923. echo ' chmod 600 $TEMPFILE' >> $backup_databases_script
  1924. echo ' mv $TEMPFILE $DAILYFILE' >> $backup_databases_script
  1925. echo '' >> $backup_databases_script
  1926. echo ' # Make the backup readable only by root' >> $backup_databases_script
  1927. echo ' chmod 600 $DAILYFILE' >> $backup_databases_script
  1928. echo 'fi' >> $backup_databases_script
  1929. weekly_backup_script=/etc/cron.weekly/backupdatabasesweekly
  1930. if ! grep -q "${database_name}" ${weekly_backup_script}; then
  1931. echo '' >> ${weekly_backup_script}
  1932. echo "# ${database_name}" >> ${weekly_backup_script}
  1933. echo "if [ -f /var/backups/${database_name}_weekly.sql ]; then" >> ${weekly_backup_script}
  1934. echo " cp -f /var/backups/${database_name}_weekly.sql /var/backups/${database_name}_2weekly.sql" >> ${weekly_backup_script}
  1935. echo 'fi' >> ${weekly_backup_script}
  1936. echo "if [ -f /var/backups/${database_name}_daily.sql ]; then" >> ${weekly_backup_script}
  1937. echo " cp -f /var/backups/${database_name}_daily.sql /var/backups/${database_name}_weekly.sql" >> ${weekly_backup_script}
  1938. echo 'fi' >> ${weekly_backup_script}
  1939. fi
  1940. monthly_backup_script=/etc/cron.monthly/backupdatabasesmonthly
  1941. if ! grep -q "${database_name}" ${monthly_backup_script}; then
  1942. echo '' >> ${monthly_backup_script}
  1943. echo "# ${database_name}" >> ${monthly_backup_script}
  1944. echo "if [ -f /var/backups/${database_name}_monthly.sql ]; then" >> ${monthly_backup_script}
  1945. echo " cp -f /var/backups/${database_name}_monthly.sql /var/backups/${database_name}_2monthly.sql" >> ${monthly_backup_script}
  1946. echo 'fi' >> ${monthly_backup_script}
  1947. echo "if [ -f /var/backups/${database_name}_weekly.sql ]; then" >> ${monthly_backup_script}
  1948. echo " cp -f /var/backups/${database_name}_weekly.sql /var/backups/${database_name}_monthly.sql" >> ${monthly_backup_script}
  1949. echo 'fi' >> ${monthly_backup_script}
  1950. fi
  1951. if ! grep -q "${database_name}" /etc/cron.hourly/repair; then
  1952. echo "${PROJECT_NAME}-repair-database ${database_name}" >> /etc/cron.hourly/repair
  1953. # remove legacy stuff
  1954. sed -i 's|/usr/bin/repairdatabase redmatrix||g' /etc/cron.hourly/repair
  1955. fi
  1956. }
  1957. function install_not_on_BBB {
  1958. if grep -Fxq "install_not_on_BBB" $COMPLETION_FILE; then
  1959. return
  1960. fi
  1961. if [[ INSTALLING_ON_BBB == "yes" ]]; then
  1962. return
  1963. fi
  1964. if [ ! $LOCAL_NETWORK_STATIC_IP_ADDRESS ]; then
  1965. return
  1966. fi
  1967. echo '# The loopback network interface' > /etc/network/interfaces
  1968. echo 'auto lo' >> /etc/network/interfaces
  1969. echo 'iface lo inet loopback' >> /etc/network/interfaces
  1970. echo '' >> /etc/network/interfaces
  1971. echo '# The primary network interface' >> /etc/network/interfaces
  1972. echo 'auto eth0' >> /etc/network/interfaces
  1973. echo 'iface eth0 inet static' >> /etc/network/interfaces
  1974. echo " address $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/network/interfaces
  1975. echo ' netmask 255.255.255.0' >> /etc/network/interfaces
  1976. echo " gateway $ROUTER_IP_ADDRESS" >> /etc/network/interfaces
  1977. echo " dns-nameservers $NAMESERVER1 $NAMESERVER2" >> /etc/network/interfaces
  1978. echo '# Example to keep MAC address between reboots' >> /etc/network/interfaces
  1979. echo '#hwaddress ether DE:AD:BE:EF:CA:FE' >> /etc/network/interfaces
  1980. echo '' >> /etc/network/interfaces
  1981. echo '# The secondary network interface' >> /etc/network/interfaces
  1982. echo '#auto eth1' >> /etc/network/interfaces
  1983. echo '#iface eth1 inet dhcp' >> /etc/network/interfaces
  1984. echo '' >> /etc/network/interfaces
  1985. echo '# WiFi Example' >> /etc/network/interfaces
  1986. echo "#auto $WIFI_INTERFACE" >> /etc/network/interfaces
  1987. echo "#iface $WIFI_INTERFACE inet dhcp" >> /etc/network/interfaces
  1988. echo '# wpa-ssid "essid"' >> /etc/network/interfaces
  1989. echo '# wpa-psk "password"' >> /etc/network/interfaces
  1990. echo '' >> /etc/network/interfaces
  1991. echo '# Ethernet/RNDIS gadget (g_ether)' >> /etc/network/interfaces
  1992. echo '# ... or on host side, usbnet and random hwaddr' >> /etc/network/interfaces
  1993. echo '# Note on some boards, usb0 is automaticly setup with an init script' >> /etc/network/interfaces
  1994. echo '#iface usb0 inet static' >> /etc/network/interfaces
  1995. echo '# address 192.168.7.2' >> /etc/network/interfaces
  1996. echo '# netmask 255.255.255.0' >> /etc/network/interfaces
  1997. echo '# network 192.168.7.0' >> /etc/network/interfaces
  1998. echo '# gateway 192.168.7.1' >> /etc/network/interfaces
  1999. echo 'install_not_on_BBB' >> $COMPLETION_FILE
  2000. }
  2001. function mark_admin_user_account {
  2002. if ! grep -q "Admin user:" $COMPLETION_FILE; then
  2003. echo "Admin user:$MY_USERNAME" >> $COMPLETION_FILE
  2004. fi
  2005. }
  2006. function mark_blog_domain {
  2007. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  2008. return
  2009. fi
  2010. if ! grep -q "Blog domain:" $COMPLETION_FILE; then
  2011. echo "Blog domain:$FULLBLOG_DOMAIN_NAME" >> $COMPLETION_FILE
  2012. fi
  2013. }
  2014. function randomize_cron {
  2015. # The predictable default timing of Debian cron jobs might
  2016. # be exploitable knowledge. Avoid too much predictability
  2017. # by randomizing the times when cron jobs run
  2018. if grep -Fxq "randomize_cron" $COMPLETION_FILE; then
  2019. return
  2020. fi
  2021. # randomize the day on which the weekly cron job runs
  2022. randdow=$(($RANDOM%6+1))
  2023. sed -i "s|\* \* 7|* * $randdow|g" /etc/crontab
  2024. # randomize the time when the weekly cron job runs
  2025. randmin=$(($RANDOM%60))
  2026. randhr=$(($RANDOM%3+1))
  2027. sed -i "s|47 6|$randmin $randhr|g" /etc/crontab
  2028. # randomize the time when the daily cron job runs
  2029. randmin=$(($RANDOM%60))
  2030. randhr=$(($RANDOM%3+4))
  2031. sed -i "s|25 6\t\* \* \*|$randmin $randhr\t* * *|g" /etc/crontab
  2032. # randomize the time when the hourly cron job runs
  2033. randmin=$(($RANDOM%60))
  2034. sed -i "s|17 \*\t|$randmin *\t|g" /etc/crontab
  2035. # randomize monthly cron job time and day
  2036. randmin=$(($RANDOM%60))
  2037. randhr=$(($RANDOM%22+1))
  2038. randdom=$(($RANDOM%27+1))
  2039. sed -i "s|52 6\t|$randmin $randhr\t|g" /etc/crontab
  2040. sed -i "s|\t1 \* \*|\t$randdom * *|g" /etc/crontab
  2041. systemctl restart cron
  2042. echo 'randomize_cron' >> $COMPLETION_FILE
  2043. }
  2044. function get_cjdns_public_key {
  2045. if [ -f /home/$MY_USERNAME/README ]; then
  2046. if grep -q "cjdns public key" /home/$MY_USERNAME/README; then
  2047. if [ ! $CJDNS_PUBLIC_KEY ]; then
  2048. CJDNS_PUBLIC_KEY=$(cat /home/$MY_USERNAME/README | grep "cjdns public key" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2049. fi
  2050. fi
  2051. fi
  2052. }
  2053. function get_cjdns_private_key {
  2054. if [ -f /home/$MY_USERNAME/README ]; then
  2055. if grep -q "cjdns private key" /home/$MY_USERNAME/README; then
  2056. if [ ! $CJDNS_PRIVATE_KEY ]; then
  2057. CJDNS_PRIVATE_KEY=$(cat /home/$MY_USERNAME/README | grep "cjdns private key" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2058. fi
  2059. fi
  2060. fi
  2061. }
  2062. function get_cjdns_ipv6_address {
  2063. if [ -f /home/$MY_USERNAME/README ]; then
  2064. if grep -q "cjdns IPv6 address" /home/$MY_USERNAME/README; then
  2065. if [ ! $CJDNS_IPV6 ]; then
  2066. CJDNS_IPV6=$(cat /home/$MY_USERNAME/README | grep "cjdns IPv6 address" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2067. fi
  2068. fi
  2069. fi
  2070. }
  2071. function get_cjdns_port {
  2072. if [ -f /home/$MY_USERNAME/README ]; then
  2073. if grep -q "cjdns port" /home/$MY_USERNAME/README; then
  2074. if [ ! $CJDNS_PORT ]; then
  2075. CJDNS_PORT=$(cat /home/$MY_USERNAME/README | grep "cjdns port" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2076. fi
  2077. fi
  2078. fi
  2079. }
  2080. function get_cjdns_password {
  2081. if [ -f /home/$MY_USERNAME/README ]; then
  2082. if grep -q "cjdns password" /home/$MY_USERNAME/README; then
  2083. if [ ! $CJDNS_PASSWORD ]; then
  2084. CJDNS_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "cjdns password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2085. fi
  2086. fi
  2087. fi
  2088. }
  2089. # script to automatically renew any Let's Encrypt certificates
  2090. function letsencrypt_renewals {
  2091. if [[ $ONION_ONLY != "no" ]]; then
  2092. return
  2093. fi
  2094. renewals_script=/etc/cron.monthly/letsencrypt
  2095. renewals_retry_script=/etc/cron.daily/letsencrypt
  2096. renewal_failure_msg=$'The certificate for $LETSENCRYPT_DOMAIN could not be renewed'
  2097. renewal_email_title=$'${PROJECT_NAME} Lets Encrypt certificate renewal'
  2098. # the main script tries to renew once per month
  2099. echo '#!/bin/bash' > $renewals_script
  2100. echo '' >> $renewals_script
  2101. echo "PROJECT_NAME='${PROJECT_NAME}'" >> $renewals_script
  2102. echo 'COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt' >> $renewals_script
  2103. echo '' >> $renewals_script
  2104. echo 'if [ -d /etc/letsencrypt ]; then' >> $renewals_script
  2105. echo ' if [ -f ~/letsencrypt_failed ]; then' >> $renewals_script
  2106. echo ' rm ~/letsencrypt_failed' >> $renewals_script
  2107. echo ' fi' >> $renewals_script
  2108. echo -n ' ADMIN_USERNAME=$(cat $COMPLETION_FILE | grep "Admin user" | ' >> $renewals_script
  2109. echo -n "awk -F ':' '{print " >> $renewals_script
  2110. echo -n '$2' >> $renewals_script
  2111. echo "}')" >> $renewals_script
  2112. echo ' ADMIN_EMAIL_ADDRESS=$ADMIN_USERNAME@$HOSTNAME' >> $renewals_script
  2113. echo ' for d in /etc/letsencrypt/live/*/ ; do' >> $renewals_script
  2114. echo -n ' LETSENCRYPT_DOMAIN=$(echo "$d" | ' >> $renewals_script
  2115. echo -n "awk -F '/' '{print " >> $renewals_script
  2116. echo -n '$5' >> $renewals_script
  2117. echo "}')" >> $renewals_script
  2118. echo ' if [ -f /etc/nginx/sites-available/$LETSENCRYPT_DOMAIN ]; then' >> $renewals_script
  2119. echo ' ${PROJECT_NAME}-renew-cert -h $LETSENCRYPT_DOMAIN -p letsencrypt' >> $renewals_script
  2120. echo ' if [ ! "$?" = "0" ]; then' >> $renewals_script
  2121. echo " echo \"${renewal_failure_msg}\" > ~/temp_renewletsencrypt.txt" >> $renewals_script
  2122. echo ' echo "" >> ~/temp_renewletsencrypt.txt' >> $renewals_script
  2123. echo ' ${PROJECT_NAME}-renew-cert -h $LETSENCRYPT_DOMAIN -p letsencrypt 2>> ~/temp_renewletsencrypt.txt' >> $renewals_script
  2124. echo -n " cat ~/temp_renewletsencrypt.txt | mail -s \"${renewal_email_title}\" " >> $renewals_script
  2125. echo '$ADMIN_EMAIL_ADDRESS' >> $renewals_script
  2126. echo ' rm ~/temp_renewletsencrypt.txt' >> $renewals_script
  2127. echo ' if [ ! -f ~/letsencrypt_failed ]; then' >> $renewals_script
  2128. echo ' touch ~/letsencrypt_failed' >> $renewals_script
  2129. echo ' fi' >> $renewals_script
  2130. echo ' fi' >> $renewals_script
  2131. echo ' fi' >> $renewals_script
  2132. echo ' done' >> $renewals_script
  2133. echo 'fi' >> $renewals_script
  2134. chmod +x $renewals_script
  2135. # a secondary script keeps trying to renew after a failure
  2136. echo '#!/bin/bash' > $renewals_retry_script
  2137. echo '' >> $renewals_retry_script
  2138. echo "PROJECT_NAME='${PROJECT_NAME}'" >> $renewals_retry_script
  2139. echo 'COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt' >> $renewals_retry_script
  2140. echo '' >> $renewals_retry_script
  2141. echo 'if [ -d /etc/letsencrypt ]; then' >> $renewals_retry_script
  2142. echo ' if [ -f ~/letsencrypt_failed ]; then' >> $renewals_retry_script
  2143. echo ' rm ~/letsencrypt_failed' >> $renewals_retry_script
  2144. echo -n ' ADMIN_USERNAME=$(cat $COMPLETION_FILE | grep "Admin user" | ' >> $renewals_retry_script
  2145. echo -n "awk -F ':' '{print " >> $renewals_retry_script
  2146. echo -n '$2' >> $renewals_retry_script
  2147. echo "}')" >> $renewals_retry_script
  2148. echo ' ADMIN_EMAIL_ADDRESS=$ADMIN_USERNAME@$HOSTNAME' >> $renewals_retry_script
  2149. echo ' for d in /etc/letsencrypt/live/*/ ; do' >> $renewals_retry_script
  2150. echo -n ' LETSENCRYPT_DOMAIN=$(echo "$d" | ' >> $renewals_retry_script
  2151. echo -n "awk -F '/' '{print " >> $renewals_retry_script
  2152. echo -n '$5' >> $renewals_retry_script
  2153. echo "}')" >> $renewals_retry_script
  2154. echo ' if [ -f /etc/nginx/sites-available/$LETSENCRYPT_DOMAIN ]; then' >> $renewals_retry_script
  2155. echo ' ${PROJECT_NAME}-renew-cert -h $LETSENCRYPT_DOMAIN -p letsencrypt' >> $renewals_retry_script
  2156. echo ' if [ ! "$?" = "0" ]; then' >> $renewals_retry_script
  2157. echo " echo \"${renewal_failure_msg}\" > ~/temp_renewletsencrypt.txt" >> $renewals_retry_script
  2158. echo ' echo "" >> ~/temp_renewletsencrypt.txt' >> $renewals_retry_script
  2159. echo ' ${PROJECT_NAME}-renew-cert -h $LETSENCRYPT_DOMAIN -p letsencrypt 2>> ~/temp_renewletsencrypt.txt' >> $renewals_retry_script
  2160. echo -n " cat ~/temp_renewletsencrypt.txt | mail -s \"${renewal_email_title}\" " >> $renewals_retry_script
  2161. echo '$ADMIN_EMAIL_ADDRESS' >> $renewals_retry_script
  2162. echo ' rm ~/temp_renewletsencrypt.txt' >> $renewals_retry_script
  2163. echo ' if [ ! -f ~/letsencrypt_failed ]; then' >> $renewals_retry_script
  2164. echo ' touch ~/letsencrypt_failed' >> $renewals_retry_script
  2165. echo ' fi' >> $renewals_retry_script
  2166. echo ' fi' >> $renewals_retry_script
  2167. echo ' fi' >> $renewals_retry_script
  2168. echo ' done' >> $renewals_retry_script
  2169. echo ' fi' >> $renewals_retry_script
  2170. echo 'fi' >> $renewals_retry_script
  2171. chmod +x $renewals_retry_script
  2172. }
  2173. function save_firewall_settings {
  2174. iptables-save > /etc/firewall.conf
  2175. ip6tables-save > /etc/firewall6.conf
  2176. printf '#!/bin/sh\n' > /etc/network/if-up.d/iptables
  2177. printf 'iptables-restore < /etc/firewall.conf\n' >> /etc/network/if-up.d/iptables
  2178. printf 'ip6tables-restore < /etc/firewall6.conf\n' >> /etc/network/if-up.d/iptables
  2179. chmod +x /etc/network/if-up.d/iptables
  2180. }
  2181. function enable_ipv6 {
  2182. # endure that ipv6 is enabled and can route
  2183. sed -i 's/net.ipv6.conf.all.disable_ipv6.*/net.ipv6.conf.all.disable_ipv6 = 0/g' /etc/sysctl.conf
  2184. #sed -i "s/net.ipv6.conf.all.accept_redirects.*/net.ipv6.conf.all.accept_redirects = 1/g" /etc/sysctl.conf
  2185. #sed -i "s/net.ipv6.conf.all.accept_source_route.*/net.ipv6.conf.all.accept_source_route = 1/g" /etc/sysctl.conf
  2186. sed -i "s/net.ipv6.conf.all.forwarding.*/net.ipv6.conf.all.forwarding=1/g" /etc/sysctl.conf
  2187. echo 1 > /proc/sys/net/ipv6/conf/all/forwarding
  2188. }
  2189. function mesh_cjdns {
  2190. if [[ $ENABLE_CJDNS != "yes" ]]; then
  2191. return
  2192. fi
  2193. # update to the next commit
  2194. set_repo_commit /etc/cjdns "cjdns commit" "$CJDNS_COMMIT" $CJDNS_REPO
  2195. if grep -Fxq "mesh_cjdns" $COMPLETION_FILE; then
  2196. return
  2197. fi
  2198. apt-get -y install nodejs git build-essential nmap
  2199. # if a README exists then obtain the cjdns parameters
  2200. get_cjdns_ipv6_address
  2201. get_cjdns_public_key
  2202. get_cjdns_private_key
  2203. get_cjdns_port
  2204. get_cjdns_password
  2205. # special compile settings for running ./do on the Beaglebone Black
  2206. if [[ $INSTALLING_ON_BBB == "yes" ]]; then
  2207. CFLAGS="-O2 -march=armv7-a -mtune=cortex-a8 -mfpu=neon -ftree-vectorize -ffast-math -mfloat-abi=hard -marm -Wno-error=maybe-uninitialized"
  2208. export LDFLAGS="$CFLAGS"
  2209. fi
  2210. if [ ! -d /etc/cjdns ]; then
  2211. git_clone $CJDNS_REPO /etc/cjdns
  2212. cd /etc/cjdns
  2213. git checkout $CJDNS_COMMIT -b $CJDNS_COMMIT
  2214. if ! grep -q "cjdns commit" $COMPLETION_FILE; then
  2215. echo "cjdns commit:$CJDNS_COMMIT" >> $COMPLETION_FILE
  2216. else
  2217. sed -i "s/cjdns commit.*/cjdns commit:$CJDNS_COMMIT/g" $COMPLETION_FILE
  2218. fi
  2219. ./do
  2220. if [ ! "$?" = "0" ]; then
  2221. exit 7439
  2222. fi
  2223. # create a configuration
  2224. if [ ! -f /etc/cjdns/cjdroute.conf ]; then
  2225. ./cjdroute --genconf > /etc/cjdns/cjdroute.conf
  2226. if [ ! "$?" = "0" ]; then
  2227. exit 5922
  2228. fi
  2229. fi
  2230. # create a user to run as
  2231. useradd cjdns
  2232. else
  2233. cd /etc/cjdns
  2234. git_pull $CJDNS_REPO
  2235. ./do
  2236. if [ ! "$?" = "0" ]; then
  2237. exit 9926
  2238. fi
  2239. fi
  2240. # set permissions
  2241. chown -R cjdns:cjdns /etc/cjdns
  2242. chmod 600 /etc/cjdns/cjdroute.conf
  2243. /sbin/ip tuntap add mode tun user cjdns dev cjdroute0
  2244. # insert values into the configuration file
  2245. if [ $CJDNS_PRIVATE_KEY ]; then
  2246. sed -i "s/\"privateKey\":.*/\"privateKey\": \"$CJDNS_PRIVATE_KEY\",/g" /etc/cjdns/cjdroute.conf
  2247. else
  2248. CJDNS_PRIVATE_KEY=$(cat /etc/cjdns/cjdroute.conf | grep '"privateKey"' | awk -F '"' '{print $4}' | sed -n 1p)
  2249. fi
  2250. if [ $CJDNS_PUBLIC_KEY ]; then
  2251. sed -i "s/\"publicKey\":.*/\"publicKey\": \"$CJDNS_PUBLIC_KEY\",/g" /etc/cjdns/cjdroute.conf
  2252. else
  2253. CJDNS_PUBLIC_KEY=$(cat /etc/cjdns/cjdroute.conf | grep '"publicKey"' | awk -F '"' '{print $4}' | sed -n 1p)
  2254. fi
  2255. if [ $CJDNS_IPV6 ]; then
  2256. sed -i "s/\"ipv6\":.*/\"ipv6\": \"$CJDNS_IPV6\",/g" /etc/cjdns/cjdroute.conf
  2257. else
  2258. CJDNS_IPV6=$(cat /etc/cjdns/cjdroute.conf | grep '"ipv6"' | awk -F '"' '{print $4}' | sed -n 1p)
  2259. fi
  2260. if [ $CJDNS_PASSWORD ]; then
  2261. sed -i "0,/{\"password\":.*/s//{\"password\": \"$CJDNS_PASSWORD\"}/g" /etc/cjdns/cjdroute.conf
  2262. else
  2263. CJDNS_PASSWORD=$(cat /etc/cjdns/cjdroute.conf | grep '"password"' | awk -F '"' '{print $4}' | sed -n 1p)
  2264. fi
  2265. if [ $CJDNS_PORT ]; then
  2266. sed -i "s/\"bind\": \"0.0.0.0:.*/\"bind\": \"0.0.0.0:$CJDNS_PORT\",/g" /etc/cjdns/cjdroute.conf
  2267. else
  2268. CJDNS_PORT=$(cat /etc/cjdns/cjdroute.conf | grep '"bind": "0.0.0.0:' | awk -F '"' '{print $4}' | awk -F ':' '{print $2}' | sed -n 1p)
  2269. fi
  2270. enable_ipv6
  2271. echo '#!/bin/sh -e' > /etc/init.d/cjdns
  2272. echo '### BEGIN INIT INFO' >> /etc/init.d/cjdns
  2273. echo '# hyperboria.sh - An init script (/etc/init.d/) for cjdns' >> /etc/init.d/cjdns
  2274. echo '# Provides: cjdroute' >> /etc/init.d/cjdns
  2275. echo '# Required-Start: $remote_fs $network' >> /etc/init.d/cjdns
  2276. echo '# Required-Stop: $remote_fs $network' >> /etc/init.d/cjdns
  2277. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/cjdns
  2278. echo '# Default-Stop: 0 1 6' >> /etc/init.d/cjdns
  2279. echo '# Short-Description: Cjdns router' >> /etc/init.d/cjdns
  2280. echo '# Description: A routing engine designed for security, scalability, speed and ease of use.' >> /etc/init.d/cjdns
  2281. echo '# cjdns git repo: https://github.com/cjdelisle/cjdns/' >> /etc/init.d/cjdns
  2282. echo '### END INIT INFO' >> /etc/init.d/cjdns
  2283. echo '' >> /etc/init.d/cjdns
  2284. echo 'PROG="cjdroute"' >> /etc/init.d/cjdns
  2285. echo 'GIT_PATH="/etc/cjdns"' >> /etc/init.d/cjdns
  2286. echo 'PROG_PATH="/etc/cjdns"' >> /etc/init.d/cjdns
  2287. echo 'CJDNS_CONFIG="cjdroute.conf"' >> /etc/init.d/cjdns
  2288. echo 'CJDNS_USER="cjdns"' >> /etc/init.d/cjdns
  2289. echo "CJDNS_IP='$CJDNS_IPV6'" >> /etc/init.d/cjdns
  2290. echo '' >> /etc/init.d/cjdns
  2291. echo 'start() {' >> /etc/init.d/cjdns
  2292. echo ' # Start it up with the user cjdns' >> /etc/init.d/cjdns
  2293. echo ' if [ $(pgrep cjdroute | wc -l) != 0 ];' >> /etc/init.d/cjdns
  2294. echo ' then' >> /etc/init.d/cjdns
  2295. echo ' echo "cjdroute is already running. Doing nothing..."' >> /etc/init.d/cjdns
  2296. echo ' else' >> /etc/init.d/cjdns
  2297. echo ' echo " * Starting cjdroute"' >> /etc/init.d/cjdns
  2298. echo ' su -c "$PROG_PATH/$PROG < $PROG_PATH/$CJDNS_CONFIG" - $CJDNS_USER' >> /etc/init.d/cjdns
  2299. echo ' /sbin/ip addr add $CJDNS_IP/8 dev tun0' >> /etc/init.d/cjdns
  2300. echo ' /sbin/ip link set mtu 1312 dev tun0' >> /etc/init.d/cjdns
  2301. echo ' /sbin/ip link set tun0 up' >> /etc/init.d/cjdns
  2302. echo ' /sbin/ip tuntap add mode tun user cjdns dev tun0' >> /etc/init.d/cjdns
  2303. echo ' fi' >> /etc/init.d/cjdns
  2304. echo '}' >> /etc/init.d/cjdns
  2305. echo '' >> /etc/init.d/cjdns
  2306. echo 'stop() {' >> /etc/init.d/cjdns
  2307. echo '' >> /etc/init.d/cjdns
  2308. echo ' if [ $(pgrep cjdroute | wc -l) != 2 ];' >> /etc/init.d/cjdns
  2309. echo ' then' >> /etc/init.d/cjdns
  2310. echo ' echo "cjdns isnt running."' >> /etc/init.d/cjdns
  2311. echo ' else' >> /etc/init.d/cjdns
  2312. echo ' echo "Killing cjdroute"' >> /etc/init.d/cjdns
  2313. echo ' killall cjdroute' >> /etc/init.d/cjdns
  2314. echo ' fi' >> /etc/init.d/cjdns
  2315. echo '}' >> /etc/init.d/cjdns
  2316. echo '' >> /etc/init.d/cjdns
  2317. echo 'status() {' >> /etc/init.d/cjdns
  2318. echo ' if [ $(pgrep cjdroute | wc -l) != 0 ];' >> /etc/init.d/cjdns
  2319. echo ' then' >> /etc/init.d/cjdns
  2320. echo ' echo "Cjdns is running"' >> /etc/init.d/cjdns
  2321. echo ' else' >> /etc/init.d/cjdns
  2322. echo ' echo "Cjdns is not running"' >> /etc/init.d/cjdns
  2323. echo ' fi' >> /etc/init.d/cjdns
  2324. echo '}' >> /etc/init.d/cjdns
  2325. echo '' >> /etc/init.d/cjdns
  2326. echo ' update() {' >> /etc/init.d/cjdns
  2327. echo ' cd $GIT_PATH' >> /etc/init.d/cjdns
  2328. echo ' echo "Updating..."' >> /etc/init.d/cjdns
  2329. echo ' git pull' >> /etc/init.d/cjdns
  2330. echo ' ./do' >> /etc/init.d/cjdns
  2331. echo '}' >> /etc/init.d/cjdns
  2332. echo '' >> /etc/init.d/cjdns
  2333. echo '## Check to see if we are running as root first.' >> /etc/init.d/cjdns
  2334. echo 'if [ "$(id -u)" != "0" ]; then' >> /etc/init.d/cjdns
  2335. echo ' echo "This script must be run as root" 1>&2' >> /etc/init.d/cjdns
  2336. echo ' exit 1' >> /etc/init.d/cjdns
  2337. echo 'fi' >> /etc/init.d/cjdns
  2338. echo '' >> /etc/init.d/cjdns
  2339. echo 'case $1 in' >> /etc/init.d/cjdns
  2340. echo ' start)' >> /etc/init.d/cjdns
  2341. echo ' start' >> /etc/init.d/cjdns
  2342. echo ' exit 0' >> /etc/init.d/cjdns
  2343. echo ' ;;' >> /etc/init.d/cjdns
  2344. echo ' stop)' >> /etc/init.d/cjdns
  2345. echo ' stop' >> /etc/init.d/cjdns
  2346. echo ' exit 0' >> /etc/init.d/cjdns
  2347. echo ' ;;' >> /etc/init.d/cjdns
  2348. echo ' reload|restart|force-reload)' >> /etc/init.d/cjdns
  2349. echo ' stop' >> /etc/init.d/cjdns
  2350. echo ' sleep 1' >> /etc/init.d/cjdns
  2351. echo ' start' >> /etc/init.d/cjdns
  2352. echo ' exit 0' >> /etc/init.d/cjdns
  2353. echo ' ;;' >> /etc/init.d/cjdns
  2354. echo ' status)' >> /etc/init.d/cjdns
  2355. echo ' status' >> /etc/init.d/cjdns
  2356. echo ' exit 0' >> /etc/init.d/cjdns
  2357. echo ' ;;' >> /etc/init.d/cjdns
  2358. echo ' update|upgrade)' >> /etc/init.d/cjdns
  2359. echo ' update' >> /etc/init.d/cjdns
  2360. echo ' stop' >> /etc/init.d/cjdns
  2361. echo ' sleep 2' >> /etc/init.d/cjdns
  2362. echo ' start' >> /etc/init.d/cjdns
  2363. echo ' exit 0' >> /etc/init.d/cjdns
  2364. echo ' ;;' >> /etc/init.d/cjdns
  2365. echo ' **)' >> /etc/init.d/cjdns
  2366. echo ' echo "Usage: $0 (start|stop|restart|status|update)" 1>&2' >> /etc/init.d/cjdns
  2367. echo ' exit 1' >> /etc/init.d/cjdns
  2368. echo ' ;;' >> /etc/init.d/cjdns
  2369. echo 'esac' >> /etc/init.d/cjdns
  2370. chmod +x /etc/init.d/cjdns
  2371. update-rc.d cjdns defaults
  2372. service cjdns start
  2373. if [ ! "$?" = "0" ]; then
  2374. systemctl status cjdns.service
  2375. exit 8260
  2376. fi
  2377. apt-get -y install radvd
  2378. echo 'interface eth0' > /etc/radvd.conf
  2379. echo '{' >> /etc/radvd.conf
  2380. echo ' AdvSendAdvert on;' >> /etc/radvd.conf
  2381. echo ' prefix fdfc::1/64' >> /etc/radvd.conf
  2382. echo ' {' >> /etc/radvd.conf
  2383. echo ' AdvRouterAddr on;' >> /etc/radvd.conf
  2384. echo ' };' >> /etc/radvd.conf
  2385. echo '};' >> /etc/radvd.conf
  2386. systemctl restart radvd
  2387. if [ ! "$?" = "0" ]; then
  2388. systemctl status radvd.service
  2389. exit 4395
  2390. fi
  2391. if ! grep -q "# Mesh Networking (cjdns)" /etc/network/interfaces; then
  2392. echo '' >> /etc/network/interfaces
  2393. echo '# Mesh Networking (cjdns)' >> /etc/network/interfaces
  2394. echo 'iface eth0 inet6 static' >> /etc/network/interfaces
  2395. echo ' pre-up modprobe ipv6' >> /etc/network/interfaces
  2396. echo ' address fdfc:0000:0000:0000:0000:0000:0000:0001' >> /etc/network/interfaces
  2397. echo ' netmask 64' >> /etc/network/interfaces
  2398. service network-manager restart
  2399. if [ ! "$?" = "0" ]; then
  2400. systemctl status networking.service
  2401. exit 6949
  2402. fi
  2403. fi
  2404. ip6tables -A INPUT -p udp --dport $CJDNS_PORT -j ACCEPT
  2405. ip6tables -A INPUT -p tcp --dport $CJDNS_PORT -j ACCEPT
  2406. save_firewall_settings
  2407. if ! grep -q $"Mesh Networking (cjdns)" /home/$MY_USERNAME/README; then
  2408. CURRENT_IP_ADDRESS=$(ip addr show | grep "inet " | sed -n 2p | awk -F ' ' '{print $2}' | awk -F '/' '{print $1}')
  2409. echo '' >> /home/$MY_USERNAME/README
  2410. echo '' >> /home/$MY_USERNAME/README
  2411. echo $'Mesh Networking (cjdns)' >> /home/$MY_USERNAME/README
  2412. echo '=======================' >> /home/$MY_USERNAME/README
  2413. echo $"cjdns IPv6 address: $CJDNS_IPV6" >> /home/$MY_USERNAME/README
  2414. echo $"cjdns public key: $CJDNS_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  2415. echo $"cjdns private key: $CJDNS_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  2416. echo $"cjdns password: $CJDNS_PASSWORD" >> /home/$MY_USERNAME/README
  2417. echo $"cjdns port: $CJDNS_PORT" >> /home/$MY_USERNAME/README
  2418. echo '' >> /home/$MY_USERNAME/README
  2419. echo $"Forward port $CJDNS_PORT from your internet router to the ${PROJECT_NAME}" >> /home/$MY_USERNAME/README
  2420. echo '' >> /home/$MY_USERNAME/README
  2421. echo $'Below is an example of your connection credentials' >> /home/$MY_USERNAME/README
  2422. echo $'that you can give to other people so they can connect' >> /home/$MY_USERNAME/README
  2423. echo $'to you using your default password' >> /home/$MY_USERNAME/README
  2424. echo $'Adding a unique password for each user is advisable' >> /home/$MY_USERNAME/README
  2425. echo $'so that leaks can be isolated.' >> /home/$MY_USERNAME/README
  2426. echo '' >> /home/$MY_USERNAME/README
  2427. echo "\"$CURRENT_IP_ADDRESS:$CJDNS_PORT\":{\"password\":\"$CJDNS_PASSWORD\",\"publicKey\":\"$CJDNS_PUBLIC_KEY\"}" >> /home/$MY_USERNAME/README
  2428. echo '' >> /home/$MY_USERNAME/README
  2429. echo $'More is not better. 3-5 cjdns peers is good. 30 peers is bad.' >> /home/$MY_USERNAME/README
  2430. echo '' >> /home/$MY_USERNAME/README
  2431. echo $'NEVER USE A PUBLIC PEER. These degrade the network and make it centralized.' >> /home/$MY_USERNAME/README
  2432. echo $'Each node can handle many peers, but no node can handle the entire internet.' >> /home/$MY_USERNAME/README
  2433. echo $'As this network grows any public peer will simply become saturated and' >> /home/$MY_USERNAME/README
  2434. echo $'useless causing issues for the entire network.' >> /home/$MY_USERNAME/README
  2435. echo $'Please report anyone offering you a public peer as they are promoting shared' >> /home/$MY_USERNAME/README
  2436. echo $'passwords which could lead to people pretending to be you. A peering pass' >> /home/$MY_USERNAME/README
  2437. echo $'should not contain someone elses nickname or info but should contain yours' >> /home/$MY_USERNAME/README
  2438. echo $'to ensure it is not shared. It also helps when editing the conf to know who' >> /home/$MY_USERNAME/README
  2439. echo $'each password is for.' >> /home/$MY_USERNAME/README
  2440. echo '' >> /home/$MY_USERNAME/README
  2441. echo $'Possible cjdns destinations of interest:' >> /home/$MY_USERNAME/README
  2442. echo ' http://transitiontech.ca/faq' >> /home/$MY_USERNAME/README
  2443. echo ' http://cjdns.ca/hypeirc.txt' >> /home/$MY_USERNAME/README
  2444. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  2445. chmod 600 /home/$MY_USERNAME/README
  2446. fi
  2447. echo 'mesh_cjdns' >> $COMPLETION_FILE
  2448. }
  2449. function create_mirrors {
  2450. if [ -d /home/trove ]; then
  2451. userdel -r trove
  2452. fi
  2453. if grep -Fxq "create_mirrors" $COMPLETION_FILE; then
  2454. return
  2455. fi
  2456. ${PROJECT_NAME}-mirrors
  2457. echo 'create_mirrors' >> $COMPLETION_FILE
  2458. }
  2459. function select_go_version {
  2460. if [ ! -d $GVM_HOME/bin ]; then
  2461. echo $'GVM was not installed'
  2462. exit 629532
  2463. fi
  2464. export GVM_ROOT=$GVM_HOME
  2465. if ! grep -q "GVM_ROOT=" ~/.bashrc; then
  2466. echo "export GVM_ROOT=$GVM_ROOT" >> ~/.bashrc
  2467. else
  2468. sed -i "s|export GVM_ROOT=.*|export GVM_ROOT=$GVM_ROOT|g" ~/.bashrc
  2469. fi
  2470. cd $GVM_ROOT/bin
  2471. [[ -s "$GVM_ROOT/scripts/gvm" ]] && source "$GVM_ROOT/scripts/gvm"
  2472. gvm use go${GO_VERSION} --default
  2473. systemctl set-environment GOPATH=$GOPATH
  2474. if [ ${#GOPATH} -lt 2 ]; then
  2475. echo $'GOPATH was not set'
  2476. exit 629825
  2477. fi
  2478. }
  2479. function mesh_cjdns_tools {
  2480. if grep -Fxq "mesh_cjdns_tools" $COMPLETION_FILE; then
  2481. return
  2482. fi
  2483. if [[ $ENABLE_CJDNS != "yes" ]]; then
  2484. return
  2485. fi
  2486. if [ ! -d /etc/cjdns ]; then
  2487. mesh_cjdns
  2488. fi
  2489. select_go_version
  2490. apt-get -y install golang mercurial
  2491. if [ ! -f ~/.bashrc ]; then
  2492. touch ~/.bashrc
  2493. fi
  2494. if [ ! -d /home/git ]; then
  2495. # add a gogs user account
  2496. adduser --disabled-login --gecos 'Gogs' git
  2497. # install Go
  2498. if ! grep -q "export GOPATH=" ~/.bashrc; then
  2499. echo "export GOPATH=$GOPATH" >> ~/.bashrc
  2500. fi
  2501. systemctl set-environment GOPATH=$GOPATH
  2502. if ! grep -q "systemctl set-environment GOPATH=" ~/.bashrc; then
  2503. echo "systemctl set-environment GOPATH=$GOPATH" >> ~/.bashrc
  2504. fi
  2505. if [ ! -d $GOPATH ]; then
  2506. mkdir -p $GOPATH
  2507. fi
  2508. fi
  2509. if ! grep -q "export GOPATH=" ~/.bashrc; then
  2510. echo "export GOPATH=$GOPATH" >> ~/.bashrc
  2511. fi
  2512. expected_go_path='export PATH=$PATH:'${GOPATH}'/bin'
  2513. export PATH=$PATH:${GOPATH}/bin
  2514. if ! grep -q "$expected_go_path" ~/.bashrc; then
  2515. echo "$expected_go_path" >> ~/.bashrc
  2516. fi
  2517. export PATH=$PATH:$GOPATH/bin
  2518. CJDCMD_REPO2=$(echo "$CJDCMD_REPO" | sed 's|https://||g')
  2519. go get $CJDCMD_REPO2
  2520. if [ ! -f $GOPATH/bin/cjdcmd ]; then
  2521. echo $'cjdcmd was not compiled. Check your golang installation'
  2522. exit 7439
  2523. fi
  2524. cp $GOPATH/bin/cjdcmd /usr/bin
  2525. # initialise from the cjdns config
  2526. /usr/bin/cjdcmd cjdnsadmin -file /etc/cjdns/cjdroute.conf
  2527. echo 'mesh_cjdns_tools' >> $COMPLETION_FILE
  2528. }
  2529. function install_zeronet_blog {
  2530. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  2531. return
  2532. fi
  2533. set_repo_commit /opt/zeronet/ZeroBlog "ZeroNet Blog commit" "$ZERONET_BLOG_COMMIT" $ZERONET_BLOG_REPO
  2534. if grep -Fxq "install_zeronet_blog" $COMPLETION_FILE; then
  2535. return
  2536. fi
  2537. if [ ! -f /home/$MY_USERNAME/README ]; then
  2538. touch /home/$MY_USERNAME/README
  2539. fi
  2540. if grep -q "ZeroNet Blog address" /home/$MY_USERNAME/README; then
  2541. return
  2542. fi
  2543. if [ ! -d /etc/avahi ]; then
  2544. echo $'Avahi is not installed'
  2545. exit 736
  2546. fi
  2547. ZERONET_DEFAULT_BLOG_TITLE="${MY_USERNAME}'s Blog"
  2548. cd /opt/zeronet
  2549. python zeronet.py --batch siteCreate 2> /opt/zeronet/blog.txt
  2550. if [ ! -f /opt/zeronet/blog.txt ]; then
  2551. echo $'Unable to create blog'
  2552. exit 479
  2553. fi
  2554. blog_address=$(cat blog.txt | grep "Site address" | awk -F ':' '{print $2}')
  2555. blog_private_key=$(cat blog.txt | grep "Site private key" | awk -F ':' '{print $2}')
  2556. ZERONET_BLOG_ADDRESS=${blog_address//[[:blank:]]/}
  2557. ZERONET_BLOG_PRIVATE_KEY=${blog_private_key//[[:blank:]]/}
  2558. if [ ${#ZERONET_BLOG_ADDRESS} -lt 20 ]; then
  2559. echo $"Address: $ZERONET_BLOG_ADDRESS"
  2560. echo $"Public key: $ZERONET_BLOG_PRIVATE_KEY"
  2561. echo $'Unable to create zeronet blog address'
  2562. exit 7358
  2563. fi
  2564. if [ ${#ZERONET_BLOG_PRIVATE_KEY} -lt 20 ]; then
  2565. echo $"Address: $ZERONET_BLOG_ADDRESS"
  2566. echo $"Public key: $ZERONET_BLOG_PRIVATE_KEY"
  2567. echo $'Unable to create zeronet blog private key'
  2568. exit 1639
  2569. fi
  2570. if [ ! -d "/opt/zeronet/data/$ZERONET_BLOG_ADDRESS" ]; then
  2571. echo $"Unable to find site directory: /opt/zeronet/data/$ZERONET_BLOG_ADDRESS"
  2572. exit 7638
  2573. fi
  2574. git_clone $ZERONET_BLOG_REPO ZeroBlog
  2575. if [ ! -d /opt/zeronet/ZeroBlog ]; then
  2576. echo $'ZeroBlog repo could not be cloned'
  2577. exit 6739
  2578. fi
  2579. cd /opt/zeronet/ZeroBlog
  2580. git checkout $ZERONET_BLOG_COMMIT -b $ZERONET_BLOG_COMMIT
  2581. if ! grep -q "ZeroNet Blog commit" $COMPLETION_FILE; then
  2582. echo "ZeroNet Blog commit:$ZERONET_BLOG_COMMIT" >> $COMPLETION_FILE
  2583. else
  2584. sed -i "s/ZeroNet Blog commit.*/ZeroNet Blog commit:$ZERONET_BLOG_COMMIT/g" $COMPLETION_FILE
  2585. fi
  2586. echo $"ZeroNet Blog address: $ZERONET_BLOG_ADDRESS"
  2587. echo $"ZeroNet Blog private key: $ZERONET_BLOG_PRIVATE_KEY"
  2588. cp -r /opt/zeronet/ZeroBlog/* /opt/zeronet/data/$ZERONET_BLOG_ADDRESS
  2589. if [ ! -d /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data ]; then
  2590. mkdir /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data
  2591. fi
  2592. cp /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data-default/data.json /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data
  2593. sed -i "s/MyZeroBlog/$ZERONET_DEFAULT_BLOG_TITLE/g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data/data.json
  2594. sed -i "s/My ZeroBlog./$ZERONET_DEFAULT_BLOG_TAGLINE/g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data/data.json
  2595. sed -i "s/ZeroBlog Demo/$ZERONET_DEFAULT_BLOG_TITLE/g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/index.html
  2596. sed -i "s|<h3 class=\"description\">.*|<h3 class=\"description\">$ZERONET_DEFAULT_BLOG_TAGLINE</h3>|g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/index.html
  2597. sed -i "s/Blogging platform Demo/Blogging platform/g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/content.json
  2598. python zeronet.py siteSign $ZERONET_BLOG_ADDRESS $ZERONET_BLOG_PRIVATE_KEY
  2599. # Add an avahi service
  2600. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /tmp/zeronet-blog.service
  2601. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /tmp/zeronet-blog.service
  2602. echo '<service-group>' >> /tmp/zeronet-blog.service
  2603. echo ' <name replace-wildcards="yes">%h ZeroNet Blog</name>' >> /tmp/zeronet-blog.service
  2604. echo ' <service>' >> /tmp/zeronet-blog.service
  2605. echo ' <type>_zeronet._udp</type>' >> /tmp/zeronet-blog.service
  2606. echo " <port>$ZERONET_PORT</port>" >> /tmp/zeronet-blog.service
  2607. echo " <txt-record>$ZERONET_URL/$ZERONET_BLOG_ADDRESS</txt-record>" >> /tmp/zeronet-blog.service
  2608. echo ' </service>' >> /tmp/zeronet-blog.service
  2609. echo '</service-group>' >> /tmp/zeronet-blog.service
  2610. cp /tmp/zeronet-blog.service /etc/avahi/services/zeronet-blog.service
  2611. if [ ! -d /home/$MY_USERNAME/.config/zeronet ]; then
  2612. mkdir -p /home/$MY_USERNAME/.config/zeronet
  2613. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.config
  2614. fi
  2615. echo "$ZERONET_URL/$ZERONET_BLOG_ADDRESS" > /home/$MY_USERNAME/.config/zeronet/myblog
  2616. if ! grep -q "ZeroNet Blog address" /home/$MY_USERNAME/README; then
  2617. echo '' >> /home/$MY_USERNAME/README
  2618. echo "ZeroNet Blog address: $ZERONET_BLOG_ADDRESS" >> /home/$MY_USERNAME/README
  2619. echo "ZeroNet Blog private key: $ZERONET_BLOG_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  2620. fi
  2621. echo 'install_zeronet_blog' >> $COMPLETION_FILE
  2622. }
  2623. function install_zeronet_mail {
  2624. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  2625. return
  2626. fi
  2627. set_repo_commit /opt/zeronet/ZeroMail "ZeroNet Mail commit" "$ZERONET_MAIL_COMMIT" $ZERONET_MAIL_REPO
  2628. if grep -Fxq "install_zeronet_mail" $COMPLETION_FILE; then
  2629. return
  2630. fi
  2631. if [ ! -f /home/$MY_USERNAME/README ]; then
  2632. touch /home/$MY_USERNAME/README
  2633. fi
  2634. if grep -q "ZeroNet Mail address" /home/$MY_USERNAME/README; then
  2635. return
  2636. fi
  2637. if [ ! -d /etc/avahi ]; then
  2638. echo 'Avahi is not installed'
  2639. exit 736
  2640. fi
  2641. ZERONET_DEFAULT_MAIL_TITLE="${MY_USERNAME}'s Mail"
  2642. cd /opt/zeronet
  2643. python zeronet.py --batch siteCreate 2> /opt/zeronet/mail.txt
  2644. if [ ! -f /opt/zeronet/mail.txt ]; then
  2645. echo $'Unable to create mail'
  2646. exit 479
  2647. fi
  2648. mail_address=$(cat mail.txt | grep "Site address" | awk -F ':' '{print $2}')
  2649. mail_private_key=$(cat mail.txt | grep "Site private key" | awk -F ':' '{print $2}')
  2650. ZERONET_MAIL_ADDRESS=${mail_address//[[:blank:]]/}
  2651. ZERONET_MAIL_PRIVATE_KEY=${mail_private_key//[[:blank:]]/}
  2652. if [ ${#ZERONET_MAIL_ADDRESS} -lt 20 ]; then
  2653. echo $"Address: $ZERONET_MAIL_ADDRESS"
  2654. echo $"Public key: $ZERONET_MAIL_PRIVATE_KEY"
  2655. echo $'Unable to create zeronet mail address'
  2656. exit 7358
  2657. fi
  2658. if [ ${#ZERONET_MAIL_PRIVATE_KEY} -lt 20 ]; then
  2659. echo $"Address: $ZERONET_MAIL_ADDRESS"
  2660. echo $"Public key: $ZERONET_MAIL_PRIVATE_KEY"
  2661. echo $'Unable to create zeronet mail private key'
  2662. exit 1639
  2663. fi
  2664. if [ ! -d "/opt/zeronet/data/$ZERONET_MAIL_ADDRESS" ]; then
  2665. echo $"Unable to find site directory: /opt/zeronet/data/$ZERONET_MAIL_ADDRESS"
  2666. exit 7638
  2667. fi
  2668. git_clone $ZERONET_MAIL_REPO ZeroMail
  2669. if [ ! -d /opt/zeronet/ZeroMail ]; then
  2670. echo $'ZeroMail repo could not be cloned'
  2671. exit 6739
  2672. fi
  2673. cd /opt/zeronet/ZeroMail
  2674. git checkout $ZERONET_MAIL_COMMIT -b $ZERONET_MAIL_COMMIT
  2675. if ! grep -q "ZeroNet Mail commit" $COMPLETION_FILE; then
  2676. echo "ZeroNet Mail commit:$ZERONET_MAIL_COMMIT" >> $COMPLETION_FILE
  2677. else
  2678. sed -i "s/ZeroNet Mail commit.*/ZeroNet Mail commit:$ZERONET_MAIL_COMMIT/g" $COMPLETION_FILE
  2679. fi
  2680. echo $"ZeroNet Mail address: $ZERONET_MAIL_ADDRESS"
  2681. echo $"ZeroNet Mail private key: $ZERONET_MAIL_PRIVATE_KEY"
  2682. cp -r /opt/zeronet/ZeroMail/* /opt/zeronet/data/$ZERONET_MAIL_ADDRESS
  2683. if [ ! -d /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data ]; then
  2684. mkdir /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data
  2685. fi
  2686. cp /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data-default/data.json /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data
  2687. sed -i "s/MyZeroMail/$ZERONET_DEFAULT_MAIL_TITLE/g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data/data.json
  2688. sed -i "s/My ZeroMail./$ZERONET_DEFAULT_MAIL_TAGLINE/g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data/data.json
  2689. sed -i "s/ZeroMail Demo/$ZERONET_DEFAULT_MAIL_TITLE/g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/index.html
  2690. sed -i "s|<h3 class=\"description\">.*|<h3 class=\"description\">$ZERONET_DEFAULT_MAIL_TAGLINE</h3>|g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/index.html
  2691. sed -i "s/Mailging platform Demo/Mailging platform/g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/content.json
  2692. python zeronet.py siteSign $ZERONET_MAIL_ADDRESS $ZERONET_MAIL_PRIVATE_KEY
  2693. # Add an avahi service
  2694. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /tmp/zeronet-mail.service
  2695. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /tmp/zeronet-mail.service
  2696. echo '<service-group>' >> /tmp/zeronet-mail.service
  2697. echo ' <name replace-wildcards="yes">%h ZeroNet Mail</name>' >> /tmp/zeronet-mail.service
  2698. echo ' <service>' >> /tmp/zeronet-mail.service
  2699. echo ' <type>_zeronet._udp</type>' >> /tmp/zeronet-mail.service
  2700. echo " <port>$ZERONET_PORT</port>" >> /tmp/zeronet-mail.service
  2701. echo " <txt-record>$ZERONET_URL/$ZERONET_MAIL_ADDRESS</txt-record>" >> /tmp/zeronet-mail.service
  2702. echo ' </service>' >> /tmp/zeronet-mail.service
  2703. echo '</service-group>' >> /tmp/zeronet-mail.service
  2704. cp /tmp/zeronet-mail.service /etc/avahi/services/zeronet-mail.service
  2705. if [ ! -d /home/$MY_USERNAME/.config/zeronet ]; then
  2706. mkdir -p /home/$MY_USERNAME/.config/zeronet
  2707. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.config
  2708. fi
  2709. echo "$ZERONET_URL/$ZERONET_MAIL_ADDRESS" > /home/$MY_USERNAME/.config/zeronet/mymail
  2710. if ! grep -q $"ZeroNet Mail address" /home/$MY_USERNAME/README; then
  2711. echo '' >> /home/$MY_USERNAME/README
  2712. echo $"ZeroNet Mail address: $ZERONET_MAIL_ADDRESS" >> /home/$MY_USERNAME/README
  2713. echo $"ZeroNet Mail private key: $ZERONET_MAIL_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  2714. fi
  2715. echo 'install_zeronet_mail' >> $COMPLETION_FILE
  2716. }
  2717. function install_zeronet_forum {
  2718. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  2719. return
  2720. fi
  2721. # update to the next commit
  2722. set_repo_commit /opt/zeronet/ZeroTalk "ZeroNet Forum commit" "$ZERONET_FORUM_COMMIT" $ZERONET_FORUM_REPO
  2723. if grep -Fxq "install_zeronet_forum" $COMPLETION_FILE; then
  2724. return
  2725. fi
  2726. if [ ! -f /home/$MY_USERNAME/README ]; then
  2727. touch /home/$MY_USERNAME/README
  2728. fi
  2729. if grep -q "ZeroNet Forum address" /home/$MY_USERNAME/README; then
  2730. return
  2731. fi
  2732. if [ ! -d /etc/avahi ]; then
  2733. echo $'Avahi is not installed'
  2734. exit 736
  2735. fi
  2736. ZERONET_DEFAULT_FORUM_TITLE=$"${MY_USERNAME}'s Forum"
  2737. cd /opt/zeronet
  2738. python zeronet.py --batch siteCreate 2> /opt/zeronet/forum.txt
  2739. if [ ! -f /opt/zeronet/forum.txt ]; then
  2740. echo $'Unable to create forum'
  2741. exit 479
  2742. fi
  2743. forum_address=$(cat forum.txt | grep "Site address" | awk -F ':' '{print $2}')
  2744. forum_private_key=$(cat forum.txt | grep "Site private key" | awk -F ':' '{print $2}')
  2745. ZERONET_FORUM_ADDRESS=${forum_address//[[:blank:]]/}
  2746. ZERONET_FORUM_PRIVATE_KEY=${forum_private_key//[[:blank:]]/}
  2747. if [ ${#ZERONET_FORUM_ADDRESS} -lt 20 ]; then
  2748. echo $"Address: $ZERONET_FORUM_ADDRESS"
  2749. echo $"Public key: $ZERONET_FORUM_PRIVATE_KEY"
  2750. echo $'Unable to create zeronet forum address'
  2751. exit 76352
  2752. fi
  2753. if [ ${#ZERONET_FORUM_PRIVATE_KEY} -lt 20 ]; then
  2754. echo $"Address: $ZERONET_FORUM_ADDRESS"
  2755. echo $"Public key: $ZERONET_FORUM_PRIVATE_KEY"
  2756. echo $'Unable to create zeronet forum private key'
  2757. exit 87356
  2758. fi
  2759. if [ ! -d "/opt/zeronet/data/$ZERONET_FORUM_ADDRESS" ]; then
  2760. echo $"Unable to find site directory: /opt/zeronet/data/$ZERONET_FORUM_ADDRESS"
  2761. exit 7638
  2762. fi
  2763. git_clone $ZERONET_FORUM_REPO ZeroTalk
  2764. if [ ! -d /opt/zeronet/ZeroTalk ]; then
  2765. echo $'ZeroTalk repo could not be cloned'
  2766. exit 6739
  2767. fi
  2768. git checkout $ZERONET_FORUM_COMMIT -b $ZERONET_FORUM_COMMIT
  2769. if ! grep -q "ZeroNet Forum commit" $COMPLETION_FILE; then
  2770. echo "ZeroNet Forum commit:$ZERONET_FORUM_COMMIT" >> $COMPLETION_FILE
  2771. else
  2772. sed -i "s/ZeroNet Forum commit.*/ZeroNet Forum commit:$ZERONET_FORUM_COMMIT/g" $COMPLETION_FILE
  2773. fi
  2774. echo $"Forum address: $ZERONET_FORUM_ADDRESS"
  2775. echo $"Forum private key: $ZERONET_FORUM_PRIVATE_KEY"
  2776. cp -r /opt/zeronet/ZeroTalk/* /opt/zeronet/data/$ZERONET_FORUM_ADDRESS
  2777. sed -i "s/ZeroBoard/$ZERONET_DEFAULT_FORUM_TITLE/g" /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/index.html
  2778. sed -i "s/ZeroTalk/$ZERONET_DEFAULT_FORUM_TITLE/g" /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/index.html
  2779. sed -i "s|Demo for dynamic, decentralized content publishing.|$ZERONET_DEFAULT_FORUM_TAGLINE|g" /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/index.html
  2780. sed -i 's/Messaging Board Demo/Messaging Board/g' /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/content.json
  2781. sed -i "s/ZeroBoard/$ZERONET_DEFAULT_FORUM_TITLE/g" /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/content.json
  2782. python zeronet.py siteSign $ZERONET_FORUM_ADDRESS $ZERONET_FORUM_PRIVATE_KEY --inner_path data/users/content.json
  2783. # Add an avahi service
  2784. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /tmp/zeronet-forum.service
  2785. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /tmp/zeronet-forum.service
  2786. echo '<service-group>' >> /tmp/zeronet-forum.service
  2787. echo ' <name replace-wildcards="yes">%h ZeroNet Forum</name>' >> /tmp/zeronet-forum.service
  2788. echo ' <service>' >> /tmp/zeronet-forum.service
  2789. echo ' <type>_zeronet._udp</type>' >> /tmp/zeronet-forum.service
  2790. echo " <port>$ZERONET_PORT</port>" >> /tmp/zeronet-forum.service
  2791. echo " <txt-record>$ZERONET_URL/$ZERONET_FORUM_ADDRESS</txt-record>" >> /tmp/zeronet-forum.service
  2792. echo ' </service>' >> /tmp/zeronet-forum.service
  2793. echo '</service-group>' >> /tmp/zeronet-forum.service
  2794. sudo cp /tmp/zeronet-forum.service /etc/avahi/services/zeronet-forum.service
  2795. if [ ! -d /home/$MY_USERNAME/.config/zeronet ]; then
  2796. mkdir -p /home/$MY_USERNAME/.config/zeronet
  2797. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.config
  2798. fi
  2799. echo "$ZERONET_URL/$ZERONET_FORUM_ADDRESS" > /home/$MY_USERNAME/.config/zeronet/myforum
  2800. if ! grep -q $"ZeroNet Forum address" /home/$MY_USERNAME/README; then
  2801. echo '' >> /home/$MY_USERNAME/README
  2802. echo $"ZeroNet Forum address: $ZERONET_FORUM_ADDRESS" >> /home/$MY_USERNAME/README
  2803. echo $"ZeroNet Forum private key: $ZERONET_FORUM_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  2804. fi
  2805. echo 'install_zeronet_forum' >> $COMPLETION_FILE
  2806. }
  2807. function install_zeronet {
  2808. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  2809. return
  2810. fi
  2811. # update to the next commit
  2812. set_repo_commit /opt/zeronet "ZeroNet commit" "$ZERONET_COMMIT" $ZERONET_REPO
  2813. if grep -Fxq "install_zeronet" $COMPLETION_FILE; then
  2814. return
  2815. fi
  2816. ${PROJECT_NAME}-mesh-install -f zeronet
  2817. systemctl daemon-reload
  2818. systemctl start tracker.service
  2819. systemctl start zeronet.service
  2820. echo 'mesh_zeronet' >> $COMPLETION_FILE
  2821. }
  2822. function install_vpn_tunnel {
  2823. if ! grep -q "repo.universe-factory.net" /etc/apt/sources.list; then
  2824. echo 'deb http://repo.universe-factory.net/debian/ sid main' >> /etc/apt/sources.list
  2825. gpg --keyserver pgpkeys.mit.edu --recv-key 16EF3F64CB201D9C
  2826. if [ ! "$?" = "0" ]; then
  2827. exit 76272
  2828. fi
  2829. gpg -a --export 16EF3F64CB201D9C | sudo apt-key add -
  2830. apt-get update
  2831. apt-get -y install fastd
  2832. if [ ! "$?" = "0" ]; then
  2833. exit 52026
  2834. fi
  2835. fi
  2836. }
  2837. # ath9k_htc driver
  2838. function install_atheros_wifi {
  2839. if grep -Fxq "install_atheros_wifi" $COMPLETION_FILE; then
  2840. return
  2841. fi
  2842. if [ $INSTALLING_ON_BBB != "yes" ]; then
  2843. return
  2844. fi
  2845. if [[ $ENABLE_BABEL != "yes" && $ENABLE_BATMAN != "yes" && $ENABLE_CJDNS != "yes" ]]; then
  2846. return
  2847. fi
  2848. if [ -d $INSTALL_DIR/open-ath9k-htc-firmware ]; then
  2849. return
  2850. fi
  2851. # have drivers already been installed ?
  2852. if [ -f /lib/firmware/htc_9271.fw ]; then
  2853. return
  2854. fi
  2855. apt-get -y install build-essential cmake git m4 texinfo
  2856. if [ ! -d $INSTALL_DIR ]; then
  2857. mkdir -p $INSTALL_DIR
  2858. fi
  2859. cd $INSTALL_DIR
  2860. if [ ! -d $INSTALL_DIR/open-ath9k-htc-firmware ]; then
  2861. git_clone $ATHEROS_WIFI_REPO $INSTALL_DIR/open-ath9k-htc-firmware
  2862. if [ ! "$?" = "0" ]; then
  2863. rm -rf $INSTALL_DIR/open-ath9k-htc-firmware
  2864. exit 74283
  2865. fi
  2866. fi
  2867. cd $INSTALL_DIR/open-ath9k-htc-firmware
  2868. git checkout 1.4.0
  2869. make toolchain
  2870. if [ ! "$?" = "0" ]; then
  2871. rm -rf $INSTALL_DIR/open-ath9k-htc-firmware
  2872. exit 24820
  2873. fi
  2874. make firmware
  2875. if [ ! "$?" = "0" ]; then
  2876. rm -rf $INSTALL_DIR/open-ath9k-htc-firmware
  2877. exit 63412
  2878. fi
  2879. cp target_firmware/*.fw /lib/firmware/
  2880. if [ ! "$?" = "0" ]; then
  2881. exit 74681
  2882. fi
  2883. echo 'install_atheros_wifi' >> $COMPLETION_FILE
  2884. }
  2885. function configure_avahi {
  2886. if grep -Fxq "configure_avahi" $COMPLETION_FILE; then
  2887. return
  2888. fi
  2889. # only enable avahi if we're doing mesh networking
  2890. if [[ $ENABLE_BABEL != "yes" && $ENABLE_BATMAN != "yes" && $ENABLE_CJDNS != "yes" ]]; then
  2891. return
  2892. fi
  2893. ${PROJECT_NAME}-mesh-install -f avahi
  2894. if [ ! "$?" = "0" ]; then
  2895. echo $'Failed to install avahi'
  2896. exit 68442
  2897. fi
  2898. if [ $DEFAULT_DOMAIN_NAME ]; then
  2899. sed -i "s|#host-name=.*|host-name=$DEFAULT_DOMAIN_NAME|g" /etc/avahi/avahi-daemon.conf
  2900. sed -i "s|host-name=.*|host-name=$DEFAULT_DOMAIN_NAME|g" /etc/avahi/avahi-daemon.conf
  2901. else
  2902. decarray=( 1 2 3 4 5 6 7 8 9 0 )
  2903. PEER_ID=${decarray[$RANDOM%10]}${decarray[$RANDOM%10]}${decarray[$RANDOM%10]}${decarray[$RANDOM%10]}${decarray[$RANDOM%10]}${decarray[$RANDOM%10]}${decarray[$RANDOM%10]}${decarray[$RANDOM%10]}
  2904. sed -i "s|#host-name=.*|host-name=P$PEER_ID|g" /etc/avahi/avahi-daemon.conf
  2905. sed -i "s|host-name=.*|host-name=P$PEER_ID|g" /etc/avahi/avahi-daemon.conf
  2906. fi
  2907. echo 'configure_avahi' >> $COMPLETION_FILE
  2908. }
  2909. function mesh_babel {
  2910. if grep -Fxq "mesh_babel" $COMPLETION_FILE; then
  2911. return
  2912. fi
  2913. if [[ $ENABLE_BABEL != "yes" ]]; then
  2914. return
  2915. fi
  2916. ${PROJECT_NAME}-mesh-install -f babel
  2917. if [ ! "$?" = "0" ]; then
  2918. echo $'Failed to install babel'
  2919. exit 67242
  2920. fi
  2921. echo 'mesh_babel' >> $COMPLETION_FILE
  2922. }
  2923. function mesh_batman {
  2924. if grep -Fxq "mesh_batman" $COMPLETION_FILE; then
  2925. return
  2926. fi
  2927. if [[ $ENABLE_BATMAN != "yes" ]]; then
  2928. return
  2929. fi
  2930. ${PROJECT_NAME}-mesh-install -f batman
  2931. if [ ! "$?" = "0" ]; then
  2932. echo $'Failed to install batman'
  2933. exit 72524
  2934. fi
  2935. if ! grep -q "Mesh Networking (B.A.T.M.A.N)" /home/$MY_USERNAME/README; then
  2936. echo '' >> /home/$MY_USERNAME/README
  2937. echo '' >> /home/$MY_USERNAME/README
  2938. echo 'Mesh Networking (B.A.T.M.A.N)' >> /home/$MY_USERNAME/README
  2939. echo '=============================' >> /home/$MY_USERNAME/README
  2940. echo "Mesh ESSID: $WIFI_SSID" >> /home/$MY_USERNAME/README
  2941. echo "Mesh cell ID: $BATMAN_CELLID" >> /home/$MY_USERNAME/README
  2942. echo "Mesh wifi channel: $WIFI_CHANNEL" >> /home/$MY_USERNAME/README
  2943. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  2944. chmod 600 /home/$MY_USERNAME/README
  2945. fi
  2946. echo 'mesh_batman' >> $COMPLETION_FILE
  2947. }
  2948. function remove_instructions_from_motd {
  2949. sed -i '/## /d' /etc/motd
  2950. }
  2951. function check_hwrng {
  2952. if [[ $HWRNG_TYPE == "beaglebone" ]]; then
  2953. # If hardware random number generation was enabled then make sure that the device exists.
  2954. # if /dev/hwrng is not found then any subsequent cryptographic key generation would
  2955. # suffer from low entropy and might be insecure
  2956. if [ ! -e /dev/hwrng ]; then
  2957. ls /dev/hw*
  2958. echo $'The hardware random number generator is enabled but could not be detected on'
  2959. echo $'/dev/hwrng. There may be a problem with the installation or the Beaglebone hardware.'
  2960. exit 75
  2961. fi
  2962. fi
  2963. # If a OneRNG device was installed then verify its firmware
  2964. #check_onerng_verification
  2965. }
  2966. function get_mariadb_password {
  2967. if [ -f /home/$MY_USERNAME/README ]; then
  2968. if grep -q "MariaDB password" /home/$MY_USERNAME/README; then
  2969. if [ -f $DATABASE_PASSWORD_FILE ]; then
  2970. MARIADB_PASSWORD=$(cat $DATABASE_PASSWORD_FILE)
  2971. else
  2972. MARIADB_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2973. echo "$MARIADB_PASSWORD" > $DATABASE_PASSWORD_FILE
  2974. chmod 600 $DATABASE_PASSWORD_FILE
  2975. fi
  2976. fi
  2977. fi
  2978. }
  2979. function get_mariadb_media_server_admin_password {
  2980. if [ -f /home/$MY_USERNAME/README ]; then
  2981. if grep -q "Media server administrator password" /home/$MY_USERNAME/README; then
  2982. MEDIA_SERVER_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Media server administrator password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2983. fi
  2984. fi
  2985. }
  2986. function get_mariadb_gnusocial_admin_password {
  2987. if [ -f /home/$MY_USERNAME/README ]; then
  2988. if grep -q "MariaDB gnusocial admin password" /home/$MY_USERNAME/README; then
  2989. MICROBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB gnusocial admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2990. fi
  2991. if grep -q "Microblog administrator password" /home/$MY_USERNAME/README; then
  2992. MICROBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Microblog administrator password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2993. fi
  2994. fi
  2995. }
  2996. function get_mariadb_webmail_admin_password {
  2997. if [ -f /home/$MY_USERNAME/README ]; then
  2998. if grep -q "MariaDB webmail admin password" /home/$MY_USERNAME/README; then
  2999. WEBMAIL_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB webmail admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  3000. fi
  3001. fi
  3002. }
  3003. function get_mariadb_rss_reader_admin_password {
  3004. if [ -f /home/$MY_USERNAME/README ]; then
  3005. if grep -q "RSS reader admin password" /home/$MY_USERNAME/README; then
  3006. RSS_READER_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "RSS reader admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  3007. fi
  3008. fi
  3009. }
  3010. function get_mariadb_git_admin_password {
  3011. if [ -f /home/$MY_USERNAME/README ]; then
  3012. if grep -q "Gogs admin user password" /home/$MY_USERNAME/README; then
  3013. GIT_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Gogs admin user password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  3014. fi
  3015. fi
  3016. }
  3017. function get_mariadb_hubzilla_admin_password {
  3018. if [ -f /home/$MY_USERNAME/README ]; then
  3019. if grep -q "MariaDB Hubzilla admin password" /home/$MY_USERNAME/README; then
  3020. HUBZILLA_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB Hubzilla admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  3021. fi
  3022. fi
  3023. }
  3024. function create_freedns_updater {
  3025. if [[ $ONION_ONLY != "no" ]]; then
  3026. return
  3027. fi
  3028. # currently inadyn doesn't work as expected with freeDNS, so this is a workaround
  3029. if grep -Fxq "create_freedns_updater" $COMPLETION_FILE; then
  3030. return
  3031. fi
  3032. if [[ $DDNS_PROVIDER != "default@freedns.afraid.org" ]]; then
  3033. return
  3034. fi
  3035. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3036. return
  3037. fi
  3038. FREEDNS_WGET='wget -q --read-timeout=0.0 --waitretry=5 --tries=4 https://freedns.afraid.org/dynamic/update.php?'
  3039. echo '#!/bin/bash' > /usr/bin/dynamicdns
  3040. echo 'cd /tmp' >> /usr/bin/dynamicdns
  3041. if [ $DEFAULT_DOMAIN_CODE ]; then
  3042. echo "# $DEFAULT_DOMAIN_NAME" >> /usr/bin/dynamicdns
  3043. echo "$FREEDNS_WGET$DEFAULT_DOMAIN_CODE=" >> /usr/bin/dynamicdns
  3044. fi
  3045. if [ $WIKI_CODE ]; then
  3046. if [[ $WIKI_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  3047. echo "# $WIKI_DOMAIN_NAME" >> /usr/bin/dynamicdns
  3048. echo "$FREEDNS_WGET$WIKI_CODE=" >> /usr/bin/dynamicdns
  3049. fi
  3050. fi
  3051. if [ $FULLBLOG_CODE ]; then
  3052. if [[ $FULLBLOG_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  3053. echo "# $FULLBLOG_DOMAIN_NAME" >> /usr/bin/dynamicdns
  3054. echo "$FREEDNS_WGET$FULLBLOG_CODE=" >> /usr/bin/dynamicdns
  3055. fi
  3056. fi
  3057. if [ $HUBZILLA_CODE ]; then
  3058. if [[ $HUBZILLA_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  3059. echo "# $HUBZILLA_DOMAIN_NAME" >> /usr/bin/dynamicdns
  3060. echo "$FREEDNS_WGET$HUBZILLA_CODE=" >> /usr/bin/dynamicdns
  3061. fi
  3062. fi
  3063. if [ $MICROBLOG_CODE ]; then
  3064. if [[ $MICROBLOG_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  3065. echo "# $MICROBLOG_DOMAIN_NAME" >> /usr/bin/dynamicdns
  3066. echo "$FREEDNS_WGET$MICROBLOG_CODE=" >> /usr/bin/dynamicdns
  3067. fi
  3068. fi
  3069. if [ $GIT_CODE ]; then
  3070. if [[ $GIT_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  3071. echo "# $GIT_DOMAIN_NAME" >> /usr/bin/dynamicdns
  3072. echo "$FREEDNS_WGET$GIT_CODE=" >> /usr/bin/dynamicdns
  3073. fi
  3074. fi
  3075. if [ $MEDIAGOBLIN_CODE ]; then
  3076. if [[ $MEDIAGOBLIN_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  3077. echo "# $MEDIAGOBLIN_DOMAIN_NAME" >> /usr/bin/dynamicdns
  3078. echo "$FREEDNS_WGET$MEDIAGOBLIN_CODE=" >> /usr/bin/dynamicdns
  3079. fi
  3080. fi
  3081. echo 'exit 0' >> /usr/bin/dynamicdns
  3082. chmod 600 /usr/bin/dynamicdns
  3083. chmod +x /usr/bin/dynamicdns
  3084. if ! grep -q "/usr/bin/dynamicdns" /etc/crontab; then
  3085. echo '*/3 * * * * root /usr/bin/dynamicdns' >> /etc/crontab
  3086. systemctl restart cron
  3087. fi
  3088. echo 'create_freedns_updater' >> $COMPLETION_FILE
  3089. }
  3090. function backup_to_friends_servers {
  3091. # update crontab
  3092. echo '#!/bin/bash' > /etc/cron.daily/backuptofriends
  3093. echo "if [ -f /usr/local/bin/${PROJECT_NAME}-backup-remote ]; then" >> /etc/cron.daily/backuptofriends
  3094. echo " /usr/local/bin/${PROJECT_NAME}-backup-remote" >> /etc/cron.daily/backuptofriends
  3095. echo 'else' >> /etc/cron.daily/backuptofriends
  3096. echo " /usr/bin/${PROJECT_NAME}-backup-remote" >> /etc/cron.daily/backuptofriends
  3097. echo 'fi' >> /etc/cron.daily/backuptofriends
  3098. chmod +x /etc/cron.daily/backuptofriends
  3099. }
  3100. function remove_default_user {
  3101. # make sure you don't use the default user account
  3102. if [[ $MY_USERNAME == "debian" ]]; then
  3103. echo 'Do not use the default debian user account. Create a different user with: adduser [username]'
  3104. exit 68
  3105. fi
  3106. # remove the default debian user to prevent it from becoming an attack vector
  3107. if [ -d /home/debian ]; then
  3108. userdel -r debian
  3109. echo 'Default debian user account removed'
  3110. fi
  3111. }
  3112. function enforce_good_passwords {
  3113. # because humans are generally bad at choosing passwords
  3114. if grep -Fxq "enforce_good_passwords" $COMPLETION_FILE; then
  3115. return
  3116. fi
  3117. apt-get -y install libpam-cracklib
  3118. 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
  3119. echo 'enforce_good_passwords' >> $COMPLETION_FILE
  3120. }
  3121. function change_login_message {
  3122. if grep -Fxq "change_login_message" $COMPLETION_FILE; then
  3123. return
  3124. fi
  3125. # remove automatic motd creator if it exists
  3126. if [ -f /etc/init.d/motd ]; then
  3127. rm -f /etc/init.d/motd
  3128. fi
  3129. echo '' > /etc/motd
  3130. echo ".---. . . " >> /etc/motd
  3131. echo "| | | " >> /etc/motd
  3132. echo "|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-. " >> /etc/motd
  3133. echo "| | (.-' (.-' ( | ( )| | | | )( )| | (.-' " >> /etc/motd
  3134. echo "' ' --' --' -' - -' ' ' -' -' -' ' - --'" >> /etc/motd
  3135. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  3136. echo $' M A I L B O X E D I T I O N' >> /etc/motd
  3137. fi
  3138. if [[ $SYSTEM_TYPE == "$VARIANT_SOCIAL" ]]; then
  3139. echo $' S O C I A L E D I T I O N' >> /etc/motd
  3140. fi
  3141. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  3142. echo $' C H A T E D I T I O N' >> /etc/motd
  3143. fi
  3144. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  3145. echo $' C L O U D E D I T I O N' >> /etc/motd
  3146. fi
  3147. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" ]]; then
  3148. echo $' W R I T E R E D I T I O N ' >> /etc/motd
  3149. fi
  3150. if [[ $SYSTEM_TYPE == "$VARIANT_MEDIA" ]]; then
  3151. echo $' M E D I A E D I T I O N' >> /etc/motd
  3152. fi
  3153. if [[ $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  3154. echo $' D E V E L O P E R E D I T I O N' >> /etc/motd
  3155. fi
  3156. echo '' >> /etc/motd
  3157. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  3158. echo $' Freedom in the Cloud' >> /etc/motd
  3159. else
  3160. echo $' Freedom in the Mesh' >> /etc/motd
  3161. fi
  3162. echo '' >> /etc/motd
  3163. echo 'change_login_message' >> $COMPLETION_FILE
  3164. }
  3165. function search_for_attached_usb_drive {
  3166. # If a USB drive is attached then search for email,
  3167. # gpg, ssh keys and emacs configuration
  3168. if grep -Fxq "search_for_attached_usb_drive" $COMPLETION_FILE; then
  3169. return
  3170. fi
  3171. if [ -b $USB_DRIVE ]; then
  3172. if [ ! -d $USB_MOUNT ]; then
  3173. echo $'Mounting USB drive'
  3174. mkdir $USB_MOUNT
  3175. mount $USB_DRIVE $USB_MOUNT
  3176. fi
  3177. 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_MESH" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  3178. if [ -d $USB_MOUNT/Maildir ]; then
  3179. echo $'Maildir found on USB drive'
  3180. IMPORT_MAILDIR=$USB_MOUNT/Maildir
  3181. fi
  3182. if [ -d $USB_MOUNT/.gnupg ]; then
  3183. echo $'Importing GPG keyring'
  3184. cp -r $USB_MOUNT/.gnupg /home/$MY_USERNAME
  3185. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.gnupg
  3186. GPG_KEYS_IMPORTED="yes"
  3187. if [ ! -f /home/$MY_USERNAME/.gnupg/secring.gpg ]; then
  3188. echo $'GPG files did not copy'
  3189. exit 73529
  3190. fi
  3191. fi
  3192. if [ -f $USB_MOUNT/.procmailrc ]; then
  3193. echo $'Importing procmail settings'
  3194. cp $USB_MOUNT/.procmailrc /home/$MY_USERNAME
  3195. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  3196. fi
  3197. if [ -f $USB_MOUNT/private_key.gpg ]; then
  3198. echo $'GPG private key found on USB drive'
  3199. MY_GPG_PRIVATE_KEY=$USB_MOUNT/private_key.gpg
  3200. fi
  3201. if [ -f $USB_MOUNT/public_key.gpg ]; then
  3202. echo $'GPG public key found on USB drive'
  3203. MY_GPG_PUBLIC_KEY=$USB_MOUNT/public_key.gpg
  3204. fi
  3205. fi
  3206. if [ -d $USB_MOUNT/prosody ]; then
  3207. if [ ! -d $XMPP_DIRECTORY ]; then
  3208. mkdir $XMPP_DIRECTORY
  3209. fi
  3210. cp -r $USB_MOUNT/prosody/* $XMPP_DIRECTORY
  3211. chown -R prosody:prosody $XMPP_DIRECTORY
  3212. fi
  3213. if [ -d $USB_MOUNT/.ssh ]; then
  3214. echo $'Importing ssh keys'
  3215. cp -r $USB_MOUNT/.ssh /home/$MY_USERNAME
  3216. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.ssh
  3217. # for security delete the ssh keys from the usb drive
  3218. if [ ! -f /home/$MY_USERNAME/.ssh/id_rsa ]; then
  3219. echo $'ssh files did not copy'
  3220. exit 8
  3221. fi
  3222. fi
  3223. if [ -f $USB_MOUNT/.emacs ]; then
  3224. echo $'Importing .emacs file'
  3225. cp -f $USB_MOUNT/.emacs /home/$MY_USERNAME/.emacs
  3226. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs
  3227. fi
  3228. if [ -d $USB_MOUNT/.emacs.d ]; then
  3229. echo $'Importing .emacs.d directory'
  3230. cp -r $USB_MOUNT/.emacs.d /home/$MY_USERNAME
  3231. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs.d
  3232. fi
  3233. if [ -d $USB_MOUNT/ssl ]; then
  3234. echo $'Importing SSL certificates'
  3235. cp -r $USB_MOUNT/ssl/* /etc/ssl
  3236. chmod 640 /etc/ssl/certs/*
  3237. chmod 400 /etc/ssl/private/*
  3238. # change ownership of some certificates
  3239. if [ -d /etc/prosody ]; then
  3240. chown prosody:prosody /etc/ssl/private/xmpp.*
  3241. chown prosody:prosody /etc/ssl/certs/xmpp.*
  3242. fi
  3243. if [ -d /etc/dovecot ]; then
  3244. chown root:dovecot /etc/ssl/certs/dovecot.*
  3245. chown root:dovecot /etc/ssl/private/dovecot.*
  3246. fi
  3247. if [ -f /etc/ssl/private/exim.key ]; then
  3248. cp /etc/ssl/private/exim.key /etc/exim4
  3249. cp /etc/ssl/certs/exim.crt /etc/exim4
  3250. cp /etc/ssl/certs/exim.dhparam /etc/exim4
  3251. chown root:Debian-exim /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  3252. chmod 640 /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  3253. fi
  3254. fi
  3255. if [ -d $USB_MOUNT/personal ]; then
  3256. echo $'Importing personal directory'
  3257. cp -r $USB_MOUNT/personal /home/$MY_USERNAME
  3258. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/personal
  3259. fi
  3260. else
  3261. if [ -d $USB_MOUNT ]; then
  3262. umount $USB_MOUNT
  3263. rm -rf $USB_MOUNT
  3264. fi
  3265. echo $'No USB drive attached'
  3266. fi
  3267. echo 'search_for_attached_usb_drive' >> $COMPLETION_FILE
  3268. }
  3269. function create_repo_sources {
  3270. if grep -Fxq "create_repo_sources" $COMPLETION_FILE; then
  3271. return
  3272. fi
  3273. rm -rf /var/lib/apt/lists/*
  3274. apt-get clean
  3275. echo "deb http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION} main" > /etc/apt/sources.list
  3276. echo "deb-src http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION} main" >> /etc/apt/sources.list
  3277. echo '' >> /etc/apt/sources.list
  3278. echo "deb http://security.debian.org/ ${DEBIAN_VERSION}/updates main" >> /etc/apt/sources.list
  3279. echo "deb-src http://security.debian.org/ ${DEBIAN_VERSION}/updates main" >> /etc/apt/sources.list
  3280. echo '' >> /etc/apt/sources.list
  3281. echo "deb http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION}-updates main" >> /etc/apt/sources.list
  3282. echo "deb-src http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION}-updates main" >> /etc/apt/sources.list
  3283. echo '' >> /etc/apt/sources.list
  3284. echo "deb http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION}-backports main" >> /etc/apt/sources.list
  3285. echo "deb-src http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION}-backports main" >> /etc/apt/sources.list
  3286. apt-get update
  3287. apt-get -y install apt-transport-https
  3288. echo 'create_repo_sources' >> $COMPLETION_FILE
  3289. }
  3290. function initial_setup {
  3291. if grep -Fxq "initial_setup" $COMPLETION_FILE; then
  3292. return
  3293. fi
  3294. apt-get -y remove --purge apache*
  3295. apt-get -y dist-upgrade
  3296. apt-get -y install ca-certificates emacs24 cpulimit
  3297. apt-get -y install cryptsetup libgfshare-bin obnam sshpass wget
  3298. apt-get -y install avahi-daemon avahi-utils avahi-discover
  3299. apt-get -y install connect-proxy
  3300. if [ ! -d $INSTALL_DIR ]; then
  3301. mkdir -p $INSTALL_DIR
  3302. fi
  3303. echo 'initial_setup' >> $COMPLETION_FILE
  3304. }
  3305. function allow_ssh_to_onion_address {
  3306. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3307. return
  3308. fi
  3309. if [ ! -d /home/$MY_USERNAME/.ssh ]; then
  3310. mkdir /home/$MY_USERNAME/.ssh
  3311. fi
  3312. if [ ! -d /etc/tor ]; then
  3313. echo $'Tor not found when updating ssh'
  3314. exit 528257
  3315. fi
  3316. if ! grep -q "onion" /home/$MY_USERNAME/.ssh/config; then
  3317. echo 'Host *.onion' >> /home/$MY_USERNAME/.ssh/config
  3318. echo 'ProxyCommand connect -R remote -5 -S 127.0.0.1:9050 %h %p' >> /home/$MY_USERNAME/.ssh/config
  3319. fi
  3320. }
  3321. function install_tor {
  3322. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3323. return
  3324. fi
  3325. if grep -Fxq "install_tor" $COMPLETION_FILE; then
  3326. return
  3327. fi
  3328. apt-get -y install tor
  3329. if [ ! -f /etc/tor/torrc ]; then
  3330. echo 'Tor failed to install'
  3331. exit 38259
  3332. fi
  3333. echo 'install_tor' >> $COMPLETION_FILE
  3334. }
  3335. function resolve_dns_via_tor {
  3336. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3337. return
  3338. fi
  3339. if grep -Fxq "resolve_dns_via_tor" $COMPLETION_FILE; then
  3340. return
  3341. fi
  3342. if [ ! -f /etc/tor/torrc ]; then
  3343. echo $'tor was not installed'
  3344. exit 52952
  3345. fi
  3346. # resolve DNS via tor
  3347. if ! grep 'DNSPort 53' /etc/tor/torrc; then
  3348. echo 'DNSPort 53' >> /etc/tor/torrc
  3349. echo 'AutomapHostsOnResolve 1' >> /etc/tor/torrc
  3350. echo 'AutomapHostsSuffixes .exit,.onion' >> /etc/tor/torrc
  3351. systemctl restart tor
  3352. fi
  3353. # don't change resolv.conf
  3354. sed -i 's|, domain-name-servers||g' /etc/dhcp/dhclient.conf
  3355. # point resolv.conf to tor
  3356. echo 'nameserver 127.0.0.1:53' > /etc/resolv.conf
  3357. # prevent resolv.conf from changing
  3358. chattr +i /etc/resolv.conf
  3359. echo 'resolve_dns_via_tor' >> $COMPLETION_FILE
  3360. }
  3361. function enable_ssh_via_onion {
  3362. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3363. return
  3364. fi
  3365. if grep -Fxq "enable_ssh_via_onion" $COMPLETION_FILE; then
  3366. return
  3367. fi
  3368. apt-get -y install tor connect-proxy
  3369. if ! grep -q 'Host *.onion' /home/$MY_USERNAME/.ssh/config; then
  3370. if [ ! -d /home/$MY_USERNAME/.ssh ]; then
  3371. mkdir /home/$MY_USERNAME/.ssh
  3372. fi
  3373. echo 'Host *.onion' >> /home/$MY_USERNAME/.ssh/config
  3374. echo 'ProxyCommand connect -R remote -5 -S 127.0.0.1:9050 %h %p' >> /home/$MY_USERNAME/.ssh/config
  3375. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.ssh
  3376. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.ssh/config
  3377. fi
  3378. if ! grep -q 'Host *.onion' /root/.ssh/config; then
  3379. if [ ! -d /root/.ssh ]; then
  3380. mkdir /root/.ssh
  3381. fi
  3382. echo 'Host *.onion' >> /root/.ssh/config
  3383. echo 'ProxyCommand connect -R remote -5 -S 127.0.0.1:9050 %h %p' >> /root/.ssh/config
  3384. fi
  3385. echo 'enable_ssh_via_onion' >> $COMPLETION_FILE
  3386. }
  3387. function install_editor {
  3388. if grep -Fxq "install_editor" $COMPLETION_FILE; then
  3389. return
  3390. fi
  3391. update-alternatives --set editor /usr/bin/emacs24
  3392. # A minimal emacs configuration
  3393. #echo -n "(add-to-list 'load-path " > /home/$MY_USERNAME/.emacs
  3394. #echo '"~/.emacs.d/")' >> /home/$MY_USERNAME/.emacs
  3395. #echo '' >> /home/$MY_USERNAME/.emacs
  3396. echo $';; ===== Remove trailing whitepace ======================================' >> /home/$MY_USERNAME/.emacs
  3397. echo '' >> /home/$MY_USERNAME/.emacs
  3398. echo ";;(add-hook 'before-save-hook 'delete-trailing-whitespace)" >> /home/$MY_USERNAME/.emacs
  3399. echo '' >> /home/$MY_USERNAME/.emacs
  3400. echo ';; Goto a line number with CTRL-l' >> /home/$MY_USERNAME/.emacs
  3401. echo -n '(global-set-key "\C-l" ' >> /home/$MY_USERNAME/.emacs
  3402. echo "'goto-line)" >> /home/$MY_USERNAME/.emacs
  3403. echo '' >> /home/$MY_USERNAME/.emacs
  3404. echo $';; ===== Show line numbers ==============================================' >> /home/$MY_USERNAME/.emacs
  3405. echo '' >> /home/$MY_USERNAME/.emacs
  3406. echo "(add-hook 'find-file-hook (lambda () (linum-mode 1)))" >> /home/$MY_USERNAME/.emacs
  3407. echo '' >> /home/$MY_USERNAME/.emacs
  3408. echo $';; ===== Enable line wrapping in org-mode ===============================' >> /home/$MY_USERNAME/.emacs
  3409. echo '' >> /home/$MY_USERNAME/.emacs
  3410. echo " (add-hook 'org-mode-hook" >> /home/$MY_USERNAME/.emacs
  3411. echo " '(lambda ()" >> /home/$MY_USERNAME/.emacs
  3412. echo " (visual-line-mode 1)))" >> /home/$MY_USERNAME/.emacs
  3413. echo '' >> /home/$MY_USERNAME/.emacs
  3414. echo $';; ===== Enable shift select in org mode ================================' >> /home/$MY_USERNAME/.emacs
  3415. echo '' >> /home/$MY_USERNAME/.emacs
  3416. echo '(setq org-support-shift-select t)' >> /home/$MY_USERNAME/.emacs
  3417. echo '' >> /home/$MY_USERNAME/.emacs
  3418. echo $';; ===== Set standard indent to 4 rather that 4 =========================' >> /home/$MY_USERNAME/.emacs
  3419. echo '' >> /home/$MY_USERNAME/.emacs
  3420. echo '(setq standard-indent 4)' >> /home/$MY_USERNAME/.emacs
  3421. echo '(setq-default tab-width 4)' >> /home/$MY_USERNAME/.emacs
  3422. echo '(setq c-basic-offset 4)' >> /home/$MY_USERNAME/.emacs
  3423. echo '' >> /home/$MY_USERNAME/.emacs
  3424. echo $';; ===== Support Wheel Mouse Scrolling ==================================' >> /home/$MY_USERNAME/.emacs
  3425. echo '' >> /home/$MY_USERNAME/.emacs
  3426. echo '(mouse-wheel-mode t)' >> /home/$MY_USERNAME/.emacs
  3427. echo '' >> /home/$MY_USERNAME/.emacs
  3428. echo $';; ===== Place Backup Files in Specific Directory =======================' >> /home/$MY_USERNAME/.emacs
  3429. echo '' >> /home/$MY_USERNAME/.emacs
  3430. echo '(setq make-backup-files t)' >> /home/$MY_USERNAME/.emacs
  3431. echo '(setq version-control t)' >> /home/$MY_USERNAME/.emacs
  3432. echo '(setq backup-directory-alist (quote ((".*" . "~/.emacs_backups/"))))' >> /home/$MY_USERNAME/.emacs
  3433. echo '' >> /home/$MY_USERNAME/.emacs
  3434. echo $';; ===== Make Text mode the default mode for new buffers ================' >> /home/$MY_USERNAME/.emacs
  3435. echo '' >> /home/$MY_USERNAME/.emacs
  3436. echo "(setq default-major-mode 'text-mode)" >> /home/$MY_USERNAME/.emacs
  3437. echo '' >> /home/$MY_USERNAME/.emacs
  3438. echo $';; ===== Line length ====================================================' >> /home/$MY_USERNAME/.emacs
  3439. echo '' >> /home/$MY_USERNAME/.emacs
  3440. echo '(setq-default fill-column 72)' >> /home/$MY_USERNAME/.emacs
  3441. echo '' >> /home/$MY_USERNAME/.emacs
  3442. echo $';; ===== Enable Line and Column Numbering ===============================' >> /home/$MY_USERNAME/.emacs
  3443. echo '' >> /home/$MY_USERNAME/.emacs
  3444. echo '(line-number-mode 1)' >> /home/$MY_USERNAME/.emacs
  3445. echo '(column-number-mode 1)' >> /home/$MY_USERNAME/.emacs
  3446. echo '' >> /home/$MY_USERNAME/.emacs
  3447. echo $';; ===== Turn on Auto Fill mode automatically in all modes ==============' >> /home/$MY_USERNAME/.emacs
  3448. echo '' >> /home/$MY_USERNAME/.emacs
  3449. echo ';; Auto-fill-mode the the automatic wrapping of lines and insertion of' >> /home/$MY_USERNAME/.emacs
  3450. echo ';; newlines when the cursor goes over the column limit.' >> /home/$MY_USERNAME/.emacs
  3451. echo '' >> /home/$MY_USERNAME/.emacs
  3452. echo ';; This should actually turn on auto-fill-mode by default in all major' >> /home/$MY_USERNAME/.emacs
  3453. echo ';; modes. The other way to do this is to turn on the fill for specific modes' >> /home/$MY_USERNAME/.emacs
  3454. echo ';; via hooks.' >> /home/$MY_USERNAME/.emacs
  3455. echo '' >> /home/$MY_USERNAME/.emacs
  3456. echo '(setq auto-fill-mode 1)' >> /home/$MY_USERNAME/.emacs
  3457. echo '' >> /home/$MY_USERNAME/.emacs
  3458. echo $';; ===== Enable GPG encryption =========================================' >> /home/$MY_USERNAME/.emacs
  3459. echo '' >> /home/$MY_USERNAME/.emacs
  3460. echo "(require 'epa)" >> /home/$MY_USERNAME/.emacs
  3461. echo '(epa-file-enable)' >> /home/$MY_USERNAME/.emacs
  3462. cp /home/$MY_USERNAME/.emacs /root/.emacs
  3463. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs
  3464. echo 'install_editor' >> $COMPLETION_FILE
  3465. }
  3466. function enable_zram {
  3467. if grep -Fxq "enable_zram" $COMPLETION_FILE; then
  3468. return
  3469. fi
  3470. if [[ $INSTALLED_WITHIN_DOCKER == "yes" || $INSTALLING_ON_BBB != "yes" ]]; then
  3471. ${PROJECT_NAME}-zram off
  3472. return
  3473. fi
  3474. ${PROJECT_NAME}-zram on
  3475. echo 'enable_zram' >> $COMPLETION_FILE
  3476. }
  3477. function check_onerng_verification {
  3478. if grep -Fxq "check_onerng_verification" $COMPLETION_FILE; then
  3479. return
  3480. fi
  3481. if [[ $HWRNG_TYPE != "onerng" ]]; then
  3482. return
  3483. fi
  3484. echo $'Checking OneRNG firmware verification'
  3485. last_onerng_validation=$(cat /var/log/syslog.1 | grep "OneRNG: firmware verification" | awk '/./{line=$0} END{print line}')
  3486. if [[ $last_onerng_validation != *"passed OK"* ]]; then
  3487. last_onerng_validation=$(cat /var/log/syslog | grep "OneRNG: firmware verification" | awk '/./{line=$0} END{print line}')
  3488. if [[ $last_onerng_validation != *"passed OK"* ]]; then
  3489. echo $last_onerng_validation
  3490. echo $'OneRNG firmware verification failed'
  3491. exit 735026
  3492. fi
  3493. fi
  3494. echo $'OneRNG firmware verification passed'
  3495. # if haveged was previously installed then remove it
  3496. apt-get -y remove haveged
  3497. echo 'check_onerng_verification' >> $COMPLETION_FILE
  3498. }
  3499. function install_onerng {
  3500. apt-get -y install rng-tools at python-gnupg
  3501. # Move to the installation directory
  3502. if [ ! -d $INSTALL_DIR ]; then
  3503. mkdir $INSTALL_DIR
  3504. fi
  3505. cd $INSTALL_DIR
  3506. # Download the package
  3507. if [ ! -f $ONERNG_PACKAGE ]; then
  3508. wget $ONERNG_PACKAGE_DOWNLOAD
  3509. mv "$ONERNG_PACKAGE?raw=true" $ONERNG_PACKAGE
  3510. fi
  3511. if [ ! -f $ONERNG_PACKAGE ]; then
  3512. echo $"OneRNG package could not be downloaded"
  3513. exit 59249
  3514. fi
  3515. # Check the hash
  3516. hash=$(sha256sum $ONERNG_PACKAGE | awk -F ' ' '{print $1}')
  3517. if [[ $hash != $ONERNG_PACKAGE_HASH ]]; then
  3518. echo $"OneRNG package: $ONERNG_PACKAGE"
  3519. echo $"Hash does not match. This could indicate that the package has been tampered with."
  3520. echo $"OneRNG expected package hash: $ONERNG_PACKAGE_HASH"
  3521. echo $"OneRNG actual hash: $hash"
  3522. exit 25934
  3523. fi
  3524. # install the package
  3525. dpkg -i $ONERNG_PACKAGE
  3526. # Check that the install worked
  3527. if [ ! -f /etc/onerng.conf ]; then
  3528. echo $'OneRNG configuration file not found. The package may not have installed successfully.'
  3529. exit 42904
  3530. fi
  3531. dialog --title $"OneRNG Device" \
  3532. --msgbox $"Please plug in the OneRNG device" 6 40
  3533. # check rng-tools configuration
  3534. if ! grep -q "/dev/$ONERNG_DEVICE" /etc/default/rng-tools; then
  3535. echo "HRNGDEVICE=/dev/$ONERNG_DEVICE" >> /etc/default/rng-tools
  3536. fi
  3537. systemctl restart rng-tools
  3538. }
  3539. function random_number_generator {
  3540. if grep -Fxq "random_number_generator" $COMPLETION_FILE; then
  3541. return
  3542. fi
  3543. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3544. # it is assumed that docker uses the random number
  3545. # generator of the host system
  3546. return
  3547. fi
  3548. # if the hrng type has not been set but /dev/hwrng is detected
  3549. if [[ $HWRNG_TYPE != "beaglebone" ]]; then
  3550. if [ -e /dev/hwrng ]; then
  3551. HWRNG_TYPE="beaglebone"
  3552. fi
  3553. fi
  3554. case $HWRNG_TYPE in
  3555. beaglebone)
  3556. apt-get -y install rng-tools
  3557. sed -i 's|#HRNGDEVICE=/dev/hwrng|HRNGDEVICE=/dev/hwrng|g' /etc/default/rng-tools
  3558. ;;
  3559. onerng)
  3560. install_onerng
  3561. ;;
  3562. *)
  3563. apt-get -y install haveged
  3564. ;;
  3565. esac
  3566. echo 'random_number_generator' >> $COMPLETION_FILE
  3567. }
  3568. function configure_ssh {
  3569. if grep -Fxq "configure_ssh" $COMPLETION_FILE; then
  3570. return
  3571. fi
  3572. sed -i "s/Port .*/Port $SSH_PORT/g" /etc/ssh/sshd_config
  3573. sed -i 's/PermitRootLogin.*/PermitRootLogin no/g' /etc/ssh/sshd_config
  3574. sed -i 's/X11Forwarding.*/X11Forwarding no/g' /etc/ssh/sshd_config
  3575. sed -i 's/ServerKeyBits.*/ServerKeyBits 4096/g' /etc/ssh/sshd_config
  3576. sed -i 's/TCPKeepAlive.*/TCPKeepAlive no/g' /etc/ssh/sshd_config
  3577. sed -i 's|HostKey /etc/ssh/ssh_host_dsa_key|#HostKey /etc/ssh/ssh_host_dsa_key|g' /etc/ssh/sshd_config
  3578. sed -i 's|HostKey /etc/ssh/ssh_host_ecdsa_key|#HostKey /etc/ssh/ssh_host_ecdsa_key|g' /etc/ssh/sshd_config
  3579. if ! grep -q 'DebianBanner' /etc/ssh/sshd_config; then
  3580. echo 'DebianBanner no' >> /etc/ssh/sshd_config
  3581. else
  3582. sed -i 's|DebianBanner.*|DebianBanner no|g' /etc/ssh/sshd_config
  3583. fi
  3584. if grep -q 'ClientAliveInterval' /etc/ssh/sshd_config; then
  3585. sed -i 's/ClientAliveInterval.*/ClientAliveInterval 60/g' /etc/ssh/sshd_config
  3586. else
  3587. echo 'ClientAliveInterval 60' >> /etc/ssh/sshd_config
  3588. fi
  3589. if grep -q 'ClientAliveCountMax' /etc/ssh/sshd_config; then
  3590. sed -i 's/ClientAliveCountMax.*/ClientAliveCountMax 3/g' /etc/ssh/sshd_config
  3591. else
  3592. echo 'ClientAliveCountMax 3' >> /etc/ssh/sshd_config
  3593. fi
  3594. if grep -q 'Ciphers' /etc/ssh/sshd_config; then
  3595. sed -i "s|Ciphers.*|Ciphers $SSH_CIPHERS|g" /etc/ssh/sshd_config
  3596. else
  3597. echo "Ciphers $SSH_CIPHERS" >> /etc/ssh/sshd_config
  3598. fi
  3599. if grep -q 'MACs' /etc/ssh/sshd_config; then
  3600. sed -i "s|MACs.*|MACs $SSH_MACS|g" /etc/ssh/sshd_config
  3601. else
  3602. echo "MACs $SSH_MACS" >> /etc/ssh/sshd_config
  3603. fi
  3604. if grep -q 'KexAlgorithms' /etc/ssh/sshd_config; then
  3605. sed -i "s|KexAlgorithms.*|KexAlgorithms $SSH_KEX|g" /etc/ssh/sshd_config
  3606. else
  3607. echo "KexAlgorithms $SSH_KEX" >> /etc/ssh/sshd_config
  3608. fi
  3609. apt-get -y install fail2ban
  3610. echo 'configure_ssh' >> $COMPLETION_FILE
  3611. }
  3612. function configure_ssh_onion {
  3613. if grep -Fxq "configure_ssh_onion" $COMPLETION_FILE; then
  3614. return
  3615. fi
  3616. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3617. return
  3618. fi
  3619. SSH_ONION_HOSTNAME=$(add_onion_service ssh ${SSH_PORT} ${SSH_PORT})
  3620. if ! grep -q "ssh onion domain" $COMPLETION_FILE; then
  3621. echo "ssh onion domain:${SSH_ONION_HOSTNAME}" >> $COMPLETION_FILE
  3622. else
  3623. sed -i "s|ssh onion domain.*|ssh onion domain:${SSH_ONION_HOSTNAME}|g" $COMPLETION_FILE
  3624. fi
  3625. echo 'configure_ssh_onion' >> $COMPLETION_FILE
  3626. }
  3627. # see https://stribika.github.io/2015/01/04/secure-secure-shell.html
  3628. function ssh_remove_small_moduli {
  3629. awk '$5 > 2000' /etc/ssh/moduli > ~/moduli
  3630. mv ~/moduli /etc/ssh/moduli
  3631. }
  3632. function configure_ssh_client {
  3633. if grep -Fxq "configure_ssh_client" $COMPLETION_FILE; then
  3634. return
  3635. fi
  3636. #sed -i 's/# PasswordAuthentication.*/ PasswordAuthentication no/g' /etc/ssh/ssh_config
  3637. #sed -i 's/# ChallengeResponseAuthentication.*/ ChallengeResponseAuthentication no/g' /etc/ssh/ssh_config
  3638. sed -i "s/# HostKeyAlgorithms.*/ HostKeyAlgorithms $SSH_HOST_KEY_ALGORITHMS/g" /etc/ssh/ssh_config
  3639. sed -i "s/# Ciphers.*/ Ciphers $SSH_CIPHERS/g" /etc/ssh/ssh_config
  3640. sed -i "s/# MACs.*/ MACs $SSH_MACS/g" /etc/ssh/ssh_config
  3641. if ! grep -q "HostKeyAlgorithms" /etc/ssh/ssh_config; then
  3642. echo " HostKeyAlgorithms $SSH_HOST_KEY_ALGORITHMS" >> /etc/ssh/ssh_config
  3643. fi
  3644. sed -i "s/Ciphers.*/Ciphers $SSH_CIPHERS/g" /etc/ssh/ssh_config
  3645. if ! grep -q "Ciphers " /etc/ssh/ssh_config; then
  3646. echo " Ciphers $SSH_CIPHERS" >> /etc/ssh/ssh_config
  3647. fi
  3648. sed -i "s/MACs.*/MACs $SSH_MACS/g" /etc/ssh/ssh_config
  3649. if ! grep -q "MACs " /etc/ssh/ssh_config; then
  3650. echo " MACs $SSH_MACS" >> /etc/ssh/ssh_config
  3651. fi
  3652. # Create ssh keys
  3653. if [ ! -f ~/.ssh/id_ed25519 ]; then
  3654. ssh-keygen -t ed25519 -o -a 100
  3655. fi
  3656. if [ ! -f ~/.ssh/id_rsa ]; then
  3657. ssh-keygen -t rsa -b 4096 -o -a 100
  3658. fi
  3659. ssh_remove_small_moduli
  3660. echo 'configure_ssh_client' >> $COMPLETION_FILE
  3661. }
  3662. function regenerate_ssh_keys {
  3663. if grep -Fxq "regenerate_ssh_keys" $COMPLETION_FILE; then
  3664. return
  3665. fi
  3666. rm -f /etc/ssh/ssh_host_*
  3667. dpkg-reconfigure openssh-server
  3668. ssh_remove_small_moduli
  3669. systemctl restart ssh
  3670. echo 'regenerate_ssh_keys' >> $COMPLETION_FILE
  3671. }
  3672. function configure_dns {
  3673. if grep -Fxq "configure_dns" $COMPLETION_FILE; then
  3674. return
  3675. fi
  3676. echo 'domain localdomain' > /etc/resolv.conf
  3677. echo 'search localdomain' >> /etc/resolv.conf
  3678. echo "nameserver $NAMESERVER1" >> /etc/resolv.conf
  3679. echo "nameserver $NAMESERVER2" >> /etc/resolv.conf
  3680. # prevent resolv.conf from changing
  3681. chattr +i /etc/resolv.conf
  3682. echo 'configure_dns' >> $COMPLETION_FILE
  3683. }
  3684. function set_hostname {
  3685. DEFAULT_DOMAIN_NAME="$1"
  3686. echo "$DEFAULT_DOMAIN_NAME" > /etc/hostname
  3687. hostname $DEFAULT_DOMAIN_NAME
  3688. if grep -q "127.0.1.1" /etc/hosts; then
  3689. sed -i "s/127.0.1.1.*/127.0.1.1 $DEFAULT_DOMAIN_NAME/g" /etc/hosts
  3690. else
  3691. echo "127.0.1.1 $DEFAULT_DOMAIN_NAME" >> /etc/hosts
  3692. fi
  3693. }
  3694. function set_your_domain_name {
  3695. if grep -Fxq "set_your_domain_name" $COMPLETION_FILE; then
  3696. return
  3697. fi
  3698. set_hostname $DEFAULT_DOMAIN_NAME
  3699. echo 'set_your_domain_name' >> $COMPLETION_FILE
  3700. }
  3701. function time_synchronisation {
  3702. # mesh peers typically don't sync over the internet
  3703. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3704. return
  3705. fi
  3706. if [ -f /usr/local/bin/${PROJECT_NAME}-update-date ]; then
  3707. cp /usr/local/bin/${PROJECT_NAME}-update-date /usr/bin/updatedate
  3708. else
  3709. cp /usr/bin/${PROJECT_NAME}-update-date /usr/bin/updatedate
  3710. fi
  3711. chmod +x /usr/bin/updatedate
  3712. if grep -Fxq "time_synchronisation" $COMPLETION_FILE; then
  3713. return
  3714. fi
  3715. apt-get -y install tlsdate
  3716. apt-get -y remove ntpdate
  3717. echo '*/15 * * * * root /usr/bin/updatedate' >> /etc/crontab
  3718. systemctl restart cron
  3719. echo 'time_synchronisation' >> $COMPLETION_FILE
  3720. }
  3721. function configure_firewall {
  3722. if grep -q "RELATED" /etc/firewall.conf; then
  3723. # recreate the firewall to remove RELATED
  3724. sed -i "/firewall/d" $COMPLETION_FILE
  3725. fi
  3726. if grep -Fxq "configure_firewall" $COMPLETION_FILE; then
  3727. return
  3728. fi
  3729. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3730. # docker does its own firewalling
  3731. return
  3732. fi
  3733. iptables -P INPUT ACCEPT
  3734. ip6tables -P INPUT ACCEPT
  3735. iptables -F
  3736. ip6tables -F
  3737. iptables -t nat -F
  3738. ip6tables -t nat -F
  3739. iptables -X
  3740. ip6tables -X
  3741. iptables -P INPUT DROP
  3742. ip6tables -P INPUT DROP
  3743. iptables -A INPUT -i lo -j ACCEPT
  3744. iptables -A INPUT -m conntrack --ctstate ESTABLISHED -j ACCEPT
  3745. # Make sure incoming tcp connections are SYN packets
  3746. iptables -A INPUT -p tcp ! --syn -m state --state NEW -j DROP
  3747. # Drop packets with incoming fragments
  3748. iptables -A INPUT -f -j DROP
  3749. # Drop bogons
  3750. iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP
  3751. iptables -A INPUT -p tcp --tcp-flags ALL FIN,PSH,URG -j DROP
  3752. iptables -A INPUT -p tcp --tcp-flags ALL SYN,RST,ACK,FIN,URG -j DROP
  3753. # Incoming malformed NULL packets:
  3754. iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP
  3755. echo 'configure_firewall' >> $COMPLETION_FILE
  3756. }
  3757. function configure_firewall_ping {
  3758. if grep -Fxq "configure_firewall_ping" $COMPLETION_FILE; then
  3759. return
  3760. fi
  3761. # Only allow ping for mesh installs
  3762. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  3763. return
  3764. fi
  3765. iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
  3766. iptables -A OUTPUT -p icmp --icmp-type echo-reply -j ACCEPT
  3767. save_firewall_settings
  3768. echo 'configure_firewall_ping' >> $COMPLETION_FILE
  3769. }
  3770. function configure_firewall_for_voip {
  3771. 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
  3772. return
  3773. fi
  3774. if grep -Fxq "configure_firewall_for_voip" $COMPLETION_FILE; then
  3775. return
  3776. fi
  3777. if [[ $ONION_ONLY != "no" ]]; then
  3778. return
  3779. fi
  3780. iptables -A INPUT -p udp --dport $VOIP_PORT -j ACCEPT
  3781. iptables -A INPUT -p tcp --dport $VOIP_PORT -j ACCEPT
  3782. save_firewall_settings
  3783. echo 'configure_firewall_for_voip' >> $COMPLETION_FILE
  3784. }
  3785. function configure_firewall_for_syncthing {
  3786. if grep -Fxq "configure_firewall_for_syncthing" $COMPLETION_FILE; then
  3787. return
  3788. fi
  3789. iptables -A INPUT -p udp --dport $SYNCTHING_PORT -j ACCEPT
  3790. iptables -A INPUT -p tcp --dport $SYNCTHING_PORT -j ACCEPT
  3791. save_firewall_settings
  3792. echo 'configure_firewall_for_syncthing' >> $COMPLETION_FILE
  3793. }
  3794. function configure_firewall_for_voip_turn {
  3795. 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
  3796. return
  3797. fi
  3798. if grep -Fxq "configure_firewall_for_voip_turn" $COMPLETION_FILE; then
  3799. return
  3800. fi
  3801. if [[ $ONION_ONLY != "no" ]]; then
  3802. return
  3803. fi
  3804. iptables -A INPUT -p udp --dport $VOIP_TURN_PORT -j ACCEPT
  3805. iptables -A INPUT -p tcp --dport $VOIP_TURN_PORT -j ACCEPT
  3806. iptables -A INPUT -p tcp --dport $VOIP_TURN_TLS_PORT -j ACCEPT
  3807. save_firewall_settings
  3808. echo 'configure_firewall_for_voip_turn' >> $COMPLETION_FILE
  3809. }
  3810. function configure_firewall_for_sip4 {
  3811. 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
  3812. return
  3813. fi
  3814. if grep -Fxq "configure_firewall_for_sip4" $COMPLETION_FILE; then
  3815. return
  3816. fi
  3817. if [[ $ONION_ONLY != "no" ]]; then
  3818. return
  3819. fi
  3820. iptables -A INPUT -p udp --dport $SIP_PORT -j ACCEPT
  3821. iptables -A INPUT -p tcp --dport $SIP_PORT -j ACCEPT
  3822. iptables -A INPUT -p udp --dport $SIP_TLS_PORT -j ACCEPT
  3823. iptables -A INPUT -p tcp --dport $SIP_TLS_PORT -j ACCEPT
  3824. save_firewall_settings
  3825. echo 'configure_firewall_for_sip4' >> $COMPLETION_FILE
  3826. }
  3827. function configure_firewall_for_ipfs {
  3828. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  3829. return
  3830. fi
  3831. if grep -Fxq "configure_firewall_for_ipfs" $COMPLETION_FILE; then
  3832. return
  3833. fi
  3834. if [[ $ONION_ONLY != "no" ]]; then
  3835. return
  3836. fi
  3837. iptables -A INPUT -p tcp --dport $IPFS_PORT -j ACCEPT
  3838. save_firewall_settings
  3839. echo 'configure_firewall_for_ipfs' >> $COMPLETION_FILE
  3840. }
  3841. function configure_firewall_for_avahi {
  3842. if grep -Fxq "configure_firewall_for_avahi" $COMPLETION_FILE; then
  3843. return
  3844. fi
  3845. iptables -A INPUT -p tcp --dport 548 -j ACCEPT
  3846. iptables -A INPUT -p udp --dport 548 -j ACCEPT
  3847. iptables -A INPUT -p tcp --dport 5353 -j ACCEPT
  3848. iptables -A INPUT -p udp --dport 5353 -j ACCEPT
  3849. iptables -A INPUT -p tcp --dport 5354 -j ACCEPT
  3850. iptables -A INPUT -p udp --dport 5354 -j ACCEPT
  3851. save_firewall_settings
  3852. echo 'configure_firewall_for_avahi' >> $COMPLETION_FILE
  3853. }
  3854. function configure_firewall_for_cjdns {
  3855. if grep -Fxq "configure_firewall_for_cjdns" $COMPLETION_FILE; then
  3856. return
  3857. fi
  3858. if [[ $ENABLE_CJDNS != "yes" ]]; then
  3859. return
  3860. fi
  3861. ip6tables -t nat -A POSTROUTING -o tun0 -j MASQUERADE
  3862. ip6tables -A FORWARD -i tun0 -o eth0 -m state --state RELATED,ESTABLISHED -j ACCEPT
  3863. save_firewall_settings
  3864. echo 'configure_firewall_for_cjdns' >> $COMPLETION_FILE
  3865. }
  3866. function configure_firewall_for_batman {
  3867. if grep -Fxq "configure_firewall_for_batman" $COMPLETION_FILE; then
  3868. return
  3869. fi
  3870. if [[ $ENABLE_BATMAN != "yes" ]]; then
  3871. return
  3872. fi
  3873. save_firewall_settings
  3874. echo 'configure_firewall_for_batman' >> $COMPLETION_FILE
  3875. }
  3876. function configure_firewall_for_babel {
  3877. if grep -Fxq "configure_firewall_for_babel" $COMPLETION_FILE; then
  3878. return
  3879. fi
  3880. if [[ $ENABLE_BABEL != "yes" ]]; then
  3881. return
  3882. fi
  3883. iptables -A INPUT -i $WIFI_INTERFACE -p udp --dport $BABEL_PORT -j ACCEPT
  3884. save_firewall_settings
  3885. echo 'configure_firewall_for_babel' >> $COMPLETION_FILE
  3886. }
  3887. function configure_firewall_for_zeronet {
  3888. if grep -Fxq "configure_firewall_for_zeronet" $COMPLETION_FILE; then
  3889. return
  3890. fi
  3891. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  3892. return
  3893. fi
  3894. iptables -A INPUT -i $WIFI_INTERFACE -p udp --dport $ZERONET_PORT -j ACCEPT
  3895. iptables -A INPUT -i $WIFI_INTERFACE -p tcp --dport $ZERONET_PORT -j ACCEPT
  3896. iptables -A INPUT -i $WIFI_INTERFACE -p udp --dport $TRACKER_PORT -j ACCEPT
  3897. iptables -A INPUT -i $WIFI_INTERFACE -p tcp --dport $TRACKER_PORT -j ACCEPT
  3898. iptables -A INPUT -i $WIFI_INTERFACE -p udp --dport 1900 -j ACCEPT
  3899. save_firewall_settings
  3900. echo 'configure_firewall_for_zeronet' >> $COMPLETION_FILE
  3901. }
  3902. function configure_firewall_for_dlna {
  3903. if grep -Fxq "configure_firewall_for_dlna" $COMPLETION_FILE; then
  3904. return
  3905. fi
  3906. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3907. # docker does its own firewalling
  3908. return
  3909. fi
  3910. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" ]]; then
  3911. return
  3912. fi
  3913. iptables -A INPUT -p udp --dport 1900 -j ACCEPT
  3914. iptables -A INPUT -p tcp --dport 8200 -j ACCEPT
  3915. save_firewall_settings
  3916. echo 'configure_firewall_for_dlna' >> $COMPLETION_FILE
  3917. }
  3918. function configure_firewall_for_dns {
  3919. if grep -Fxq "configure_firewall_for_dns" $COMPLETION_FILE; then
  3920. return
  3921. fi
  3922. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3923. # docker does its own firewalling
  3924. return
  3925. fi
  3926. iptables -A INPUT -p udp -m udp --dport 1024:65535 --sport 53 -j ACCEPT
  3927. save_firewall_settings
  3928. echo 'configure_firewall_for_dns' >> $COMPLETION_FILE
  3929. }
  3930. function configure_firewall_for_xmpp {
  3931. if [ ! -d /etc/prosody ]; then
  3932. return
  3933. fi
  3934. if grep -Fxq "configure_firewall_for_xmpp" $COMPLETION_FILE; then
  3935. return
  3936. fi
  3937. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3938. # docker does its own firewalling
  3939. return
  3940. fi
  3941. if [[ $ONION_ONLY != "no" ]]; then
  3942. return
  3943. fi
  3944. iptables -A INPUT -p tcp --dport 5222:5223 -j ACCEPT
  3945. iptables -A INPUT -p tcp --dport 5269 -j ACCEPT
  3946. iptables -A INPUT -p tcp --dport 5280:5281 -j ACCEPT
  3947. save_firewall_settings
  3948. echo 'configure_firewall_for_xmpp' >> $COMPLETION_FILE
  3949. }
  3950. function configure_firewall_for_irc {
  3951. if [ ! -d /etc/ngircd ]; then
  3952. return
  3953. fi
  3954. if grep -Fxq "configure_firewall_for_irc" $COMPLETION_FILE; then
  3955. return
  3956. fi
  3957. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3958. # docker does its own firewalling
  3959. return
  3960. fi
  3961. if [[ $ONION_ONLY != "no" ]]; then
  3962. return
  3963. fi
  3964. iptables -A INPUT -p tcp --dport $IRC_PORT -j ACCEPT
  3965. iptables -I INPUT -p tcp --dport 1024:65535 --sport $IRC_PORT -j ACCEPT
  3966. save_firewall_settings
  3967. echo 'configure_firewall_for_irc' >> $COMPLETION_FILE
  3968. }
  3969. function configure_firewall_for_ftp {
  3970. if grep -Fxq "configure_firewall_for_ftp" $COMPLETION_FILE; then
  3971. return
  3972. fi
  3973. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3974. # docker does its own firewalling
  3975. return
  3976. fi
  3977. if [[ $ONION_ONLY != "no" ]]; then
  3978. return
  3979. fi
  3980. iptables -I INPUT -p tcp --dport 1024:65535 --sport 20:21 -j ACCEPT
  3981. save_firewall_settings
  3982. echo 'configure_firewall_for_ftp' >> $COMPLETION_FILE
  3983. }
  3984. function configure_firewall_for_web_access {
  3985. if grep -Fxq "configure_firewall_for_web_access" $COMPLETION_FILE; then
  3986. return
  3987. fi
  3988. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3989. # docker does its own firewalling
  3990. return
  3991. fi
  3992. if [[ $ONION_ONLY != "no" ]]; then
  3993. return
  3994. fi
  3995. iptables -A INPUT -p tcp --dport 32768:61000 --sport 80 -j ACCEPT
  3996. iptables -A INPUT -p tcp --dport 32768:61000 --sport 443 -j ACCEPT
  3997. save_firewall_settings
  3998. echo 'configure_firewall_for_web_access' >> $COMPLETION_FILE
  3999. }
  4000. function configure_firewall_for_web_server {
  4001. if grep -Fxq "configure_firewall_for_web_server" $COMPLETION_FILE; then
  4002. return
  4003. fi
  4004. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4005. # docker does its own firewalling
  4006. return
  4007. fi
  4008. if [[ $ONION_ONLY != "no" ]]; then
  4009. return
  4010. fi
  4011. iptables -A INPUT -p tcp --dport 80 -j ACCEPT
  4012. iptables -A INPUT -p tcp --dport 443 -j ACCEPT
  4013. save_firewall_settings
  4014. echo 'configure_firewall_for_web_server' >> $COMPLETION_FILE
  4015. }
  4016. function configure_firewall_for_tox {
  4017. if grep -Fxq "configure_firewall_for_tox" $COMPLETION_FILE; then
  4018. return
  4019. fi
  4020. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4021. # docker does its own firewalling
  4022. return
  4023. fi
  4024. if [[ $ONION_ONLY != "no" ]]; then
  4025. return
  4026. fi
  4027. iptables -A INPUT -p tcp --dport $TOX_PORT -j ACCEPT
  4028. save_firewall_settings
  4029. echo 'configure_firewall_for_tox' >> $COMPLETION_FILE
  4030. }
  4031. function configure_firewall_for_ssh {
  4032. if grep -Fxq "configure_firewall_for_ssh" $COMPLETION_FILE; then
  4033. return
  4034. fi
  4035. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4036. # docker does its own firewalling
  4037. return
  4038. fi
  4039. iptables -A INPUT -p tcp --dport 22 -j ACCEPT
  4040. iptables -A INPUT -p tcp --dport $SSH_PORT -j ACCEPT
  4041. save_firewall_settings
  4042. echo 'configure_firewall_for_ssh' >> $COMPLETION_FILE
  4043. }
  4044. function configure_firewall_for_git {
  4045. if grep -Fxq "configure_firewall_for_git" $COMPLETION_FILE; then
  4046. return
  4047. fi
  4048. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4049. # docker does its own firewalling
  4050. return
  4051. fi
  4052. if [[ $ONION_ONLY != "no" ]]; then
  4053. return
  4054. fi
  4055. iptables -A INPUT -p tcp --dport 9418 -j ACCEPT
  4056. save_firewall_settings
  4057. echo 'configure_firewall_for_git' >> $COMPLETION_FILE
  4058. }
  4059. function configure_firewall_for_email {
  4060. 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_MESH" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" ]]; then
  4061. return
  4062. fi
  4063. if grep -Fxq "configure_firewall_for_email" $COMPLETION_FILE; then
  4064. return
  4065. fi
  4066. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  4067. # docker does its own firewalling
  4068. return
  4069. fi
  4070. if [[ $ONION_ONLY != "no" ]]; then
  4071. return
  4072. fi
  4073. iptables -A INPUT -p tcp --dport 25 -j ACCEPT
  4074. iptables -A INPUT -p tcp --dport 587 -j ACCEPT
  4075. iptables -A INPUT -p tcp --dport 465 -j ACCEPT
  4076. iptables -A INPUT -p tcp --dport 993 -j ACCEPT
  4077. save_firewall_settings
  4078. echo 'configure_firewall_for_email' >> $COMPLETION_FILE
  4079. }
  4080. function configure_internet_protocol {
  4081. if grep -Fxq "configure_internet_protocol" $COMPLETION_FILE; then
  4082. return
  4083. fi
  4084. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4085. return
  4086. fi
  4087. sed -i "s/#net.ipv4.tcp_syncookies=1/net.ipv4.tcp_syncookies=1/g" /etc/sysctl.conf
  4088. sed -i "s/#net.ipv4.conf.all.accept_redirects = 0/net.ipv4.conf.all.accept_redirects = 0/g" /etc/sysctl.conf
  4089. sed -i "s/#net.ipv6.conf.all.accept_redirects = 0/net.ipv6.conf.all.accept_redirects = 0/g" /etc/sysctl.conf
  4090. sed -i "s/#net.ipv4.conf.all.send_redirects = 0/net.ipv4.conf.all.send_redirects = 0/g" /etc/sysctl.conf
  4091. sed -i "s/#net.ipv4.conf.all.accept_source_route = 0/net.ipv4.conf.all.accept_source_route = 0/g" /etc/sysctl.conf
  4092. sed -i "s/#net.ipv6.conf.all.accept_source_route = 0/net.ipv6.conf.all.accept_source_route = 0/g" /etc/sysctl.conf
  4093. sed -i "s/#net.ipv4.conf.default.rp_filter=1/net.ipv4.conf.default.rp_filter=1/g" /etc/sysctl.conf
  4094. sed -i "s/#net.ipv4.conf.all.rp_filter=1/net.ipv4.conf.all.rp_filter=1/g" /etc/sysctl.conf
  4095. sed -i "s/#net.ipv4.ip_forward=1/net.ipv4.ip_forward=0/g" /etc/sysctl.conf
  4096. sed -i "s/#net.ipv6.conf.all.forwarding=1/net.ipv6.conf.all.forwarding=0/g" /etc/sysctl.conf
  4097. if ! grep -q "ignore pings" /etc/sysctl.conf; then
  4098. echo '# ignore pings' >> /etc/sysctl.conf
  4099. echo 'net.ipv4.icmp_echo_ignore_all = 1' >> /etc/sysctl.conf
  4100. echo 'net.ipv6.icmp_echo_ignore_all = 1' >> /etc/sysctl.conf
  4101. fi
  4102. if ! grep -q "disable ipv6" /etc/sysctl.conf; then
  4103. echo '# disable ipv6' >> /etc/sysctl.conf
  4104. echo 'net.ipv6.conf.all.disable_ipv6 = 1' >> /etc/sysctl.conf
  4105. fi
  4106. if ! grep -q "net.ipv4.tcp_synack_retries" /etc/sysctl.conf; then
  4107. echo 'net.ipv4.tcp_synack_retries = 2' >> /etc/sysctl.conf
  4108. echo 'net.ipv4.tcp_syn_retries = 1' >> /etc/sysctl.conf
  4109. fi
  4110. if ! grep -q "keepalive" /etc/sysctl.conf; then
  4111. echo '# keepalive' >> /etc/sysctl.conf
  4112. echo 'net.ipv4.tcp_keepalive_probes = 9' >> /etc/sysctl.conf
  4113. echo 'net.ipv4.tcp_keepalive_intvl = 75' >> /etc/sysctl.conf
  4114. echo 'net.ipv4.tcp_keepalive_time = 7200' >> /etc/sysctl.conf
  4115. fi
  4116. echo 'configure_internet_protocol' >> $COMPLETION_FILE
  4117. }
  4118. function install_command_line_browser {
  4119. if grep -Fxq "install_command_line_browser" $COMPLETION_FILE; then
  4120. return
  4121. fi
  4122. apt-get -y install elinks
  4123. # set the home page
  4124. if ! grep -q "WWW_HOME" /home/$MY_USERNAME/.bashrc; then
  4125. if ! grep -q 'control' /home/$MY_USERNAME/.bashrc; then
  4126. echo "export WWW_HOME=$DEFAULT_SEARCH" >> /home/$MY_USERNAME/.bashrc
  4127. else
  4128. sed -i "/control/i export WWW_HOME=$DEFAULT_SEARCH" /home/$MY_USERNAME/.bashrc
  4129. fi
  4130. fi
  4131. echo 'install_command_line_browser' >> $COMPLETION_FILE
  4132. }
  4133. function configure_email {
  4134. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4135. return
  4136. fi
  4137. if grep -Fxq "configure_email" $COMPLETION_FILE; then
  4138. return
  4139. fi
  4140. apt-get -y remove postfix
  4141. apt-get -y install exim4 sasl2-bin swaks libnet-ssleay-perl procmail xinetd
  4142. if [ ! -d /etc/exim4 ]; then
  4143. echo $"ERROR: Exim does not appear to have installed. $CHECK_MESSAGE"
  4144. exit 48
  4145. fi
  4146. onion_service_name='email'
  4147. if [ ! -d /var/lib/tor ]; then
  4148. echo $"No Tor installation found. ${onion_service_name} onion site cannot be configured."
  4149. exit 877367
  4150. fi
  4151. if ! grep -q "hidden_service_${onion_service_name}" /etc/tor/torrc; then
  4152. echo "HiddenServiceDir /var/lib/tor/hidden_service_${onion_service_name}/" >> /etc/tor/torrc
  4153. echo 'HiddenServicePort 25 127.0.0.1:25' >> /etc/tor/torrc
  4154. echo 'HiddenServicePort 587 127.0.0.1:587' >> /etc/tor/torrc
  4155. echo 'HiddenServicePort 465 127.0.0.1:465' >> /etc/tor/torrc
  4156. echo 'HiddenServicePort 993 127.0.0.1:993' >> /etc/tor/torrc
  4157. echo $"Added onion site for ${onion_service_name}"
  4158. fi
  4159. systemctl restart tor
  4160. wait_for_onion_service ${onion_service_name}
  4161. if [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  4162. echo $"${onion_service_name} onion site hostname not found"
  4163. exit 76362
  4164. fi
  4165. EMAIL_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_${onion_service_name}/hostname)
  4166. if [[ $ONION_ONLY != "no" ]]; then
  4167. set_hostname ${EMAIL_ONION_HOSTNAME}
  4168. MY_EMAIL_ADDRESS=${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}
  4169. fi
  4170. if ! grep -q "Email onion domain" $COMPLETION_FILE; then
  4171. echo "Email onion domain:${EMAIL_ONION_HOSTNAME}" >> $COMPLETION_FILE
  4172. else
  4173. sed -i "s|Email onion domain.*|Email onion domain:${EMAIL_ONION_HOSTNAME}|g" $COMPLETION_FILE
  4174. fi
  4175. # see https://github.com/petterreinholdtsen/exim4-smtorp
  4176. echo '# tor stuff first' > /etc/exim4/conf.d/router/100_exim4-smtorp
  4177. echo '#' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4178. echo '# if were submitting mail *from* a .tor/.onion address,' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4179. echo '# make sure any header lines that may give us away is' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4180. echo '# stripped out, and add a new, cryptic Message-ID.' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4181. echo '# In address_data we store the name we should HELO as.' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4182. echo 'tor_to_any:' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4183. echo ' debug_print = "R: manualroute from .onion to $local_part@$domain"' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4184. echo ' driver = manualroute' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4185. echo ' domains = ! +local_domains' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4186. echo ' condition = ${if match {$sender_address_domain}{\N.*\.(onion|tor)$\N}}' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4187. echo ' address_data = $sender_address_domain' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4188. echo ' transport = remote_smtp_onion' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4189. echo ' self = send' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4190. echo ' route_list = * localhost' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4191. echo ' headers_remove = Received:Message-ID:X-Mailer:User-Agent' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4192. echo ' headers_add = Message-ID: <${lc:${sha1:$message_id}}@$sender_address_domain>' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4193. echo '' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4194. echo '# this catches the case where were submitting mail' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4195. echo '# from a regular email address where we dont need to' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4196. echo '# rewrite any headers' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4197. echo 'any_to_tor:' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4198. echo ' debug_print = "R: manualroute for $local_part@$domain"' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4199. echo ' driver = manualroute' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4200. echo ' domains = ! +local_domains' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4201. echo ' transport = remote_smtp_onion' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4202. echo ' self = send' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4203. echo ' route_list = *.onion localhost ; *.tor localhost' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4204. echo ' address_data = $smtp_active_hostname' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4205. echo 'remote_smtp_onion:' > /etc/exim4/conf.d/transport/100_exim4-smtorp
  4206. echo ' debug_print = "T: remote_smtp_onion for $local_part@$original_domain"' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4207. echo ' driver = smtp' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4208. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4209. echo ' # set helo_data to where we want to connect to,' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4210. echo ' # for the proxy program tor-smtp' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4211. echo ' helo_data = "$address_data $original_domain"' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4212. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4213. echo ' # wherever we configured our script at' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4214. echo ' port = 12668' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4215. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4216. echo ' # cannot use TLS otherwise it will EHLO again!!' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4217. echo ' hosts_avoid_tls = *' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4218. if [ ! -d $INSTALL_DIR ]; then
  4219. mkdir -p $INSTALL_DIR
  4220. fi
  4221. cd $INSTALL_DIR
  4222. git_clone $EXIM_ONION_REPO $INSTALL_DIR/exim4-smtorp
  4223. cd $INSTALL_DIR/exim4-smtorp/tor-smtp
  4224. make
  4225. if [ ! -f $INSTALL_DIR/exim4-smtorp/tor-smtp/tor-smtp ]; then
  4226. echo $'Unable to make tor smtp transport'
  4227. exit 52629
  4228. fi
  4229. if [ ! -d /usr/lib/exim4-smtorp ]; then
  4230. mkdir /usr/lib/exim4-smtorp
  4231. fi
  4232. cp $INSTALL_DIR/exim4-smtorp/tor-smtp/tor-smtp /usr/lib/exim4-smtorp/tor-smtp
  4233. if [ ! -f /usr/lib/exim4-smtorp/tor-smtp ]; then
  4234. echo $'Unable to copy tor-smtp'
  4235. exit 83503
  4236. fi
  4237. cp $INSTALL_DIR/exim4-smtorp/xinetd /etc/xinetd.d/tor-smtp
  4238. if [ ! -f /etc/xinetd.d/tor-smtp ]; then
  4239. echo $'Unable to copy to xinetd.d'
  4240. exit 835954
  4241. fi
  4242. systemctl restart xinetd
  4243. # configure for Maildir format
  4244. sed -i 's/MAIL_DIR/#MAIL_DIR/g' /etc/login.defs
  4245. sed -i 's|#MAIL_FILE.*|MAIL_FILE Maildir/|g' /etc/login.defs
  4246. if ! grep -q "export MAIL" /etc/profile; then
  4247. echo 'export MAIL=~/Maildir' >> /etc/profile
  4248. fi
  4249. sed -i 's|pam_mail.so standard|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/login
  4250. sed -i 's|pam_mail.so standard noenv|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/sshd
  4251. sed -i 's|pam_mail.so nopen|pam_mail.so dir=~/Maildir nopen|g' /etc/pam.d/su
  4252. echo 'dc_eximconfig_configtype="internet"' > /etc/exim4/update-exim4.conf.conf
  4253. if [[ $ONION_ONLY == "no" ]]; then
  4254. # both ICANN and onion domains
  4255. echo "dc_other_hostnames='${DEFAULT_DOMAIN_NAME};${EMAIL_ONION_HOSTNAME}'" >> /etc/exim4/update-exim4.conf.conf
  4256. else
  4257. echo "dc_other_hostnames='${EMAIL_ONION_HOSTNAME}'" >> /etc/exim4/update-exim4.conf.conf
  4258. fi
  4259. echo "dc_local_interfaces=''" >> /etc/exim4/update-exim4.conf.conf
  4260. echo "dc_readhost=''" >> /etc/exim4/update-exim4.conf.conf
  4261. echo "dc_relay_domains=''" >> /etc/exim4/update-exim4.conf.conf
  4262. echo "dc_minimaldns='false'" >> /etc/exim4/update-exim4.conf.conf
  4263. RELAY_NETS='192.168.1.0/24'
  4264. if [ $LOCAL_NETWORK_STATIC_IP_ADDRESS ]; then
  4265. RELAY_NETS=$(echo $LOCAL_NETWORK_STATIC_IP_ADDRESS | awk -F '.' '{print $1 "." $2 "." $3 ".0/24"}')
  4266. fi
  4267. echo "dc_relay_nets='$RELAY_NETS'" >> /etc/exim4/update-exim4.conf.conf
  4268. echo "dc_smarthost=''" >> /etc/exim4/update-exim4.conf.conf
  4269. echo "CFILEMODE='644'" >> /etc/exim4/update-exim4.conf.conf
  4270. echo "dc_use_split_config='false'" >> /etc/exim4/update-exim4.conf.conf
  4271. echo "dc_hide_mailname=''" >> /etc/exim4/update-exim4.conf.conf
  4272. echo "dc_mailname_in_oh='true'" >> /etc/exim4/update-exim4.conf.conf
  4273. echo "dc_localdelivery='maildir_home'" >> /etc/exim4/update-exim4.conf.conf
  4274. update-exim4.conf
  4275. sed -i "s/START=no/START=yes/g" /etc/default/saslauthd
  4276. systemctl start saslauthd
  4277. # make a tls certificate for email
  4278. if [ ! -f /etc/ssl/certs/exim.dhparam ]; then
  4279. ${PROJECT_NAME}-addcert -h exim --dhkey $DH_KEYLENGTH
  4280. check_certificates exim
  4281. fi
  4282. cp /etc/ssl/private/exim.key /etc/exim4
  4283. cp /etc/ssl/certs/exim.crt /etc/exim4
  4284. cp /etc/ssl/certs/exim.dhparam /etc/exim4
  4285. chown root:Debian-exim /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  4286. chmod 640 /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  4287. sed -i '/login_saslauthd_server/,/.endif/ s/# *//' /etc/exim4/exim4.conf.template
  4288. sed -i "/.ifdef MAIN_HARDCODE_PRIMARY_HOSTNAME/i\MAIN_HARDCODE_PRIMARY_HOSTNAME = $DEFAULT_DOMAIN_NAME\nMAIN_TLS_ENABLE = true" /etc/exim4/exim4.conf.template
  4289. sed -i "s|SMTPLISTENEROPTIONS=''|SMTPLISTENEROPTIONS='-oX 465:25:587 -oP /var/run/exim4/exim.pid'|g" /etc/default/exim4
  4290. if ! grep -q "tls_on_connect_ports=465" /etc/exim4/exim4.conf.template; then
  4291. sed -i '/SSL configuration for exim/i\tls_on_connect_ports=465' /etc/exim4/exim4.conf.template
  4292. fi
  4293. adduser $MY_USERNAME sasl
  4294. addgroup Debian-exim sasl
  4295. systemctl restart exim4
  4296. if [ ! -d /etc/skel/Maildir ]; then
  4297. mkdir -m 700 /etc/skel/.mutt
  4298. mkdir -m 700 /etc/skel/Maildir
  4299. mkdir -m 700 /etc/skel/Maildir/new
  4300. mkdir -m 700 /etc/skel/Maildir/cur
  4301. mkdir -m 700 /etc/skel/Maildir/Sent
  4302. mkdir -m 700 /etc/skel/Maildir/Sent/tmp
  4303. mkdir -m 700 /etc/skel/Maildir/Sent/cur
  4304. mkdir -m 700 /etc/skel/Maildir/Sent/new
  4305. mkdir -m 700 /etc/skel/Maildir/.learn-spam
  4306. mkdir -m 700 /etc/skel/Maildir/.learn-spam/cur
  4307. mkdir -m 700 /etc/skel/Maildir/.learn-spam/new
  4308. mkdir -m 700 /etc/skel/Maildir/.learn-spam/tmp
  4309. mkdir -m 700 /etc/skel/Maildir/.learn-ham
  4310. mkdir -m 700 /etc/skel/Maildir/.learn-ham/cur
  4311. mkdir -m 700 /etc/skel/Maildir/.learn-ham/new
  4312. mkdir -m 700 /etc/skel/Maildir/.learn-ham/tmp
  4313. ln -s /etc/skel/Maildir/.learn-spam /etc/skel/Maildir/spam
  4314. ln -s /etc/skel/Maildir/.learn-ham /etc/skel/Maildir/ham
  4315. fi
  4316. if [ ! -d /home/$MY_USERNAME/Maildir ]; then
  4317. mkdir -m 700 /home/$MY_USERNAME/.mutt
  4318. mkdir -m 700 /home/$MY_USERNAME/Maildir
  4319. mkdir -m 700 /home/$MY_USERNAME/Maildir/cur
  4320. mkdir -m 700 /home/$MY_USERNAME/Maildir/tmp
  4321. mkdir -m 700 /home/$MY_USERNAME/Maildir/new
  4322. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent
  4323. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/cur
  4324. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/tmp
  4325. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/new
  4326. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam
  4327. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/cur
  4328. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/new
  4329. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/tmp
  4330. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham
  4331. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/cur
  4332. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/new
  4333. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/tmp
  4334. ln -s /home/$MY_USERNAME/Maildir/.learn-spam /home/$MY_USERNAME/Maildir/spam
  4335. ln -s /home/$MY_USERNAME/Maildir/.learn-ham /home/$MY_USERNAME/Maildir/ham
  4336. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  4337. fi
  4338. echo 'configure_email' >> $COMPLETION_FILE
  4339. }
  4340. function create_procmail {
  4341. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4342. return
  4343. fi
  4344. if grep -Fxq "create_procmail" $COMPLETION_FILE; then
  4345. return
  4346. fi
  4347. if [ ! -f /home/$MY_USERNAME/.procmailrc ]; then
  4348. echo 'MAILDIR=$HOME/Maildir' > /home/$MY_USERNAME/.procmailrc
  4349. echo 'DEFAULT=$MAILDIR/' >> /home/$MY_USERNAME/.procmailrc
  4350. echo 'LOGFILE=$HOME/log/procmail.log' >> /home/$MY_USERNAME/.procmailrc
  4351. echo 'LOGABSTRACT=all' >> /home/$MY_USERNAME/.procmailrc
  4352. echo '' >> /home/$MY_USERNAME/.procmailrc
  4353. echo $"# Tripwire reports which have no violations don't need to be logged" >> /home/$MY_USERNAME/.procmailrc
  4354. echo ':0 BD:' >> /home/$MY_USERNAME/.procmailrc
  4355. TRIPWIRE_VIOLATIONS_STR=$'Total violations found: 0'
  4356. echo " * .*$TRIPWIRE_VIOLATIONS_STR" >> /home/$MY_USERNAME/.procmailrc
  4357. echo '/dev/null' >> /home/$MY_USERNAME/.procmailrc
  4358. echo '' >> /home/$MY_USERNAME/.procmailrc
  4359. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  4360. fi
  4361. mkdir -p /home/$MY_USERNAME/Maildir/admin/new
  4362. mkdir -p /home/$MY_USERNAME/Maildir/admin/cur
  4363. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir/admin
  4364. if [ ! -f /etc/skel/.procmailrc ]; then
  4365. cp /home/$MY_USERNAME/.procmailrc /etc/skel/.procmailrc
  4366. chown root:root /etc/skel/.procmailrc
  4367. fi
  4368. echo 'create_procmail' >> $COMPLETION_FILE
  4369. }
  4370. function handle_admin_emails {
  4371. # keep emails for root in a separate folder
  4372. if [ -d /home/$MY_USERNAME/Maildir/admin ]; then
  4373. return
  4374. fi
  4375. freedombone-addemail -u $MY_USERNAME -e "root@$DEFAULT_DOMAIN_NAME" -g admin --public no
  4376. }
  4377. function spam_filtering {
  4378. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4379. return
  4380. fi
  4381. if grep -Fxq "spam_filtering" $COMPLETION_FILE; then
  4382. return
  4383. fi
  4384. apt-get -y install exim4-daemon-heavy
  4385. apt-get -y install spamassassin
  4386. if [ ! -f /etc/default/spamassassin ]; then
  4387. echo 'Spamassassin was not installed'
  4388. exit 72570
  4389. fi
  4390. sa-update -v
  4391. sed -i 's/ENABLED=0/ENABLED=1/g' /etc/default/spamassassin
  4392. sed -i 's/# spamd_address = 127.0.0.1 783/spamd_address = 127.0.0.1 783/g' /etc/exim4/exim4.conf.template
  4393. # This configuration is based on https://wiki.debian.org/DebianSpamAssassin
  4394. sed -i 's/local_parts = postmaster/local_parts = postmaster:abuse/g' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  4395. sed -i '/domains = +local_domains : +relay_to_domains/a\ set acl_m0 = rfcnames' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  4396. sed -i 's/accept/accept condition = ${if eq{$acl_m0}{rfcnames} {1}{0}}/g' /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4397. echo 'warn message = X-Spam-Score: $spam_score ($spam_bar)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4398. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4399. echo 'warn message = X-Spam-Flag: YES' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4400. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4401. echo 'warn message = X-Spam-Report: $spam_report' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4402. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4403. echo '# reject spam at high scores (> 12)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4404. echo 'deny message = This message scored $spam_score spam points.' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4405. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4406. echo ' condition = ${if >{$spam_score_int}{120}{1}{0}}' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4407. # procmail configuration
  4408. echo '# get spamassassin to check emails' >> /home/$MY_USERNAME/.procmailrc
  4409. echo ':0fw: .spamassassin.lock' >> /home/$MY_USERNAME/.procmailrc
  4410. echo ' * < 256000' >> /home/$MY_USERNAME/.procmailrc
  4411. echo '| spamc' >> /home/$MY_USERNAME/.procmailrc
  4412. echo '# strong spam are discarded' >> /home/$MY_USERNAME/.procmailrc
  4413. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4414. echo ' * ^X-Spam-Level: \*\*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  4415. echo '/dev/null' >> /home/$MY_USERNAME/.procmailrc
  4416. echo '# weak spam are kept just in case - clear this out every now and then' >> /home/$MY_USERNAME/.procmailrc
  4417. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4418. echo ' * ^X-Spam-Level: \*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  4419. echo 'maybe-spam/' >> /home/$MY_USERNAME/.procmailrc
  4420. echo '# otherwise, marginal spam goes here for revision' >> /home/$MY_USERNAME/.procmailrc
  4421. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4422. echo ' * ^X-Spam-Level: \*\*' >> /home/$MY_USERNAME/.procmailrc
  4423. echo 'spam/' >> /home/$MY_USERNAME/.procmailrc
  4424. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  4425. echo '# get spamassassin to check emails' >> /etc/skel/.procmailrc
  4426. echo ':0fw: .spamassassin.lock' >> /etc/skel/.procmailrc
  4427. echo ' * < 256000' >> /etc/skel/.procmailrc
  4428. echo '| spamc' >> /etc/skel/.procmailrc
  4429. echo '# strong spam are discarded' >> /etc/skel/.procmailrc
  4430. echo ':0' >> /etc/skel/.procmailrc
  4431. echo ' * ^X-Spam-Level: \*\*\*\*\*\*' >> /etc/skel/.procmailrc
  4432. echo '/dev/null' >> /etc/skel/.procmailrc
  4433. echo '# weak spam are kept just in case - clear this out every now and then' >> /etc/skel/.procmailrc
  4434. echo ':0' >> /etc/skel/.procmailrc
  4435. echo ' * ^X-Spam-Level: \*\*\*\*\*' >> /etc/skel/.procmailrc
  4436. echo 'maybe-spam/' >> /etc/skel/.procmailrc
  4437. echo '# otherwise, marginal spam goes here for revision' >> /etc/skel/.procmailrc
  4438. echo ':0' >> /etc/skel/.procmailrc
  4439. echo ' * ^X-Spam-Level: \*\*' >> /etc/skel/.procmailrc
  4440. echo 'spam/' >> /etc/skel/.procmailrc
  4441. # filtering scripts
  4442. echo '#!/bin/bash' > /usr/bin/filterspam
  4443. echo 'for d in /home/*/ ; do' >> /usr/bin/filterspam
  4444. echo ' USERNAME=$(echo "$d" | awk -F '"'"'/'"'"' '"'"'{print $3}'"'"')' >> /usr/bin/filterspam
  4445. echo ' if [[ $USERNAME != "git" && $USERNAME != "mirrors" && $USERNAME != "sync" ]]; then' >> /usr/bin/filterspam
  4446. echo ' MAILDIR=/home/$USERNAME/Maildir/.learn-spam' >> /usr/bin/filterspam
  4447. echo ' if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterspam
  4448. echo ' exit' >> /usr/bin/filterspam
  4449. echo ' fi' >> /usr/bin/filterspam
  4450. echo ' for f in `ls $MAILDIR/cur`' >> /usr/bin/filterspam
  4451. echo ' do' >> /usr/bin/filterspam
  4452. echo ' spamc -L spam < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterspam
  4453. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterspam
  4454. echo ' done' >> /usr/bin/filterspam
  4455. echo ' for f in `ls $MAILDIR/new`' >> /usr/bin/filterspam
  4456. echo ' do' >> /usr/bin/filterspam
  4457. echo ' spamc -L spam < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterspam
  4458. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterspam
  4459. echo ' done' >> /usr/bin/filterspam
  4460. echo ' fi' >> /usr/bin/filterspam
  4461. echo 'done' >> /usr/bin/filterspam
  4462. echo 'exit 0' >> /usr/bin/filterspam
  4463. echo '#!/bin/bash' > /usr/bin/filterham
  4464. echo 'for d in /home/*/ ; do' >> /usr/bin/filterham
  4465. echo ' USERNAME=$(echo "$d" | awk -F '"'"'/'"'"' '"'"'{print $3}'"'"')' >> /usr/bin/filterham
  4466. echo ' if [[ $USERNAME != "git" && $USERNAME != "mirrors" && $USERNAME != "sync" ]]; then' >> /usr/bin/filterham
  4467. echo ' MAILDIR=/home/$USERNAME/Maildir/.learn-ham' >> /usr/bin/filterham
  4468. echo ' if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterham
  4469. echo ' exit' >> /usr/bin/filterham
  4470. echo ' fi' >> /usr/bin/filterham
  4471. echo ' for f in `ls $MAILDIR/cur`' >> /usr/bin/filterham
  4472. echo ' do' >> /usr/bin/filterham
  4473. echo ' spamc -L ham < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterham
  4474. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterham
  4475. echo ' done' >> /usr/bin/filterham
  4476. echo ' for f in `ls $MAILDIR/new`' >> /usr/bin/filterham
  4477. echo ' do' >> /usr/bin/filterham
  4478. echo ' spamc -L ham < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterham
  4479. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterham
  4480. echo ' done' >> /usr/bin/filterham
  4481. echo ' fi' >> /usr/bin/filterham
  4482. echo 'done' >> /usr/bin/filterham
  4483. echo 'exit 0' >> /usr/bin/filterham
  4484. if ! grep -q "filterspam" /etc/crontab; then
  4485. echo "*/3 * * * * root /usr/bin/timeout 120 /usr/bin/filterspam" >> /etc/crontab
  4486. fi
  4487. if ! grep -q "filterham" /etc/crontab; then
  4488. echo "*/3 * * * * root /usr/bin/timeout 120 /usr/bin/filterham" >> /etc/crontab
  4489. fi
  4490. chmod 655 /usr/bin/filterspam /usr/bin/filterham
  4491. sed -i 's/# use_bayes 1/use_bayes 1/g' /etc/mail/spamassassin/local.cf
  4492. sed -i 's/# bayes_auto_learn 1/bayes_auto_learn 1/g' /etc/mail/spamassassin/local.cf
  4493. # user preferences
  4494. if [ ! -d /home/$MY_USERNAME/.spamassassin ]; then
  4495. mkdir /home/$MY_USERNAME/.spamassassin
  4496. echo $'# How many points before a mail is considered spam.' > /home/$MY_USERNAME/.spamassassin/user_prefs
  4497. echo '# required_score 5' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4498. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4499. echo $'# Whitelist and blacklist addresses are now file-glob-style patterns, so' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4500. echo $'# "friend@somewhere.com", "*@isp.com", or "*.domain.net" will all work.' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4501. echo '# whitelist_from someone@somewhere.com' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4502. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4503. echo $'# Add your own customised scores for some tests below. The default scores are' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4504. echo $'# read from the installed spamassassin rules files, but you can override them' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4505. echo $'# here. To see the list of tests and their default scores, go to' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4506. echo '# http://spamassassin.apache.org/tests.html .' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4507. echo '#' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4508. echo '# score SYMBOLIC_TEST_NAME n.nn' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4509. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4510. echo $'# Speakers of Asian languages, like Chinese, Japanese and Korean, will almost' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4511. echo $'# definitely want to uncomment the following lines. They will switch off some' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4512. echo $'# rules that detect 8-bit characters, which commonly trigger on mails using CJK' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4513. echo $'# character sets, or that assume a western-style charset is in use. ' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4514. echo '# ' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4515. echo '# score HTML_COMMENT_8BITS 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4516. echo '# score UPPERCASE_25_50 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4517. echo '# score UPPERCASE_50_75 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4518. echo '# score UPPERCASE_75_100 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4519. echo '# score OBSCURED_EMAIL 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4520. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4521. echo $'# Speakers of any language that uses non-English, accented characters may wish' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4522. echo $'# to uncomment the following lines. They turn off rules that fire on' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4523. echo $'# misformatted messages generated by common mail apps in contravention of the' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4524. echo $'# email RFCs.' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4525. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4526. echo '# score SUBJ_ILLEGAL_CHARS 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4527. fi
  4528. # this must be accessible by root
  4529. chown -R $MY_USERNAME:root /home/$MY_USERNAME/.spamassassin
  4530. systemctl restart spamassassin
  4531. systemctl restart exim4
  4532. systemctl restart cron
  4533. echo 'spam_filtering' >> $COMPLETION_FILE
  4534. }
  4535. function configure_imap {
  4536. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4537. return
  4538. fi
  4539. if grep -Fxq "configure_imap" $COMPLETION_FILE; then
  4540. return
  4541. fi
  4542. dpkg -P dovecot-imapd
  4543. dpkg -P dovecot-core
  4544. apt-get -y install dovecot-imapd
  4545. if [ ! -d /etc/dovecot ]; then
  4546. echo $"ERROR: Dovecot does not appear to have installed. $CHECK_MESSAGE"
  4547. exit 48
  4548. fi
  4549. if [ ! -f /etc/ssl/certs/dovecot.dhparam ]; then
  4550. ${PROJECT_NAME}-addcert -h dovecot --dhkey $DH_KEYLENGTH
  4551. check_certificates dovecot
  4552. fi
  4553. chown root:dovecot /etc/ssl/certs/dovecot.*
  4554. chown root:dovecot /etc/ssl/private/dovecot.*
  4555. if [ ! -f /etc/dovecot/conf.d/10-ssl.conf ]; then
  4556. echo $'Unable to find /etc/dovecot/conf.d/10-ssl.conf'
  4557. exit 83629
  4558. fi
  4559. sed -i 's|#ssl =.*|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  4560. sed -i 's|ssl = no|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  4561. sed -i 's|ssl = yes|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  4562. sed -i 's|#ssl_cert =.*|ssl_cert = </etc/ssl/certs/dovecot.crt|g' /etc/dovecot/conf.d/10-ssl.conf
  4563. sed -i 's|ssl_cert =.*|ssl_cert = </etc/ssl/certs/dovecot.crt|g' /etc/dovecot/conf.d/10-ssl.conf
  4564. sed -i 's|#ssl_key =.*|ssl_key = </etc/ssl/private/dovecot.key|g' /etc/dovecot/conf.d/10-ssl.conf
  4565. sed -i 's|ssl_key =.*|ssl_key = </etc/ssl/private/dovecot.key|g' /etc/dovecot/conf.d/10-ssl.conf
  4566. sed -i 's|#ssl_dh_parameters_length.*|ssl_dh_parameters_length = 2048|g' /etc/dovecot/conf.d/10-ssl.conf
  4567. sed -i 's/#ssl_prefer_server_ciphers.*/ssl_prefer_server_ciphers = yes/g' /etc/dovecot/conf.d/10-ssl.conf
  4568. sed -i "s|#ssl_protocols =.*|ssl_protocols = '$SSL_PROTOCOLS'|g" /etc/dovecot/conf.d/10-ssl.conf
  4569. sed -i "s|ssl_protocols =.*|ssl_protocols = '$SSL_PROTOCOLS'|g" /etc/dovecot/conf.d/10-ssl.conf
  4570. echo "ssl_cipher_list = '$SSL_CIPHERS'" >> /etc/dovecot/conf.d/10-ssl.conf
  4571. if [ ! -f /etc/dovecot/conf.d/10-master.conf ]; then
  4572. echo $'Unable to find /etc/dovecot/conf.d/10-master.conf'
  4573. exit 49259
  4574. fi
  4575. sed -i 's/#process_limit =.*/process_limit = 100/g' /etc/dovecot/conf.d/10-master.conf
  4576. sed -i 's/#default_client_limit.*/default_client_limit = 100/g' /etc/dovecot/conf.d/10-master.conf
  4577. sed -i 's|#default_process_limit =.*|default_process_limit = 100|g' /etc/dovecot/conf.d/10-master.conf
  4578. if [ ! -f /etc/dovecot/conf.d/10-logging.conf ]; then
  4579. echo $'Unable to find /etc/dovecot/conf.d/10-logging.conf'
  4580. exit 48936
  4581. fi
  4582. sed -i 's/#auth_verbose.*/auth_verbose = yes/g' /etc/dovecot/conf.d/10-logging.conf
  4583. if [ ! -f /etc/dovecot/dovecot.conf ]; then
  4584. echo $'Unable to find /etc/dovecot/dovecot.conf'
  4585. exit 43890
  4586. fi
  4587. sed -i 's/#listen =.*/listen = */g' /etc/dovecot/dovecot.conf
  4588. if [ ! -f /etc/dovecot/conf.d/10-auth.conf ]; then
  4589. echo $'Unable to find /etc/dovecot/conf.d/10-auth.conf'
  4590. exit 843256
  4591. fi
  4592. sed -i 's/#disable_plaintext_auth =.*/disable_plaintext_auth = no/g' /etc/dovecot/conf.d/10-auth.conf
  4593. sed -i 's/auth_mechanisms =.*/auth_mechanisms = plain login/g' /etc/dovecot/conf.d/10-auth.conf
  4594. if [ ! -f /etc/dovecot/conf.d/10-mail.conf ]; then
  4595. echo $'Unable to find /etc/dovecot/conf.d/10-mail.conf'
  4596. exit 42036
  4597. fi
  4598. sed -i 's|mail_location =.*|mail_location = maildir:~/Maildir:LAYOUT=fs|g' /etc/dovecot/conf.d/10-mail.conf
  4599. # This long notify interval makes the system more suited for use with
  4600. # battery powered mobile devices
  4601. sed -i 's|#imap_idle_notify_interval =.*|imap_idle_notify_interval = 29|g' /etc/dovecot/conf.d/20-imap.conf
  4602. if [ -f /var/lib/dovecot/ssl-parameters.dat ]; then
  4603. rm /var/lib/dovecot/ssl-parameters.dat
  4604. fi
  4605. systemctl restart dovecot
  4606. echo 'configure_imap' >> $COMPLETION_FILE
  4607. }
  4608. function configure_imap_client_certs {
  4609. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4610. return
  4611. fi
  4612. if grep -Fxq "configure_imap_client_certs" $COMPLETION_FILE; then
  4613. return
  4614. fi
  4615. # http://strange.systems/certificate-based-auth-with-dovecot-sendmail/
  4616. sed -i 's|#default_process_limit =.*|default_process_limit = 100|g' /etc/dovecot/conf.d/10-master.conf
  4617. sed -i 's/disable_plaintext_auth =.*/disable_plaintext_auth = yes/g' /etc/dovecot/conf.d/10-auth.conf
  4618. sed -i 's|#auth_ssl_require_client_cert =.*|auth_ssl_require_client_cert = yes|g' /etc/dovecot/conf.d/10-auth.conf
  4619. sed -i 's|#auth_ssl_username_from_cert =.*|auth_ssl_username_from_cert = yes|g' /etc/dovecot/conf.d/10-auth.conf
  4620. sed -i "s|#ssl_ca =.*|ssl_ca = /etc/ssl/certs/ca-$DEFAULT_DOMAIN_NAME.crt|g" /etc/dovecot/conf.d/10-ssl.conf
  4621. sed -i 's|#ssl_cert_username_field =.*|ssl_cert_username_field = commonName|g' /etc/dovecot/conf.d/10-ssl.conf
  4622. sed -i 's|#ssl_verify_client_cert =.*|ssl_verify_client_cert = yes|g' /etc/dovecot/conf.d/10-ssl.conf
  4623. if ! grep -q "passdb {" /etc/dovecot/conf.d/10-auth.conf; then
  4624. echo '' >> /etc/dovecot/conf.d/10-auth.conf
  4625. echo 'passdb {' >> /etc/dovecot/conf.d/10-auth.conf
  4626. echo ' driver = passwd-file' >> /etc/dovecot/conf.d/10-auth.conf
  4627. echo ' args = /etc/dovecot/passwd-file' >> /etc/dovecot/conf.d/10-auth.conf
  4628. echo ' deny = no' >> /etc/dovecot/conf.d/10-auth.conf
  4629. echo ' master = no' >> /etc/dovecot/conf.d/10-auth.conf
  4630. echo ' pass = no' >> /etc/dovecot/conf.d/10-auth.conf
  4631. echo '}' >> /etc/dovecot/conf.d/10-auth.conf
  4632. fi
  4633. if [[ $ONION_ONLY == "no" ]]; then
  4634. # make a CA cert
  4635. if [ ! -f /etc/ssl/private/ca-$DEFAULT_DOMAIN_NAME.key ]; then
  4636. if [[ $LETSENCRYPT_ENABLED != "yes" ]]; then
  4637. ${PROJECT_NAME}-addcert -h $DEFAULT_DOMAIN_NAME --ca "" --dhkey $DH_KEYLENGTH
  4638. else
  4639. ${PROJECT_NAME}-addcert -e $DEFAULT_DOMAIN_NAME -s $LETSENCRYPT_SERVER --ca "" --dhkey $DH_KEYLENGTH --email $MY_EMAIL_ADDRESS
  4640. fi
  4641. fi
  4642. fi
  4643. # CA configuration
  4644. echo '[ ca ]' > /etc/ssl/dovecot-ca.cnf
  4645. echo "default_ca = dovecot-ca" >> /etc/ssl/dovecot-ca.cnf
  4646. echo '' >> /etc/ssl/dovecot-ca.cnf
  4647. echo '[ crl_ext ]' >> /etc/ssl/dovecot-ca.cnf
  4648. echo 'authorityKeyIdentifier=keyid:always' >> /etc/ssl/dovecot-ca.cnf
  4649. echo '' >> /etc/ssl/dovecot-ca.cnf
  4650. echo '[ dovecot-ca ]' >> /etc/ssl/dovecot-ca.cnf
  4651. echo 'new_certs_dir = .' >> /etc/ssl/dovecot-ca.cnf
  4652. echo 'unique_subject = no' >> /etc/ssl/dovecot-ca.cnf
  4653. echo "certificate = /etc/ssl/certs/ca-$DEFAULT_DOMAIN_NAME.crt" >> /etc/ssl/dovecot-ca.cnf
  4654. echo 'database = ssldb' >> /etc/ssl/dovecot-ca.cnf
  4655. echo "private_key = /etc/ssl/private/ca-$DEFAULT_DOMAIN_NAME.key" >> /etc/ssl/dovecot-ca.cnf
  4656. echo 'serial = sslserial' >> /etc/ssl/dovecot-ca.cnf
  4657. echo 'default_days = 3650' >> /etc/ssl/dovecot-ca.cnf
  4658. echo 'default_md = sha256' >> /etc/ssl/dovecot-ca.cnf
  4659. echo 'default_bits = 4096' >> /etc/ssl/dovecot-ca.cnf
  4660. echo 'policy = dovecot-ca_policy' >> /etc/ssl/dovecot-ca.cnf
  4661. echo 'x509_extensions = dovecot-ca_extensions' >> /etc/ssl/dovecot-ca.cnf
  4662. echo '' >> /etc/ssl/dovecot-ca.cnf
  4663. echo '[ dovecot-ca_policy ]' >> /etc/ssl/dovecot-ca.cnf
  4664. echo 'commonName = supplied' >> /etc/ssl/dovecot-ca.cnf
  4665. echo 'stateOrProvinceName = supplied' >> /etc/ssl/dovecot-ca.cnf
  4666. echo 'countryName = supplied' >> /etc/ssl/dovecot-ca.cnf
  4667. echo 'emailAddress = optional' >> /etc/ssl/dovecot-ca.cnf
  4668. echo 'organizationName = supplied' >> /etc/ssl/dovecot-ca.cnf
  4669. echo 'organizationalUnitName = optional' >> /etc/ssl/dovecot-ca.cnf
  4670. echo '' >> /etc/ssl/dovecot-ca.cnf
  4671. echo '[ dovecot-ca_extensions ]' >> /etc/ssl/dovecot-ca.cnf
  4672. echo 'basicConstraints = CA:false' >> /etc/ssl/dovecot-ca.cnf
  4673. echo 'subjectKeyIdentifier = hash' >> /etc/ssl/dovecot-ca.cnf
  4674. echo 'authorityKeyIdentifier = keyid:always' >> /etc/ssl/dovecot-ca.cnf
  4675. echo 'keyUsage = digitalSignature,keyEncipherment' >> /etc/ssl/dovecot-ca.cnf
  4676. echo 'extendedKeyUsage = clientAuth' >> /etc/ssl/dovecot-ca.cnf
  4677. if [ -f /etc/ssl/ssldb ]; then
  4678. rm /etc/ssl/ssldb
  4679. fi
  4680. if [ -f /etc/ssl/sslserial ]; then
  4681. rm /etc/ssl/sslserial
  4682. fi
  4683. touch /etc/ssl/ssldb
  4684. echo 0001 > /etc/ssl/sslserial
  4685. #${PROJECT_NAME}-clientcert -u $MY_USERNAME
  4686. systemctl restart dovecot
  4687. echo 'configure_imap_client_certs' >> $COMPLETION_FILE
  4688. }
  4689. function create_gpg_subkey {
  4690. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4691. return
  4692. fi
  4693. if grep -Fxq "create_gpg_subkey" $COMPLETION_FILE; then
  4694. return
  4695. fi
  4696. apt-get -y install gnupg
  4697. GPG_KEY_USAGE=$1
  4698. if [[ $GPG_KEY_USAGE != "sign" && $GPG_KEY_USAGE != "auth" && $GPG_KEY_USAGE != "encrypt" ]]; then
  4699. echo $"Unknown subkey usage: $GPG_KEY_USAGE"
  4700. echo $'Available types: sign|auth|encrypt'
  4701. exit 14783
  4702. fi
  4703. KEYGRIP=$(gpg --fingerprint --fingerprint $MY_EMAIL_ADDRESS | grep fingerprint | tail -1 | cut -d= -f2 | sed -e 's/ //g')
  4704. # Generate a GPG subkey
  4705. # Here a 2048bit length is used to be compatible with yubikey
  4706. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  4707. echo "Key-Grip: $KEYGRIP" > /home/$MY_USERNAME/gpg-genkey.conf
  4708. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  4709. echo 'Subkey-Length: 2048' >> /home/$MY_USERNAME/gpg-genkey.conf
  4710. echo "subkey-Usage: $GPG_KEY_USAGE" > /home/$MY_USERNAME/gpg-genkey.conf
  4711. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  4712. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  4713. echo "Name-Comment: $GPG_KEY_USAGE" >> /home/$MY_USERNAME/gpg-genkey.conf
  4714. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  4715. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  4716. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  4717. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  4718. MY_GPG_SUBKEY_ID=$(su -c "gpg --list-keys $MY_EMAIL_ADDRESS | grep 'pub '" - $MY_USERNAME | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4719. echo 'create_gpg_subkey' >> $COMPLETION_FILE
  4720. }
  4721. function gpg_key_exists {
  4722. key_owner_username=$1
  4723. key_search_text=$2
  4724. if [[ $key_owner_username != "root" ]]; then
  4725. KEY_EXISTS=$(su -c "gpg --list-keys \"${key_search_text}\"" - $key_owner_username)
  4726. else
  4727. KEY_EXISTS=$(gpg --list-keys "${key_search_text}")
  4728. fi
  4729. if [ ! "$KEY_EXISTS" ]; then
  4730. echo "no"
  4731. return
  4732. fi
  4733. if [ "$KEY_EXISTS" == *"error"* ]; then
  4734. echo "no"
  4735. return
  4736. fi
  4737. echo "yes"
  4738. }
  4739. function gpg_pubkey_from_email {
  4740. key_owner_username=$1
  4741. key_email_address=$2
  4742. key_id=
  4743. if [[ $key_owner_username != "root" ]]; then
  4744. key_id=$(su -c "gpg --list-keys $key_email_address | grep 'pub '" - $key_owner_username | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4745. else
  4746. key_id=$(gpg --list-keys $key_email_address | grep 'pub ' | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4747. fi
  4748. echo $key_id
  4749. }
  4750. function configure_gpg {
  4751. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4752. return
  4753. fi
  4754. if grep -Fxq "configure_gpg" $COMPLETION_FILE; then
  4755. return
  4756. fi
  4757. apt-get -y install gnupg
  4758. gpg_dir=/home/$MY_USERNAME/.gnupg
  4759. # if gpg keys directory was previously imported from usb
  4760. if [[ $GPG_KEYS_IMPORTED == "yes" && -d $gpg_dir ]]; then
  4761. echo $'GPG keys were imported'
  4762. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" $gpg_dir/gpg.conf
  4763. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4764. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  4765. echo $'GPG public key ID could not be obtained'
  4766. fi
  4767. chown -R $MY_USERNAME:$MY_USERNAME $gpg_dir
  4768. chmod 700 $gpg_dir
  4769. chmod 600 $gpg_dir/*
  4770. echo 'configure_gpg' >> $COMPLETION_FILE
  4771. return
  4772. fi
  4773. if [ ! -d $gpg_dir ]; then
  4774. mkdir $gpg_dir
  4775. echo "keyserver $GPG_KEYSERVER" >> $gpg_dir/gpg.conf
  4776. echo 'keyserver-options auto-key-retrieve' >> $gpg_dir/gpg.conf
  4777. fi
  4778. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" $gpg_dir/gpg.conf
  4779. if ! grep -q "# default preferences" $gpg_dir/gpg.conf; then
  4780. echo '' >> $gpg_dir/gpg.conf
  4781. echo '# default preferences' >> $gpg_dir/gpg.conf
  4782. echo 'personal-digest-preferences SHA256' >> $gpg_dir/gpg.conf
  4783. echo 'cert-digest-algo SHA256' >> $gpg_dir/gpg.conf
  4784. echo 'default-preference-list SHA512 SHA384 SHA256 SHA224 AES256 AES192 AES CAST5 ZLIB BZIP2 ZIP Uncompressed' >> $gpg_dir/gpg.conf
  4785. fi
  4786. chown -R $MY_USERNAME:$MY_USERNAME $gpg_dir
  4787. chmod 700 $gpg_dir
  4788. chmod 600 $gpg_dir/*
  4789. if [[ $MY_GPG_PUBLIC_KEY && $MY_GPG_PRIVATE_KEY ]]; then
  4790. echo $'Importing GPG keys from file'
  4791. echo $"Public key: $MY_GPG_PUBLIC_KEY"
  4792. echo $"Private key: $MY_GPG_PRIVATE_KEY"
  4793. # use your existing GPG keys which were exported
  4794. if [ ! -f $MY_GPG_PUBLIC_KEY ]; then
  4795. echo $"GPG public key file $MY_GPG_PUBLIC_KEY was not found"
  4796. exit 2483
  4797. fi
  4798. if [ ! -f $MY_GPG_PRIVATE_KEY ]; then
  4799. echo $"GPG private key file $MY_GPG_PRIVATE_KEY was not found"
  4800. exit 5383
  4801. fi
  4802. su -c "gpg --import $MY_GPG_PUBLIC_KEY" - $MY_USERNAME
  4803. su -c "gpg --allow-secret-key-import --import $MY_GPG_PRIVATE_KEY" - $MY_USERNAME
  4804. KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4805. if [[ $KEY_EXISTS == "no" ]]; then
  4806. echo $"The GPG key for $MY_EMAIL_ADDRESS could not be imported"
  4807. exit 13821
  4808. fi
  4809. # for security ensure that the private key file doesn't linger around
  4810. shred -zu $MY_GPG_PRIVATE_KEY
  4811. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4812. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  4813. echo $'GPG public key ID could not be obtained'
  4814. fi
  4815. else
  4816. # Generate a GPG key
  4817. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  4818. echo 'Key-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4819. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  4820. echo 'Subkey-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4821. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  4822. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  4823. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  4824. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  4825. echo $'Generating a new GPG key'
  4826. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  4827. KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4828. if [[ $KEY_EXISTS == "no" ]]; then
  4829. echo $"A GPG key for $MY_EMAIL_ADDRESS could not be created"
  4830. exit 6362
  4831. fi
  4832. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  4833. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4834. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  4835. echo $'GPG public key ID could not be obtained'
  4836. fi
  4837. MY_GPG_PUBLIC_KEY=/tmp/public_key.gpg
  4838. su -c "gpg --output $MY_GPG_PUBLIC_KEY --armor --export $MY_GPG_PUBLIC_KEY_ID" - $MY_USERNAME
  4839. if grep -q "configure_email" $COMPLETION_FILE; then
  4840. if ! grep -q $"Change your GPG password" /home/$MY_USERNAME/README; then
  4841. echo '' >> /home/$MY_USERNAME/README
  4842. echo '' >> /home/$MY_USERNAME/README
  4843. echo $'Change your GPG password' >> /home/$MY_USERNAME/README
  4844. echo '========================' >> /home/$MY_USERNAME/README
  4845. echo $"It's very important to add a password to your GPG key so that" >> /home/$MY_USERNAME/README
  4846. echo $"if anyone does get access to your email they still won't be able" >> /home/$MY_USERNAME/README
  4847. echo $'to read them without knowning the GPG password.' >> /home/$MY_USERNAME/README
  4848. echo $'You can change the it with:' >> /home/$MY_USERNAME/README
  4849. echo '' >> /home/$MY_USERNAME/README
  4850. echo " gpg --edit-key $MY_GPG_PUBLIC_KEY_ID" >> /home/$MY_USERNAME/README
  4851. echo ' passwd' >> /home/$MY_USERNAME/README
  4852. echo ' save' >> /home/$MY_USERNAME/README
  4853. echo ' quit' >> /home/$MY_USERNAME/README
  4854. fi
  4855. if ! grep -q $"Publish your GPG public key" /home/$MY_USERNAME/README; then
  4856. echo '' >> /home/$MY_USERNAME/README
  4857. echo '' >> /home/$MY_USERNAME/README
  4858. echo $'Publish your GPG public key' >> /home/$MY_USERNAME/README
  4859. echo '===========================' >> /home/$MY_USERNAME/README
  4860. echo $'So that others can send emails to you securely you should' >> /home/$MY_USERNAME/README
  4861. echo $'publish your GPG public key with the command:' >> /home/$MY_USERNAME/README
  4862. echo '' >> /home/$MY_USERNAME/README
  4863. echo " gpg --send-keys $MY_GPG_PUBLIC_KEY_ID" >> /home/$MY_USERNAME/README
  4864. fi
  4865. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  4866. chmod 600 /home/$MY_USERNAME/README
  4867. fi
  4868. fi
  4869. echo 'configure_gpg' >> $COMPLETION_FILE
  4870. }
  4871. function refresh_gpg_keys {
  4872. REFRESH_GPG_KEYS_SCRIPT=/usr/bin/update-gpg-keys
  4873. echo '#!/bin/bash' > $REFRESH_GPG_KEYS_SCRIPT
  4874. echo "if [ -f /usr/local/bin/${PROJECT_NAME}-sec ]; then" >> $REFRESH_GPG_KEYS_SCRIPT
  4875. echo " /usr/bin/timeout 600 /usr/local/bin/${PROJECT_NAME}-sec --refresh yes" >> $REFRESH_GPG_KEYS_SCRIPT
  4876. echo 'else' >> $REFRESH_GPG_KEYS_SCRIPT
  4877. echo " /usr/bin/timeout 600 /usr/bin/${PROJECT_NAME}-sec --refresh yes" >> $REFRESH_GPG_KEYS_SCRIPT
  4878. echo 'fi' >> $REFRESH_GPG_KEYS_SCRIPT
  4879. chmod +x $REFRESH_GPG_KEYS_SCRIPT
  4880. if grep -q "${PROJECT_NAME}-sec" /etc/crontab; then
  4881. sed -i "/${PROJECT_NAME}-sec /d" /etc/crontab
  4882. fi
  4883. if ! grep -q "$REFRESH_GPG_KEYS_SCRIPT" /etc/crontab; then
  4884. GPG_REFRESH_TIME=$(( RANDOM % 60 ))
  4885. echo "$GPG_REFRESH_TIME */$REFRESH_GPG_KEYS_HOURS * * * root cronic $REFRESH_GPG_KEYS_SCRIPT" >> /etc/crontab
  4886. systemctl restart cron
  4887. else
  4888. sed -i "s|root $REFRESH_GPG_KEYS_SCRIPT.*|root cronic $REFRESH_GPG_KEYS_SCRIPT|g" /etc/crontab
  4889. fi
  4890. }
  4891. function configure_backup_key {
  4892. if grep -Fxq "configure_backup_key" $COMPLETION_FILE; then
  4893. return
  4894. fi
  4895. apt-get -y install gnupg
  4896. BACKUP_KEY_EXISTS=$(gpg_key_exists "root" "$MY_NAME (backup key)")
  4897. if [[ $BACKUP_KEY_EXISTS == "yes" ]]; then
  4898. return
  4899. fi
  4900. # Generate a GPG key for backups
  4901. BACKUP_KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_NAME (backup key)")
  4902. if [[ $BACKUP_KEY_EXISTS == "no" ]]; then
  4903. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  4904. echo 'Key-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4905. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  4906. echo 'Subkey-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4907. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  4908. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  4909. echo "Name-Comment: backup key" >> /home/$MY_USERNAME/gpg-genkey.conf
  4910. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  4911. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  4912. echo $'Backup key does not exist. Creating it.'
  4913. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  4914. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  4915. echo $'Checking that the Backup key was created'
  4916. BACKUP_KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_NAME (backup key)")
  4917. if [[ $BACKUP_KEY_EXISTS == "no" ]]; then
  4918. echo $'Backup key could not be created'
  4919. exit 43382
  4920. fi
  4921. fi
  4922. MY_BACKUP_KEY_ID=$(su -c "gpg --list-keys \"$MY_NAME (backup key)\" | grep 'pub '" - $MY_USERNAME | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4923. echo "Backup key: $MY_BACKUP_KEY_ID"
  4924. MY_BACKUP_KEY=/home/$MY_USERNAME/backup_key
  4925. su -c "gpg --output ${MY_BACKUP_KEY}_public.asc --armor --export $MY_BACKUP_KEY_ID" - $MY_USERNAME
  4926. su -c "gpg --output ${MY_BACKUP_KEY}_private.asc --armor --export-secret-key $MY_BACKUP_KEY_ID" - $MY_USERNAME
  4927. if [ ! -f ${MY_BACKUP_KEY}_public.asc ]; then
  4928. echo 'Public backup key could not be exported'
  4929. exit 36829
  4930. fi
  4931. if [ ! -f ${MY_BACKUP_KEY}_private.asc ]; then
  4932. echo 'Private backup key could not be exported'
  4933. exit 29235
  4934. fi
  4935. # import backup key to root user
  4936. gpg --import --import ${MY_BACKUP_KEY}_public.asc
  4937. gpg --allow-secret-key-import --import ${MY_BACKUP_KEY}_private.asc
  4938. shred -zu ${MY_BACKUP_KEY}_public.asc
  4939. shred -zu ${MY_BACKUP_KEY}_private.asc
  4940. echo 'configure_backup_key' >> $COMPLETION_FILE
  4941. }
  4942. function install_monkeysphere {
  4943. if grep -Fxq "install_monkeysphere" $COMPLETION_FILE; then
  4944. return
  4945. fi
  4946. apt-get -y install monkeysphere msva-perl
  4947. #su -c "monkeysphere gen-subkey $MY_GPG_PUBLIC_KEY_ID" - $MY_USERNAME
  4948. mkdir /home/$MY_USERNAME/.monkeysphere
  4949. chmod 755 /home/$MY_USERNAME/.monkeysphere
  4950. echo "$MY_NAME <${MY_EMAIL_ADDRESS}>" > /home/$MY_USERNAME/.monkeysphere/authorized_user_ids
  4951. chmod 644 /home/$MY_USERNAME/.monkeysphere/authorized_user_ids
  4952. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.monkeysphere
  4953. monkeysphere-authentication update-users
  4954. if [ ! -f /etc/ssh/ssh_host_rsa_key ]; then
  4955. echo $'monkeysphere import: ssh host key not found'
  4956. exit 76295
  4957. fi
  4958. monkeysphere-host import-key /etc/ssh/ssh_host_rsa_key ssh://$DEFAULT_DOMAIN_NAME
  4959. SSH_ONION_HOSTNAME=$(cat ${COMPLETION_FILE} | grep 'ssh onion domain' | awk -F ':' '{print $2}')
  4960. monkeysphere-host import-key /etc/ssh/ssh_host_rsa_key ssh://$SSH_ONION_HOSTNAME
  4961. if [ ! $MY_GPG_PUBLIC_KEY_ID ]; then
  4962. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_USERNAME@$HOSTNAME")
  4963. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  4964. echo $'monkeysphere unable to get GPG key ID for user $MY_USERNAME'
  4965. exit 52825
  4966. fi
  4967. fi
  4968. # The admin user is the identity certifier
  4969. fpr=$(gpg --with-colons --fingerprint $MY_GPG_PUBLIC_KEY_ID | grep fpr | head -n 1 | awk -F ':' '{print $10}')
  4970. monkeysphere-authentication add-identity-certifier $fpr
  4971. echo 'install_monkeysphere' >> $COMPLETION_FILE
  4972. }
  4973. function encrypt_incoming_email {
  4974. # encrypts incoming mail using your GPG public key
  4975. # so even if an attacker gains access to the data at rest they still need
  4976. # to know your GPG key password to be able to read anything
  4977. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4978. return
  4979. fi
  4980. # update to the next commit
  4981. set_repo_commit $INSTALL_DIR/gpgit "gpgit commit" "$GPGIT_COMMIT" $GPGIT_REPO
  4982. if grep -Fxq "encrypt_incoming_email" $COMPLETION_FILE; then
  4983. return
  4984. fi
  4985. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  4986. return
  4987. fi
  4988. if [ ! -f /usr/bin/gpgit.pl ]; then
  4989. apt-get -y install git libmail-gnupg-perl
  4990. cd $INSTALL_DIR
  4991. git_clone $GPGIT_REPO $INSTALL_DIR/gpgit
  4992. cd $INSTALL_DIR/gpgit
  4993. git checkout $GPGIT_COMMIT -b $GPGIT_COMMIT
  4994. if ! grep -q "gpgit commit" $COMPLETION_FILE; then
  4995. echo "gpgit commit:$GPGIT_COMMIT" >> $COMPLETION_FILE
  4996. else
  4997. sed -i "s/gpgit commit.*/gpgit commit:$GPGIT_COMMIT/g" $COMPLETION_FILE
  4998. fi
  4999. cp gpgit.pl /usr/bin
  5000. fi
  5001. # add a procmail rule
  5002. if ! grep -q "/usr/bin/gpgit.pl" /home/$MY_USERNAME/.procmailrc; then
  5003. echo '' >> /home/$MY_USERNAME/.procmailrc
  5004. echo ':0 f' >> /home/$MY_USERNAME/.procmailrc
  5005. echo "| /usr/bin/gpgit.pl --encrypt-mode prefer-inline --inline-flatten $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/.procmailrc
  5006. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  5007. echo '' >> /etc/skel/.procmailrc
  5008. echo ':0 f' >> /etc/skel/.procmailrc
  5009. echo -n '| /usr/bin/gpgit.pl --encrypt-mode prefer-inline --inline-flatten $USER@' >> /etc/skel/.procmailrc
  5010. echo "$DEFAULT_DOMAIN_NAME" >> /etc/skel/.procmailrc
  5011. fi
  5012. echo 'encrypt_incoming_email' >> $COMPLETION_FILE
  5013. }
  5014. function encrypt_outgoing_email {
  5015. # encrypts outgoing mail using your GPG public key
  5016. # so even if an attacker gains access to the data at rest they still need
  5017. # to know your GPG key password to be able to read sent mail
  5018. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5019. return
  5020. fi
  5021. if grep -Fxq "encrypt_outgoing_email" $COMPLETION_FILE; then
  5022. return
  5023. fi
  5024. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  5025. return
  5026. fi
  5027. if [ ! -d /home/$MY_USERNAME/.gnupg ]; then
  5028. return
  5029. fi
  5030. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  5031. return
  5032. fi
  5033. # obtain your public key ID
  5034. if [ ! $MY_GPG_PUBLIC_KEY_ID ]; then
  5035. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  5036. if [ ! "$MY_GPG_PUBLIC_KEY_ID" ]; then
  5037. return
  5038. fi
  5039. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  5040. return
  5041. fi
  5042. fi
  5043. if ! grep -q "pgp_encrypt_only_command" /home/$MY_USERNAME/.muttrc; then
  5044. echo '' >> /home/$MY_USERNAME/.muttrc
  5045. echo $'# Encrypt items in the Sent folder' >> /home/$MY_USERNAME/.muttrc
  5046. 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
  5047. else
  5048. 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
  5049. fi
  5050. if ! grep -q "pgp_encrypt_sign_command" /home/$MY_USERNAME/.muttrc; then
  5051. 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
  5052. else
  5053. 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
  5054. fi
  5055. echo 'encrypt_outgoing_email' >> $COMPLETION_FILE
  5056. }
  5057. function encrypt_all_email {
  5058. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5059. return
  5060. fi
  5061. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  5062. return
  5063. fi
  5064. if [ -f /usr/local/bin/${PROJECT_NAME}-encrypt-mail ]; then
  5065. cp /usr/local/bin/${PROJECT_NAME}-encrypt-mail /usr/bin/encmaildir
  5066. else
  5067. cp /usr/bin/${PROJECT_NAME}-encrypt-mail /usr/bin/encmaildir
  5068. fi
  5069. chmod +x /usr/bin/encmaildir
  5070. if grep -Fxq "encrypt_all_email" $COMPLETION_FILE; then
  5071. return
  5072. fi
  5073. if [ ! /home/$MY_USERNAME/README ]; then
  5074. touch /home/$MY_USERNAME/README
  5075. fi
  5076. if ! grep -q $"If you have imported legacy email which is not encrypted" /home/$MY_USERNAME/README; then
  5077. echo '' >> /home/$MY_USERNAME/README
  5078. echo '' >> /home/$MY_USERNAME/README
  5079. echo $'Encrypting legacy email' >> /home/$MY_USERNAME/README
  5080. echo '=======================' >> /home/$MY_USERNAME/README
  5081. echo $'If you have imported legacy email which is not encrypted' >> /home/$MY_USERNAME/README
  5082. echo $'then it can be encrypted with the command:' >> /home/$MY_USERNAME/README
  5083. echo '' >> /home/$MY_USERNAME/README
  5084. echo ' encmaildir' >> /home/$MY_USERNAME/README
  5085. echo '' >> /home/$MY_USERNAME/README
  5086. echo $'But be warned that depending upon how much email you have' >> /home/$MY_USERNAME/README
  5087. echo $'this could take a seriously LONG time on the Beaglebone' >> /home/$MY_USERNAME/README
  5088. echo $'and may be better done on a faster machine.' >> /home/$MY_USERNAME/README
  5089. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5090. chmod 600 /home/$MY_USERNAME/README
  5091. fi
  5092. echo 'encrypt_all_email' >> $COMPLETION_FILE
  5093. }
  5094. function email_client {
  5095. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5096. return
  5097. fi
  5098. if grep -Fxq "email_client" $COMPLETION_FILE; then
  5099. return
  5100. fi
  5101. apt-get -y install mutt-patched lynx abook
  5102. if [ ! -f /etc/Muttrc ]; then
  5103. echo $"ERROR: Mutt does not appear to have installed. $CHECK_MESSAGE"
  5104. exit 49
  5105. fi
  5106. if [ ! -d /home/$MY_USERNAME/.mutt ]; then
  5107. mkdir /home/$MY_USERNAME/.mutt
  5108. fi
  5109. echo "text/html; lynx -dump -width=78 -nolist %s | sed ‘s/^ //’; copiousoutput; needsterminal; nametemplate=%s.html" > /home/$MY_USERNAME/.mutt/mailcap
  5110. cp /home/$MY_USERNAME/.mutt/mailcap /etc/skel/.mutt
  5111. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt
  5112. chown -R root:root /etc/skel/.mutt
  5113. echo 'set mbox_type=Maildir' >> /etc/Muttrc
  5114. echo 'set folder="~/Maildir"' >> /etc/Muttrc
  5115. echo 'set mask="!^\\.[^.]"' >> /etc/Muttrc
  5116. echo 'set mbox="~/Maildir"' >> /etc/Muttrc
  5117. echo 'set record="+Sent"' >> /etc/Muttrc
  5118. echo 'set postponed="+Drafts"' >> /etc/Muttrc
  5119. echo 'set trash="+Trash"' >> /etc/Muttrc
  5120. echo 'set spoolfile="~/Maildir"' >> /etc/Muttrc
  5121. echo 'auto_view text/x-vcard text/html text/enriched' >> /etc/Muttrc
  5122. echo 'set editor="emacs -q --load ~/.emacs-mutt"' >> /etc/Muttrc
  5123. echo 'set header_cache="+.cache"' >> /etc/Muttrc
  5124. echo '' >> /etc/Muttrc
  5125. echo 'macro index S "<tag-prefix><decode-save>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  5126. echo 'macro pager S "<decode-save>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  5127. echo 'macro index H "<tag-prefix><decode-copy>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  5128. echo 'macro pager H "<decode-copy>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  5129. echo '' >> /etc/Muttrc
  5130. echo '# set up the sidebar' >> /etc/Muttrc
  5131. echo 'set sidebar_width=22' >> /etc/Muttrc
  5132. echo 'set sidebar_visible=yes' >> /etc/Muttrc
  5133. echo "set sidebar_delim='|'" >> /etc/Muttrc
  5134. echo 'set sidebar_sort=yes' >> /etc/Muttrc
  5135. echo '' >> /etc/Muttrc
  5136. echo 'set rfc2047_parameters' >> /etc/Muttrc
  5137. echo '' >> /etc/Muttrc
  5138. echo '# Show inbox and sent items' >> /etc/Muttrc
  5139. echo 'mailboxes = =Sent =maybe-spam =spam' >> /etc/Muttrc
  5140. echo '' >> /etc/Muttrc
  5141. echo '# Alter these colours as needed for maximum bling' >> /etc/Muttrc
  5142. echo 'color sidebar_new yellow default' >> /etc/Muttrc
  5143. echo 'color normal white default' >> /etc/Muttrc
  5144. echo 'color hdrdefault brightcyan default' >> /etc/Muttrc
  5145. echo 'color signature green default' >> /etc/Muttrc
  5146. echo 'color attachment brightyellow default' >> /etc/Muttrc
  5147. echo 'color quoted green default' >> /etc/Muttrc
  5148. echo 'color quoted1 white default' >> /etc/Muttrc
  5149. echo 'color tilde blue default' >> /etc/Muttrc
  5150. echo '' >> /etc/Muttrc
  5151. echo '# ctrl-n, ctrl-p to select next, prev folder' >> /etc/Muttrc
  5152. echo '# ctrl-o to open selected folder' >> /etc/Muttrc
  5153. echo 'bind index \Cp sidebar-prev' >> /etc/Muttrc
  5154. echo 'bind index \Cn sidebar-next' >> /etc/Muttrc
  5155. echo 'bind index \Co sidebar-open' >> /etc/Muttrc
  5156. echo 'bind pager \Cp sidebar-prev' >> /etc/Muttrc
  5157. echo 'bind pager \Cn sidebar-next' >> /etc/Muttrc
  5158. echo 'bind pager \Co sidebar-open' >> /etc/Muttrc
  5159. echo '' >> /etc/Muttrc
  5160. echo '# ctrl-b toggles sidebar visibility' >> /etc/Muttrc
  5161. echo "macro index,pager \Cb '<enter-command>toggle sidebar_visible<enter><redraw-screen>' 'toggle sidebar'" >> /etc/Muttrc
  5162. echo '' >> /etc/Muttrc
  5163. echo '# esc-m Mark new messages as read' >> /etc/Muttrc
  5164. echo 'macro index <esc>m "T~N<enter>;WNT~O<enter>;WO\CT~T<enter>" "mark all messages read"' >> /etc/Muttrc
  5165. echo '' >> /etc/Muttrc
  5166. echo '# Collapsing threads' >> /etc/Muttrc
  5167. echo 'macro index [ "<collapse-thread>" "collapse/uncollapse thread"' >> /etc/Muttrc
  5168. echo 'macro index ] "<collapse-all>" "collapse/uncollapse all threads"' >> /etc/Muttrc
  5169. echo '' >> /etc/Muttrc
  5170. echo '# threads containing new messages' >> /etc/Muttrc
  5171. echo 'uncolor index "~(~N)"' >> /etc/Muttrc
  5172. echo 'color index brightblue default "~(~N)"' >> /etc/Muttrc
  5173. echo '' >> /etc/Muttrc
  5174. echo '# new messages themselves' >> /etc/Muttrc
  5175. echo 'uncolor index "~N"' >> /etc/Muttrc
  5176. echo 'color index brightyellow default "~N"' >> /etc/Muttrc
  5177. echo '' >> /etc/Muttrc
  5178. echo '# GPG/PGP integration' >> /etc/Muttrc
  5179. echo '# this set the number of seconds to keep in memory the passphrase used to encrypt/sign' >> /etc/Muttrc
  5180. echo 'set pgp_timeout=1800' >> /etc/Muttrc
  5181. echo '' >> /etc/Muttrc
  5182. echo '# automatically sign and encrypt with PGP/MIME' >> /etc/Muttrc
  5183. echo 'set pgp_autosign # autosign all outgoing mails' >> /etc/Muttrc
  5184. echo 'set pgp_autoencrypt # Try to encrypt automatically' >> /etc/Muttrc
  5185. echo 'set pgp_replyencrypt # autocrypt replies to crypted' >> /etc/Muttrc
  5186. echo 'set pgp_replysign # autosign replies to signed' >> /etc/Muttrc
  5187. echo 'set pgp_auto_decode=yes # decode attachments' >> /etc/Muttrc
  5188. echo 'set fcc_clear=no # Keep encrypted copy of sent encrypted mail' >> /etc/Muttrc
  5189. echo 'unset smime_is_default' >> /etc/Muttrc
  5190. echo '' >> /etc/Muttrc
  5191. echo 'set alias_file=~/.mutt-alias' >> /etc/Muttrc
  5192. echo 'source ~/.mutt-alias' >> /etc/Muttrc
  5193. echo 'set query_command= "abook --mutt-query \"%s\""' >> /etc/Muttrc
  5194. echo 'macro index,pager A "<pipe-message>abook --add-email-quiet<return>" "add the sender address to abook"' >> /etc/Muttrc
  5195. echo '' >> /etc/Muttrc
  5196. echo '# Optional relay of SMTP via ISP' >> /etc/Muttrc
  5197. echo '#set smtp_url="smtps://username:password@isp_mail_domain:465/"' >> /etc/Muttrc
  5198. # create an Emacs configuration specifically for use with Mutt, which
  5199. # has word wrap and spell checking on by default
  5200. echo "(add-hook 'before-save-hook 'delete-trailing-whitespace)" > /home/$MY_USERNAME/.emacs-mutt
  5201. echo '(setq org-support-shift-select t)' >> /home/$MY_USERNAME/.emacs-mutt
  5202. echo '(setq standard-indent 4)' >> /home/$MY_USERNAME/.emacs-mutt
  5203. echo '(setq-default tab-width 4)' >> /home/$MY_USERNAME/.emacs-mutt
  5204. echo '(setq c-basic-offset 4)' >> /home/$MY_USERNAME/.emacs-mutt
  5205. echo '(mouse-wheel-mode t)' >> /home/$MY_USERNAME/.emacs-mutt
  5206. echo '(setq make-backup-files t)' >> /home/$MY_USERNAME/.emacs-mutt
  5207. echo '(setq version-control t)' >> /home/$MY_USERNAME/.emacs-mutt
  5208. echo '(setq backup-directory-alist (quote ((".*" . "~/.emacs_backups/"))))' >> /home/$MY_USERNAME/.emacs-mutt
  5209. echo "(setq default-major-mode 'text-mode)" >> /home/$MY_USERNAME/.emacs-mutt
  5210. echo "(dolist (hook '(text-mode-hook))" >> /home/$MY_USERNAME/.emacs-mutt
  5211. echo ' (add-hook hook (lambda () (flyspell-mode 1))))' >> /home/$MY_USERNAME/.emacs-mutt
  5212. echo '(setq-default fill-column 72)' >> /home/$MY_USERNAME/.emacs-mutt
  5213. echo '(setq auto-fill-mode 0)' >> /home/$MY_USERNAME/.emacs-mutt
  5214. echo "(add-hook 'text-mode-hook 'turn-on-auto-fill)" >> /home/$MY_USERNAME/.emacs-mutt
  5215. echo "(setq-default auto-fill-function 'do-auto-fill)" >> /home/$MY_USERNAME/.emacs-mutt
  5216. # add the emacs mutt configuration to the user profile skeleton
  5217. if [ ! -f /etc/skel/.emacs-mutt ]; then
  5218. cp /home/$MY_USERNAME/.emacs-mutt /etc/skel/.emacs-mutt
  5219. chown root:root /etc/skel/.emacs-mutt
  5220. fi
  5221. cp -f /etc/Muttrc /home/$MY_USERNAME/.muttrc
  5222. cp -f /etc/Muttrc /etc/skel/.muttrc
  5223. touch /home/$MY_USERNAME/.mutt-alias
  5224. cp /home/$MY_USERNAME/.mutt-alias /etc/skel/.mutt-alias
  5225. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs-mutt
  5226. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.muttrc
  5227. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt-alias
  5228. # default user on generic images
  5229. if [ -d /home/${GENERIC_IMAGE_USERNAME} ]; then
  5230. cp -f /etc/Muttrc /home/${GENERIC_IMAGE_USERNAME}/.muttrc
  5231. chown ${GENERIC_IMAGE_USERNAME}:${GENERIC_IMAGE_USERNAME} /home/${GENERIC_IMAGE_USERNAME}/.muttrc
  5232. touch /home/${GENERIC_IMAGE_USERNAME}/.mutt-alias
  5233. chown ${GENERIC_IMAGE_USERNAME}:${GENERIC_IMAGE_USERNAME} /home/${GENERIC_IMAGE_USERNAME}/.mutt-alias
  5234. cp /etc/skel/.emacs-mutt /home/${GENERIC_IMAGE_USERNAME}/.emacs-mutt
  5235. chown ${GENERIC_IMAGE_USERNAME}:${GENERIC_IMAGE_USERNAME} /home/${GENERIC_IMAGE_USERNAME}/.emacs-mutt
  5236. fi
  5237. echo 'email_client' >> $COMPLETION_FILE
  5238. }
  5239. function email_archiving {
  5240. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5241. return
  5242. fi
  5243. # ensure that the mail archive script is up to date
  5244. if [ -f /usr/local/bin/${PROJECT_NAME}-archive-mail ]; then
  5245. cp /usr/local/bin/${PROJECT_NAME}-archive-mail /etc/cron.daily/archivemail
  5246. else
  5247. if [ -f /usr/bin/${PROJECT_NAME}-archive-mail ]; then
  5248. cp /usr/bin/${PROJECT_NAME}-archive-mail /etc/cron.daily/archivemail
  5249. else
  5250. echo "/usr/bin/${PROJECT_NAME}-archive-mail was not found. ${PROJECT_NAME} might not have fully installed."
  5251. exit 62379
  5252. fi
  5253. fi
  5254. chmod +x /etc/cron.daily/archivemail
  5255. # update to the next commit
  5256. set_repo_commit $INSTALL_DIR/cleanup-maildir "cleanup-maildir commit" "$CLEANUP_MAILDIR_COMMIT" $CLEANUP_MAILDIR_REPO
  5257. if grep -Fxq "email_archiving" $COMPLETION_FILE; then
  5258. return
  5259. fi
  5260. if [ ! -d $INSTALL_DIR ]; then
  5261. mkdir $INSTALL_DIR
  5262. fi
  5263. cd $INSTALL_DIR
  5264. git_clone $CLEANUP_MAILDIR_REPO $INSTALL_DIR/cleanup-maildir
  5265. cd $INSTALL_DIR/cleanup-maildir
  5266. git checkout $CLEANUP_MAILDIR_COMMIT -b $CLEANUP_MAILDIR_COMMIT
  5267. if ! grep -q "cleanup-maildir commit" $COMPLETION_FILE; then
  5268. echo "cleanup-maildir commit:$CLEANUP_MAILDIR_COMMIT" >> $COMPLETION_FILE
  5269. else
  5270. sed -i "s/cleanup-maildir commit.*/cleanup-maildir commit:$CLEANUP_MAILDIR_COMMIT/g" $COMPLETION_FILE
  5271. fi
  5272. cp $INSTALL_DIR/cleanup-maildir/cleanup-maildir /usr/bin
  5273. echo 'email_archiving' >> $COMPLETION_FILE
  5274. }
  5275. # Ensure that the from field is correct when sending email from Mutt
  5276. function email_from_address {
  5277. if grep -Fxq "email_from_address" $COMPLETION_FILE; then
  5278. return
  5279. fi
  5280. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  5281. return
  5282. fi
  5283. if grep -q "set from=" /home/$MY_USERNAME/.muttrc; then
  5284. sed -i "s|set from=.*|set from='$MY_NAME <$MY_EMAIL_ADDRESS>'|g" /home/$MY_USERNAME/.muttrc
  5285. else
  5286. echo "set from='$MY_NAME <$MY_EMAIL_ADDRESS>'" >> /home/$MY_USERNAME/.muttrc
  5287. fi
  5288. echo 'email_from_address' >> $COMPLETION_FILE
  5289. }
  5290. function create_public_mailing_list {
  5291. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5292. return
  5293. fi
  5294. if grep -Fxq "create_public_mailing_list" $COMPLETION_FILE; then
  5295. return
  5296. fi
  5297. if [ ! $PUBLIC_MAILING_LIST ]; then
  5298. return
  5299. fi
  5300. # does the mailing list have a separate domain name?
  5301. if [ ! $PUBLIC_MAILING_LIST_DOMAIN_NAME ]; then
  5302. PUBLIC_MAILING_LIST_DOMAIN_NAME=$DEFAULT_DOMAIN_NAME
  5303. fi
  5304. PUBLIC_MAILING_LIST_USER="mlmmj"
  5305. apt-get -y install mlmmj
  5306. adduser --system $PUBLIC_MAILING_LIST_USER
  5307. addgroup $PUBLIC_MAILING_LIST_USER
  5308. adduser $PUBLIC_MAILING_LIST_USER $PUBLIC_MAILING_LIST_USER
  5309. echo ''
  5310. echo $"Creating the $PUBLIC_MAILING_LIST mailing list"
  5311. echo ''
  5312. # create the list
  5313. mlmmj-make-ml -a -L "$PUBLIC_MAILING_LIST" -c $PUBLIC_MAILING_LIST_USER
  5314. echo 'SYSTEM_ALIASES_PIPE_TRANSPORT = address_pipe' > /etc/exim4/conf.d/main/000_localmacros
  5315. echo "SYSTEM_ALIASES_USER = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  5316. echo "SYSTEM_ALIASES_GROUP = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  5317. # router
  5318. echo 'mlmmj_router:' > /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5319. echo ' debug_print = "R: mlmmj_router for $local_part@$domain"' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5320. echo ' driver = accept' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5321. echo ' domains = +mlmmj_domains' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5322. echo ' #require_files = MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5323. 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
  5324. echo ' # Exim will then spawn a new process running under the UID of "mlmmj".' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5325. echo ' require_files = mlmmj:MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5326. echo ' local_part_suffix = +*' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5327. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5328. echo ' headers_remove = Delivered-To' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5329. echo ' headers_add = Delivered-To: $local_part$local_part_suffix@$domain' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5330. echo ' transport = mlmmj_transport' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5331. # transport
  5332. echo 'mlmmj_transport:' > /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5333. echo ' debug_print = "T: mlmmj_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5334. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5335. echo ' return_path_add' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5336. echo ' user = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5337. echo ' group = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5338. echo ' home_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5339. echo ' current_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5340. echo ' command = /usr/bin/mlmmj-receive -F -L MLMMJ_HOME/${lc:$local_part}' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5341. if ! grep -q "MLMMJ_HOME=/var/spool/mlmmj" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5342. sed -i '/MAIN CONFIGURATION SETTINGS/a\MLMMJ_HOME=/var/spool/mlmmj' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5343. fi
  5344. if ! grep -q "domainlist mlmmj_domains =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5345. sed -i "/MLMMJ_HOME/a\domainlist mlmmj_domains = $PUBLIC_MAILING_LIST_DOMAIN_NAME" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5346. fi
  5347. if ! grep -q "delay_warning_condition =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5348. 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
  5349. fi
  5350. if ! grep -q ": +mlmmj_domains" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5351. 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
  5352. fi
  5353. if ! grep -q "! +mlmmj_domains" /etc/exim4/conf.d/router/200_exim4-config_primary; then
  5354. sed -i 's/domains = ! +local_domains/domains = ! +mlmmj_domains : ! +local_domains/g' /etc/exim4/conf.d/router/200_exim4-config_primary
  5355. fi
  5356. update-exim4.conf.template -r
  5357. update-exim4.conf
  5358. systemctl restart exim4
  5359. if ! grep -q $"$PUBLIC_MAILING_LIST mailing list" /home/$MY_USERNAME/README; then
  5360. echo '' >> /home/$MY_USERNAME/README
  5361. echo '' >> /home/$MY_USERNAME/README
  5362. echo $"$PUBLIC_MAILING_LIST mailing list" >> /home/$MY_USERNAME/README
  5363. echo '=================================' >> /home/$MY_USERNAME/README
  5364. echo $"To subscribe to the $PUBLIC_MAILING_LIST mailing list send a" >> /home/$MY_USERNAME/README
  5365. echo $"cleartext email to $PUBLIC_MAILING_LIST+subscribe@$DEFAULT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  5366. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5367. chmod 600 /home/$MY_USERNAME/README
  5368. fi
  5369. ${PROJECT_NAME}-addlist -u $MY_USERNAME -l "$PUBLIC_MAILING_LIST" -s "$PUBLIC_MAILING_LIST"
  5370. echo 'create_public_mailing_list' >> $COMPLETION_FILE
  5371. }
  5372. function create_private_mailing_list {
  5373. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5374. return
  5375. fi
  5376. # This installation doesn't work, results in ruby errors
  5377. # There is currently no schleuder package for Debian jessie
  5378. if grep -Fxq "create_private_mailing_list" $COMPLETION_FILE; then
  5379. return
  5380. fi
  5381. if [ ! $PRIVATE_MAILING_LIST ]; then
  5382. return
  5383. fi
  5384. if [[ $PRIVATE_MAILING_LIST == $MY_USERNAME ]]; then
  5385. echo $'The name of the private mailing list should not be the same as your username'
  5386. exit 10
  5387. fi
  5388. if [ ! $MY_GPG_PUBLIC_KEY ]; then
  5389. echo $'To create a private mailing list you need to specify a file'
  5390. echo $'containing your exported GPG key within MY_GPG_PUBLIC_KEY at'
  5391. echo $'the top of the script'
  5392. exit 11
  5393. fi
  5394. apt-get -y install ruby ruby-dev ruby-gpgme libgpgme11-dev libmagic-dev
  5395. gem install schleuder
  5396. schleuder-fix-gem-dependencies
  5397. schleuder-init-setup --gem
  5398. # NOTE: this is version number sensitive and so might need changing
  5399. ln -s /var/lib/gems/2.1.0/gems/schleuder-2.2.4 /var/lib/schleuder
  5400. sed -i 's/#smtp_port: 25/smtp_port: 465/g' /etc/schleuder/schleuder.conf
  5401. sed -i 's/#superadminaddr: root@localhost/superadminaddr: root@localhost' /etc/schleuder/schleuder.conf
  5402. 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
  5403. ${PROJECT_NAME}-addemail -u $MY_USERNAME -e $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME -l $PRIVATE_MAILING_LIST
  5404. echo 'schleuder:' > /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5405. echo ' debug_print = "R: schleuder for $local_part@$domain"' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5406. echo ' driver = accept' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5407. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5408. echo ' local_part_suffix = +* : -bounce : -sendkey' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5409. echo ' domains = +local_domains' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5410. echo ' user = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5411. echo ' group = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5412. echo ' require_files = schleuder:+/var/lib/schleuder/$domain/${local_part}' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5413. echo ' transport = schleuder_transport' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5414. echo 'schleuder_transport:' > /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5415. echo ' debug_print = "T: schleuder_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5416. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5417. echo ' home_directory = "/var/lib/schleuder/$domain/$local_part"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5418. echo ' command = "/usr/bin/schleuder $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5419. chown -R schleuder:schleuder /var/lib/schleuder
  5420. update-exim4.conf.template -r
  5421. update-exim4.conf
  5422. systemctl restart exim4
  5423. useradd -d /var/schleuderlists -s /bin/false schleuder
  5424. adduser Debian-exim schleuder
  5425. usermod -a -G mail schleuder
  5426. #exim -d -bt $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME
  5427. echo 'create_private_mailing_list' >> $COMPLETION_FILE
  5428. }
  5429. function split_gpg_key_into_fragments {
  5430. # split the gpg key into fragments if social key management is enabled
  5431. if [[ $ENABLE_SOCIAL_KEY_MANAGEMENT == "yes" ]]; then
  5432. echo 'Splitting GPG key. You may need to enter your passphrase.'
  5433. ${PROJECT_NAME}-splitkey -u $MY_USERNAME -e $MY_EMAIL_ADDRESS --fullname "$MY_NAME"
  5434. if [ ! -d /home/$MY_USERNAME/.gnupg_fragments ]; then
  5435. echo 'Yhe GPG key could not be split'
  5436. exit 86548
  5437. fi
  5438. fi
  5439. }
  5440. function import_email {
  5441. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5442. return
  5443. fi
  5444. EMAIL_COMPLETE_MSG=$"
  5445. *** ${PROJECT_NAME} mailbox installation is complete ***
  5446. Now on your internet router forward ports
  5447. 25, 587, 465, 993 and 2222 to the ${PROJECT_NAME}
  5448. "
  5449. if grep -Fxq "import_email" $COMPLETION_FILE; then
  5450. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  5451. backup_to_friends_servers
  5452. intrusion_detection
  5453. split_gpg_key_into_fragments
  5454. clear
  5455. echo ''
  5456. echo "$EMAIL_COMPLETE_MSG"
  5457. if [ -d $USB_MOUNT ]; then
  5458. umount $USB_MOUNT
  5459. rm -rf $USB_MOUNT
  5460. echo $' You can now remove the USB drive'
  5461. fi
  5462. exit 0
  5463. fi
  5464. return
  5465. fi
  5466. if [ $IMPORT_MAILDIR ]; then
  5467. if [ -d $IMPORT_MAILDIR ]; then
  5468. echo $'Transfering email files'
  5469. cp -r $IMPORT_MAILDIR /home/$MY_USERNAME
  5470. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  5471. else
  5472. echo $"Email import directory $IMPORT_MAILDIR not found"
  5473. exit 9
  5474. fi
  5475. fi
  5476. echo 'import_email' >> $COMPLETION_FILE
  5477. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  5478. backup_to_friends_servers
  5479. intrusion_detection
  5480. split_gpg_key_into_fragments
  5481. # unmount any attached usb drive
  5482. clear
  5483. echo ''
  5484. echo "$EMAIL_COMPLETE_MSG"
  5485. echo ''
  5486. if [ -d $USB_MOUNT ]; then
  5487. umount $USB_MOUNT
  5488. rm -rf $USB_MOUNT
  5489. echo $' You can now remove the USB drive'
  5490. fi
  5491. exit 0
  5492. fi
  5493. }
  5494. function install_web_server {
  5495. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  5496. return
  5497. fi
  5498. # update to the next commit
  5499. set_repo_commit $INSTALL_DIR/nginx_ensite "Nginx-ensite commit" "$NGINX_ENSITE_COMMIT" $NGINX_ENSITE_REPO
  5500. if grep -Fxq "install_web_server" $COMPLETION_FILE; then
  5501. return
  5502. fi
  5503. # remove apache
  5504. apt-get -y remove --purge apache2
  5505. if [ -d /etc/apache2 ]; then
  5506. rm -rf /etc/apache2
  5507. fi
  5508. # install nginx
  5509. apt-get -y install nginx php5-fpm git
  5510. # limit the number of php processes
  5511. sed -i 's/; process.max =.*/process.max = 32/g' /etc/php5/fpm/php-fpm.conf
  5512. #sed -i 's/;process_control_timeout =.*/process_control_timeout = 300/g' /etc/php5/fpm/php-fpm.conf
  5513. if ! grep -q "pm.max_children" /etc/php5/fpm/php-fpm.conf; then
  5514. echo 'pm.max_children = 10' >> /etc/php5/fpm/php-fpm.conf
  5515. echo 'pm.start_servers = 2' >> /etc/php5/fpm/php-fpm.conf
  5516. echo 'pm.min_spare_servers = 2' >> /etc/php5/fpm/php-fpm.conf
  5517. echo 'pm.max_spare_servers = 5' >> /etc/php5/fpm/php-fpm.conf
  5518. echo 'pm.max_requests = 50' >> /etc/php5/fpm/php-fpm.conf
  5519. fi
  5520. if [ ! -d /etc/nginx ]; then
  5521. echo $"ERROR: nginx does not appear to have installed. $CHECK_MESSAGE"
  5522. exit 51
  5523. fi
  5524. # Nginx settings
  5525. echo 'user www-data;' > /etc/nginx/nginx.conf
  5526. #echo "worker_processes; $CPU_CORES" >> /etc/nginx/nginx.conf
  5527. echo 'pid /run/nginx.pid;' >> /etc/nginx/nginx.conf
  5528. echo '' >> /etc/nginx/nginx.conf
  5529. echo 'events {' >> /etc/nginx/nginx.conf
  5530. echo ' worker_connections 50;' >> /etc/nginx/nginx.conf
  5531. echo ' # multi_accept on;' >> /etc/nginx/nginx.conf
  5532. echo '}' >> /etc/nginx/nginx.conf
  5533. echo '' >> /etc/nginx/nginx.conf
  5534. echo 'http {' >> /etc/nginx/nginx.conf
  5535. echo ' # limit the number of connections per single IP' >> /etc/nginx/nginx.conf
  5536. echo ' limit_conn_zone $binary_remote_addr zone=conn_limit_per_ip:10m;' >> /etc/nginx/nginx.conf
  5537. echo '' >> /etc/nginx/nginx.conf
  5538. echo ' # limit the number of requests for a given session' >> /etc/nginx/nginx.conf
  5539. echo ' limit_req_zone $binary_remote_addr zone=req_limit_per_ip:10m rate=140r/s;' >> /etc/nginx/nginx.conf
  5540. echo '' >> /etc/nginx/nginx.conf
  5541. 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
  5542. echo ' client_body_buffer_size 128k;' >> /etc/nginx/nginx.conf
  5543. echo '' >> /etc/nginx/nginx.conf
  5544. echo ' # headerbuffer size for the request header from client, its set for testing purpose' >> /etc/nginx/nginx.conf
  5545. echo ' client_header_buffer_size 3m;' >> /etc/nginx/nginx.conf
  5546. echo '' >> /etc/nginx/nginx.conf
  5547. echo ' # maximum number and size of buffers for large headers to read from client request' >> /etc/nginx/nginx.conf
  5548. echo ' large_client_header_buffers 4 256k;' >> /etc/nginx/nginx.conf
  5549. echo '' >> /etc/nginx/nginx.conf
  5550. echo ' # read timeout for the request body from client, its set for testing purpose' >> /etc/nginx/nginx.conf
  5551. echo ' client_body_timeout 3m;' >> /etc/nginx/nginx.conf
  5552. echo '' >> /etc/nginx/nginx.conf
  5553. echo ' # how long to wait for the client to send a request header, its set for testing purpose' >> /etc/nginx/nginx.conf
  5554. echo ' client_header_timeout 3m;' >> /etc/nginx/nginx.conf
  5555. echo '' >> /etc/nginx/nginx.conf
  5556. echo ' ##' >> /etc/nginx/nginx.conf
  5557. echo ' # Basic Settings' >> /etc/nginx/nginx.conf
  5558. echo ' ##' >> /etc/nginx/nginx.conf
  5559. echo '' >> /etc/nginx/nginx.conf
  5560. echo ' sendfile on;' >> /etc/nginx/nginx.conf
  5561. echo ' tcp_nopush on;' >> /etc/nginx/nginx.conf
  5562. echo ' tcp_nodelay on;' >> /etc/nginx/nginx.conf
  5563. echo ' keepalive_timeout 65;' >> /etc/nginx/nginx.conf
  5564. echo ' types_hash_max_size 2048;' >> /etc/nginx/nginx.conf
  5565. echo ' server_tokens off;' >> /etc/nginx/nginx.conf
  5566. echo '' >> /etc/nginx/nginx.conf
  5567. echo ' # server_names_hash_bucket_size 64;' >> /etc/nginx/nginx.conf
  5568. echo ' # server_name_in_redirect off;' >> /etc/nginx/nginx.conf
  5569. echo '' >> /etc/nginx/nginx.conf
  5570. echo ' include /etc/nginx/mime.types;' >> /etc/nginx/nginx.conf
  5571. echo ' default_type application/octet-stream;' >> /etc/nginx/nginx.conf
  5572. echo '' >> /etc/nginx/nginx.conf
  5573. echo ' ##' >> /etc/nginx/nginx.conf
  5574. echo ' # Logging Settings' >> /etc/nginx/nginx.conf
  5575. echo ' ##' >> /etc/nginx/nginx.conf
  5576. echo '' >> /etc/nginx/nginx.conf
  5577. echo ' access_log /var/log/nginx/access.log;' >> /etc/nginx/nginx.conf
  5578. echo ' error_log /var/log/nginx/error.log;' >> /etc/nginx/nginx.conf
  5579. echo '' >> /etc/nginx/nginx.conf
  5580. echo ' ###' >> /etc/nginx/nginx.conf
  5581. echo ' # Gzip Settings' >> /etc/nginx/nginx.conf
  5582. echo ' ##' >> /etc/nginx/nginx.conf
  5583. echo ' gzip on;' >> /etc/nginx/nginx.conf
  5584. echo ' gzip_disable "msie6";' >> /etc/nginx/nginx.conf
  5585. echo '' >> /etc/nginx/nginx.conf
  5586. echo ' # gzip_vary on;' >> /etc/nginx/nginx.conf
  5587. echo ' # gzip_proxied any;' >> /etc/nginx/nginx.conf
  5588. echo ' # gzip_comp_level 6;' >> /etc/nginx/nginx.conf
  5589. echo ' # gzip_buffers 16 8k;' >> /etc/nginx/nginx.conf
  5590. echo ' # gzip_http_version 1.1;' >> /etc/nginx/nginx.conf
  5591. echo ' # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;' >> /etc/nginx/nginx.conf
  5592. echo '' >> /etc/nginx/nginx.conf
  5593. echo ' ##' >> /etc/nginx/nginx.conf
  5594. echo ' # Virtual Host Configs' >> /etc/nginx/nginx.conf
  5595. echo ' ##' >> /etc/nginx/nginx.conf
  5596. echo '' >> /etc/nginx/nginx.conf
  5597. echo ' include /etc/nginx/conf.d/*.conf;' >> /etc/nginx/nginx.conf
  5598. echo ' include /etc/nginx/sites-enabled/*;' >> /etc/nginx/nginx.conf
  5599. echo '}' >> /etc/nginx/nginx.conf
  5600. # install a script to easily enable and disable nginx virtual hosts
  5601. if [ ! -d $INSTALL_DIR ]; then
  5602. mkdir $INSTALL_DIR
  5603. fi
  5604. cd $INSTALL_DIR
  5605. git_clone $NGINX_ENSITE_REPO $INSTALL_DIR/nginx_ensite
  5606. cd $INSTALL_DIR/nginx_ensite
  5607. git checkout $NGINX_ENSITE_COMMIT -b $NGINX_ENSITE_COMMIT
  5608. if ! grep -q "Nginx-ensite commit" $COMPLETION_FILE; then
  5609. echo "Nginx-ensite commit:$NGINX_ENSITE_COMMIT" >> $COMPLETION_FILE
  5610. else
  5611. sed -i "s/Nginx-ensite commit.*/Nginx-ensite commit:$NGINX_ENSITE_COMMIT/g" $COMPLETION_FILE
  5612. fi
  5613. make install
  5614. nginx_dissite default
  5615. echo 'install_web_server' >> $COMPLETION_FILE
  5616. }
  5617. function install_web_server_access_control {
  5618. if [ ! -f /etc/pam.d/nginx ]; then
  5619. echo '#%PAM-1.0' > /etc/pam.d/nginx
  5620. echo '@include common-auth' >> /etc/pam.d/nginx
  5621. echo '@include common-account' >> /etc/pam.d/nginx
  5622. echo '@include common-session' >> /etc/pam.d/nginx
  5623. fi
  5624. }
  5625. function configure_php {
  5626. sed -i "s/memory_limit = 128M/memory_limit = ${MAX_PHP_MEMORY}M/g" /etc/php5/fpm/php.ini
  5627. sed -i 's/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/g' /etc/php5/fpm/php.ini
  5628. sed -i "s/memory_limit = -1/memory_limit = ${MAX_PHP_MEMORY}M/g" /etc/php5/cli/php.ini
  5629. sed -i "s/upload_max_filesize = 2M/upload_max_filesize = 50M/g" /etc/php5/fpm/php.ini
  5630. sed -i "s/post_max_size = 8M/post_max_size = 50M/g" /etc/php5/fpm/php.ini
  5631. }
  5632. function install_mariadb {
  5633. if grep -Fxq "install_mariadb" $COMPLETION_FILE; then
  5634. return
  5635. fi
  5636. apt-get -y install python-software-properties debconf-utils
  5637. apt-get -y install software-properties-common
  5638. apt-get -y update
  5639. get_mariadb_password
  5640. if [ ! $MARIADB_PASSWORD ]; then
  5641. if [ -f $IMAGE_PASSWORD_FILE ]; then
  5642. MARIADB_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  5643. else
  5644. MARIADB_PASSWORD="$(openssl rand -base64 32 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  5645. fi
  5646. echo "$MARIADB_PASSWORD" > $DATABASE_PASSWORD_FILE
  5647. chmod 600 $DATABASE_PASSWORD_FILE
  5648. echo '' >> /home/$MY_USERNAME/README
  5649. echo '' >> /home/$MY_USERNAME/README
  5650. echo 'MariaDB / MySql' >> /home/$MY_USERNAME/README
  5651. echo '===============' >> /home/$MY_USERNAME/README
  5652. echo $"Your MariaDB password is: $MARIADB_PASSWORD" >> /home/$MY_USERNAME/README
  5653. echo '' >> /home/$MY_USERNAME/README
  5654. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5655. chmod 600 /home/$MY_USERNAME/README
  5656. fi
  5657. debconf-set-selections <<< "mariadb-server mariadb-server/root_password password $MARIADB_PASSWORD"
  5658. debconf-set-selections <<< "mariadb-server mariadb-server/root_password_again password $MARIADB_PASSWORD"
  5659. apt-get -y install mariadb-server
  5660. apt-get -y remove --purge apache*
  5661. if [ -d /etc/apache2 ]; then
  5662. rm -rf /etc/apache2
  5663. echo $'Removed Apache installation after MariaDB install'
  5664. fi
  5665. if [ ! -d /etc/mysql ]; then
  5666. echo $"ERROR: mariadb-server does not appear to have installed. $CHECK_MESSAGE"
  5667. exit 54
  5668. fi
  5669. mysqladmin -u root password "$MARIADB_PASSWORD"
  5670. echo 'install_mariadb' >> $COMPLETION_FILE
  5671. }
  5672. function backup_databases_script_header {
  5673. if [ ! -f /usr/bin/backupdatabases ]; then
  5674. # daily
  5675. echo '#!/bin/sh' > /usr/bin/backupdatabases
  5676. echo '' >> /usr/bin/backupdatabases
  5677. echo "EMAIL='$MY_EMAIL_ADDRESS'" >> /usr/bin/backupdatabases
  5678. echo '' >> /usr/bin/backupdatabases
  5679. echo -n 'MYSQL_PASSWORD=$(cat ' >> /usr/bin/backupdatabases
  5680. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/backupdatabases
  5681. echo 'umask 0077' >> /usr/bin/backupdatabases
  5682. echo '' >> /usr/bin/backupdatabases
  5683. echo '# exit if we are backing up to friends servers' >> /usr/bin/backupdatabases
  5684. echo "if [ -f $FRIENDS_SERVERS_LIST ]; then" >> /usr/bin/backupdatabases
  5685. echo ' exit 1' >> /usr/bin/backupdatabases
  5686. echo 'fi' >> /usr/bin/backupdatabases
  5687. chmod 600 /usr/bin/backupdatabases
  5688. chmod +x /usr/bin/backupdatabases
  5689. echo '#!/bin/sh' > /etc/cron.daily/backupdatabasesdaily
  5690. echo '/usr/bin/backupdatabases' >> /etc/cron.daily/backupdatabasesdaily
  5691. chmod 600 /etc/cron.daily/backupdatabasesdaily
  5692. chmod +x /etc/cron.daily/backupdatabasesdaily
  5693. # weekly
  5694. echo '#!/bin/sh' > /etc/cron.weekly/backupdatabasesweekly
  5695. echo '' >> /etc/cron.weekly/backupdatabasesweekly
  5696. echo 'umask 0077' >> /etc/cron.weekly/backupdatabasesweekly
  5697. chmod 600 /etc/cron.weekly/backupdatabasesweekly
  5698. chmod +x /etc/cron.weekly/backupdatabasesweekly
  5699. # monthly
  5700. echo '#!/bin/sh' > /etc/cron.monthly/backupdatabasesmonthly
  5701. echo '' >> /etc/cron.monthly/backupdatabasesmonthly
  5702. echo 'umask 0077' >> /etc/cron.monthly/backupdatabasesmonthly
  5703. chmod 600 /etc/cron.monthly/backupdatabasesmonthly
  5704. chmod +x /etc/cron.monthly/backupdatabasesmonthly
  5705. fi
  5706. }
  5707. function repair_databases_script {
  5708. if [ -f /etc/cron.hourly/repair ]; then
  5709. sed -i "s|/usr/bin/repairdatabase|${PROJECT_NAME}-repair-database|g" /etc/cron.hourly/repair
  5710. fi
  5711. if grep -Fxq "repair_databases_script" $COMPLETION_FILE; then
  5712. return
  5713. fi
  5714. if [ ! -f $DATABASE_PASSWORD_FILE ]; then
  5715. return
  5716. fi
  5717. echo '#!/bin/bash' > /etc/cron.hourly/repair
  5718. echo '' >> /etc/cron.hourly/repair
  5719. chmod 600 /etc/cron.hourly/repair
  5720. chmod +x /etc/cron.hourly/repair
  5721. echo 'repair_databases_script' >> $COMPLETION_FILE
  5722. }
  5723. function add_ddns_domain {
  5724. if [ ! $1 ]; then
  5725. echo $'ddns domain not specified'
  5726. exit 5638
  5727. fi
  5728. CURRENT_DDNS_DOMAIN="$1"
  5729. if [[ $ONION_ONLY != "no" ]]; then
  5730. return
  5731. fi
  5732. if [ ! -f /etc/inadyn.conf ]; then
  5733. echo $'Unable to find inadyn configuration file /etc/inadyn.conf'
  5734. exit 5745
  5735. fi
  5736. if ! grep -q "$DDNS_PROVIDER" /etc/inadyn.conf; then
  5737. echo '' >> /etc/inadyn.conf
  5738. echo "system $DDNS_PROVIDER" >> /etc/inadyn.conf
  5739. echo ' ssl' >> /etc/inadyn.conf
  5740. echo " checkip-url $GET_IP_ADDRESS_URL /" >> /etc/inadyn.conf
  5741. if [ $DDNS_USERNAME ]; then
  5742. echo " username $DDNS_USERNAME" >> /etc/inadyn.conf
  5743. fi
  5744. if [ $DDNS_PASSWORD ]; then
  5745. echo " password $DDNS_PASSWORD" >> /etc/inadyn.conf
  5746. fi
  5747. fi
  5748. if ! grep -q "$CURRENT_DDNS_DOMAIN" /etc/inadyn.conf; then
  5749. echo " alias $CURRENT_DDNS_DOMAIN" >> /etc/inadyn.conf
  5750. fi
  5751. chmod 600 /etc/inadyn.conf
  5752. systemctl restart inadyn
  5753. systemctl daemon-reload
  5754. }
  5755. function install_syncthing {
  5756. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5757. return
  5758. fi
  5759. if grep -Fxq "install_syncthing" $COMPLETION_FILE; then
  5760. return
  5761. fi
  5762. apt-get -y install curl
  5763. curl -s https://syncthing.net/release-key.txt | apt-key add -
  5764. echo "deb http://apt.syncthing.net/ syncthing release" | tee /etc/apt/sources.list.d/syncthing.list
  5765. apt-get update
  5766. apt-get -y install syncthing
  5767. # This probably does need to run as root so that it can access the Sync directories
  5768. # in each user's home directory
  5769. echo '[Unit]' > /etc/systemd/system/syncthing.service
  5770. echo 'Description=Syncthing - Open Source Continuous File Synchronization' >> /etc/systemd/system/syncthing.service
  5771. echo 'Documentation=man:syncthing(1)' >> /etc/systemd/system/syncthing.service
  5772. echo 'After=network.target' >> /etc/systemd/system/syncthing.service
  5773. echo 'Wants=syncthing-inotify@.service' >> /etc/systemd/system/syncthing.service
  5774. echo '' >> /etc/systemd/system/syncthing.service
  5775. echo '[Service]' >> /etc/systemd/system/syncthing.service
  5776. echo 'User=root' >> /etc/systemd/system/syncthing.service
  5777. echo "Environment='all_proxy=socks5://localhost:9050'" >> /etc/systemd/system/syncthing.service
  5778. echo 'ExecStart=/usr/bin/syncthing -no-browser -no-restart -logflags=0' >> /etc/systemd/system/syncthing.service
  5779. echo 'Restart=on-failure' >> /etc/systemd/system/syncthing.service
  5780. echo 'SuccessExitStatus=3 4' >> /etc/systemd/system/syncthing.service
  5781. echo 'RestartForceExitStatus=3 4' >> /etc/systemd/system/syncthing.service
  5782. echo '' >> /etc/systemd/system/syncthing.service
  5783. echo '[Install]' >> /etc/systemd/system/syncthing.service
  5784. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/syncthing.service
  5785. systemctl enable syncthing
  5786. systemctl daemon-reload
  5787. systemctl start syncthing
  5788. if ! grep -q "syncthing" /etc/crontab; then
  5789. echo "*/1 * * * * root /usr/local/bin/freedombone-syncthing > /dev/null" >> /etc/crontab
  5790. systemctl restart cron
  5791. fi
  5792. echo 'install_syncthing' >> $COMPLETION_FILE
  5793. }
  5794. function upgrade_golang {
  5795. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5796. return
  5797. fi
  5798. # NOTE: this is annoyingly hacky and going in the opposite
  5799. # direction of a pure blend, but it's necessary if you want
  5800. # to run the latest version of gogs
  5801. # update to the next commit
  5802. set_repo_commit $INSTALL_DIR/gvm "gvm commit" "$GVM_COMMIT" $GVM_REPO
  5803. if grep -Fxq "upgrade_golang" $COMPLETION_FILE; then
  5804. return
  5805. fi
  5806. export GVM_ROOT=$GVM_HOME
  5807. apt-get -y install curl git mercurial make binutils bison gcc build-essential
  5808. if [ ! -d $INSTALL_DIR ]; then
  5809. mkdir $INSTALL_DIR
  5810. fi
  5811. cd $INSTALL_DIR
  5812. git_clone $GVM_REPO gvm
  5813. cd $INSTALL_DIR/gvm
  5814. git checkout $GVM_COMMIT -b $GVM_COMMIT
  5815. if [ ! -f binscripts/gvm-installer ]; then
  5816. echo $'gvm installer not found'
  5817. fi
  5818. chmod +x binscripts/gvm-installer
  5819. if [ -d /root/.gvm ]; then
  5820. rm -rf /root/.gvm
  5821. fi
  5822. if [ -d $GVM_ROOT ]; then
  5823. rm -rf $GVM_ROOT
  5824. fi
  5825. sed -i "s|export GVM_ROOT=.*|export GVM_ROOT=$GVM_ROOT|g" ~/.bashrc
  5826. if [ ! -d /home/git ]; then
  5827. # add a gogs user account within which the gvm home directory will exist
  5828. adduser --disabled-login --gecos 'Gogs' git
  5829. fi
  5830. if [ -d /home/git/Maildir ]; then
  5831. rm -rf /home/git/Maildir
  5832. fi
  5833. # TODO: this script is all over the place
  5834. # and contains hardcoded github. See if you can do better
  5835. ./binscripts/gvm-installer master /home/git
  5836. if [ ! -d $GVM_ROOT ]; then
  5837. echo $'Unable to install gvm'
  5838. exit 83537
  5839. fi
  5840. [[ -s "$GVM_ROOT/scripts/gvm" ]] && source "$GVM_ROOT/scripts/gvm"
  5841. if [ ! -f $GVM_ROOT/bin/gvm ]; then
  5842. echo $'gvm was not installed'
  5843. fi
  5844. if ! grep -q "export GVM_ROOT=" ~/.bashrc; then
  5845. echo "export GVM_ROOT=$GVM_ROOT" >> ~/.bashrc
  5846. fi
  5847. cd $GVM_ROOT/bin
  5848. gvm install go1.4
  5849. gvm use go1.4
  5850. export GOROOT_BOOTSTRAP=$GOROOT
  5851. gvm install go${GO_VERSION}
  5852. if [ ! "$?" = "0" ]; then
  5853. echo $'Unable to upgrade golang'
  5854. exit 529252
  5855. fi
  5856. gvm use go${GO_VERSION} --default
  5857. chown -R git:git $GVM_HOME
  5858. if ! grep -q "gvm commit" $COMPLETION_FILE; then
  5859. echo "gvm commit:$GVM_COMMIT" >> $COMPLETION_FILE
  5860. else
  5861. sed -i "s/gvm commit.*/gvm commit:$GVM_COMMIT/g" $COMPLETION_FILE
  5862. fi
  5863. echo 'upgrade_golang' >> $COMPLETION_FILE
  5864. }
  5865. function install_gogs {
  5866. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5867. return
  5868. fi
  5869. if [ ! $GIT_DOMAIN_NAME ]; then
  5870. return
  5871. fi
  5872. select_go_version
  5873. # update to the next commit
  5874. set_repo_commit $GOPATH/src/github.com/gogits/gogs "Gogs commit" "$GOGS_COMMIT" $GIT_DOMAIN_REPO
  5875. if grep -Fxq "install_gogs" $COMPLETION_FILE; then
  5876. return
  5877. fi
  5878. if [ -d $GOPATH/src/github.com/gogits ]; then
  5879. rm -rf $GOPATH/src/github.com/gogits
  5880. fi
  5881. if [ -d /home/git/gvm/pkgsets/go${GO_VERSION}/global/src/github.com/gogits ]; then
  5882. rm -rf /home/git/gvm/pkgsets/go${GO_VERSION}/global/src/github.com/gogits
  5883. fi
  5884. if [ -d /home/git/gogs-repositories ]; then
  5885. rm -rf /home/git/gogs-repositories
  5886. fi
  5887. if [ ! -d /home/git ]; then
  5888. # add a gogs user account
  5889. adduser --disabled-login --gecos 'Gogs' git
  5890. fi
  5891. if [ -d /home/git/Maildir ]; then
  5892. rm -rf /home/git/Maildir
  5893. fi
  5894. if [ -d $GOPATH/src/github.com/gogits ]; then
  5895. rm -rf $GOPATH/src/github.com/gogits
  5896. fi
  5897. # install Go
  5898. apt-get -y install golang libpam0g-dev
  5899. if ! grep -q "export GOPATH=" ~/.bashrc; then
  5900. echo "export GOPATH=$GOPATH" >> ~/.bashrc
  5901. else
  5902. sed -i "s|export GOPATH=.*|export GOPATH=$GOPATH|g" ~/.bashrc
  5903. fi
  5904. systemctl set-environment GOPATH=$GOPATH
  5905. if ! grep -q "systemctl set-environment GOPATH=" ~/.bashrc; then
  5906. echo "systemctl set-environment GOPATH=$GOPATH" >> ~/.bashrc
  5907. else
  5908. sed -i "s|systemctl set-environment GOPATH=.*|systemctl set-environment GOPATH=$GOPATH|g" ~/.bashrc
  5909. fi
  5910. if [ ! -d $GOPATH ]; then
  5911. mkdir -p $GOPATH
  5912. fi
  5913. GO_PACKAGE_MANAGER_REPO2=$(echo "$GO_PACKAGE_MANAGER_REPO" | sed 's|https://||g')
  5914. go get -u $GO_PACKAGE_MANAGER_REPO2
  5915. if [ ! "$?" = "0" ]; then
  5916. echo $'install_gogs: go get failed'
  5917. exit 479832
  5918. fi
  5919. # clone the repo
  5920. if [ ! -d $GOPATH/src/github.com/gogits ]; then
  5921. mkdir -p $GOPATH/src/github.com/gogits
  5922. fi
  5923. git_clone $GIT_DOMAIN_REPO $GOPATH/src/github.com/gogits/gogs
  5924. if [ ! -d $GOPATH/src/github.com/gogits/gogs ]; then
  5925. echo $"Unable to clone repo $GOPATH/src/github.com/gogits/gogs"
  5926. exit 85482
  5927. fi
  5928. cd $GOPATH/src/github.com/gogits/gogs
  5929. # install
  5930. go get -u ./...
  5931. git checkout $GOGS_COMMIT -b $GOGS_COMMIT
  5932. if ! grep -q "Gogs commit" $COMPLETION_FILE; then
  5933. echo "Gogs commit:$GOGS_COMMIT" >> $COMPLETION_FILE
  5934. else
  5935. sed -i "s/Gogs commit.*/Gogs commit:$GOGS_COMMIT/g" $COMPLETION_FILE
  5936. fi
  5937. go build
  5938. if [ ! "$?" = "0" ]; then
  5939. echo $'install_gogs: go build failed'
  5940. exit 546750
  5941. fi
  5942. install_mariadb
  5943. get_mariadb_password
  5944. get_mariadb_git_admin_password
  5945. if [ ! $GIT_ADMIN_PASSWORD ]; then
  5946. if [ -f $IMAGE_PASSWORD_FILE ]; then
  5947. GIT_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  5948. else
  5949. GIT_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  5950. fi
  5951. fi
  5952. if ! grep -q $"Gogs admin user password" /home/$MY_USERNAME/README; then
  5953. echo '' >> /home/$MY_USERNAME/README
  5954. echo '' >> /home/$MY_USERNAME/README
  5955. echo 'Gogs' >> /home/$MY_USERNAME/README
  5956. echo '====' >> /home/$MY_USERNAME/README
  5957. echo $'Install Steps For First-time Run:' >> /home/$MY_USERNAME/README
  5958. echo $'Leave email service settings empty' >> /home/$MY_USERNAME/README
  5959. echo $'Check "Enable Register Confirmation"' >> /home/$MY_USERNAME/README
  5960. echo $'Check "Enable Mail Notification"' >> /home/$MY_USERNAME/README
  5961. echo '' >> /home/$MY_USERNAME/README
  5962. echo $'If you want to disable new account registrations then append the following:' >> /home/$MY_USERNAME/README
  5963. echo ' [service]' >> /home/$MY_USERNAME/README
  5964. echo ' DISABLE_REGISTRATION = true' >> /home/$MY_USERNAME/README
  5965. echo $'Then restart with:' >> /home/$MY_USERNAME/README
  5966. echo ' systemctl restart gogs' >> /home/$MY_USERNAME/README
  5967. echo '' >> /home/$MY_USERNAME/README
  5968. echo $"Note that there's a usability/security trade-off made here." >> /home/$MY_USERNAME/README
  5969. echo $"In order to allow git clone via http we don't redirect everything" >> /home/$MY_USERNAME/README
  5970. echo $'over https. Instead only critical things such as user login,' >> /home/$MY_USERNAME/README
  5971. echo $'settings and admin are encrypted.' >> /home/$MY_USERNAME/README
  5972. echo $'There are also potential security issues with cloning/pulling/pushing' >> /home/$MY_USERNAME/README
  5973. echo $'code over http, since a determined adversary could inject malware' >> /home/$MY_USERNAME/README
  5974. echo $'into the stream as it passes, so beware.' >> /home/$MY_USERNAME/README
  5975. echo $'If you have a bought domain and a non-self signed cert then you' >> /home/$MY_USERNAME/README
  5976. echo $"should change /etc/nginx/sites-available/$GIT_DOMAIN_NAME to redirect everything over https." >> /home/$MY_USERNAME/README
  5977. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5978. chmod 600 /home/$MY_USERNAME/README
  5979. fi
  5980. create_database gogs "$GOGS_ADMIN_PASSWORD"
  5981. if [ ! -f $GOPATH/src/github.com/gogits/gogs/scripts/mysql.sql ]; then
  5982. echo $'MySql template for Gogs was not found'
  5983. exit 72528
  5984. fi
  5985. mysql -u root --password="$MARIADB_PASSWORD" -D gogs < $GOPATH/src/github.com/gogits/gogs/scripts/mysql.sql
  5986. chmod 600 $GOPATH/src/github.com/gogits/gogs/custom/conf/app.ini
  5987. chown -R git:git /home/git
  5988. echo '[Unit]' > /etc/systemd/system/gogs.service
  5989. echo 'Description=Gogs (Go Git Service)' >> /etc/systemd/system/gogs.service
  5990. echo 'After=syslog.target' >> /etc/systemd/system/gogs.service
  5991. echo 'After=network.target' >> /etc/systemd/system/gogs.service
  5992. echo 'After=mysqld.service' >> /etc/systemd/system/gogs.service
  5993. echo '' >> /etc/systemd/system/gogs.service
  5994. echo '[Service]' >> /etc/systemd/system/gogs.service
  5995. echo '#LimitMEMLOCK=infinity' >> /etc/systemd/system/gogs.service
  5996. echo '#LimitNOFILE=65535' >> /etc/systemd/system/gogs.service
  5997. echo 'Type=simple' >> /etc/systemd/system/gogs.service
  5998. echo 'User=git' >> /etc/systemd/system/gogs.service
  5999. echo 'Group=git' >> /etc/systemd/system/gogs.service
  6000. echo "WorkingDirectory=$GOPATH/src/github.com/gogits/gogs" >> /etc/systemd/system/gogs.service
  6001. echo "ExecStart=$GOPATH/src/github.com/gogits/gogs/gogs web" >> /etc/systemd/system/gogs.service
  6002. echo 'Restart=always' >> /etc/systemd/system/gogs.service
  6003. echo 'RestartSec=10' >> /etc/systemd/system/gogs.service
  6004. echo 'TimeoutStartSec=120' >> /etc/systemd/system/gogs.service
  6005. echo "Environment=\"USER=git\" \"HOME=/home/git\" \"GOPATH=$GOPATH\" \"GVM_ROOT=$GVM_HOME\"" >> /etc/systemd/system/gogs.service
  6006. echo '' >> /etc/systemd/system/gogs.service
  6007. echo '[Install]' >> /etc/systemd/system/gogs.service
  6008. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/gogs.service
  6009. systemctl enable gogs
  6010. systemctl daemon-reload
  6011. systemctl restart gogs
  6012. if [ ! -d /var/www/$GIT_DOMAIN_NAME ]; then
  6013. mkdir /var/www/$GIT_DOMAIN_NAME
  6014. fi
  6015. if [ -d /var/www/$GIT_DOMAIN_NAME/htdocs ]; then
  6016. rm -rf /var/www/$GIT_DOMAIN_NAME/htdocs
  6017. fi
  6018. if [[ $ONION_ONLY == "no" ]]; then
  6019. echo 'server {' > /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6020. echo ' listen 80;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6021. echo " server_name $GIT_DOMAIN_NAME;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6022. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6023. echo " error_log /var/log/nginx/${GIT_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6024. nginx_disable_sniffing $GIT_DOMAIN_NAME
  6025. nginx_limits $GIT_DOMAIN_NAME
  6026. echo ' location / {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6027. echo ' proxy_pass http://localhost:3000;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6028. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6029. echo ' location ^~ /user/ {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6030. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6031. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6032. echo ' location ^~ /admin/ {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6033. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6034. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6035. echo '}' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6036. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6037. echo 'server {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6038. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6039. echo " root /var/www/$GIT_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6040. echo " server_name $GIT_DOMAIN_NAME;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6041. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6042. echo " error_log /var/log/nginx/${GIT_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6043. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6044. nginx_limits $GIT_DOMAIN_NAME '10G'
  6045. nginx_ssl $GIT_DOMAIN_NAME
  6046. nginx_disable_sniffing $GIT_DOMAIN_NAME
  6047. echo ' add_header Strict-Transport-Security max-age=0;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6048. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6049. echo ' location / {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6050. echo ' proxy_pass http://localhost:3000;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6051. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6052. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6053. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6054. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6055. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6056. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6057. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6058. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6059. echo ' allow all;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6060. echo ' log_not_found off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6061. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6062. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6063. echo '}' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6064. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6065. else
  6066. echo -n '' > /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6067. fi
  6068. echo 'server {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6069. echo " listen 127.0.0.1:${GIT_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6070. echo " root /var/www/$GIT_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6071. echo " server_name $GIT_DOMAIN_NAME;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6072. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6073. echo " error_log /var/log/nginx/${GIT_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6074. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6075. nginx_limits $GIT_DOMAIN_NAME '10G'
  6076. nginx_disable_sniffing $GIT_DOMAIN_NAME
  6077. echo ' add_header Strict-Transport-Security max-age=0;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6078. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6079. echo ' location / {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6080. echo ' proxy_pass http://localhost:3000;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6081. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6082. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6083. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6084. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6085. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6086. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6087. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6088. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6089. echo ' allow all;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6090. echo ' log_not_found off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6091. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6092. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6093. echo '}' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  6094. configure_php
  6095. create_site_certificate $GIT_DOMAIN_NAME
  6096. nginx_ensite $GIT_DOMAIN_NAME
  6097. if [ ! -d /var/lib/tor ]; then
  6098. echo $'No Tor installation found. Gogs onion site cannot be configured.'
  6099. exit 877367
  6100. fi
  6101. if ! grep -q "hidden_service_gogs" /etc/tor/torrc; then
  6102. echo 'HiddenServiceDir /var/lib/tor/hidden_service_gogs/' >> /etc/tor/torrc
  6103. echo "HiddenServicePort 80 127.0.0.1:${GIT_ONION_PORT}" >> /etc/tor/torrc
  6104. echo "HiddenServicePort 9418 127.0.0.1:9418" >> /etc/tor/torrc
  6105. echo $'Added onion site for Gogs'
  6106. fi
  6107. systemctl restart tor
  6108. wait_for_onion_service 'gogs'
  6109. GIT_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_gogs/hostname)
  6110. systemctl restart php5-fpm
  6111. systemctl restart nginx
  6112. if ! grep -q "Gogs onion domain" /home/$MY_USERNAME/README; then
  6113. echo "Gogs onion domain: ${GIT_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  6114. echo '' >> /home/$MY_USERNAME/README
  6115. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6116. chmod 600 /home/$MY_USERNAME/README
  6117. fi
  6118. if ! grep -q "Gogs onion domain" $COMPLETION_FILE; then
  6119. echo "Gogs onion domain:${GIT_ONION_HOSTNAME}" >> $COMPLETION_FILE
  6120. fi
  6121. add_ddns_domain $GIT_DOMAIN_NAME
  6122. # obtain the secret key
  6123. GOGS_SECRET_KEY=
  6124. if grep -q "Gogs secret key:" /home/$MY_USERNAME/README; then
  6125. GOGS_SECRET_KEY=$(cat /home/$MY_USERNAME/README | grep "Gogs secret key:" | awk -F ':' '{print $2}' | sed 's/^ *//')
  6126. else
  6127. GOGS_SECRET_KEY="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  6128. echo "Gogs secret key:$GOGS_SECRET_KEY" >> /home/$MY_USERNAME/README
  6129. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6130. fi
  6131. # create the configuration
  6132. GOGS_CONFIG_PATH=/home/git/gvm/pkgsets/go${GO_VERSION}/global/src/github.com/gogits/gogs/custom/conf
  6133. if [ ! -d $GOGS_CONFIG_PATH ]; then
  6134. mkdir -p $GOGS_CONFIG_PATH
  6135. fi
  6136. GOGS_CONFIG_FILE=$GOGS_CONFIG_PATH/app.ini
  6137. echo 'RUN_USER = git' > $GOGS_CONFIG_FILE
  6138. echo 'RUN_MODE = prod' >> $GOGS_CONFIG_FILE
  6139. echo '' >> $GOGS_CONFIG_FILE
  6140. echo '[database]' >> $GOGS_CONFIG_FILE
  6141. echo 'DB_TYPE = mysql' >> $GOGS_CONFIG_FILE
  6142. echo 'HOST = 127.0.0.1:3306' >> $GOGS_CONFIG_FILE
  6143. echo 'NAME = gogs' >> $GOGS_CONFIG_FILE
  6144. echo 'USER = root' >> $GOGS_CONFIG_FILE
  6145. echo "PASSWD = $MARIADB_PASSWORD" >> $GOGS_CONFIG_FILE
  6146. echo 'SSL_MODE = disable' >> $GOGS_CONFIG_FILE
  6147. echo 'PATH = data/gogs.db' >> $GOGS_CONFIG_FILE
  6148. echo '' >> $GOGS_CONFIG_FILE
  6149. echo '[repository]' >> $GOGS_CONFIG_FILE
  6150. echo 'ROOT = /home/git/gogs-repositories' >> $GOGS_CONFIG_FILE
  6151. echo '' >> $GOGS_CONFIG_FILE
  6152. echo '[server]' >> $GOGS_CONFIG_FILE
  6153. if [[ $ONION_ONLY == 'no' ]]; then
  6154. echo "DOMAIN = ${GIT_DOMAIN_NAME}" >> $GOGS_CONFIG_FILE
  6155. else
  6156. echo "DOMAIN = ${GIT_ONION_HOSTNAME}" >> $GOGS_CONFIG_FILE
  6157. fi
  6158. echo 'HTTP_PORT = 3000' >> $GOGS_CONFIG_FILE
  6159. echo "ROOT_URL = http://$GIT_DOMAIN_NAME/" >> $GOGS_CONFIG_FILE
  6160. echo "SSH_PORT = $SSH_PORT" >> $GOGS_CONFIG_FILE
  6161. echo 'SSH_DOMAIN = %(DOMAIN)s' >> $GOGS_CONFIG_FILE
  6162. echo "CERT_FILE = /etc/ssl/certs/${GIT_DOMAIN_NAME}.crt" >> $GOGS_CONFIG_FILE
  6163. echo "KEY_FILE = /etc/ssl/private/${GIT_DOMAIN_NAME}.key" >> $GOGS_CONFIG_FILE
  6164. echo 'DISABLE_ROUTER_LOG = true' >> $GOGS_CONFIG_FILE
  6165. echo '' >> $GOGS_CONFIG_FILE
  6166. echo '[session]' >> $GOGS_CONFIG_FILE
  6167. echo 'PROVIDER = file' >> $GOGS_CONFIG_FILE
  6168. echo '' >> $GOGS_CONFIG_FILE
  6169. echo '[log]' >> $GOGS_CONFIG_FILE
  6170. echo 'MODE = file' >> $GOGS_CONFIG_FILE
  6171. echo 'LEVEL = Info' >> $GOGS_CONFIG_FILE
  6172. echo '' >> $GOGS_CONFIG_FILE
  6173. echo '[security]' >> $GOGS_CONFIG_FILE
  6174. echo 'INSTALL_LOCK = true' >> $GOGS_CONFIG_FILE
  6175. echo "SECRET_KEY = $GOGS_SECRET_KEY" >> $GOGS_CONFIG_FILE
  6176. echo '' >> $GOGS_CONFIG_FILE
  6177. echo '[service]' >> $GOGS_CONFIG_FILE
  6178. echo 'DISABLE_REGISTRATION = false' >> $GOGS_CONFIG_FILE
  6179. echo 'SHOW_REGISTRATION_BUTTON = true' >> $GOGS_CONFIG_FILE
  6180. echo 'REQUIRE_SIGNIN_VIEW = false' >> $GOGS_CONFIG_FILE
  6181. echo 'ENABLE_CAPTCHA = false' >> $GOGS_CONFIG_FILE
  6182. echo '' >> $GOGS_CONFIG_FILE
  6183. echo '[other]' >> $GOGS_CONFIG_FILE
  6184. echo 'SHOW_FOOTER_BRANDING = false' >> $GOGS_CONFIG_FILE
  6185. echo 'SHOW_FOOTER_VERSION = false' >> $GOGS_CONFIG_FILE
  6186. chmod 750 $GOGS_CONFIG_FILE
  6187. chown -R git:git /home/git
  6188. systemctl restart gogs
  6189. if ! grep -q "Gogs domain:" $COMPLETION_FILE; then
  6190. echo "Gogs domain:$GIT_DOMAIN_NAME" >> $COMPLETION_FILE
  6191. fi
  6192. echo 'install_gogs' >> $COMPLETION_FILE
  6193. }
  6194. function tox_avahi {
  6195. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  6196. return
  6197. fi
  6198. if grep -Fxq "tox_avahi" $COMPLETION_FILE; then
  6199. return
  6200. fi
  6201. if [ ! -d /etc/avahi ]; then
  6202. echo $'tox_avahi: avahi is not installed'
  6203. exit 87359
  6204. fi
  6205. # install a command to obtain the Tox ID
  6206. cd $INSTALL_DIR
  6207. git_clone $TOXID_REPO $INSTALL_DIR/toxid
  6208. if [ ! -d $INSTALL_DIR/toxid ]; then
  6209. exit 63921
  6210. fi
  6211. cd $INSTALL_DIR/toxid
  6212. make
  6213. if [ ! "$?" = "0" ]; then
  6214. exit 58432
  6215. fi
  6216. make install
  6217. toxavahi
  6218. # publish regularly
  6219. if ! grep -q "toxavahi" /etc/crontab; then
  6220. echo "* * * * * root toxavahi > /dev/null" >> /etc/crontab
  6221. fi
  6222. systemctl restart avahi-daemon
  6223. echo 'tox_avahi' >> $COMPLETION_FILE
  6224. }
  6225. function install_tox_node {
  6226. 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
  6227. return
  6228. fi
  6229. # update to the next commit
  6230. set_repo_commit $INSTALL_DIR/toxcore "toxcore commit" "$TOXCORE_COMMIT" $TOXCORE_REPO
  6231. if grep -Fxq "install_tox_node" $COMPLETION_FILE; then
  6232. return
  6233. fi
  6234. ${PROJECT_NAME}-mesh-install -f tox_node
  6235. if [ ! "$?" = "0" ]; then
  6236. echo $'Failed to install tox node'
  6237. exit 26778
  6238. fi
  6239. TOX_ONION_HOSTNAME=$(add_onion_service tox ${TOX_PORT} ${TOX_PORT})
  6240. if ! grep -q "tox onion domain" $COMPLETION_FILE; then
  6241. echo "tox onion domain:${TOX_ONION_HOSTNAME}" >> $COMPLETION_FILE
  6242. else
  6243. sed -i "s|tox onion domain.*|tox onion domain:${TOX_ONION_HOSTNAME}|g" $COMPLETION_FILE
  6244. fi
  6245. systemctl restart tox-bootstrapd.service
  6246. TOX_PUBLIC_KEY=$(cat /var/log/syslog | grep tox | grep "Public Key" | awk -F ' ' '{print $8}' | tail -1)
  6247. if [ ${#TOX_PUBLIC_KEY} -lt 30 ]; then
  6248. echo $'Could not obtain the tox node public key'
  6249. exit 6529
  6250. fi
  6251. # save the public key for later reference
  6252. echo "$TOX_PUBLIC_KEY" > $TOX_BOOTSTRAP_ID_FILE
  6253. configure_firewall_for_tox
  6254. if ! grep -q $"Your Tox node public key is" /home/$MY_USERNAME/README; then
  6255. echo '' >> /home/$MY_USERNAME/README
  6256. echo '' >> /home/$MY_USERNAME/README
  6257. echo 'Tox' >> /home/$MY_USERNAME/README
  6258. echo '===' >> /home/$MY_USERNAME/README
  6259. echo $"tox onion domain: ${TOX_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  6260. echo $"Your Tox node public key is: $TOX_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  6261. echo $'In the Toxic client you can connect to it with:' >> /home/$MY_USERNAME/README
  6262. echo " /connect $DEFAULT_DOMAIN_NAME.local $TOX_PORT $TOX_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  6263. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6264. chmod 600 /home/$MY_USERNAME/README
  6265. fi
  6266. echo 'install_tox_node' >> $COMPLETION_FILE
  6267. }
  6268. function install_tox_client {
  6269. 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
  6270. return
  6271. fi
  6272. # update to the next commit
  6273. set_repo_commit $INSTALL_DIR/toxic "Toxic commit" "$TOXIC_COMMIT" $TOXIC_REPO
  6274. if grep -Fxq "install_tox_client" $COMPLETION_FILE; then
  6275. return
  6276. fi
  6277. ${PROJECT_NAME}-mesh-install -f tox_client
  6278. if [ ! "$?" = "0" ]; then
  6279. echo $'Could not install Tox client'
  6280. exit 67248
  6281. fi
  6282. # initial setup of username
  6283. #su -c "echo 'n
  6284. #/nick $MY_USERNAME
  6285. #/exit
  6286. #' | $TOXIC_FILE -d" - $MY_USERNAME
  6287. echo 'install_tox_client' >> $COMPLETION_FILE
  6288. }
  6289. function update_prosody_modules {
  6290. if [ ! -d $INSTALL_DIR/prosody-modules ]; then
  6291. return
  6292. fi
  6293. if [ ! -d /usr/lib/prosody ]; then
  6294. return
  6295. fi
  6296. cd $INSTALL_DIR/prosody-modules
  6297. hg pull
  6298. hg update
  6299. # support onion addresses
  6300. if [ -f $INSTALL_DIR/prosody-modules/mod_onions/mod_onions.lua ]; then
  6301. cp $INSTALL_DIR/prosody-modules/mod_onions/mod_onions.lua /usr/lib/prosody/modules/mod_onions.lua
  6302. fi
  6303. # message archive management
  6304. # https://modules.prosody.im/mod_mam.html
  6305. # Allows you to download your previous messages onto a new client
  6306. # This only applies if you are not using forward secret crypto
  6307. # such as OTR or OMEMO (eg. OpenPGP)
  6308. if [ -d $INSTALL_DIR/prosody-modules/mod_mam ]; then
  6309. cp $INSTALL_DIR/prosody-modules/mod_mam/*.lua /usr/lib/prosody/modules
  6310. fi
  6311. # Client State Indication
  6312. # Notifies the server if the app is in the background or not
  6313. if [ -d $INSTALL_DIR/prosody-modules/mod_csi ]; then
  6314. cp $INSTALL_DIR/prosody-modules/mod_csi/*.lua /usr/lib/prosody/modules
  6315. fi
  6316. # Message Carbons
  6317. # Ensures all messages get delivered to all clients (if you have a mobile and desktop client)
  6318. if [ -d $INSTALL_DIR/prosody-modules/mod_carbons ]; then
  6319. cp $INSTALL_DIR/prosody-modules/mod_carbons/*.lua /usr/lib/prosody/modules
  6320. fi
  6321. # Stream management
  6322. # Helps mobile apps recover when a device switches networks.
  6323. if [ -d $INSTALL_DIR/prosody-modules/mod_smacks ]; then
  6324. cp $INSTALL_DIR/prosody-modules/mod_smacks/*.lua /usr/lib/prosody/modules
  6325. fi
  6326. if [ -d $INSTALL_DIR/prosody-modules/mod_smacks_offline ]; then
  6327. cp $INSTALL_DIR/prosody-modules/mod_smacks_offline/*.lua /usr/lib/prosody/modules
  6328. fi
  6329. }
  6330. function install_xmpp {
  6331. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  6332. return
  6333. fi
  6334. update_prosody_modules
  6335. if grep -Fxq "install_xmpp" $COMPLETION_FILE; then
  6336. return
  6337. fi
  6338. apt-get -y install lua-sec lua-bitop
  6339. apt-get -y install prosody prosody-modules mercurial
  6340. if [ ! -d /etc/prosody ]; then
  6341. echo $"ERROR: prosody does not appear to have installed. $CHECK_MESSAGE"
  6342. exit 52
  6343. fi
  6344. # obtain the prosody modules
  6345. cd $INSTALL_DIR
  6346. hg clone https://hg.prosody.im/prosody-modules/ prosody-modules
  6347. if [ ! -d $INSTALL_DIR/prosody-modules/mod_onions ]; then
  6348. echo $'mod_onions prosody module could not be found'
  6349. exit 73254
  6350. fi
  6351. # install the onions module
  6352. update_prosody_modules
  6353. if [ ! -f /usr/lib/prosody/modules/mod_onions.lua ]; then
  6354. echo $'mod_onions.lua could not be copied to the prosody modules directory'
  6355. exit 63952
  6356. fi
  6357. # create a certificate
  6358. if [ ! -f /etc/ssl/certs/xmpp.dhparam ]; then
  6359. ${PROJECT_NAME}-addcert -h xmpp --dhkey $DH_KEYLENGTH
  6360. check_certificates xmpp
  6361. fi
  6362. chown prosody:prosody /etc/ssl/private/xmpp.key
  6363. chown prosody:prosody /etc/ssl/certs/xmpp.*
  6364. cp -a /etc/prosody/conf.avail/example.com.cfg.lua /etc/prosody/conf.avail/xmpp.cfg.lua
  6365. sed -i 's|/etc/prosody/certs/example.com.key|/etc/ssl/private/xmpp.key|g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6366. sed -i 's|/etc/prosody/certs/example.com.crt|/etc/ssl/certs/xmpp.crt|g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6367. if ! grep -q "xmpp.dhparam" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6368. sed -i '/certificate =/a\ dhparam = "/etc/ssl/certs/xmpp.dhparam";' /etc/prosody/conf.avail/xmpp.cfg.lua
  6369. fi
  6370. if ! grep -q 'options = {"no_sslv2", "no_sslv3" }' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6371. sed -i '/certificate =/a\ options = {"no_sslv2", "no_sslv3" };' /etc/prosody/conf.avail/xmpp.cfg.lua
  6372. fi
  6373. if ! grep -q 'ciphers =' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6374. sed -i "/certificate =/a\ ciphers = $XMPP_CIPHERS;" /etc/prosody/conf.avail/xmpp.cfg.lua
  6375. fi
  6376. if ! grep -q 'depth = "1";' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6377. sed -i '/certificate =/a\ depth = "1";' /etc/prosody/conf.avail/xmpp.cfg.lua
  6378. fi
  6379. if ! grep -q 'curve =' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6380. sed -i "/certificate =/a\ curve = $XMPP_ECC_CURVE;" /etc/prosody/conf.avail/xmpp.cfg.lua
  6381. fi
  6382. sed -i "s/example.com/$DEFAULT_DOMAIN_NAME/g" /etc/prosody/conf.avail/xmpp.cfg.lua
  6383. sed -i 's/enabled = false -- Remove this line to enable this host//g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6384. if ! grep -q "modules_enabled" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6385. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6386. echo 'modules_enabled = {' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6387. echo ' "bosh"; -- Enable mod_bosh' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6388. echo ' "tls"; -- Enable mod_tls' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6389. echo ' "saslauth"; -- Enable mod_saslauth' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6390. echo ' "onions"; -- Enable chat via onion service' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6391. echo ' "mam"; -- Message archive management' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6392. echo ' "csi"; -- Client state indication' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6393. echo ' "carbons"; -- Message carbons' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6394. echo ' "smacks"; -- Stream management' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6395. echo ' "smacks_offline"; -- Stream management' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6396. echo ' "pep"; -- Personal Eventing Protocol (to support OMEMO)' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6397. echo '}' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6398. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6399. echo 'c2s_require_encryption = true' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6400. echo 's2s_require_encryption = true' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6401. echo 'allow_unencrypted_plain_auth = false' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6402. fi
  6403. ln -sf /etc/prosody/conf.avail/xmpp.cfg.lua /etc/prosody/conf.d/xmpp.cfg.lua
  6404. sed -i 's|/etc/prosody/certs/localhost.key|/etc/ssl/private/xmpp.key|g' /etc/prosody/prosody.cfg.lua
  6405. sed -i 's|/etc/prosody/certs/localhost.crt|/etc/ssl/certs/xmpp.crt|g' /etc/prosody/prosody.cfg.lua
  6406. if ! grep -q "xmpp.dhparam" /etc/prosody/prosody.cfg.lua; then
  6407. sed -i '/certificate =/a\ dhparam = "/etc/ssl/certs/xmpp.dhparam";' /etc/prosody/prosody.cfg.lua
  6408. fi
  6409. if ! grep -q 'options = {"no_sslv2", "no_sslv3" }' /etc/prosody/prosody.cfg.lua; then
  6410. sed -i '/certificate =/a\ options = {"no_sslv2", "no_sslv3" };' /etc/prosody/prosody.cfg.lua
  6411. fi
  6412. if ! grep -q 'ciphers =' /etc/prosody/prosody.cfg.lua; then
  6413. sed -i "/certificate =/a\ ciphers = $XMPP_CIPHERS;" /etc/prosody/prosody.cfg.lua
  6414. fi
  6415. if ! grep -q 'depth = "1";' /etc/prosody/prosody.cfg.lua; then
  6416. sed -i '/certificate =/a\ depth = "1";' /etc/prosody/prosody.cfg.lua
  6417. fi
  6418. if ! grep -q 'curve =' /etc/prosody/prosody.cfg.lua; then
  6419. sed -i "/certificate =/a\ curve = $XMPP_ECC_CURVE;" /etc/prosody/prosody.cfg.lua
  6420. fi
  6421. sed -i 's/c2s_require_encryption = false/c2s_require_encryption = true/g' /etc/prosody/prosody.cfg.lua
  6422. if ! grep -q "s2s_require_encryption" /etc/prosody/prosody.cfg.lua; then
  6423. sed -i '/c2s_require_encryption/a\s2s_require_encryption = true' /etc/prosody/prosody.cfg.lua
  6424. fi
  6425. if ! grep -q "allow_unencrypted_plain_auth" /etc/prosody/prosody.cfg.lua; then
  6426. echo 'allow_unencrypted_plain_auth = false' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6427. fi
  6428. sed -i 's/--"bosh";/"bosh";/g' /etc/prosody/prosody.cfg.lua
  6429. sed -i 's/authentication = "internal_plain"/authentication = "internal_hashed"/g' /etc/prosody/prosody.cfg.lua
  6430. sed -i 's/enabled = false -- Remove this line to enable this host//g' /etc/prosody/prosody.cfg.lua
  6431. sed -i 's|key = "/etc/prosody/certs/example.com.key"|key = "/etc/ssl/private/xmpp.key"|g' /etc/prosody/prosody.cfg.lua
  6432. sed -i 's|certificate = "/etc/prosody/certs/example.com.crt"|certificate = "/etc/ssl/certs/xmpp.crt"|g' /etc/prosody/prosody.cfg.lua
  6433. sed -i "s/example.com/$DEFAULT_DOMAIN_NAME/g" /etc/prosody/prosody.cfg.lua
  6434. systemctl restart prosody
  6435. touch /home/$MY_USERNAME/README
  6436. if [ ! -d /var/lib/tor ]; then
  6437. echo $'No Tor installation found. XMPP onion site cannot be configured.'
  6438. exit 877367
  6439. fi
  6440. if ! grep -q "hidden_service_xmpp" /etc/tor/torrc; then
  6441. echo 'HiddenServiceDir /var/lib/tor/hidden_service_xmpp/' >> /etc/tor/torrc
  6442. echo "HiddenServicePort 5222 127.0.0.1:5222" >> /etc/tor/torrc
  6443. echo "HiddenServicePort 5269 127.0.0.1:5269" >> /etc/tor/torrc
  6444. echo $'Added onion site for XMPP chat'
  6445. fi
  6446. systemctl restart tor
  6447. wait_for_onion_service 'xmpp'
  6448. if [ ! -f /var/lib/tor/hidden_service_xmpp/hostname ]; then
  6449. echo $'XMPP onion site hostname not found'
  6450. exit 65349
  6451. fi
  6452. XMPP_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_xmpp/hostname)
  6453. if ! grep -q "${XMPP_ONION_HOSTNAME}" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6454. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6455. echo "VirtualHost \"${XMPP_ONION_HOSTNAME}\"" >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6456. echo ' modules_enabled = { "onions" };' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6457. fi
  6458. if ! grep -q "XMPP onion domain" $COMPLETION_FILE; then
  6459. echo "XMPP onion domain:${XMPP_ONION_HOSTNAME}" >> $COMPLETION_FILE
  6460. else
  6461. sed -i "s|XMPP onion domain.*|XMPP onion domain:${XMPP_ONION_HOSTNAME}|g" $COMPLETION_FILE
  6462. fi
  6463. if ! grep -q "Your XMPP password is" /home/$MY_USERNAME/README; then
  6464. if [ ${#XMPP_PASSWORD} -lt 8 ]; then
  6465. if [ -f $IMAGE_PASSWORD_FILE ]; then
  6466. XMPP_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  6467. else
  6468. XMPP_PASSWORD="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  6469. fi
  6470. fi
  6471. prosodyctl register $MY_USERNAME $DEFAULT_DOMAIN_NAME $XMPP_PASSWORD
  6472. echo '' >> /home/$MY_USERNAME/README
  6473. echo '' >> /home/$MY_USERNAME/README
  6474. echo $'XMPP' >> /home/$MY_USERNAME/README
  6475. echo '====' >> /home/$MY_USERNAME/README
  6476. echo $"XMPP onion domain: ${XMPP_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  6477. echo $"Your XMPP password is: $XMPP_PASSWORD" >> /home/$MY_USERNAME/README
  6478. echo $'You can change it with: ' >> /home/$MY_USERNAME/README
  6479. echo '' >> /home/$MY_USERNAME/README
  6480. echo " prosodyctl passwd $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/README
  6481. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6482. chmod 600 /home/$MY_USERNAME/README
  6483. fi
  6484. echo 'install_xmpp' >> $COMPLETION_FILE
  6485. }
  6486. function install_xmpp_client {
  6487. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  6488. return
  6489. fi
  6490. if grep -Fxq "install_xmpp_client" $COMPLETION_FILE; then
  6491. return
  6492. fi
  6493. apt-get -y install profanity
  6494. XMPP_CLIENT_DIR=/home/$MY_USERNAME/.local/share/profanity
  6495. XMPP_CLIENT_ACCOUNTS=$XMPP_CLIENT_DIR/accounts
  6496. if [ ! -d $XMPP_CLIENT_DIR ]; then
  6497. mkdir -p $XMPP_CLIENT_DIR
  6498. fi
  6499. if [[ $ONION_ONLY == 'no' ]]; then
  6500. echo "[${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}]" > $XMPP_CLIENT_ACCOUNTS
  6501. echo 'enabled=true' >> $XMPP_CLIENT_ACCOUNTS
  6502. echo "jid=${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}" >> $XMPP_CLIENT_ACCOUNTS
  6503. echo 'resource=profanity' >> $XMPP_CLIENT_ACCOUNTS
  6504. echo "muc.service=conference.${DEFAULT_DOMAIN_NAME}" >> $XMPP_CLIENT_ACCOUNTS
  6505. echo "muc.nick=${MY_USERNAME}" >> $XMPP_CLIENT_ACCOUNTS
  6506. echo 'presence.last=online' >> $XMPP_CLIENT_ACCOUNTS
  6507. echo 'presence.login=online' >> $XMPP_CLIENT_ACCOUNTS
  6508. echo 'priority.online=0' >> $XMPP_CLIENT_ACCOUNTS
  6509. echo 'priority.chat=0' >> $XMPP_CLIENT_ACCOUNTS
  6510. echo 'priority.away=0' >> $XMPP_CLIENT_ACCOUNTS
  6511. echo 'priority.xa=0' >> $XMPP_CLIENT_ACCOUNTS
  6512. echo 'priority.dnd=0' >> $XMPP_CLIENT_ACCOUNTS
  6513. if [ ${#XMPP_PASSWORD} -gt 2 ]; then
  6514. echo "password=$XMPP_PASSWORD" >> $XMPP_CLIENT_ACCOUNTS
  6515. fi
  6516. fi
  6517. if [ -f /var/lib/tor/hidden_service_xmpp/hostname ]; then
  6518. XMPP_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_xmpp/hostname)
  6519. echo "[${MY_USERNAME}@${XMPP_ONION_HOSTNAME}]" >> $XMPP_CLIENT_ACCOUNTS
  6520. if [[ $ONION_ONLY == 'no' ]]; then
  6521. echo 'enabled=false' >> $XMPP_CLIENT_ACCOUNTS
  6522. else
  6523. echo 'enabled=true' >> $XMPP_CLIENT_ACCOUNTS
  6524. fi
  6525. echo "jid=${MY_USERNAME}@${XMPP_ONION_HOSTNAME}" >> $XMPP_CLIENT_ACCOUNTS
  6526. echo 'resource=profanity' >> $XMPP_CLIENT_ACCOUNTS
  6527. echo "muc.service=conference.${XMPP_ONION_HOSTNAME}" >> $XMPP_CLIENT_ACCOUNTS
  6528. echo "muc.nick=${MY_USERNAME}" >> $XMPP_CLIENT_ACCOUNTS
  6529. echo 'presence.last=online' >> $XMPP_CLIENT_ACCOUNTS
  6530. echo 'presence.login=online' >> $XMPP_CLIENT_ACCOUNTS
  6531. echo 'priority.online=0' >> $XMPP_CLIENT_ACCOUNTS
  6532. echo 'priority.chat=0' >> $XMPP_CLIENT_ACCOUNTS
  6533. echo 'priority.away=0' >> $XMPP_CLIENT_ACCOUNTS
  6534. echo 'priority.xa=0' >> $XMPP_CLIENT_ACCOUNTS
  6535. echo 'priority.dnd=0' >> $XMPP_CLIENT_ACCOUNTS
  6536. if [ ${#XMPP_PASSWORD} -gt 2 ]; then
  6537. echo "password=$XMPP_PASSWORD" >> $XMPP_CLIENT_ACCOUNTS
  6538. fi
  6539. fi
  6540. if [ ! -d /home/$MY_USERNAME/.config/profanity ]; then
  6541. mkdir /home/$MY_USERNAME/.config/profanity
  6542. fi
  6543. echo '[connection]' > /home/$MY_USERNAME/.config/profanity/profrc
  6544. echo "account=${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}" >> /home/$MY_USERNAME/.config/profanity/profrc
  6545. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.local
  6546. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.config
  6547. echo 'install_xmpp_client' >> $COMPLETION_FILE
  6548. }
  6549. function install_watchdog_script {
  6550. if grep -Fxq "install_watchdog_script" $COMPLETION_FILE; then
  6551. return
  6552. fi
  6553. echo '#!/bin/bash' > /usr/bin/$WATCHDOG_SCRIPT_NAME
  6554. echo 'LOGFILE=/var/log/keepon.log' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6555. echo 'CURRENT_DATE=$(date)' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6556. # application specific stuff is added later
  6557. chmod +x /usr/bin/$WATCHDOG_SCRIPT_NAME
  6558. if ! grep -q "/usr/bin/$WATCHDOG_SCRIPT_NAME" /etc/crontab; then
  6559. echo "* * * * * root /usr/bin/$WATCHDOG_SCRIPT_NAME" >> /etc/crontab
  6560. fi
  6561. echo 'install_watchdog_script' >> $COMPLETION_FILE
  6562. }
  6563. function install_irc_client {
  6564. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  6565. return
  6566. fi
  6567. if grep -Fxq "install_irc_client" $COMPLETION_FILE; then
  6568. return
  6569. fi
  6570. apt-get -y install irssi
  6571. if [ ! -d /home/$MY_USERNAME/.irssi ]; then
  6572. mkdir /home/$MY_USERNAME/.irssi
  6573. fi
  6574. echo 'servers = (' > /home/$MY_USERNAME/.irssi/config
  6575. echo ' {' >> /home/$MY_USERNAME/.irssi/config
  6576. echo ' address = "chat.freenode.net";' >> /home/$MY_USERNAME/.irssi/config
  6577. echo ' chatnet = "Freenode";' >> /home/$MY_USERNAME/.irssi/config
  6578. echo ' port = "6667";' >> /home/$MY_USERNAME/.irssi/config
  6579. echo ' autoconnect = "no";' >> /home/$MY_USERNAME/.irssi/config
  6580. echo ' },' >> /home/$MY_USERNAME/.irssi/config
  6581. echo ' {' >> /home/$MY_USERNAME/.irssi/config
  6582. echo ' address = "irc.oftc.net";' >> /home/$MY_USERNAME/.irssi/config
  6583. echo ' chatnet = "OFTC";' >> /home/$MY_USERNAME/.irssi/config
  6584. echo ' port = "6667";' >> /home/$MY_USERNAME/.irssi/config
  6585. echo ' autoconnect = "yes";' >> /home/$MY_USERNAME/.irssi/config
  6586. echo ' },' >> /home/$MY_USERNAME/.irssi/config
  6587. echo ' {' >> /home/$MY_USERNAME/.irssi/config
  6588. echo " address = \"127.0.0.1\";" >> /home/$MY_USERNAME/.irssi/config
  6589. if [[ $ONION_ONLY == 'no' ]]; then
  6590. echo " port = \"${IRC_PORT}\";" >> /home/$MY_USERNAME/.irssi/config
  6591. echo ' use_ssl = "yes";' >> /home/$MY_USERNAME/.irssi/config
  6592. else
  6593. IRC_ONION_HOSTNAME=$(cat $COMPLETION_FILE | grep "IRC onion domain" | awk -F ':' '{print $2}')
  6594. echo " port = \"${IRC_ONION_PORT}\";" >> /home/$MY_USERNAME/.irssi/config
  6595. echo ' use_ssl = "no";' >> /home/$MY_USERNAME/.irssi/config
  6596. fi
  6597. echo ' chatnet = "Freedombone";' >> /home/$MY_USERNAME/.irssi/config
  6598. echo ' ssl_verify = "no";' >> /home/$MY_USERNAME/.irssi/config
  6599. echo ' autoconnect = "yes";' >> /home/$MY_USERNAME/.irssi/config
  6600. if [ $IRC_PASSWORD ]; then
  6601. echo " password = \"${IRC_PASSWORD}\";" >> /home/$MY_USERNAME/.irssi/config
  6602. fi
  6603. echo ' }' >> /home/$MY_USERNAME/.irssi/config
  6604. echo ');' >> /home/$MY_USERNAME/.irssi/config
  6605. echo '' >> /home/$MY_USERNAME/.irssi/config
  6606. echo 'chatnets = {' >> /home/$MY_USERNAME/.irssi/config
  6607. echo ' Freedombone = {' >> /home/$MY_USERNAME/.irssi/config
  6608. echo ' type = "IRC";' >> /home/$MY_USERNAME/.irssi/config
  6609. echo ' max_kicks = "1";' >> /home/$MY_USERNAME/.irssi/config
  6610. echo ' max_msgs = "4";' >> /home/$MY_USERNAME/.irssi/config
  6611. echo ' max_whois = "1";' >> /home/$MY_USERNAME/.irssi/config
  6612. echo ' };' >> /home/$MY_USERNAME/.irssi/config
  6613. echo ' Freenode = {' >> /home/$MY_USERNAME/.irssi/config
  6614. echo ' type = "IRC";' >> /home/$MY_USERNAME/.irssi/config
  6615. echo ' max_kicks = "1";' >> /home/$MY_USERNAME/.irssi/config
  6616. echo ' max_msgs = "4";' >> /home/$MY_USERNAME/.irssi/config
  6617. echo ' max_whois = "1";' >> /home/$MY_USERNAME/.irssi/config
  6618. echo ' };' >> /home/$MY_USERNAME/.irssi/config
  6619. echo ' OFTC = {' >> /home/$MY_USERNAME/.irssi/config
  6620. echo ' type = "IRC";' >> /home/$MY_USERNAME/.irssi/config
  6621. echo ' max_kicks = "1";' >> /home/$MY_USERNAME/.irssi/config
  6622. echo ' max_msgs = "1";' >> /home/$MY_USERNAME/.irssi/config
  6623. echo ' max_whois = "1";' >> /home/$MY_USERNAME/.irssi/config
  6624. echo ' };' >> /home/$MY_USERNAME/.irssi/config
  6625. echo '};' >> /home/$MY_USERNAME/.irssi/config
  6626. echo '' >> /home/$MY_USERNAME/.irssi/config
  6627. echo 'channels = (' >> /home/$MY_USERNAME/.irssi/config
  6628. echo ' { name = "#freedombone"; chatnet = "Freedombone"; autojoin = "Yes"; },' >> /home/$MY_USERNAME/.irssi/config
  6629. echo ');' >> /home/$MY_USERNAME/.irssi/config
  6630. echo '' >> /home/$MY_USERNAME/.irssi/config
  6631. echo 'settings = {' >> /home/$MY_USERNAME/.irssi/config
  6632. echo " core = { real_name = \"$MY_NAME\"; user_name = \"$MY_USERNAME\"; nick = \"$MY_USERNAME\"; };" >> /home/$MY_USERNAME/.irssi/config
  6633. echo ' "fe-text" = { actlist_sort = "refnum"; };' >> /home/$MY_USERNAME/.irssi/config
  6634. echo '};' >> /home/$MY_USERNAME/.irssi/config
  6635. echo 'ignores = ( { level = "CTCPS"; } );' >> /home/$MY_USERNAME/.irssi/config
  6636. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.irssi
  6637. echo 'install_irc_client' >> $COMPLETION_FILE
  6638. }
  6639. function install_irc_server {
  6640. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  6641. return
  6642. fi
  6643. if grep -Fxq "install_irc_server" $COMPLETION_FILE; then
  6644. return
  6645. fi
  6646. apt-get -y install ngircd
  6647. if [ ! -d /etc/ngircd ]; then
  6648. echo $"ERROR: ngircd does not appear to have installed. $CHECK_MESSAGE"
  6649. exit 53
  6650. fi
  6651. if [ ! -f /etc/ssl/certs/ngircd.dhparam ]; then
  6652. ${PROJECT_NAME}-addcert -h ngircd --dhkey $DH_KEYLENGTH
  6653. check_certificates ngircd
  6654. fi
  6655. DEFAULTDOMAIN=$DEFAULT_DOMAIN_NAME
  6656. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  6657. DEFAULTDOMAIN="${DEFAULT_DOMAIN_NAME}.local"
  6658. fi
  6659. # create a login password if needed
  6660. if [ ! $IRC_PASSWORD ]; then
  6661. IRC_PASSWORD="$(openssl rand -base64 32 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  6662. fi
  6663. echo '**************************************************' > /etc/ngircd/motd
  6664. echo $'* F R E E D O M B O N E I R C *' >> /etc/ngircd/motd
  6665. echo '* *' >> /etc/ngircd/motd
  6666. echo $'* Freedom in the Cloud *' >> /etc/ngircd/motd
  6667. echo '**************************************************' >> /etc/ngircd/motd
  6668. sed -i 's|MotdFile = /etc/ngircd/ngircd.motd|MotdFile = /etc/ngircd/motd|g' /etc/ngircd/ngircd.conf
  6669. sed -i "s/irc@irc.example.com/$MY_EMAIL_ADDRESS/g" /etc/ngircd/ngircd.conf
  6670. sed -i "s/irc.example.net/$DEFAULTDOMAIN/g" /etc/ngircd/ngircd.conf
  6671. sed -i "s|Yet another IRC Server running on Debian GNU/Linux|IRC Server of $DEFAULTDOMAIN|g" /etc/ngircd/ngircd.conf
  6672. sed -i 's/;Password = wealllikedebian/Password =/g' /etc/ngircd/ngircd.conf
  6673. sed -i 's|;CertFile = /etc/ssl/certs/server.crt|CertFile = /etc/ssl/certs/ngircd.crt|g' /etc/ngircd/ngircd.conf
  6674. sed -i 's|;DHFile = /etc/ngircd/dhparams.pem|DHFile = /etc/ssl/certs/ngircd.dhparam|g' /etc/ngircd/ngircd.conf
  6675. sed -i 's|;KeyFile = /etc/ssl/private/server.key|KeyFile = /etc/ssl/private/ngircd.key|g' /etc/ngircd/ngircd.conf
  6676. sed -i "s/;Ports =.*/Ports = $IRC_PORT/1" /etc/ngircd/ngircd.conf
  6677. sed -i "s/;Ports =.*/Ports = $IRC_PORT/2" /etc/ngircd/ngircd.conf
  6678. sed -i "s/;Name = #ngircd/Name = #${PROJECT_NAME}/g" /etc/ngircd/ngircd.conf
  6679. sed -i "s/;Topic = Our ngircd testing channel/Topic = ${PROJECT_NAME} chat channel/g" /etc/ngircd/ngircd.conf
  6680. sed -i 's/;MaxUsers = 23/MaxUsers = 23/g' /etc/ngircd/ngircd.conf
  6681. sed -i "s|;KeyFile = /etc/ngircd/#chan.key|KeyFile = /etc/ngircd/#${PROJECT_NAME}.key|g" /etc/ngircd/ngircd.conf
  6682. sed -i "s/;CloakHost = cloaked.host/CloakHost = ${PROJECT_NAME}/g" /etc/ngircd/ngircd.conf
  6683. IRC_SALT="$(openssl rand -base64 32 | cut -c1-30)"
  6684. if [ -f $IMAGE_PASSWORD_FILE ]; then
  6685. IRC_OPERATOR_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  6686. else
  6687. IRC_OPERATOR_PASSWORD="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  6688. fi
  6689. sed -i "s|;CloakHostSalt = abcdefghijklmnopqrstuvwxyz|CloakHostSalt = $IRC_SALT|g" /etc/ngircd/ngircd.conf
  6690. sed -i 's/;ConnectIPv4 = yes/ConnectIPv4 = yes/g' /etc/ngircd/ngircd.conf
  6691. sed -i 's/;MorePrivacy = no/MorePrivacy = yes/g' /etc/ngircd/ngircd.conf
  6692. sed -i 's/;RequireAuthPing = no/RequireAuthPing = no/g' /etc/ngircd/ngircd.conf
  6693. sed -i "s/;Name = TheOper/Name = $MY_USERNAME/g" /etc/ngircd/ngircd.conf
  6694. sed -i "s/;Password = ThePwd/Password = $IRC_OPERATOR_PASSWORD/g" /etc/ngircd/ngircd.conf
  6695. sed -i 's|;Listen =.*|Listen = 0.0.0.0,0.0.0.0:9050,127.0.0.1,127.0.0.1:9050|g' /etc/ngircd/ngircd.conf
  6696. if [ $IRC_PASSWORD ]; then
  6697. sed -i "0,/RE/s/Password =.*/Password =$IRC_PASSWORD/" /etc/ngircd/ngircd.conf
  6698. fi
  6699. # If we are on a mesh then DNS is not available
  6700. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  6701. sed -i "s/;DNS =.*/DNS = no/g" /etc/ngircd/ngircd.conf
  6702. fi
  6703. # upgrade a cypher
  6704. sed -i 's|SECURE128|SECURE256|g' /etc/ngircd/ngircd.conf
  6705. mkdir /var/run/ircd
  6706. chown -R irc:irc /var/run/ircd
  6707. mkdir /var/run/ngircd
  6708. touch /var/run/ngircd/ngircd.pid
  6709. chown -R irc:irc /var/run/ngircd
  6710. IRC_ONION_HOSTNAME=$(add_onion_service irc ${IRC_PORT} ${IRC_ONION_PORT})
  6711. if ! grep -q $"IRC onion domain" $COMPLETION_FILE; then
  6712. echo "IRC onion domain:$IRC_ONION_HOSTNAME" >> $COMPLETION_FILE
  6713. fi
  6714. systemctl restart ngircd
  6715. # keep the daemon running
  6716. echo '' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6717. echo '# keep irc daemon running' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6718. echo 'IRC_RUNNING=$(pgrep ngircd > /dev/null && echo Running)' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6719. echo 'if [ ! $IRC_RUNNING ]; then' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6720. echo ' systemctl start ngircd' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6721. echo ' echo -n $CURRENT_DATE >> $LOGFILE' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6722. echo ' echo " IRC daemon restarted" >> $LOGFILE' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6723. echo 'fi' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6724. if ! grep -q $"IRC Server" /home/$MY_USERNAME/README; then
  6725. echo '' >> /home/$MY_USERNAME/README
  6726. echo '' >> /home/$MY_USERNAME/README
  6727. echo $'IRC Server' >> /home/$MY_USERNAME/README
  6728. echo '==========' >> /home/$MY_USERNAME/README
  6729. echo $'To connect to your IRC server in irssi:' >> /home/$MY_USERNAME/README
  6730. echo '' >> /home/$MY_USERNAME/README
  6731. if [[ $ONION_ONLY != 'yes' ]]; then
  6732. echo " irssi" >> /home/$MY_USERNAME/README
  6733. echo " /server add -auto -ssl $DEFAULTDOMAIN $IRC_PORT" >> /home/$MY_USERNAME/README
  6734. echo " /connect $DEFAULT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  6735. else
  6736. echo " usetorwith irssi" >> /home/$MY_USERNAME/README
  6737. echo " /server add -auto $IRC_ONION_HOSTNAME $IRC_PORT" >> /home/$MY_USERNAME/README
  6738. echo " /connect $IRC_ONION_HOSTNAME" >> /home/$MY_USERNAME/README
  6739. fi
  6740. echo " /join #${PROJECT_NAME}" >> /home/$MY_USERNAME/README
  6741. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6742. chmod 600 /home/$MY_USERNAME/README
  6743. fi
  6744. echo 'install_irc_server' >> $COMPLETION_FILE
  6745. }
  6746. function get_wiki_admin_password {
  6747. if [ -f /home/$MY_USERNAME/README ]; then
  6748. if grep -q "Wiki password" /home/$MY_USERNAME/README; then
  6749. WIKI_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Wiki password:" | awk -F ':' '{print $2}' | sed 's/^ *//')
  6750. fi
  6751. fi
  6752. }
  6753. function install_wiki {
  6754. 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" || $SYSTEM_TYPE == "$VARIANT_MASH" ]]; then
  6755. return
  6756. fi
  6757. if grep -Fxq "install_wiki" $COMPLETION_FILE; then
  6758. return
  6759. fi
  6760. if [ ! $WIKI_DOMAIN_NAME ]; then
  6761. return
  6762. fi
  6763. apt-get -y install dokuwiki
  6764. apt-get -y remove --purge apache*
  6765. if [ -d /etc/apache2 ]; then
  6766. rm -rf /etc/apache2
  6767. echo $'Removed Apache installation after Dokuwiki install'
  6768. fi
  6769. if [ ! -d /var/www/$WIKI_DOMAIN_NAME ]; then
  6770. mkdir /var/www/$WIKI_DOMAIN_NAME
  6771. fi
  6772. if [ -d /var/www/$WIKI_DOMAIN_NAME/htdocs ]; then
  6773. rm -rf /var/www/$WIKI_DOMAIN_NAME/htdocs
  6774. fi
  6775. ln -s /usr/share/dokuwiki /var/www/$WIKI_DOMAIN_NAME/htdocs
  6776. mkdir /var/lib/dokuwiki/custom
  6777. cp /etc/dokuwiki/local.php.dist /var/lib/dokuwiki/custom/local.php
  6778. ln -s /var/lib/dokuwiki/custom/local.php /etc/dokuwiki/local.php
  6779. chown www-data /var/lib/dokuwiki/custom
  6780. chown www-data /var/lib/dokuwiki/custom/local.php
  6781. chown -R www-data /etc/dokuwiki
  6782. chown -R www-data /usr/share/dokuwiki/lib/
  6783. chmod 600 /var/lib/dokuwiki/custom/local.php
  6784. chmod -R 755 /usr/share/dokuwiki/lib
  6785. sed -i 's|//$conf|$conf|g' /var/lib/dokuwiki/custom/local.php
  6786. sed -i "s|joe|$MY_USERNAME|g" /var/lib/dokuwiki/custom/local.php
  6787. sed -i "s|Debian DokuWiki|$WIKI_TITLE|g" /etc/dokuwiki/local.php
  6788. # set the admin user
  6789. sed -i "s/@admin/$MY_USERNAME/g" /etc/dokuwiki/local.php
  6790. # disallow registration of new users
  6791. if ! grep -q "disableactions" /etc/dokuwiki/local.php; then
  6792. echo "\$conf['disableactions'] = 'register';" >> /etc/dokuwiki/local.php
  6793. fi
  6794. if ! grep -q "disableactions" /var/lib/dokuwiki/custom/local.php; then
  6795. echo "\$conf['disableactions'] = 'register';" >> /var/lib/dokuwiki/custom/local.php
  6796. fi
  6797. if ! grep -q "authtype" /var/lib/dokuwiki/custom/local.php; then
  6798. echo "\$conf['authtype'] = 'authplain';" >> /var/lib/dokuwiki/custom/local.php
  6799. fi
  6800. if ! grep -q "authtype" /etc/dokuwiki/local.php; then
  6801. echo "\$conf['authtype'] = 'authplain';" >> /etc/dokuwiki/local.php
  6802. fi
  6803. get_wiki_admin_password
  6804. if [ ! $WIKI_ADMIN_PASSWORD ]; then
  6805. if [ -f $IMAGE_PASSWORD_FILE ]; then
  6806. WIKI_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  6807. else
  6808. WIKI_ADMIN_PASSWORD="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  6809. fi
  6810. fi
  6811. HASHED_WIKI_PASSWORD=$(echo -n "$WIKI_ADMIN_PASSWORD" | md5sum | awk -F ' ' '{print $1}')
  6812. echo -n "$MY_USERNAME:$HASHED_WIKI_PASSWORD:$MY_NAME:$MY_EMAIL:admin,user,upload" > /var/lib/dokuwiki/acl/users.auth.php
  6813. chmod 640 /var/lib/dokuwiki/acl/users.auth.php
  6814. if ! grep -q "video/ogg" /etc/dokuwiki/mime.conf; then
  6815. echo 'ogv video/ogg' >> /etc/dokuwiki/mime.conf
  6816. fi
  6817. if ! grep -q "video/mp4" /etc/dokuwiki/mime.conf; then
  6818. echo 'mp4 video/mp4' >> /etc/dokuwiki/mime.conf
  6819. fi
  6820. if ! grep -q "video/webm" /etc/dokuwiki/mime.conf; then
  6821. echo 'webm video/webm' >> /etc/dokuwiki/mime.conf
  6822. fi
  6823. WIKI_ONION_HOSTNAME=$(add_onion_service wiki 80 ${WIKI_ONION_PORT})
  6824. if [[ $ONION_ONLY == "no" ]]; then
  6825. echo 'server {' > /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6826. echo ' listen 80;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6827. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6828. echo " server_name $WIKI_DOMAIN_NAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6829. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6830. echo " error_log /var/log/nginx/${WIKI_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6831. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6832. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6833. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6834. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6835. nginx_disable_sniffing $WIKI_DOMAIN_NAME
  6836. nginx_limits $WIKI_DOMAIN_NAME
  6837. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6838. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6839. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6840. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6841. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6842. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6843. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6844. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6845. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6846. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6847. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6848. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6849. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6850. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6851. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6852. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6853. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6854. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6855. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6856. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6857. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6858. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6859. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6860. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6861. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6862. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6863. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6864. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6865. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6866. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6867. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6868. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6869. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6870. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6871. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6872. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6873. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6874. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6875. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6876. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6877. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6878. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6879. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6880. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6881. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6882. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6883. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6884. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6885. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6886. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6887. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6888. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6889. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6890. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6891. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6892. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6893. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6894. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6895. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6896. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6897. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6898. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6899. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6900. echo 'server {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6901. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6902. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6903. echo " server_name $WIKI_DOMAIN_NAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6904. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6905. echo " error_log /var/log/nginx/${WIKI_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6906. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6907. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6908. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6909. nginx_limits $WIKI_DOMAIN_NAME
  6910. nginx_ssl $WIKI_DOMAIN_NAME
  6911. nginx_disable_sniffing $WIKI_DOMAIN_NAME
  6912. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6913. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6914. echo ' # webmail' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6915. echo ' location /webmail {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6916. echo ' rewrite ^/(.*) /webmail/index.php last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6917. echo ' rewrite ^/(.*) /webmail/installer/index.php last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6918. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6919. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6920. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6921. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6922. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6923. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6924. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6925. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6926. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6927. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6928. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6929. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6930. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6931. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6932. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6933. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6934. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6935. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6936. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6937. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6938. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6939. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6940. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6941. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6942. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6943. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6944. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6945. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6946. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6947. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6948. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6949. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6950. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6951. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6952. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6953. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6954. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6955. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6956. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6957. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6958. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6959. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6960. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6961. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6962. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6963. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6964. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6965. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6966. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6967. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6968. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6969. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6970. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6971. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6972. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6973. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6974. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6975. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6976. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6977. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6978. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6979. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6980. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6981. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6982. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6983. else
  6984. echo -n '' > /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6985. fi
  6986. echo 'server {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6987. echo " listen 127.0.0.1:${WIKI_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6988. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6989. echo " server_name $WIKI_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6990. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6991. echo " error_log /var/log/nginx/${WIKI_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6992. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6993. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6994. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6995. nginx_limits $WIKI_DOMAIN_NAME
  6996. nginx_disable_sniffing $WIKI_DOMAIN_NAME
  6997. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6998. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6999. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7000. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7001. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7002. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7003. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7004. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7005. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7006. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7007. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7008. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7009. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7010. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7011. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7012. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7013. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7014. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7015. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7016. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7017. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7018. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7019. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7020. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7021. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7022. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7023. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7024. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7025. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7026. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7027. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7028. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7029. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7030. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7031. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7032. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7033. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7034. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7035. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7036. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7037. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7038. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7039. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7040. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7041. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7042. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7043. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7044. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7045. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7046. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7047. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7048. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7049. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7050. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7051. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7052. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7053. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7054. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7055. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7056. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7057. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7058. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7059. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7060. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  7061. create_site_certificate $WIKI_DOMAIN_NAME
  7062. configure_php
  7063. nginx_ensite $WIKI_DOMAIN_NAME
  7064. systemctl restart php5-fpm
  7065. systemctl restart nginx
  7066. echo "Wiki onion domain:${WIKI_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7067. add_ddns_domain $WIKI_DOMAIN_NAME
  7068. # add some post-install instructions
  7069. if ! grep -q $"Wiki password" /home/$MY_USERNAME/README; then
  7070. echo '' >> /home/$MY_USERNAME/README
  7071. echo '' >> /home/$MY_USERNAME/README
  7072. echo $'Wiki' >> /home/$MY_USERNAME/README
  7073. echo '====' >> /home/$MY_USERNAME/README
  7074. echo $"Wiki onion domain: ${WIKI_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  7075. echo $"Wiki username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  7076. echo $"Wiki password: $WIKI_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7077. echo '' >> /home/$MY_USERNAME/README
  7078. echo $'Once you have set up the wiki then remove the install file:' >> /home/$MY_USERNAME/README
  7079. echo '' >> /home/$MY_USERNAME/README
  7080. echo " rm /var/www/$WIKI_DOMAIN_NAME/htdocs/install.php" >> /home/$MY_USERNAME/README
  7081. echo '' >> /home/$MY_USERNAME/README
  7082. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7083. chmod 600 /home/$MY_USERNAME/README
  7084. fi
  7085. echo "Wiki domain:$WIKI_DOMAIN_NAME" >> $COMPLETION_FILE
  7086. echo 'install_wiki' >> $COMPLETION_FILE
  7087. }
  7088. function get_blog_admin_password {
  7089. if [ -f /home/$MY_USERNAME/README ]; then
  7090. if grep -q "Your blog password is" /home/$MY_USERNAME/README; then
  7091. FULLBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Your blog password is" | awk -F ':' '{print $2}' | sed 's/^ *//')
  7092. fi
  7093. fi
  7094. }
  7095. function install_blog {
  7096. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7097. return
  7098. fi
  7099. if [ ! $FULLBLOG_DOMAIN_NAME ]; then
  7100. echo $'The blog domain name was not specified'
  7101. exit 5062
  7102. fi
  7103. # update to the next commit
  7104. set_repo_commit /var/www/$FULLBLOG_DOMAIN_NAME/htdocs "Blog commit" "$FULLBLOG_COMMIT" $FULLBLOG_REPO
  7105. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  7106. return
  7107. fi
  7108. # for the avatar changing command
  7109. apt-get -y install imagemagick
  7110. if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME ]; then
  7111. mkdir /var/www/$FULLBLOG_DOMAIN_NAME
  7112. fi
  7113. cd /var/www/$FULLBLOG_DOMAIN_NAME
  7114. git_clone $FULLBLOG_REPO htdocs
  7115. cd htdocs
  7116. git checkout $FULLBLOG_COMMIT -b $FULLBLOG_COMMIT
  7117. if ! grep -q "Blog commit" $COMPLETION_FILE; then
  7118. echo "Blog commit:$FULLBLOG_COMMIT" >> $COMPLETION_FILE
  7119. else
  7120. sed -i "s/Blog commit.*/Blog commit:$FULLBLOG_COMMIT/g" $COMPLETION_FILE
  7121. fi
  7122. cd /var/www/$FULLBLOG_DOMAIN_NAME
  7123. chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs
  7124. if [[ $ONION_ONLY == "no" ]]; then
  7125. echo 'server {' > /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7126. echo ' listen 80;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7127. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7128. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7129. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7130. echo " error_log /var/log/nginx/${FULLBLOG_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7131. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7132. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7133. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7134. nginx_limits $FULLBLOG_DOMAIN_NAME
  7135. nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
  7136. echo ' # Always redirect the login page to https' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7137. echo ' location /login {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7138. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7139. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7140. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7141. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7142. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7143. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7144. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7145. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7146. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7147. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7148. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7149. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7150. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7151. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7152. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7153. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7154. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7155. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7156. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7157. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7158. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7159. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7160. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7161. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7162. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7163. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7164. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7165. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7166. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7167. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7168. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7169. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7170. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7171. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7172. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7173. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7174. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7175. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7176. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7177. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7178. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7179. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7180. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7181. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7182. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7183. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7184. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7185. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7186. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7187. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7188. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7189. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7190. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7191. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7192. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7193. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7194. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7195. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7196. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7197. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7198. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7199. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7200. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7201. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7202. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7203. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7204. echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7205. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7206. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7207. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7208. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7209. echo " error_log /var/log/nginx/${FULLBLOG_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7210. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7211. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7212. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7213. nginx_limits $FULLBLOG_DOMAIN_NAME
  7214. nginx_ssl $FULLBLOG_DOMAIN_NAME
  7215. nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
  7216. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7217. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7218. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7219. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7220. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7221. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7222. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7223. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7224. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7225. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7226. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7227. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7228. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7229. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7230. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7231. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7232. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7233. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7234. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7235. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7236. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7237. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7238. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7239. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7240. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7241. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7242. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7243. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7244. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7245. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7246. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7247. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7248. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7249. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7250. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7251. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7252. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7253. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7254. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7255. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7256. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7257. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7258. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7259. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7260. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7261. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7262. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7263. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7264. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7265. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7266. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7267. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7268. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7269. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7270. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7271. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7272. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7273. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7274. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7275. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7276. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7277. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7278. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7279. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7280. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7281. else
  7282. echo -n '' > /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7283. fi
  7284. echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7285. echo " listen 127.0.0.1:${FULLBLOG_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7286. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7287. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7288. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7289. echo " error_log /var/log/nginx/${FULLBLOG_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7290. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7291. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7292. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7293. nginx_limits $FULLBLOG_DOMAIN_NAME
  7294. nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
  7295. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7296. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7297. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7298. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7299. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7300. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7301. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7302. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7303. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7304. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7305. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7306. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7307. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7308. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7309. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7310. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7311. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7312. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7313. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7314. echo ' try_files $uri /index.php?q=$uri&$args;' >> /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 ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7318. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7319. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7320. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7321. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7322. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7323. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7324. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7325. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7326. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7327. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7328. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7329. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7330. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7331. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7332. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7333. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7334. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7335. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7336. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7337. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7338. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7339. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7340. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7341. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7342. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7343. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7344. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7345. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7346. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7347. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7348. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7349. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7350. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7351. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7352. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7353. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7354. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7355. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7356. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7357. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7358. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  7359. create_site_certificate $FULLBLOG_DOMAIN_NAME
  7360. configure_php
  7361. # blog settings
  7362. cp /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini.example /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7363. sed -i "s|site.url.*|site.url = '/'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7364. sed -i "s|blog.title.*|blog.title = '$MY_BLOG_TITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7365. sed -i "s|blog.tagline.*|blog.tagline = '$MY_BLOG_SUBTITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7366. sed -i 's|timezone.*|timezone = "Europe/London"|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7367. sed -i "s|Your name|$MY_NAME|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7368. # set social networks
  7369. if grep -q "social.hubzilla" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini; then
  7370. sed -i "s|;social.hubzilla|social.hubzilla|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7371. sed -i "s|social.hubzilla.*|social.hubzilla = \"$HUBZILLA_DOMAIN_NAME\"|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7372. fi
  7373. if grep -q "social.gnusocial" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini; then
  7374. sed -i "s|;social.gnusocial|social.gnusocial|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7375. sed -i "s|social.gnusocial.*|social.gnusocial = \"$MICROBLOG_DOMAIN_NAME\"|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7376. fi
  7377. # clear proprietary social network strings
  7378. sed -i 's|social.facebook.*|social.facebook = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7379. sed -i 's|social.twitter.*|social.twitter = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7380. sed -i 's|social.google.*|social.google = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7381. # create a user password
  7382. get_blog_admin_password
  7383. if [ ! $FULLBLOG_ADMIN_PASSWORD ]; then
  7384. if [ -f $IMAGE_PASSWORD_FILE ]; then
  7385. FULLBLOG_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  7386. else
  7387. FULLBLOG_ADMIN_PASSWORD="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  7388. fi
  7389. echo '' >> /home/$MY_USERNAME/README
  7390. echo '' >> /home/$MY_USERNAME/README
  7391. echo $'HTMLy Blog' >> /home/$MY_USERNAME/README
  7392. echo '==========' >> /home/$MY_USERNAME/README
  7393. echo $"Your blog username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  7394. echo $"Your blog password is: $FULLBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7395. if [[ $ONION_ONLY == 'no' ]]; then
  7396. echo $"Log into your blog at https://$FULLBLOG_DOMAIN_NAME/login" >> /home/$MY_USERNAME/README
  7397. fi
  7398. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7399. chmod 600 /home/$MY_USERNAME/README
  7400. fi
  7401. # create a user
  7402. FULLBLOG_ADMIN_PASSWORD_HASH=$(freedombone-sec --bloghash "$FULLBLOG_ADMIN_PASSWORD")
  7403. if [ ${#FULLBLOG_ADMIN_PASSWORD_HASH} -lt 8 ]; then
  7404. echo $'Blog admin password could not be hashed'
  7405. exit 625728
  7406. fi
  7407. echo ';Password' > /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7408. echo "password = $FULLBLOG_ADMIN_PASSWORD_HASH" >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7409. echo 'encryption = password_hash' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7410. echo ';Role' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7411. echo 'role = admin' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7412. nginx_ensite $FULLBLOG_DOMAIN_NAME
  7413. FULLBLOG_ONION_HOSTNAME=$(add_onion_service blog 80 ${FULLBLOG_ONION_PORT})
  7414. systemctl restart php5-fpm
  7415. systemctl restart nginx
  7416. if ! grep -q "Blog onion domain" /home/$MY_USERNAME/README; then
  7417. echo $"Blog onion domain: ${FULLBLOG_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  7418. echo $"Log into your blog at https://${FULLBLOG_ONION_HOSTNAME}/login" >> /home/$MY_USERNAME/README
  7419. echo '' >> /home/$MY_USERNAME/README
  7420. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7421. chmod 600 /home/$MY_USERNAME/README
  7422. fi
  7423. echo "Blog onion domain:${FULLBLOG_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7424. add_ddns_domain $FULLBLOG_DOMAIN_NAME
  7425. echo 'install_blog' >> $COMPLETION_FILE
  7426. }
  7427. function install_rss_reader {
  7428. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7429. return
  7430. fi
  7431. # update to the next commit
  7432. set_repo_commit $RSS_READER_PATH "RSS reader commit" "$RSS_READER_COMMIT" $RSS_READER_REPO
  7433. if grep -Fxq "install_rss_reader" $COMPLETION_FILE; then
  7434. return
  7435. fi
  7436. apt-get -y install php-gettext php5-curl php5-gd php5-mysql git curl php-xml-parser
  7437. if [ ! -d /etc/share ]; then
  7438. mkdir /etc/share
  7439. fi
  7440. cd /etc/share
  7441. git_clone $RSS_READER_REPO tt-rss
  7442. if [ ! -d $RSS_READER_PATH ]; then
  7443. echo $'Could not clone RSS reader repo'
  7444. exit 52925
  7445. fi
  7446. cd $RSS_READER_PATH
  7447. git checkout $RSS_READER_COMMIT -b $RSS_READER_COMMIT
  7448. if ! grep -q "RSS reader commit" $COMPLETION_FILE; then
  7449. echo "RSS reader commit:$RSS_READER_COMMIT" >> $COMPLETION_FILE
  7450. fi
  7451. install_mariadb
  7452. get_mariadb_password
  7453. repair_databases_script
  7454. get_mariadb_rss_reader_admin_password
  7455. if [ ! $RSS_READER_ADMIN_PASSWORD ]; then
  7456. if [ -f $IMAGE_PASSWORD_FILE ]; then
  7457. RSS_READER_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  7458. else
  7459. RSS_READER_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  7460. fi
  7461. fi
  7462. create_database ttrss "$RSS_READER_ADMIN_PASSWORD" $MY_USERNAME
  7463. RSS_READER_ONION_HOSTNAME=$(add_onion_service ttrss 80 ${RSS_READER_ONION_PORT})
  7464. RSS_MOBILE_READER_ONION_HOSTNAME=$(add_onion_service ttrss 80 ${RSS_MOBILE_READER_ONION_PORT})
  7465. echo 'server {' > /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7466. echo " listen 127.0.0.1:$RSS_MOBILE_READER_ONION_PORT;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7467. echo " server_name $RSS_MOBILE_READER_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7468. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7469. echo ' access_log off;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7470. echo ' error_log off;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7471. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7472. echo ' root /etc/share/ttrss-mobile;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7473. echo ' index index.html index.php;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7474. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7475. echo ' location ~ \.php {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7476. echo ' include snippets/fastcgi-php.conf;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7477. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7478. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7479. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7480. echo ' location / {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7481. echo ' try_files $uri $uri/ @ttrss;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7482. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7483. echo ' location /tt-rss {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7484. echo ' try_files $uri $uri/ @ttrss_base;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7485. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7486. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7487. echo ' location @ttrss {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7488. echo ' rewrite ^(.*)$ /index.html?p=$1 last;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7489. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7490. echo ' location @ttrss_base {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7491. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7492. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7493. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7494. echo ' location ~ /\.(git) {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7495. echo ' deny all;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7496. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7497. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7498. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7499. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7500. echo ' client_max_body_size 15m;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7501. echo '}' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7502. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7503. echo 'server {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7504. echo " listen 127.0.0.1:$RSS_READER_ONION_PORT default_server;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7505. echo " server_name $RSS_READER_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7506. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7507. echo ' access_log off;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7508. echo ' error_log off;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7509. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7510. echo ' root /etc/share/tt-rss;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7511. echo ' index index.php;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7512. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7513. echo ' location ~ \.php {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7514. echo ' include snippets/fastcgi-php.conf;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7515. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7516. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7517. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7518. echo ' set $mobile_rewrite do_not_perform;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7519. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7520. echo ' ## chi http_user_agent for mobile / smart phones ##' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7521. echo ' if ($http_user_agent ~* "(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino") {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7522. echo ' set $mobile_rewrite perform;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7523. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7524. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7525. echo ' if ($http_user_agent ~* "^(1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-)") {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7526. echo ' set $mobile_rewrite perform;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7527. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7528. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7529. echo ' if ($mobile_rewrite = perform) {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7530. echo " rewrite ^/(.*) http://$RSS_MOBILE_READER_ONION_HOSTNAME permanent;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7531. echo ' break;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7532. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7533. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7534. echo ' location ~ \.php {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7535. echo ' include snippets/fastcgi-php.conf;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7536. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7537. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7538. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7539. echo ' location / {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7540. echo ' try_files $uri $uri/ @ttrss;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7541. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7542. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7543. echo ' location @ttrss {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7544. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7545. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7546. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7547. echo ' location ~ /\.(git) {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7548. echo ' deny all;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7549. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7550. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7551. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7552. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7553. echo ' client_max_body_size 15m;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7554. echo '}' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7555. if [ ! -f $RSS_READER_PATH/config.php ]; then
  7556. # generate a config file
  7557. RSS_FEED_CRYPT_KEY="$(openssl rand -base64 26 | cut -c1-24)"
  7558. echo '<?php' > $RSS_READER_PATH/config.php
  7559. echo " define ('_CURL_HTTP_PROXY', '127.0.0.1:9050');" >> $RSS_READER_PATH/config.php
  7560. echo " define('DB_TYPE', 'mysql');" >> $RSS_READER_PATH/config.php
  7561. echo " define('DB_HOST', 'localhost');" >> $RSS_READER_PATH/config.php
  7562. echo " define('DB_USER', 'root');" >> $RSS_READER_PATH/config.php
  7563. echo " define('DB_NAME', 'ttrss');" >> $RSS_READER_PATH/config.php
  7564. echo " define('DB_PASS', '${MARIADB_PASSWORD}');" >> $RSS_READER_PATH/config.php
  7565. echo " define('DB_PORT', '3306');" >> $RSS_READER_PATH/config.php
  7566. echo " define('MYSQL_CHARSET', 'UTF8');" >> $RSS_READER_PATH/config.php
  7567. echo " define('SELF_URL_PATH', 'http://${RSS_READER_ONION_HOSTNAME}/');" >> $RSS_READER_PATH/config.php
  7568. echo " define('FEED_CRYPT_KEY', '${RSS_FEED_CRYPT_KEY}');" >> $RSS_READER_PATH/config.php
  7569. echo " define('SINGLE_USER_MODE', false);" >> $RSS_READER_PATH/config.php
  7570. echo " define('SIMPLE_UPDATE_MODE', false);" >> $RSS_READER_PATH/config.php
  7571. echo " define('PHP_EXECUTABLE', '/usr/bin/php');" >> $RSS_READER_PATH/config.php
  7572. echo " define('LOCK_DIRECTORY', 'lock');" >> $RSS_READER_PATH/config.php
  7573. echo " define('CACHE_DIR', 'cache');" >> $RSS_READER_PATH/config.php
  7574. echo " define('ICONS_DIR', \"feed-icons\");" >> $RSS_READER_PATH/config.php
  7575. echo " define('ICONS_URL', \"feed-icons\");" >> $RSS_READER_PATH/config.php
  7576. echo " define('AUTH_AUTO_CREATE', true);" >> $RSS_READER_PATH/config.php
  7577. echo " define('AUTH_AUTO_LOGIN', true);" >> $RSS_READER_PATH/config.php
  7578. echo " define('FORCE_ARTICLE_PURGE', 0);" >> $RSS_READER_PATH/config.php
  7579. echo " define('PUBSUBHUBBUB_HUB', '');" >> $RSS_READER_PATH/config.php
  7580. echo " define('PUBSUBHUBBUB_ENABLED', false);" >> $RSS_READER_PATH/config.php
  7581. echo " define('SPHINX_SERVER', 'localhost:9312');" >> $RSS_READER_PATH/config.php
  7582. echo " define('SPHINX_INDEX', 'ttrss, delta');" >> $RSS_READER_PATH/config.php
  7583. echo " define('ENABLE_REGISTRATION', false);" >> $RSS_READER_PATH/config.php
  7584. echo " define('REG_NOTIFY_ADDRESS', '${MY_EMAIL_ADDRESS}');" >> $RSS_READER_PATH/config.php
  7585. echo " define('REG_MAX_USERS', 10);" >> $RSS_READER_PATH/config.php
  7586. echo " define('SESSION_COOKIE_LIFETIME', 86400);" >> $RSS_READER_PATH/config.php
  7587. echo " define('SMTP_FROM_NAME', 'Tiny Tiny RSS');" >> $RSS_READER_PATH/config.php
  7588. echo " define('SMTP_FROM_ADDRESS', 'noreply@${RSS_READER_ONION_HOSTNAME}');" >> $RSS_READER_PATH/config.php
  7589. echo " define('DIGEST_SUBJECT', '[tt-rss] New headlines for last 24 hours');" >> $RSS_READER_PATH/config.php
  7590. echo " define('SMTP_SERVER', '');" >> $RSS_READER_PATH/config.php
  7591. echo " define('SMTP_LOGIN', '');" >> $RSS_READER_PATH/config.php
  7592. echo " define('SMTP_PASSWORD', '');" >> $RSS_READER_PATH/config.php
  7593. echo " define('SMTP_SECURE', '');" >> $RSS_READER_PATH/config.php
  7594. echo " define('CHECK_FOR_UPDATES', false);" >> $RSS_READER_PATH/config.php
  7595. echo " define('ENABLE_GZIP_OUTPUT', false);" >> $RSS_READER_PATH/config.php
  7596. echo " define('PLUGINS', 'auth_internal, note, gnusocial');" >> $RSS_READER_PATH/config.php
  7597. echo " define('LOG_DESTINATION', 'sql');" >> $RSS_READER_PATH/config.php
  7598. echo " define('CONFIG_VERSION', 26);" >> $RSS_READER_PATH/config.php
  7599. fi
  7600. # initialize the database
  7601. if [ ! -f $RSS_READER_PATH/schema/ttrss_schema_mysql.sql ]; then
  7602. echo $'No database schema found for rss reader'
  7603. exit 52926
  7604. fi
  7605. mysql -u root --password="$MARIADB_PASSWORD" -D ttrss < $RSS_READER_PATH/schema/ttrss_schema_mysql.sql
  7606. # change the password from the default
  7607. RSS_READER_ADMIN_PASSWORD_HASH=$(echo -n "${RSS_READER_ADMIN_PASSWORD}" | sha1sum | awk -F ' ' '{print $1}')
  7608. mysql -u root --password="$MARIADB_PASSWORD" -e "update ttrss_users set pwd_hash = 'SHA1:${RSS_READER_ADMIN_PASSWORD_HASH}', salt= '' WHERE login = 'admin';" ttrss
  7609. rss_reader_modifications
  7610. configure_php
  7611. nginx_ensite $RSS_READER_DOMAIN_NAME
  7612. systemctl restart php5-fpm
  7613. systemctl restart nginx
  7614. if ! grep -q "RSS reader onion domain" $COMPLETION_FILE; then
  7615. echo "RSS reader onion domain:${RSS_READER_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7616. fi
  7617. if ! grep -q "RSS reader domain" $COMPLETION_FILE; then
  7618. echo "RSS reader domain:${RSS_READER_DOMAIN_NAME}" >> $COMPLETION_FILE
  7619. fi
  7620. # daemon to update feeds
  7621. echo '[Unit]' > /etc/systemd/system/ttrss.service
  7622. echo 'Description=ttrss_backend' >> /etc/systemd/system/ttrss.service
  7623. echo 'After=network.target mysql.service' >> /etc/systemd/system/ttrss.service
  7624. echo 'After=tor.service' >> /etc/systemd/system/ttrss.service
  7625. echo '' >> /etc/systemd/system/ttrss.service
  7626. echo '[Service]' >> /etc/systemd/system/ttrss.service
  7627. echo 'User=www-data' >> /etc/systemd/system/ttrss.service
  7628. echo "ExecStart=/usr/bin/php $RSS_READER_PATH/update.php --daemon" >> /etc/systemd/system/ttrss.service
  7629. echo '' >> /etc/systemd/system/ttrss.service
  7630. echo '[Install]' >> /etc/systemd/system/ttrss.service
  7631. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/ttrss.service
  7632. systemctl enable ttrss
  7633. systemctl daemon-reload
  7634. systemctl start ttrss
  7635. # some post-install instructions for the user
  7636. if ! grep -q $"RSS Reader" /home/$MY_USERNAME/README; then
  7637. echo '' >> /home/$MY_USERNAME/README
  7638. echo '' >> /home/$MY_USERNAME/README
  7639. echo $'RSS Reader' >> /home/$MY_USERNAME/README
  7640. echo '==========' >> /home/$MY_USERNAME/README
  7641. echo $"RSS reader domain: ${RSS_READER_DOMAIN_NAME}" >> /home/$MY_USERNAME/README
  7642. echo $"RSS reader onion domain: ${RSS_READER_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  7643. echo $"RSS reader admin username: admin" >> /home/$MY_USERNAME/README
  7644. echo $"RSS reader admin password: ${RSS_READER_ADMIN_PASSWORD}" >> /home/$MY_USERNAME/README
  7645. echo '' >> /home/$MY_USERNAME/README
  7646. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7647. chmod 600 /home/$MY_USERNAME/README
  7648. fi
  7649. echo 'install_rss_reader' >> $COMPLETION_FILE
  7650. }
  7651. function install_rss_reader_gnusocial {
  7652. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7653. return
  7654. fi
  7655. if [ ! $MICROBLOG_DOMAIN_NAME ]; then
  7656. return
  7657. fi
  7658. if [ ! $RSS_READER_PATH ]; then
  7659. RSS_READER_PATH=/etc/share/tt-rss
  7660. fi
  7661. RSS_READER_GNUSOCIAL_PATH=${RSS_READER_PATH}/plugins/gnusocial
  7662. # update to the next commit
  7663. set_repo_commit $RSS_READER_GNUSOCIAL_PATH "RSS reader gnusocial commit" "$RSS_READER_GNUSOCIAL_COMMIT" $RSS_READER_GNUSOCIAL_REPO
  7664. chown -R www-data:www-data $RSS_READER_GNUSOCIAL_PATH
  7665. if grep -Fxq "install_rss_reader_gnusocial" $COMPLETION_FILE; then
  7666. return
  7667. fi
  7668. if [ ! -d $INSTALL_DIR ]; then
  7669. mkdir -p $INSTALL_DIR
  7670. fi
  7671. cd $INSTALL_DIR
  7672. git_clone $RSS_READER_GNUSOCIAL_REPO ttrss-gnusocial
  7673. if [ ! -d $INSTALL_DIR/ttrss-gnusocial ]; then
  7674. echo $'Could not clone repo for RSS reader GNU Social plugin'
  7675. exit 52838
  7676. fi
  7677. cp -r $INSTALL_DIR/ttrss-gnusocial $RSS_READER_GNUSOCIAL_PATH
  7678. cd $RSS_READER_GNUSOCIAL_PATH
  7679. git checkout $RSS_READER_GNUSOCIAL_COMMIT -b $RSS_READER_GNUSOCIAL_COMMIT
  7680. if ! grep -q "RSS reader gnusocial commit" $COMPLETION_FILE; then
  7681. echo "RSS reader gnusocial commit:$RSS_READER_GNUSOCIAL_COMMIT" >> $COMPLETION_FILE
  7682. fi
  7683. chown -R www-data:www-data $RSS_READER_GNUSOCIAL_PATH
  7684. echo 'install_rss_reader_gnusocial' >> $COMPLETION_FILE
  7685. }
  7686. function install_rss_mobile_reader {
  7687. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7688. return
  7689. fi
  7690. if [ ! $RSS_READER_PATH ]; then
  7691. RSS_READER_PATH=/etc/share/tt-rss
  7692. fi
  7693. if [ ! -d $RSS_READER_PATH ]; then
  7694. echo $'tt-rss is not installed, so the mobile version cannot be installed'
  7695. exit 63452
  7696. fi
  7697. RSS_MOBILE_READER_PATH=/etc/share/ttrss-mobile
  7698. # remove any previous install
  7699. if [ -d $RSS_READER_PATH/g2ttree-mobile ]; then
  7700. if grep -Fxq "install_rss_mobile_reader" $COMPLETION_FILE; then
  7701. sed -i '/install_rss_mobile_reader/d' $COMPLETION_FILE
  7702. sed -i '/RSS mobile reader commit/d' $COMPLETION_FILE
  7703. rm -rf $RSS_READER_PATH/g2ttree-mobile
  7704. fi
  7705. fi
  7706. # update to the next commit
  7707. set_repo_commit $RSS_MOBILE_READER_PATH "RSS mobile reader commit" "$RSS_MOBILE_READER_COMMIT" $RSS_MOBILE_READER_REPO
  7708. if grep -Fxq "install_rss_mobile_reader" $COMPLETION_FILE; then
  7709. return
  7710. fi
  7711. cd /etc/share
  7712. git_clone $RSS_MOBILE_READER_REPO ttrss-mobile
  7713. if [ ! -d $RSS_MOBILE_READER_PATH ]; then
  7714. echo $'Could not clone RSS mobile reader repo'
  7715. exit 24816
  7716. fi
  7717. cd $RSS_MOBILE_READER_PATH
  7718. git checkout $RSS_MOBILE_READER_COMMIT -b $RSS_MOBILE_READER_COMMIT
  7719. if ! grep -q "RSS mobile reader commit" $COMPLETION_FILE; then
  7720. echo "RSS mobile reader commit:$RSS_MOBILE_READER_COMMIT" >> $COMPLETION_FILE
  7721. fi
  7722. echo 'define({' > $RSS_MOBILE_READER_PATH/scripts/conf.js
  7723. echo ' apiPath: "/tt-rss/"' >> $RSS_MOBILE_READER_PATH/scripts/conf.js
  7724. echo '});' >> $RSS_MOBILE_READER_PATH/scripts/conf.js
  7725. # link to the main site
  7726. ln -s $RSS_READER_PATH $RSS_MOBILE_READER_PATH/tt-rss
  7727. chown -R www-data:www-data $RSS_MOBILE_READER_PATH
  7728. chown -R www-data:www-data $RSS_READER_PATH
  7729. chmod a+x $RSS_MOBILE_READER_PATH
  7730. echo 'install_rss_mobile_reader' >> $COMPLETION_FILE
  7731. }
  7732. function install_gnu_social {
  7733. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7734. return
  7735. fi
  7736. if [ ! $MICROBLOG_DOMAIN_NAME ]; then
  7737. echo $'No domain name was given for the microblog'
  7738. exit 7359
  7739. fi
  7740. # update to the next commit
  7741. set_repo_commit /var/www/$MICROBLOG_DOMAIN_NAME/htdocs "GNU Social commit" "$MICROBLOG_COMMIT" $MICROBLOG_REPO
  7742. # add a script to check that the daemon is running
  7743. echo '#!/bin/bash' > /etc/cron.hourly/gnusocial-daemons
  7744. echo 'daemon_lines=$(ps aux | grep "scripts/queuedaemon.php" | grep "/var/www")' >> /etc/cron.hourly/gnusocial-daemons
  7745. echo 'if [[ $daemon_lines != *"/var/www/"* ]]; then' >> /etc/cron.hourly/gnusocial-daemons
  7746. echo " ADMIN_USER=\$(cat $COMPLETION_FILE | grep 'Admin user' | awk -F ':' '{print \$2}')" >> /etc/cron.hourly/gnusocial-daemons
  7747. echo ' MY_EMAIL_ADDRESS=$ADMIN_USER@$HOSTNAME' >> /etc/cron.hourly/gnusocial-daemons
  7748. echo ' echo "Restarting GNU Social daemons" | mail -s "GNU Social daemons not found" $MY_EMAIL_ADDRESS' >> /etc/cron.hourly/gnusocial-daemons
  7749. echo " cd /var/www/${MICROBLOG_DOMAIN_NAME}/htdocs" >> /etc/cron.hourly/gnusocial-daemons
  7750. echo ' scripts/startdaemons.sh' >> /etc/cron.hourly/gnusocial-daemons
  7751. echo 'fi' >> /etc/cron.hourly/gnusocial-daemons
  7752. chmod +x /etc/cron.hourly/gnusocial-daemons
  7753. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  7754. return
  7755. fi
  7756. install_mariadb
  7757. get_mariadb_password
  7758. repair_databases_script
  7759. apt-get -y install php-gettext php5-curl php5-gd php5-mysql git curl php-xml-parser
  7760. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME ]; then
  7761. mkdir /var/www/$MICROBLOG_DOMAIN_NAME
  7762. fi
  7763. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs ]; then
  7764. git_clone $MICROBLOG_REPO /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7765. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs ]; then
  7766. echo $'Unable to clone gnusocial repo'
  7767. exit 87525
  7768. fi
  7769. fi
  7770. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7771. git checkout $MICROBLOG_COMMIT -b $MICROBLOG_COMMIT
  7772. if ! grep -q "GNU Social commit" $COMPLETION_FILE; then
  7773. echo "GNU Social commit:$MICROBLOG_COMMIT" >> $COMPLETION_FILE
  7774. else
  7775. sed -i "s/GNU Social commit.*/GNU Social commit:$MICROBLOG_COMMIT/g" $COMPLETION_FILE
  7776. fi
  7777. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7778. chown www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7779. chmod +x /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php
  7780. get_mariadb_gnusocial_admin_password
  7781. if [ ! $MICROBLOG_ADMIN_PASSWORD ]; then
  7782. if [ -f $IMAGE_PASSWORD_FILE ]; then
  7783. MICROBLOG_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  7784. else
  7785. MICROBLOG_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  7786. fi
  7787. fi
  7788. create_database gnusocial "$MICROBLOG_ADMIN_PASSWORD" $MY_USERNAME
  7789. if [ ! -f "/etc/aliases" ]; then
  7790. touch /etc/aliases
  7791. fi
  7792. if ! grep -q "www-data: root" /etc/aliases; then
  7793. echo 'www-data: root' >> /etc/aliases
  7794. fi
  7795. if ! grep -q "/var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php" /etc/aliases; then
  7796. echo "*: /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php" >> /etc/aliases
  7797. fi
  7798. add_ddns_domain $MICROBLOG_DOMAIN_NAME
  7799. microblog_nginx_site=/etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7800. if [[ $ONION_ONLY == "no" ]]; then
  7801. nginx_http_redirect $MICROBLOG_DOMAIN_NAME
  7802. echo 'server {' >> $microblog_nginx_site
  7803. echo ' listen 443 ssl;' >> $microblog_nginx_site
  7804. echo " server_name $MICROBLOG_DOMAIN_NAME;" >> $microblog_nginx_site
  7805. echo '' >> $microblog_nginx_site
  7806. echo ' # Security' >> $microblog_nginx_site
  7807. nginx_ssl $MICROBLOG_DOMAIN_NAME
  7808. nginx_disable_sniffing $MICROBLOG_DOMAIN_NAME
  7809. nginx_limits $MICROBLOG_DOMAIN_NAME '15m'
  7810. echo ' add_header Strict-Transport-Security max-age=15768000;' >> $microblog_nginx_site
  7811. echo '' >> $microblog_nginx_site
  7812. echo ' # Logs' >> $microblog_nginx_site
  7813. echo ' access_log off;' >> $microblog_nginx_site
  7814. echo ' error_log off;' >> $microblog_nginx_site
  7815. echo '' >> $microblog_nginx_site
  7816. echo ' # Root' >> $microblog_nginx_site
  7817. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> $microblog_nginx_site
  7818. echo '' >> $microblog_nginx_site
  7819. echo ' # Index' >> $microblog_nginx_site
  7820. echo ' index index.php;' >> $microblog_nginx_site
  7821. echo '' >> $microblog_nginx_site
  7822. echo ' # PHP' >> $microblog_nginx_site
  7823. echo ' location ~ \.php {' >> $microblog_nginx_site
  7824. echo ' include snippets/fastcgi-php.conf;' >> $microblog_nginx_site
  7825. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> $microblog_nginx_site
  7826. echo ' }' >> $microblog_nginx_site
  7827. echo '' >> $microblog_nginx_site
  7828. echo ' # Location' >> $microblog_nginx_site
  7829. echo ' location / {' >> $microblog_nginx_site
  7830. echo ' try_files $uri $uri/ @gnusocial;' >> $microblog_nginx_site
  7831. echo ' }' >> $microblog_nginx_site
  7832. echo '' >> $microblog_nginx_site
  7833. echo ' # Fancy URLs' >> $microblog_nginx_site
  7834. echo ' location @gnusocial {' >> $microblog_nginx_site
  7835. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> $microblog_nginx_site
  7836. echo ' }' >> $microblog_nginx_site
  7837. echo '' >> $microblog_nginx_site
  7838. echo ' # Restrict access that is unnecessary anyway' >> $microblog_nginx_site
  7839. echo ' location ~ /\.(ht|git) {' >> $microblog_nginx_site
  7840. echo ' deny all;' >> $microblog_nginx_site
  7841. echo ' }' >> $microblog_nginx_site
  7842. echo '}' >> $microblog_nginx_site
  7843. else
  7844. echo -n '' > $microblog_nginx_site
  7845. fi
  7846. echo 'server {' >> $microblog_nginx_site
  7847. echo " listen 127.0.0.1:$MICROBLOG_ONION_PORT default_server;" >> $microblog_nginx_site
  7848. echo " server_name $MICROBLOG_DOMAIN_NAME;" >> $microblog_nginx_site
  7849. echo '' >> $microblog_nginx_site
  7850. nginx_disable_sniffing $MICROBLOG_DOMAIN_NAME
  7851. nginx_limits $MICROBLOG_DOMAIN_NAME '15m'
  7852. echo '' >> $microblog_nginx_site
  7853. echo ' # Logs' >> $microblog_nginx_site
  7854. echo ' access_log off;' >> $microblog_nginx_site
  7855. echo ' error_log off;' >> $microblog_nginx_site
  7856. echo '' >> $microblog_nginx_site
  7857. echo ' # Root' >> $microblog_nginx_site
  7858. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> $microblog_nginx_site
  7859. echo '' >> $microblog_nginx_site
  7860. echo ' # Index' >> $microblog_nginx_site
  7861. echo ' index index.php;' >> $microblog_nginx_site
  7862. echo '' >> $microblog_nginx_site
  7863. echo ' # PHP' >> $microblog_nginx_site
  7864. echo ' location ~ \.php {' >> $microblog_nginx_site
  7865. echo ' include snippets/fastcgi-php.conf;' >> $microblog_nginx_site
  7866. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> $microblog_nginx_site
  7867. echo ' }' >> $microblog_nginx_site
  7868. echo '' >> $microblog_nginx_site
  7869. echo ' # Location' >> $microblog_nginx_site
  7870. echo ' location / {' >> $microblog_nginx_site
  7871. echo ' try_files $uri $uri/ @gnusocial;' >> $microblog_nginx_site
  7872. echo ' }' >> $microblog_nginx_site
  7873. echo '' >> $microblog_nginx_site
  7874. echo ' # Fancy URLs' >> $microblog_nginx_site
  7875. echo ' location @gnusocial {' >> $microblog_nginx_site
  7876. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> $microblog_nginx_site
  7877. echo ' }' >> $microblog_nginx_site
  7878. echo '' >> $microblog_nginx_site
  7879. echo ' # Restrict access that is unnecessary anyway' >> $microblog_nginx_site
  7880. echo ' location ~ /\.(ht|git) {' >> $microblog_nginx_site
  7881. echo ' deny all;' >> $microblog_nginx_site
  7882. echo ' }' >> $microblog_nginx_site
  7883. echo '}' >> $microblog_nginx_site
  7884. configure_php
  7885. create_site_certificate $MICROBLOG_DOMAIN_NAME 'yes'
  7886. # Ensure that the database gets backed up locally, if remote
  7887. # backups are not being used
  7888. backup_databases_script_header
  7889. backup_database_local gnusocial
  7890. nginx_ensite $MICROBLOG_DOMAIN_NAME
  7891. # NOTE: For the typical case always enable SSL and only
  7892. # disable it if in onion only mode. This is due to complexities
  7893. # with the way URLs are generated by GNU Social
  7894. gnu_social_ssl='always'
  7895. if [[ $ONION_ONLY != 'no' ]]; then
  7896. gnu_social_ssl='never'
  7897. fi
  7898. MICROBLOG_ONION_HOSTNAME=$(add_onion_service microblog 80 ${MICROBLOG_ONION_PORT})
  7899. MICROBLOG_SERVER=${MICROBLOG_DOMAIN_NAME}
  7900. if [[ $ONION_ONLY != 'no' ]]; then
  7901. MICROBLOG_SERVER=${MICROBLOG_ONION_HOSTNAME}
  7902. fi
  7903. # Create the configuration
  7904. gnu_social_installer=/var/www/${MICROBLOG_DOMAIN_NAME}/htdocs/scripts/install_cli.php
  7905. if [ ! -f $gnu_social_installer ]; then
  7906. echo $'No GNU Social commandline installer found'
  7907. exit 53026
  7908. fi
  7909. ${gnu_social_installer} --server "${MICROBLOG_SERVER}" \
  7910. --host="localhost" --database="gnusocial" \
  7911. --dbtype=mysql --username="root" -v \
  7912. --password="$MARIADB_PASSWORD" \
  7913. --sitename=$"GNU Social" --fancy='yes' \
  7914. --admin-nick="$MY_USERNAME" \
  7915. --admin-pass="$MICROBLOG_ADMIN_PASSWORD" \
  7916. --site-profile="community" \
  7917. --ssl=${gnu_social_ssl}
  7918. # There can be a lot of warnings here so the return value check is disabled
  7919. #if [ ! "$?" = "0" ]; then
  7920. # # failed to install
  7921. # echo $'Could not install GNU Social'
  7922. # exit 72357
  7923. #fi
  7924. # check microblog has a config file
  7925. microblog_config_file=/var/www/$MICROBLOG_DOMAIN_NAME/htdocs/config.php
  7926. if [ ! -f $microblog_config_file ]; then
  7927. echo $'Microblog config.php not found'
  7928. exit 87586
  7929. fi
  7930. # Some useful settings
  7931. if ! grep -q "Recommended GNU social settings" $microblog_config_file; then
  7932. echo "" >> $microblog_config_file
  7933. echo "// Recommended GNU social settings" >> $microblog_config_file
  7934. echo "\$config['thumbnail']['maxsize'] = 3000;" >> $microblog_config_file
  7935. echo "\$config['profile']['delete'] = true;" >> $microblog_config_file
  7936. echo "\$config['profile']['changenick'] = true;" >> $microblog_config_file
  7937. echo "\$config['public']['localonly'] = false;" >> $microblog_config_file
  7938. echo "addPlugin('StoreRemoteMedia');" >> $microblog_config_file
  7939. echo "\$config['queue']['enabled'] = true;" >> $microblog_config_file
  7940. echo "\$config['queue']['daemon'] = true;" >> $microblog_config_file
  7941. fi
  7942. # This improves performance
  7943. sed -i "s|//\$config\['db'\]\['schemacheck'\].*|\$config\['db'\]\['schemacheck'\] = 'script';|g" $microblog_config_file
  7944. systemctl restart php5-fpm
  7945. systemctl restart nginx
  7946. freedombone-addemail -u $MY_USERNAME -e "noreply@$MICROBLOG_DOMAIN_NAME" -g gnusocial --public no
  7947. # some post-install instructions for the user
  7948. if ! grep -q $"Microblog administrator" /home/$MY_USERNAME/README; then
  7949. echo '' >> /home/$MY_USERNAME/README
  7950. echo '' >> /home/$MY_USERNAME/README
  7951. echo $'Microblog' >> /home/$MY_USERNAME/README
  7952. echo '=========' >> /home/$MY_USERNAME/README
  7953. echo $"Microblog administrator nickname: $MY_USERNAME" >> /home/$MY_USERNAME/README
  7954. echo $"Microblog administrator password: $MICROBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7955. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7956. chmod 600 /home/$MY_USERNAME/README
  7957. fi
  7958. if ! grep -q "Microblog onion domain" /home/$MY_USERNAME/README; then
  7959. echo $"Microblog onion domain: ${MICROBLOG_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  7960. echo '' >> /home/$MY_USERNAME/README
  7961. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7962. chmod 600 /home/$MY_USERNAME/README
  7963. fi
  7964. echo "GNU Social onion domain:${MICROBLOG_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7965. echo "GNU Social domain:$MICROBLOG_DOMAIN_NAME" >> $COMPLETION_FILE
  7966. echo 'install_gnu_social' >> $COMPLETION_FILE
  7967. }
  7968. function install_gnu_social_plugin_sharings {
  7969. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7970. return
  7971. fi
  7972. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins ]; then
  7973. echo $'No local/plugins directory found for the microblog'
  7974. exit 72945
  7975. fi
  7976. # update to the next commit
  7977. set_repo_commit /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins "GNU Social sharings plugin commit" "$SHARINGS_COMMIT" $SHARINGS_REPO
  7978. if grep -Fxq "install_gnu_social_plugin_sharings" $COMPLETION_FILE; then
  7979. return
  7980. fi
  7981. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins
  7982. git_clone $SHARINGS_REPO Sharings
  7983. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Sharings ]; then
  7984. echo $'Unable to clone microblog sharings plugin'
  7985. exit 36738
  7986. fi
  7987. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Sharings
  7988. git stash
  7989. git checkout master
  7990. git branch -D $SHARINGS_COMMIT
  7991. git checkout $SHARINGS_COMMIT -b $SHARINGS_COMMIT
  7992. # enable the plugin
  7993. if ! grep -q "addPlugin('Sharings');" /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/config.php; then
  7994. echo "addPlugin('Sharings');" >> /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/config.php
  7995. fi
  7996. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7997. php scripts/checkschema.php
  7998. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Sharings
  7999. php scripts/seedsharings.php
  8000. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  8001. php scripts/checkschema.php
  8002. # Languages
  8003. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Sharings/locale/en/LC_MESSAGES
  8004. msgfmt -o Sharings.mo Sharings.po
  8005. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Sharings/locale/en_GB/LC_MESSAGES
  8006. msgfmt -o Sharings.mo Sharings.po
  8007. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Sharings/locale/en_US/LC_MESSAGES
  8008. msgfmt -o Sharings.mo Sharings.po
  8009. chown -R www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  8010. if ! grep -q "GNU Social sharings plugin commit" $COMPLETION_FILE; then
  8011. echo "GNU Social sharings plugin commit:$SHARINGS_COMMIT" >> $COMPLETION_FILE
  8012. else
  8013. sed -i "s|GNU Social sharings plugin commit.*|GNU Social sharings plugin commit:$SHARINGS_COMMIT|g" $COMPLETION_FILE
  8014. fi
  8015. echo 'install_gnu_social_plugin_sharings' >> $COMPLETION_FILE
  8016. }
  8017. function install_gnu_social_plugin_sharings_theme {
  8018. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8019. return
  8020. fi
  8021. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins ]; then
  8022. echo $'No local/plugins directory found for the microblog'
  8023. exit 74458
  8024. fi
  8025. # update to the next commit
  8026. set_repo_commit /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins "GNU Social sharings theme plugin commit" "$SHARINGS_THEME_COMMIT" $SHARINGS_THEME_REPO
  8027. if grep -Fxq "install_gnu_social_plugin_sharings_theme" $COMPLETION_FILE; then
  8028. return
  8029. fi
  8030. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins
  8031. git_clone $SHARINGS_THEME_REPO SharingsTheme
  8032. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/SharingsTheme ]; then
  8033. echo $'Unable to clone microblog sharings plugin theme'
  8034. exit 639253
  8035. fi
  8036. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/SharingsTheme
  8037. git stash
  8038. git checkout master
  8039. git branch -D $SHARINGS_THEME_COMMIT
  8040. git checkout $SHARINGS_THEME_COMMIT -b $SHARINGS_THEME_COMMIT
  8041. # enable the plugin
  8042. if ! grep -q "addPlugin('SharingsTheme');" /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/config.php; then
  8043. echo "addPlugin('SharingsTheme');" >> /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/config.php
  8044. fi
  8045. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  8046. php scripts/checkschema.php
  8047. chown -R www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  8048. if ! grep -q "GNU Social sharings plugin theme commit" $COMPLETION_FILE; then
  8049. echo "GNU Social sharings plugin theme commit:$SHARINGS_THEME_COMMIT" >> $COMPLETION_FILE
  8050. else
  8051. sed -i "s|GNU Social sharings plugin theme commit.*|GNU Social sharings plugin theme commit:$SHARINGS_THEME_COMMIT|g" $COMPLETION_FILE
  8052. fi
  8053. echo 'install_gnu_social_plugin_sharings_theme' >> $COMPLETION_FILE
  8054. }
  8055. function expire_gnu_social_posts {
  8056. # To prevent the database size from growing endlessly this script expires posts
  8057. # after a number of months
  8058. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8059. return
  8060. fi
  8061. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs ]; then
  8062. return
  8063. fi
  8064. gnusocial_expire_script=/usr/bin/gnusocial-expire
  8065. echo '<?php' > $gnusocial_expire_script
  8066. echo '' >> $gnusocial_expire_script
  8067. echo '// GNU Social post expiry script, based on StatExpire by Tony Baldwin' >> $gnusocial_expire_script
  8068. echo '// https://github.com/tonybaldwin/statexpire' >> $gnusocial_expire_script
  8069. echo '' >> $gnusocial_expire_script
  8070. echo '$oldate=date(("Y-m-d"), strtotime("-3 months"));' >> $gnusocial_expire_script
  8071. echo '$username="root";' >> $gnusocial_expire_script
  8072. echo "\$password=trim(file_get_contents(\"$DATABASE_PASSWORD_FILE\"));" >> $gnusocial_expire_script
  8073. echo '$database="gnusocial";' >> $gnusocial_expire_script
  8074. echo '' >> $gnusocial_expire_script
  8075. echo 'if (!$link = mysql_connect("localhost", $username, $password)) {' >> $gnusocial_expire_script
  8076. echo ' echo "Could not connect to mariadb";' >> $gnusocial_expire_script
  8077. echo ' exit;' >> $gnusocial_expire_script
  8078. echo '}' >> $gnusocial_expire_script
  8079. echo '' >> $gnusocial_expire_script
  8080. echo 'if (!mysql_select_db($database, $link)) {' >> $gnusocial_expire_script
  8081. echo ' echo "Could not select gnusocial database";' >> $gnusocial_expire_script
  8082. echo ' exit;' >> $gnusocial_expire_script
  8083. echo '}' >> $gnusocial_expire_script
  8084. echo '' >> $gnusocial_expire_script
  8085. echo "\$notice_query=\"DELETE FROM notice WHERE created <= '\$oldate 01:01:01'\";" >> $gnusocial_expire_script
  8086. echo "\$conversation_query=\"DELETE FROM conversation WHERE created <= '$oldate 01:01:01'\";" >> $gnusocial_expire_script
  8087. echo "\$reply_query=\"DELETE FROM reply WHERE modified <= '\$oldate 01:01:01'\";" >> $gnusocial_expire_script
  8088. echo '' >> $gnusocial_expire_script
  8089. echo 'mysql_query($notice_query);' >> $gnusocial_expire_script
  8090. echo '$rowaff1=mysql_affected_rows();' >> $gnusocial_expire_script
  8091. echo 'mysql_query($conversation_query);' >> $gnusocial_expire_script
  8092. echo '$rowaff2=mysql_affected_rows();' >> $gnusocial_expire_script
  8093. echo 'mysql_query($reply_query);' >> $gnusocial_expire_script
  8094. echo '$rowaff3=mysql_affected_rows();' >> $gnusocial_expire_script
  8095. echo 'mysql_close();' >> $gnusocial_expire_script
  8096. echo '' >> $gnusocial_expire_script
  8097. echo 'echo "Expire GNU Social posts: $rowaff1 notices, $rowaff2 conversations, and $rowaff3 replies deleted from database.\n";' >> $gnusocial_expire_script
  8098. chmod +x $gnusocial_expire_script
  8099. # Add a cron job
  8100. if ! grep -q "$gnusocial_expire_script" /etc/crontab; then
  8101. echo "10 3 5 * * root /usr/bin/timeout 500 /usr/bin/php $gnusocial_expire_script" >> /etc/crontab
  8102. fi
  8103. # remove old expire script
  8104. if [ -f /etc/cron.weekly/clear-microblog-database ]; then
  8105. rm /etc/cron.weekly/clear-microblog-database
  8106. fi
  8107. }
  8108. function install_gnu_social_theme {
  8109. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8110. return
  8111. fi
  8112. # update to the next commit
  8113. set_repo_commit /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Qvitter "GNU Social theme commit" "$MICROBLOG_THEME_COMMIT" $MICROBLOG_THEME_REPO
  8114. # customise with project logo
  8115. if [ -f /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Qvitter/img/sprite.png ]; then
  8116. if [ -f ~/freedombone/img/gnusocial_sprite.png ]; then
  8117. cp ~/freedombone/img/gnusocial_sprite.png /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Qvitter/img/sprite.png
  8118. fi
  8119. fi
  8120. if grep -Fxq "install_gnu_social_theme" $COMPLETION_FILE; then
  8121. return
  8122. fi
  8123. apt-get -y install wget
  8124. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins ]; then
  8125. mkdir -p /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins
  8126. fi
  8127. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins
  8128. git_clone $MICROBLOG_THEME_REPO Qvitter
  8129. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Qvitter
  8130. git checkout $MICROBLOG_THEME_COMMIT -b $MICROBLOG_THEME_COMMIT
  8131. # download a custom background image
  8132. MICROBLOG_BACKGROUND_IMAGE_URL_EXT=
  8133. if [ $MICROBLOG_BACKGROUND_IMAGE_URL ]; then
  8134. if [[ $$MICROBLOG_BACKGROUND_IMAGE_URL == *".jpeg" || $$MICROBLOG_BACKGROUND_IMAGE_URL == *".jpg" ]]; then
  8135. MICROBLOG_BACKGROUND_IMAGE_URL_EXT="jpg"
  8136. fi
  8137. if [[ $$MICROBLOG_BACKGROUND_IMAGE_URL == *".png" ]]; then
  8138. MICROBLOG_BACKGROUND_IMAGE_URL_EXT="png"
  8139. fi
  8140. if [[ $$MICROBLOG_BACKGROUND_IMAGE_URL == *".gif" ]]; then
  8141. MICROBLOG_BACKGROUND_IMAGE_URL_EXT="gif"
  8142. fi
  8143. if [ $MICROBLOG_BACKGROUND_IMAGE_URL_EXT ]; then
  8144. wget $MICROBLOG_BACKGROUND_IMAGE_URL -O img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT}
  8145. if [ ! -f img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT} ]; then
  8146. echo "$MICROBLOG_BACKGROUND_IMAGE_URL"
  8147. echo $'Custom background image for microblog could not be downloaded'
  8148. exit 87524
  8149. fi
  8150. fi
  8151. fi
  8152. microblog_config_file=/var/www/$MICROBLOG_DOMAIN_NAME/htdocs/config.php
  8153. if ! grep -q "addPlugin('Qvitter')" $microblog_config_file; then
  8154. MICROBLOG_WELCOME_MESSAGE=$(echo $MICROBLOG_WELCOME_MESSAGE | sed "s|\$MICROBLOG_DOMAIN_NAME|$MICROBLOG_DOMAIN_NAME|g")
  8155. echo "" >> $microblog_config_file
  8156. echo "// Qvitter settings" >> $microblog_config_file
  8157. echo "addPlugin('Qvitter');" >> $microblog_config_file
  8158. echo "\$config['site']['qvitter']['enabledbydefault'] = true;" >> $microblog_config_file
  8159. echo "\$config['site']['qvitter']['defaultbackgroundcolor'] = '#f4f4f4';" >> $microblog_config_file
  8160. echo "\$config['site']['qvitter']['defaultlinkcolor'] = '#0084B4';" >> $microblog_config_file
  8161. echo "\$config['site']['qvitter']['timebetweenpolling'] = 30000; // 30 secs" >> $microblog_config_file
  8162. echo "\$config['site']['qvitter']['urlshortenerapiurl'] = 'http://qttr.at/shortener.php';" >> $microblog_config_file
  8163. echo "\$config['site']['qvitter']['urlshortenersignature'] = 'b6afeec983';" >> $microblog_config_file
  8164. if [ $MICROBLOG_BACKGROUND_IMAGE_URL ]; then
  8165. echo "\$config['site']['qvitter']['sitebackground'] = 'img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT}';" >> $microblog_config_file
  8166. else
  8167. echo "\$config['site']['qvitter']['sitebackground'] = 'img/vagnsmossen.jpg';" >> $microblog_config_file
  8168. fi
  8169. echo "\$config['site']['qvitter']['favicon'] = 'img/favicon.ico?v=4';" >> $microblog_config_file
  8170. echo "\$config['site']['qvitter']['sprite'] = Plugin::staticPath('Qvitter', '').'img/sprite.png?v=40';" >> $microblog_config_file
  8171. echo "\$config['site']['qvitter']['enablewelcometext'] = true;" >> $microblog_config_file
  8172. echo "\$config['site']['qvitter']['customwelcometext']['en'] = '$MICROBLOG_WELCOME_MESSAGE';" >> $microblog_config_file
  8173. echo "\$config['site']['qvitter']['customwelcometext']['de'] = '$MICROBLOG_WELCOME_MESSAGE';" >> $microblog_config_file
  8174. echo "\$config['site']['qvitter']['customwelcometext']['fr'] = '$MICROBLOG_WELCOME_MESSAGE';" >> $microblog_config_file
  8175. echo "\$config['site']['qvitter']['customwelcometext']['es'] = '$MICROBLOG_WELCOME_MESSAGE';" >> $microblog_config_file
  8176. echo "\$config['site']['qvitter']['blocked_ips'] = array();" >> $microblog_config_file
  8177. else
  8178. if [ $MICROBLOG_BACKGROUND_IMAGE_URL_EXT ]; then
  8179. if [ -f img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT} ]; then
  8180. sed -i "s|\$config['site']['qvitter']['sitebackground'].*|\$config['site']['qvitter']['sitebackground'] = 'img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT}';|g" $microblog_config_file
  8181. fi
  8182. fi
  8183. fi
  8184. # customise with project logo
  8185. if [ -f /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Qvitter/img/sprite.png ]; then
  8186. if [ -f ~/freedombone/img/gnusocial_sprite.png ]; then
  8187. cp ~/freedombone/img/gnusocial_sprite.png /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Qvitter/img/sprite.png
  8188. fi
  8189. fi
  8190. if ! grep -q "GNU Social theme commit" $COMPLETION_FILE; then
  8191. echo "GNU Social theme commit:$MICROBLOG_THEME_COMMIT" >> $COMPLETION_FILE
  8192. fi
  8193. chown -R www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  8194. echo 'install_gnu_social_theme' >> $COMPLETION_FILE
  8195. }
  8196. function install_gnu_social_markdown {
  8197. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8198. return
  8199. fi
  8200. MICROBLOG_PATH=/var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  8201. # update to the next commit
  8202. set_repo_commit $MICROBLOG_PATH/local/plugins/Markdown "GNU Social Markdown commit" "$MICROBLOG_MARKDOWN_COMMIT" $MICROBLOG_MARKDOWN_REPO
  8203. if grep -Fxq "install_gnu_social_markdown" $COMPLETION_FILE; then
  8204. return
  8205. fi
  8206. if [ -d $MICROBLOG_PATH/local/plugins/Markdown ]; then
  8207. rm -rf $MICROBLOG_PATH/local/plugins/Markdown
  8208. fi
  8209. if [ ! -d $MICROBLOG_PATH/local/plugins ]; then
  8210. mkdir -p $MICROBLOG_PATH/local/plugins
  8211. fi
  8212. cd $MICROBLOG_PATH/local/plugins
  8213. git_clone $MICROBLOG_MARKDOWN_REPO Markdown
  8214. cd $MICROBLOG_PATH/local/plugins/Markdown
  8215. git checkout $MICROBLOG_MARKDOWN_COMMIT -b $MICROBLOG_MARKDOWN_COMMIT
  8216. microblog_config_file=$MICROBLOG_PATH/config.php
  8217. if ! grep -q "addPlugin('Markdown'" $microblog_config_file; then
  8218. echo "" >> $microblog_config_file
  8219. echo "// Markdown settings" >> $microblog_config_file
  8220. echo "addPlugin('Markdown');" >> $microblog_config_file
  8221. fi
  8222. if ! grep -q "GNU Social Markdown commit" $COMPLETION_FILE; then
  8223. echo "GNU Social Markdown commit:$MICROBLOG_MARKDOWN_COMMIT" >> $COMPLETION_FILE
  8224. fi
  8225. chown -R www-data:www-data $MICROBLOG_PATH
  8226. echo 'install_gnu_social_markdown' >> $COMPLETION_FILE
  8227. }
  8228. function install_search_engine {
  8229. # Note: currently socks5 outgoing proxies to other search engines does not work
  8230. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8231. return
  8232. fi
  8233. if [ ! -d /etc/nginx ]; then
  8234. echo $'Webserver is not installed'
  8235. exit 62429
  8236. fi
  8237. # update to a new commit if needed
  8238. set_repo_commit $SEARCH_ENGINE_PATH/searx "Search engine commit" "$SEARCH_ENGINE_COMMIT" $SEARCH_ENGINE_REPO
  8239. if grep "Search engine key" $COMPLETION_FILE; then
  8240. if [ -f ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml ]; then
  8241. # note: this might change to a --tor option in a later version
  8242. if ! grep 'socks5://127.0.0.1:9050' ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml; then
  8243. echo 'outgoing: # communication with search engines' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8244. echo ' proxies:' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8245. echo ' http : socks5://127.0.0.1:9050' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8246. echo ' https: socks5://127.0.0.1:9050' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8247. fi
  8248. SEARCH_ENGINE_SECRET_KEY=$(cat $COMPLETION_FILE | grep "Search engine key" | awk -F ':' '{print $2}')
  8249. sed -i "s|secret_key.*|secret_key : \"${SEARCH_ENGINE_SECRET_KEY}\"|g" ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8250. if [ -f /var/lib/tor/hidden_service_searx/hostname ]; then
  8251. SEARCH_ENGINE_ONION_HOSTNAME=$(echo /var/lib/tor/hidden_service_searx/hostname)
  8252. sed -i '0,/RE/s/base_url.*/base_url : \"http://${SEARCH_ENGINE_ONION_HOSTNAME}\/' ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8253. fi
  8254. fi
  8255. fi
  8256. if grep -Fxq "install_search_engine" $COMPLETION_FILE; then
  8257. return
  8258. fi
  8259. apt-get -y install python-pip libyaml-dev python-werkzeug python-babel python-lxml apache2-utils
  8260. apt-get -y install git build-essential libxslt-dev python-dev python-virtualenv python-pybabel zlib1g-dev uwsgi uwsgi-plugin-python libapache2-mod-uwsgi
  8261. pip install --upgrade pip
  8262. pip install certifi
  8263. if [ ! "$?" = "0" ]; then
  8264. echo $'Failed to install certifi'
  8265. exit 737692
  8266. fi
  8267. pip install pyyaml
  8268. if [ ! "$?" = "0" ]; then
  8269. echo $'Failed to install pyyaml'
  8270. exit 469242
  8271. fi
  8272. pip install flask --upgrade
  8273. if [ ! "$?" = "0" ]; then
  8274. echo $'Failed to install flask'
  8275. exit 888575
  8276. fi
  8277. pip install flask_restless --upgrade
  8278. if [ ! "$?" = "0" ]; then
  8279. echo $'Failed to install flask_restless'
  8280. exit 54835
  8281. fi
  8282. pip install flask_babel --upgrade
  8283. if [ ! "$?" = "0" ]; then
  8284. echo $'Failed to install flask_babel'
  8285. exit 63738
  8286. fi
  8287. if [ ! -d $SEARCH_ENGINE_PATH ]; then
  8288. mkdir -p $SEARCH_ENGINE_PATH
  8289. fi
  8290. # clone the repo
  8291. cd $SEARCH_ENGINE_PATH
  8292. git_clone $SEARCH_ENGINE_REPO searx
  8293. git checkout $SEARCH_ENGINE_COMMIT -b $SEARCH_ENGINE_COMMIT
  8294. if ! grep -q "Search engine commit" $COMPLETION_FILE; then
  8295. echo "Search engine commit:$SEARCH_ENGINE_COMMIT" >> $COMPLETION_FILE
  8296. else
  8297. sed -i "s/Search engine commit.*/Search engine commit:$SEARCH_ENGINE_COMMIT/g" $COMPLETION_FILE
  8298. fi
  8299. # create an onion service
  8300. SEARCH_ENGINE_ONION_HOSTNAME=$(add_onion_service searx 80 ${SEARCH_ENGINE_ONION_PORT})
  8301. if ! grep "Search engine onion domain" $COMPLETION_FILE; then
  8302. echo "Search engine onion domain:${SEARCH_ENGINE_ONION_HOSTNAME}" >> $COMPLETION_FILE
  8303. else
  8304. sed -i "s|Search engine onion domain.*|Search engine onion domain:${SEARCH_ENGINE_ONION_HOSTNAME}|g" $COMPLETION_FILE
  8305. fi
  8306. # an unprivileged user to run as
  8307. useradd -d ${SEARCH_ENGINE_PATH}/searx/ -s /bin/false searx
  8308. adduser searx debian-tor
  8309. # daemon
  8310. echo '[Unit]' > /etc/systemd/system/searx.service
  8311. echo 'Description=Searx (search engine)' >> /etc/systemd/system/searx.service
  8312. echo 'After=syslog.target' >> /etc/systemd/system/searx.service
  8313. echo 'After=network.target' >> /etc/systemd/system/searx.service
  8314. echo '' >> /etc/systemd/system/searx.service
  8315. echo '[Service]' >> /etc/systemd/system/searx.service
  8316. echo 'Type=simple' >> /etc/systemd/system/searx.service
  8317. echo 'User=searx' >> /etc/systemd/system/searx.service
  8318. echo 'Group=searx' >> /etc/systemd/system/searx.service
  8319. echo "WorkingDirectory=${SEARCH_ENGINE_PATH}/searx" >> /etc/systemd/system/searx.service
  8320. echo "ExecStart=/usr/bin/python ${SEARCH_ENGINE_PATH}/searx/searx/webapp.py" >> /etc/systemd/system/searx.service
  8321. echo 'Restart=always' >> /etc/systemd/system/searx.service
  8322. echo 'Environment="USER=searx"' >> /etc/systemd/system/searx.service
  8323. echo '' >> /etc/systemd/system/searx.service
  8324. echo '[Install]' >> /etc/systemd/system/searx.service
  8325. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/searx.service
  8326. # create a webserver file
  8327. echo 'server {' > /etc/nginx/sites-available/searx
  8328. echo " listen 127.0.0.1:${SEARCH_ENGINE_ONION_PORT} default_server;" >> /etc/nginx/sites-available/searx
  8329. echo " root ${SEARCH_ENGINE_PATH}/searx;" >> /etc/nginx/sites-available/searx
  8330. echo " server_name ${SEARCH_ENGINE_ONION_HOSTNAME};" >> /etc/nginx/sites-available/searx
  8331. echo ' access_log off;' >> /etc/nginx/sites-available/searx
  8332. echo " error_log /var/log/searx_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/searx
  8333. echo '' >> /etc/nginx/sites-available/searx
  8334. nginx_limits searx '1M'
  8335. nginx_disable_sniffing searx
  8336. echo ' add_header Strict-Transport-Security max-age=0;' >> /etc/nginx/sites-available/searx
  8337. echo '' >> /etc/nginx/sites-available/searx
  8338. echo ' location / {' >> /etc/nginx/sites-available/searx
  8339. echo ' proxy_pass http://localhost:8888;' >> /etc/nginx/sites-available/searx
  8340. echo ' proxy_set_header Host $host;' >> /etc/nginx/sites-available/searx
  8341. echo ' proxy_set_header X-Real-IP $remote_addr;' >> /etc/nginx/sites-available/searx
  8342. echo ' proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;' >> /etc/nginx/sites-available/searx
  8343. echo ' proxy_set_header X-Remote-Port $remote_port;' >> /etc/nginx/sites-available/searx
  8344. echo ' proxy_set_header X-Forwarded-Proto $scheme;' >> /etc/nginx/sites-available/searx
  8345. echo ' proxy_redirect off;' >> /etc/nginx/sites-available/searx
  8346. echo " auth_basic \"${SEARCH_ENGINE_LOGIN_TEXT}\";" >> /etc/nginx/sites-available/searx
  8347. echo ' auth_basic_user_file /etc/nginx/.htpasswd;' >> /etc/nginx/sites-available/searx
  8348. echo ' }' >> /etc/nginx/sites-available/searx
  8349. echo '' >> /etc/nginx/sites-available/searx
  8350. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/searx
  8351. echo '' >> /etc/nginx/sites-available/searx
  8352. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/searx
  8353. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/searx
  8354. echo '' >> /etc/nginx/sites-available/searx
  8355. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/searx
  8356. echo ' allow all;' >> /etc/nginx/sites-available/searx
  8357. echo ' log_not_found off;' >> /etc/nginx/sites-available/searx
  8358. echo ' access_log off;' >> /etc/nginx/sites-available/searx
  8359. echo ' }' >> /etc/nginx/sites-available/searx
  8360. echo '}' >> /etc/nginx/sites-available/searx
  8361. # replace the secret key
  8362. if ! grep "Search engine key" $COMPLETION_FILE; then
  8363. SEARCH_ENGINE_SECRET_KEY="$(openssl rand -base64 32 | cut -c1-30)"
  8364. echo "Search engine key:${SEARCH_ENGINE_SECRET_KEY}" >> $COMPLETION_FILE
  8365. else
  8366. SEARCH_ENGINE_SECRET_KEY=$(cat $COMPLETION_FILE | grep "Search engine key" | awk -F ':' '{print $2}')
  8367. fi
  8368. sed -i "s|secret_key.*|secret_key : \"${SEARCH_ENGINE_SECRET_KEY}\"|g" ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8369. sed -i "s|secret_key.*|secret_key : \"${SEARCH_ENGINE_SECRET_KEY}\"|g" ${SEARCH_ENGINE_PATH}/searx/searx/settings_robot.yml
  8370. sed -i '0,/RE/s/base_url.*/base_url : \"http://${SEARCH_ENGINE_ONION_HOSTNAME}\/' ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8371. sed -i '0,/RE/s/base_url.*/base_url : \"http://${SEARCH_ENGINE_ONION_HOSTNAME}\/' ${SEARCH_ENGINE_PATH}/searx/searx/settings_robot.yml
  8372. # note: this might change to a --tor option in a later version
  8373. if ! grep 'socks5://127.0.0.1:9050' ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml; then
  8374. echo 'outgoing: # communication with search engines' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8375. echo ' proxies:' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8376. echo ' http : socks5://127.0.0.1:9050' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8377. echo ' https: socks5://127.0.0.1:9050' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  8378. fi
  8379. chown -R searx:searx ${SEARCH_ENGINE_PATH}/searx
  8380. # enable the site
  8381. nginx_ensite searx
  8382. # restart the web server
  8383. systemctl restart php5-fpm
  8384. systemctl restart nginx
  8385. # start the daemon
  8386. systemctl enable searx.service
  8387. systemctl daemon-reload
  8388. systemctl start searx.service
  8389. if ! grep -q "Your search engine password is" /home/$MY_USERNAME/README; then
  8390. if [ ${#SEARCH_ENGINE_PASSWORD} -lt 8 ]; then
  8391. if [ -f $IMAGE_PASSWORD_FILE ]; then
  8392. SEARCH_ENGINE_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  8393. else
  8394. SEARCH_ENGINE_PASSWORD="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  8395. fi
  8396. fi
  8397. echo "$SEARCH_ENGINE_PASSWORD" | htpasswd -i -s -c /etc/nginx/.htpasswd $MY_USERNAME
  8398. echo '' >> /home/$MY_USERNAME/README
  8399. echo '' >> /home/$MY_USERNAME/README
  8400. echo $'Search Engine' >> /home/$MY_USERNAME/README
  8401. echo '=============' >> /home/$MY_USERNAME/README
  8402. echo $"Search engine onion domain: ${SEARCH_ENGINE_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  8403. echo $"Your search engine password is: $SEARCH_ENGINE_PASSWORD" >> /home/$MY_USERNAME/README
  8404. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  8405. chmod 600 /home/$MY_USERNAME/README
  8406. fi
  8407. echo 'install_search_engine' >> $COMPLETION_FILE
  8408. }
  8409. function install_webmail {
  8410. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8411. return
  8412. fi
  8413. WEB_PATH=/var/www
  8414. WEBMAIL_PATH=$WEB_PATH/webmail
  8415. # update to a new commit if needed
  8416. set_repo_commit $WEBMAIL_PATH "Webmail commit" "$WEBMAIL_COMMIT" $WEBMAIL_REPO
  8417. if grep -Fxq "install_webmail" $COMPLETION_FILE; then
  8418. return
  8419. fi
  8420. if [ -d /etc/apache2 ]; then
  8421. rm -rf /etc/apache2
  8422. echo $'Removed Apache installation after Dokuwiki install'
  8423. fi
  8424. install_mariadb
  8425. get_mariadb_password
  8426. repair_databases_script
  8427. apt-get -y install php5-common php5-cli php5-curl php5-gd php5-mysql php5-mcrypt git
  8428. apt-get -y install php5-dev imagemagick php5-imagick php5-sqlite php-auth-sasl php-net-smtp php-mime-type
  8429. apt-get -y install php-mail-mime php-mail-mimedecode php-net-ldap3 php5-pspell
  8430. pear install Net_IDNA2
  8431. if [ ! -f $WEBMAIL_PATH/index.php ]; then
  8432. cd $WEB_PATH
  8433. git_clone $WEBMAIL_REPO webmail
  8434. cd $WEBMAIL_PATH
  8435. git checkout $WEBMAIL_COMMIT -b $WEBMAIL_COMMIT
  8436. if ! grep -q "Webmail commit" $COMPLETION_FILE; then
  8437. echo "Webmail commit:$WEBMAIL_COMMIT" >> $COMPLETION_FILE
  8438. else
  8439. sed -i "s/Webmail commit.*/Webmail commit:$WEBMAIL_COMMIT/g" $COMPLETION_FILE
  8440. fi
  8441. fi
  8442. if [ ! -f $WEBMAIL_PATH/index.php ]; then
  8443. echo $'Did not clone webmail repo'
  8444. exit 52825
  8445. fi
  8446. WEBMAIL_ONION_HOSTNAME=$(add_onion_service webmail 80 ${WEBMAIL_ONION_PORT})
  8447. echo "Webmail onion domain:${WEBMAIL_ONION_HOSTNAME}" >> $COMPLETION_FILE
  8448. get_mariadb_webmail_admin_password
  8449. if [ ! $WEBMAIL_ADMIN_PASSWORD ]; then
  8450. if [ -f $IMAGE_PASSWORD_FILE ]; then
  8451. WEBMAIL_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  8452. else
  8453. WEBMAIL_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  8454. fi
  8455. fi
  8456. create_database webmail "$WEBMAIL_ADMIN_PASSWORD"
  8457. mysql -u root --password="$MARIADB_PASSWORD" -D webmail < $WEBMAIL_PATH/SQL/mysql.initial.sql
  8458. if [ ! -d /var/www/$DEFAULT_DOMAIN_NAME/htdocs ]; then
  8459. mkdir -p /var/www/$DEFAULT_DOMAIN_NAME/htdocs
  8460. fi
  8461. ln -s $WEBMAIL_PATH /var/www/$DEFAULT_DOMAIN_NAME/htdocs/webmail
  8462. if [ ! -f /var/www/webmail/config/config.inc.php ]; then
  8463. # generate the configuration
  8464. echo '<?php' > /var/www/webmail/config/config.inc.php
  8465. echo "\$config['db_dsnw'] = 'mysql://root:${MARIADB_PASSWORD}@localhost/webmail';" >> /var/www/webmail/config/config.inc.php
  8466. echo "\$config['default_host'] = 'localhost';" >> /var/www/webmail/config/config.inc.php
  8467. echo "\$config['support_url'] = '';" >> /var/www/webmail/config/config.inc.php
  8468. WEBMAIL_DES_KEY="$(openssl rand -base64 32 | cut -c1-25)"
  8469. echo "\$config['des_key'] = '${WEBMAIL_DES_KEY}';" >> /var/www/webmail/config/config.inc.php
  8470. echo "\$config['product_name'] = '${PROJECT_NAME}';" >> /var/www/webmail/config/config.inc.php
  8471. echo "\$config['plugins'] = array('enigma');" >> /var/www/webmail/config/config.inc.php
  8472. echo "\$config['mime_param_folding'] = 0;" >> /var/www/webmail/config/config.inc.php
  8473. echo "\$config['enable_installer'] = false;" >> /var/www/webmail/config/config.inc.php
  8474. fi
  8475. chown -R www-data:www-data $WEBMAIL_PATH
  8476. echo 'server {' > /etc/nginx/sites-available/webmail
  8477. echo " listen 127.0.0.1:$WEBMAIL_ONION_PORT default_server;" >> /etc/nginx/sites-available/webmail
  8478. echo " server_name $WEBMAIL_ONION_HOSTNAME;" >> /etc/nginx/sites-available/webmail
  8479. echo " root ${WEBMAIL_PATH};" >> /etc/nginx/sites-available/webmail
  8480. echo ' index index.php index.html index.htm;' >> /etc/nginx/sites-available/webmail
  8481. echo ' access_log off;' >> /etc/nginx/sites-available/webmail
  8482. echo ' error_log off;' >> /etc/nginx/sites-available/webmail
  8483. echo ' location / {' >> /etc/nginx/sites-available/webmail
  8484. echo ' try_files $uri $uri/ /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/webmail
  8485. echo ' }' >> /etc/nginx/sites-available/webmail
  8486. echo ' error_page 404 /404.html;' >> /etc/nginx/sites-available/webmail
  8487. echo ' error_page 500 502 503 504 /50x.html;' >> /etc/nginx/sites-available/webmail
  8488. echo ' location = /50x.html {' >> /etc/nginx/sites-available/webmail
  8489. echo " root ${WEBMAIL_PATH};" >> /etc/nginx/sites-available/webmail
  8490. echo ' }' >> /etc/nginx/sites-available/webmail
  8491. echo ' location ~ ^/(README.md|INSTALL|LICENSE|CHANGELOG|UPGRADING)$ {' >> /etc/nginx/sites-available/webmail
  8492. echo ' deny all;' >> /etc/nginx/sites-available/webmail
  8493. echo ' }' >> /etc/nginx/sites-available/webmail
  8494. echo ' location ~ ^/(config|temp|logs)/ {' >> /etc/nginx/sites-available/webmail
  8495. echo ' deny all;' >> /etc/nginx/sites-available/webmail
  8496. echo ' }' >> /etc/nginx/sites-available/webmail
  8497. echo ' location ~ /\. {' >> /etc/nginx/sites-available/webmail
  8498. echo ' deny all;' >> /etc/nginx/sites-available/webmail
  8499. echo ' access_log off;' >> /etc/nginx/sites-available/webmail
  8500. echo ' log_not_found off;' >> /etc/nginx/sites-available/webmail
  8501. echo ' }' >> /etc/nginx/sites-available/webmail
  8502. echo ' location ~ \.php$ {' >> /etc/nginx/sites-available/webmail
  8503. echo ' try_files $uri =404;' >> /etc/nginx/sites-available/webmail
  8504. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/webmail
  8505. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/webmail
  8506. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/webmail
  8507. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/webmail
  8508. echo ' }' >> /etc/nginx/sites-available/webmail
  8509. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/webmail
  8510. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/webmail
  8511. echo ' client_max_body_size 15m;' >> /etc/nginx/sites-available/webmail
  8512. echo '}' >> /etc/nginx/sites-available/webmail
  8513. nginx_ensite webmail
  8514. systemctl restart php5-fpm
  8515. systemctl restart nginx
  8516. if ! grep -q "Webmail" /home/$MY_USERNAME/README; then
  8517. echo '' >> /home/$MY_USERNAME/README
  8518. echo '' >> /home/$MY_USERNAME/README
  8519. echo 'Webmail' >> /home/$MY_USERNAME/README
  8520. echo '=======' >> /home/$MY_USERNAME/README
  8521. if [[ $ONION_ONLY == 'no' ]]; then
  8522. echo $"Open https://$DEFAULT_DOMAIN_NAME/webmail/index.php" >> /home/$MY_USERNAME/README
  8523. else
  8524. echo $"Open http://$WEBMAIL_ONION_HOSTNAME" >> /home/$MY_USERNAME/README
  8525. fi
  8526. echo $"MariaDB webmail admin password: $WEBMAIL_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  8527. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  8528. chmod 600 /home/$MY_USERNAME/README
  8529. fi
  8530. echo 'install_webmail' >> $COMPLETION_FILE
  8531. }
  8532. function install_hubzilla {
  8533. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8534. return
  8535. fi
  8536. if [ ! $HUBZILLA_DOMAIN_NAME ]; then
  8537. return
  8538. fi
  8539. HUBZILLA_PATH=/var/www/$HUBZILLA_DOMAIN_NAME/htdocs
  8540. # update to a new commit if needed
  8541. set_repo_commit $HUBZILLA_PATH "Hubzilla commit" "$HUBZILLA_COMMIT" $HUBZILLA_REPO
  8542. set_repo_commit $HUBZILLA_PATH/addon "Hubzilla addons commit" "$HUBZILLA_ADDONS_COMMIT" $HUBZILLA_ADDONS_REPO
  8543. if [ -d $HUBZILLA_PATH/redmatrix-themes1 ]; then
  8544. cd $HUBZILLA_PATH/redmatrix-themes1
  8545. git stash
  8546. git pull
  8547. cp -r $HUBZILLA_PATH/redmatrix-themes1/* $HUBZILLA_PATH/view/theme/
  8548. chown -R www-data:www-data $HUBZILLA_PATH
  8549. fi
  8550. if grep -Fxq "install_hubzilla" $COMPLETION_FILE; then
  8551. return
  8552. fi
  8553. install_mariadb
  8554. get_mariadb_password
  8555. repair_databases_script
  8556. apt-get -y install php5-common php5-cli php5-curl php5-gd php5-mysql php5-mcrypt git
  8557. apt-get -y install php5-dev imagemagick php5-imagick
  8558. if [ ! -d /var/www/$HUBZILLA_DOMAIN_NAME ]; then
  8559. mkdir /var/www/$HUBZILLA_DOMAIN_NAME
  8560. fi
  8561. if [ ! -d $HUBZILLA_PATH ]; then
  8562. mkdir $HUBZILLA_PATH
  8563. fi
  8564. if [ ! -f $HUBZILLA_PATH/index.php ]; then
  8565. cd $INSTALL_DIR
  8566. git_clone $HUBZILLA_REPO hubzilla
  8567. git checkout $HUBZILLA_COMMIT -b $HUBZILLA_COMMIT
  8568. if ! grep -q "Hubzilla commit" $COMPLETION_FILE; then
  8569. echo "Hubzilla commit:$HUBZILLA_COMMIT" >> $COMPLETION_FILE
  8570. else
  8571. sed -i "s/Hubzilla commit.*/Hubzilla commit:$HUBZILLA_COMMIT/g" $COMPLETION_FILE
  8572. fi
  8573. rm -rf $HUBZILLA_PATH
  8574. mv hubzilla $HUBZILLA_PATH
  8575. git_clone $HUBZILLA_ADDONS_REPO $HUBZILLA_PATH/addon
  8576. cd $HUBZILLA_PATH/addon
  8577. git checkout $HUBZILLA_ADDONS_COMMIT -b $HUBZILLA_ADDONS_COMMIT
  8578. if ! grep -q "Hubzilla addons commit" $COMPLETION_FILE; then
  8579. echo "Hubzilla addons commit:$HUBZILLA_ADDONS_COMMIT" >> $COMPLETION_FILE
  8580. else
  8581. sed -i "s/Hubzilla addons commit.*/Hubzilla addons commit:$HUBZILLA_ADDONS_COMMIT/g" $COMPLETION_FILE
  8582. fi
  8583. # some extra themes
  8584. git_clone $HUBZILLA_THEMES_REPO $HUBZILLA_PATH/redmatrix-themes1
  8585. cp -r $HUBZILLA_PATH/redmatrix-themes1/* $HUBZILLA_PATH/view/theme/
  8586. chown -R www-data:www-data $HUBZILLA_PATH
  8587. fi
  8588. HUBZILLA_ONION_HOSTNAME=
  8589. if [[ $ONION_ONLY != "no" ]]; then
  8590. HUBZILLA_ONION_HOSTNAME=$(add_onion_service hubzilla 80 ${HUBZILLA_ONION_PORT})
  8591. echo "Hubzilla onion domain:${HUBZILLA_ONION_HOSTNAME}" >> $COMPLETION_FILE
  8592. fi
  8593. get_mariadb_hubzilla_admin_password
  8594. if [ ! $HUBZILLA_ADMIN_PASSWORD ]; then
  8595. if [ -f $IMAGE_PASSWORD_FILE ]; then
  8596. HUBZILLA_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  8597. else
  8598. HUBZILLA_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  8599. fi
  8600. echo '' >> /home/$MY_USERNAME/README
  8601. echo '' >> /home/$MY_USERNAME/README
  8602. echo 'Hubzilla' >> /home/$MY_USERNAME/README
  8603. echo '========' >> /home/$MY_USERNAME/README
  8604. if [[ $ONION_ONLY == 'no' ]]; then
  8605. echo $"Open https://$HUBZILLA_DOMAIN_NAME and register a new user" >> /home/$MY_USERNAME/README
  8606. else
  8607. echo $"Open http://$HUBZILLA_ONION_HOSTNAME and register a new user" >> /home/$MY_USERNAME/README
  8608. fi
  8609. echo $"Your MariaDB Hubzilla admin password is: $HUBZILLA_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  8610. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  8611. chmod 600 /home/$MY_USERNAME/README
  8612. fi
  8613. create_database hubzilla "$HUBZILLA_ADMIN_PASSWORD"
  8614. if ! grep -q "$HUBZILLA_PATH" /etc/crontab; then
  8615. echo "12,22,32,42,52 * * * * root cd $HUBZILLA_PATH; /usr/bin/timeout 500 /usr/bin/php include/poller.php" >> /etc/crontab
  8616. fi
  8617. add_ddns_domain $HUBZILLA_DOMAIN_NAME
  8618. if [[ $ONION_ONLY == "no" ]]; then
  8619. nginx_http_redirect $HUBZILLA_DOMAIN_NAME
  8620. echo 'server {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8621. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8622. echo " root $HUBZILLA_PATH;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8623. echo " server_name $HUBZILLA_DOMAIN_NAME;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8624. echo " error_log /var/log/nginx/${HUBZILLA_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8625. echo ' index index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8626. echo ' charset utf-8;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8627. echo ' access_log off;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8628. nginx_limits $HUBZILLA_DOMAIN_NAME
  8629. nginx_ssl $HUBZILLA_DOMAIN_NAME
  8630. nginx_disable_sniffing $HUBZILLA_DOMAIN_NAME
  8631. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8632. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8633. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8634. echo ' location / {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8635. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8636. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8637. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8638. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8639. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8640. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8641. echo ' allow all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8642. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8643. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8644. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8645. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8646. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8647. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8648. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8649. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8650. echo ' expires 30d;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8651. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8652. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8653. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8654. echo ' # block these file types' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8655. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8656. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8657. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8658. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8659. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8660. echo ' # or a unix socket' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8661. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8662. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8663. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8664. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8665. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8666. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8667. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8668. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8669. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8670. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8671. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8672. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8673. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8674. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8675. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8676. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8677. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8678. echo ' fastcgi_read_timeout 300;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8679. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8680. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8681. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8682. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8683. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8684. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8685. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8686. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8687. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8688. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8689. echo '}' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8690. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8691. else
  8692. echo 'server {' > /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8693. echo " listen 127.0.0.1:${HUBZILLA_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8694. echo " root $HUBZILLA_PATH;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8695. echo " server_name $HUBZILLA_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8696. echo " error_log /var/log/nginx/${HUBZILLA_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8697. echo ' index index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8698. echo ' charset utf-8;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8699. echo ' access_log off;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8700. nginx_limits $HUBZILLA_DOMAIN_NAME
  8701. nginx_disable_sniffing $HUBZILLA_DOMAIN_NAME
  8702. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8703. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8704. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8705. echo ' location / {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8706. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8707. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8708. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8709. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8710. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8711. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8712. echo ' allow all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8713. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8714. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8715. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8716. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8717. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8718. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8719. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8720. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8721. echo ' expires 30d;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8722. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8723. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8724. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8725. echo ' # block these file types' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8726. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8727. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8728. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8729. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8730. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8731. echo ' # or a unix socket' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8732. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8733. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8734. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8735. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8736. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8737. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8738. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8739. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8740. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8741. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8742. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8743. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8744. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8745. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8746. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8747. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8748. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8749. echo ' fastcgi_read_timeout 300;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8750. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8751. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8752. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8753. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8754. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8755. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8756. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8757. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8758. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8759. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8760. echo '}' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8761. fi
  8762. configure_php
  8763. create_site_certificate $HUBZILLA_DOMAIN_NAME 'yes'
  8764. if [ ! -d $HUBZILLA_PATH/view/tpl/smarty3 ]; then
  8765. mkdir $HUBZILLA_PATH/view/tpl/smarty3
  8766. fi
  8767. if [ ! -d "$HUBZILLA_PATH/store" ]; then
  8768. mkdir "$HUBZILLA_PATH/store"
  8769. fi
  8770. if [ ! -d "$HUBZILLA_PATH/store/[data]" ]; then
  8771. mkdir "$HUBZILLA_PATH/store/[data]"
  8772. fi
  8773. if [ ! -d "$HUBZILLA_PATH/store/[data]/smarty3" ]; then
  8774. mkdir "$HUBZILLA_PATH/store/[data]/smarty3"
  8775. chmod 777 "$HUBZILLA_PATH/store/[data]/smarty3"
  8776. fi
  8777. chmod 777 $HUBZILLA_PATH/view/tpl
  8778. chown -R www-data:www-data "$HUBZILLA_PATH/store"
  8779. chmod 777 $HUBZILLA_PATH/view/tpl/smarty3
  8780. # Ensure that the database gets backed up locally, if remote
  8781. # backups are not being used
  8782. backup_databases_script_header
  8783. backup_database_local hubzilla
  8784. chown -R www-data:www-data $HUBZILLA_PATH
  8785. nginx_ensite $HUBZILLA_DOMAIN_NAME
  8786. # initialize the database
  8787. if [ ! -f $HUBZILLA_PATH/install/schema_mysql.sql ]; then
  8788. echo $'No database schema found for hubzilla'
  8789. exit 252782
  8790. fi
  8791. mysql -u root --password="$MARIADB_PASSWORD" -D hubzilla < $HUBZILLA_PATH/install/schema_mysql.sql
  8792. if [ ! "$?" = "0" ]; then
  8793. exit 62952
  8794. fi
  8795. # create the config file
  8796. echo '<?php' > $HUBZILLA_PATH/.htconfig.php
  8797. echo "\$db_host = 'localhost';" >> $HUBZILLA_PATH/.htconfig.php
  8798. echo "\$db_port = '0';" >> $HUBZILLA_PATH/.htconfig.php
  8799. echo "\$db_user = 'root';" >> $HUBZILLA_PATH/.htconfig.php
  8800. echo "\$db_pass = '${MARIADB_PASSWORD}';" >> $HUBZILLA_PATH/.htconfig.php
  8801. echo "\$db_data = 'hubzilla';" >> $HUBZILLA_PATH/.htconfig.php
  8802. echo "\$db_type = '0';" >> $HUBZILLA_PATH/.htconfig.php
  8803. echo "\$default_timezone = 'Europe/London';" >> $HUBZILLA_PATH/.htconfig.php
  8804. if [[ $ONION_ONLY == 'no' ]]; then
  8805. echo "\$a->config['system']['baseurl'] = 'https://${HUBZILLA_DOMAIN_NAME}';" >> $HUBZILLA_PATH/.htconfig.php
  8806. else
  8807. echo "\$a->config['system']['baseurl'] = 'http://${HUBZILLA_ONION_HOSTNAME}';" >> $HUBZILLA_PATH/.htconfig.php
  8808. fi
  8809. echo "\$a->config['system']['sitename'] = \"Hubzilla\";" >> $HUBZILLA_PATH/.htconfig.php
  8810. HUBZILLA_LOCATION_HASH="$(openssl rand -base64 32 | cut -c1-30)"
  8811. echo "\$a->config['system']['location_hash'] = '${HUBZILLA_LOCATION_HASH}';" >> $HUBZILLA_PATH/.htconfig.php
  8812. echo "\$a->config['system']['register_policy'] = REGISTER_OPEN;" >> $HUBZILLA_PATH/.htconfig.php
  8813. echo "\$a->config['system']['register_text'] = '';" >> $HUBZILLA_PATH/.htconfig.php
  8814. echo "\$a->config['system']['admin_email'] = '${MY_EMAIL_ADDRESS}';" >> $HUBZILLA_PATH/.htconfig.php
  8815. echo "\$a->config['system']['verify_email'] = 1;" >> $HUBZILLA_PATH/.htconfig.php
  8816. echo "\$a->config['system']['access_policy'] = ACCESS_PRIVATE;" >> $HUBZILLA_PATH/.htconfig.php
  8817. echo "\$a->config['system']['sellpage'] = '';" >> $HUBZILLA_PATH/.htconfig.php
  8818. echo "\$a->config['system']['max_import_size'] = 200000;" >> $HUBZILLA_PATH/.htconfig.php
  8819. echo "\$a->config['system']['php_path'] = '/usr/bin/php';" >> $HUBZILLA_PATH/.htconfig.php
  8820. echo "\$a->config['system']['directory_mode'] = DIRECTORY_MODE_NORMAL;" >> $HUBZILLA_PATH/.htconfig.php
  8821. echo "\$a->config['system']['theme'] = 'redbasic';" >> $HUBZILLA_PATH/.htconfig.php
  8822. chown www-data:www-data $HUBZILLA_PATH/.htconfig.php
  8823. chmod 755 $HUBZILLA_PATH/.htconfig.php
  8824. systemctl restart php5-fpm
  8825. systemctl restart nginx
  8826. systemctl restart cron
  8827. freedombone-addemail -u $MY_USERNAME -e "noreply@$HUBZILLA_DOMAIN_NAME" -g hubzilla --public no
  8828. echo "Hubzilla domain:${HUBZILLA_DOMAIN_NAME}" >> $COMPLETION_FILE
  8829. echo 'install_hubzilla' >> $COMPLETION_FILE
  8830. }
  8831. function script_for_attaching_usb_drive {
  8832. if grep -Fxq "script_for_attaching_usb_drive" $COMPLETION_FILE; then
  8833. return
  8834. fi
  8835. echo '#!/bin/bash' > /usr/bin/attach-music
  8836. echo 'remove-music' >> /usr/bin/attach-music
  8837. echo "if [ ! -d $USB_MOUNT ]; then" >> /usr/bin/attach-music
  8838. echo " mkdir $USB_MOUNT" >> /usr/bin/attach-music
  8839. echo 'fi' >> /usr/bin/attach-music
  8840. echo "mount /dev/sda1 $USB_MOUNT" >> /usr/bin/attach-music
  8841. echo "chown root:root $USB_MOUNT" >> /usr/bin/attach-music
  8842. echo "chown -R minidlna:minidlna $USB_MOUNT/*" >> /usr/bin/attach-music
  8843. echo 'service minidlna restart' >> /usr/bin/attach-music
  8844. echo 'minidlnad -R' >> /usr/bin/attach-music
  8845. chmod +x /usr/bin/attach-music
  8846. ln -s /usr/bin/attach-music /usr/bin/attach-usb
  8847. ln -s /usr/bin/attach-music /usr/bin/attach-videos
  8848. ln -s /usr/bin/attach-music /usr/bin/attach-pictures
  8849. ln -s /usr/bin/attach-music /usr/bin/attach-media
  8850. echo '#!/bin/bash' > /usr/bin/remove-music
  8851. echo "if [ -d $USB_MOUNT ]; then" >> /usr/bin/remove-music
  8852. echo " umount $USB_MOUNT" >> /usr/bin/remove-music
  8853. echo " rm -rf $USB_MOUNT" >> /usr/bin/remove-music
  8854. echo 'fi' >> /usr/bin/remove-music
  8855. chmod +x /usr/bin/remove-music
  8856. ln -s /usr/bin/remove-music /usr/bin/detach-music
  8857. ln -s /usr/bin/remove-music /usr/bin/detach-usb
  8858. ln -s /usr/bin/remove-music /usr/bin/remove-usb
  8859. ln -s /usr/bin/remove-music /usr/bin/detach-media
  8860. ln -s /usr/bin/remove-music /usr/bin/remove-media
  8861. ln -s /usr/bin/remove-music /usr/bin/detach-videos
  8862. ln -s /usr/bin/remove-music /usr/bin/remove-videos
  8863. ln -s /usr/bin/remove-music /usr/bin/detach-pictures
  8864. ln -s /usr/bin/remove-music /usr/bin/remove-pictures
  8865. echo 'script_for_attaching_usb_drive' >> $COMPLETION_FILE
  8866. }
  8867. function install_dlna_server {
  8868. if grep -Fxq "install_dlna_server" $COMPLETION_FILE; then
  8869. return
  8870. fi
  8871. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8872. return
  8873. fi
  8874. apt-get -y install minidlna
  8875. if [ ! -f /etc/minidlna.conf ]; then
  8876. echo $"ERROR: minidlna does not appear to have installed. $CHECK_MESSAGE"
  8877. exit 55
  8878. fi
  8879. sed -i "s|media_dir=/var/lib/minidlna|media_dir=A,/home/$MY_USERNAME/Music|g" /etc/minidlna.conf
  8880. if ! grep -q "/home/$MY_USERNAME/Pictures" /etc/minidlna.conf; then
  8881. echo "media_dir=P,/home/$MY_USERNAME/Pictures" >> /etc/minidlna.conf
  8882. fi
  8883. if ! grep -q "/home/$MY_USERNAME/Videos" /etc/minidlna.conf; then
  8884. echo "media_dir=V,/home/$MY_USERNAME/Videos" >> /etc/minidlna.conf
  8885. fi
  8886. if ! grep -q "$USB_MOUNT/Music" /etc/minidlna.conf; then
  8887. echo "media_dir=A,$USB_MOUNT/Music" >> /etc/minidlna.conf
  8888. fi
  8889. if ! grep -q "$USB_MOUNT/Pictures" /etc/minidlna.conf; then
  8890. echo "media_dir=P,$USB_MOUNT/Pictures" >> /etc/minidlna.conf
  8891. fi
  8892. if ! grep -q "$USB_MOUNT/Videos" /etc/minidlna.conf; then
  8893. echo "media_dir=V,$USB_MOUNT/Videos" >> /etc/minidlna.conf
  8894. fi
  8895. sed -i 's/#root_container=./root_container=B/g' /etc/minidlna.conf
  8896. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  8897. sed -i 's/#network_interface=/network_interface=eth0/g' /etc/minidlna.conf
  8898. else
  8899. sed -i 's/#network_interface=/network_interface=$WIFI_INTERFACE/g' /etc/minidlna.conf
  8900. fi
  8901. sed -i "s/#friendly_name=/friendly_name=\"${PROJECT_NAME} Media\"/g" /etc/minidlna.conf
  8902. sed -i 's|#db_dir=/var/cache/minidlna|db_dir=/var/cache/minidlna|g' /etc/minidlna.conf
  8903. sed -i 's/#inotify=yes/inotify=yes/g' /etc/minidlna.conf
  8904. sed -i 's/#notify_interval=895/notify_interval=300/g' /etc/minidlna.conf
  8905. sed -i "s|#presentation_url=/|presentation_url=http://localhost:8200|g" /etc/minidlna.conf
  8906. service minidlna force-reload
  8907. service minidlna reload
  8908. sed -i 's/fs.inotify.max_user_watches*/fs.inotify.max_user_watches=65536/g' /etc/sysctl.conf
  8909. if ! grep -q "max_user_watches" $COMPLETION_FILE; then
  8910. echo 'fs.inotify.max_user_watches=65536' >> /etc/sysctl.conf
  8911. fi
  8912. /sbin/sysctl -p
  8913. echo 'install_dlna_server' >> $COMPLETION_FILE
  8914. }
  8915. function install_media_server {
  8916. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8917. return
  8918. fi
  8919. if [ ! $MEDIA_SERVER_DOMAIN_NAME ]; then
  8920. return
  8921. fi
  8922. # update to a new commit if needed
  8923. set_repo_commit $MEDIA_SERVER_WORKING_DIRECTORY "Media server commit" "$MEDIA_SERVER_COMMIT" $MEDIA_SERVER_REPO
  8924. if [ -d $MEDIA_SERVER_WORKING_DIRECTORY ]; then
  8925. chown -R www-data:www-data $MEDIA_SERVER_WORKING_DIRECTORY
  8926. fi
  8927. if grep -Fxq "install_media_server" $COMPLETION_FILE; then
  8928. return
  8929. fi
  8930. echo $'Installing media server'
  8931. apt-get -y install git-core python python-dev python-lxml python-pil
  8932. apt-get -y install python-virtualenv automake python-pip
  8933. apt-get -y install fcgiwrap libmysqlclient-dev
  8934. apt-get -y install libjpeg-dev zlib1g-dev libfreetype6-dev
  8935. apt-get -y install python-setuptools python-virtualenv
  8936. apt-get -y install uwsgi uwsgi-plugin-python
  8937. pip install --upgrade pip
  8938. pip install paster==0.8
  8939. pip install bleach==1.4.3
  8940. pip install aniso8601==1.0.0
  8941. pip install decorator==3.3.2
  8942. pip install unidecode==0.4.19
  8943. pip install google-api-python-client==1.5.1
  8944. pip install akismet==0.2.0
  8945. pip install MySQL-python==1.2.5
  8946. pip install tw.forms==0.9.9
  8947. pip install repoze.who.plugins.sa==2.3
  8948. pip install repoze.who-friendlyform==1.0.8
  8949. pip install repoze.who==1.0.18
  8950. pip install Routes==1.12.3
  8951. pip install Genshi==0.7
  8952. pip install alembic==0.8.6
  8953. pip install SQLAlchemy==0.7.6
  8954. pip install WebHelpers==1.0
  8955. pip install Pylons==-1.0.2
  8956. pip install ddt==1.1.0
  8957. pip install iso8601==0.1.11
  8958. pip install httplib2==0.9.1
  8959. pip install pyasn1==0.1.8
  8960. pip install uwsgi --upgrade
  8961. if [ -d $MEDIA_SERVER_BASE_DIRECTORY ]; then
  8962. rm -rf $MEDIA_SERVER_BASE_DIRECTORY
  8963. fi
  8964. mkdir -p $MEDIA_SERVER_BASE_DIRECTORY
  8965. install_mariadb
  8966. get_mariadb_password
  8967. repair_databases_script
  8968. get_mariadb_media_server_admin_password
  8969. if [ ! $MEDIA_SERVER_ADMIN_PASSWORD ]; then
  8970. if [ -f $IMAGE_PASSWORD_FILE ]; then
  8971. MEDIA_SERVER_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  8972. else
  8973. MEDIA_SERVER_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  8974. fi
  8975. fi
  8976. create_database mediadrop "$MEDIA_SERVER_ADMIN_PASSWORD" mediadropadmin
  8977. useradd -d ${MEDIA_SERVER_WORKING_DIRECTORY} -s /bin/false mediadrop
  8978. # create python environment
  8979. cd $MEDIA_SERVER_BASE_DIRECTORY
  8980. virtualenv --distribute --no-site-packages venv
  8981. source venv/bin/activate
  8982. # clone the repo
  8983. git_clone $MEDIA_SERVER_REPO $MEDIA_SERVER_WORKING_DIRECTORY
  8984. if [ ! -d $MEDIA_SERVER_WORKING_DIRECTORY ]; then
  8985. echo $'Unable to clone mediadrop'
  8986. exit 732581
  8987. fi
  8988. cd $MEDIA_SERVER_WORKING_DIRECTORY
  8989. git checkout $MEDIA_SERVER_COMMIT -b $MEDIA_SERVER_COMMIT
  8990. python setup.py develop
  8991. # create a configuration
  8992. if [ -f deployment.ini ]; then
  8993. rm deployment.ini
  8994. fi
  8995. paster make-config MediaDrop deployment.ini
  8996. if [ ! -f deployment.ini ]; then
  8997. echo $'deployment.ini not created'
  8998. exit 726567
  8999. fi
  9000. # database authentication
  9001. sed -i "s|sqlalchemy.url.*|sqlalchemy.url = mysql://mediadrop:${MEDIA_SERVER_ADMIN_PASSWORD}@localhost/mediadrop?charset=utf8&use_unicode=0|g" deployment.ini
  9002. # faster file serve
  9003. sed -i 's|files_serve_method.*|files_serve_method = nginx_redirect|g' deployment.ini
  9004. # initial data
  9005. cp -a mediadrop/data .
  9006. paster setup-app deployment.ini
  9007. # add uwsgi to deployment.ini
  9008. echo '' >> deployment.ini
  9009. echo '[uwsgi]' >> deployment.ini
  9010. echo 'socket = /tmp/uwsgi-mediadrop.soc' >> deployment.ini
  9011. echo 'master = true' >> deployment.ini
  9012. echo 'processes = 5' >> deployment.ini
  9013. echo "home = $MEDIA_SERVER_BASE_DIRECTORY" >> deployment.ini
  9014. echo 'daemonize = /var/log/uwsgi.log' >> deployment.ini
  9015. # enable full test search
  9016. mysql -u mediadrop --password="$MEDIA_SERVER_ADMIN_PASSWORD" mediadrop < mediadrop/setup_triggers.sql
  9017. chown -R mediadrop:mediadrop $MEDIA_SERVER_BASE_DIRECTORY
  9018. # script to be called by the daemon
  9019. echo '#!/bin/bash' > /usr/bin/start-mediadrop
  9020. echo "cd ${MEDIA_SERVER_WORKING_DIRECTORY}" >> /usr/bin/start-mediadrop
  9021. echo "uwsgi --ini-paste deployment.ini" >> /usr/bin/start-mediadrop
  9022. echo "paster serve --reload deployment.ini" >> /usr/bin/start-mediadrop
  9023. chmod +x /usr/bin/start-mediadrop
  9024. # create daemon
  9025. echo '[Unit]' > /etc/systemd/system/mediadrop.service
  9026. echo 'Description=Mediadrop - media playing on the web' >> /etc/systemd/system/mediadrop.service
  9027. echo 'After=network.target' >> /etc/systemd/system/mediadrop.service
  9028. echo '' >> /etc/systemd/system/mediadrop.service
  9029. echo '[Service]' >> /etc/systemd/system/mediadrop.service
  9030. echo 'User=mediadrop' >> /etc/systemd/system/mediadrop.service
  9031. echo "Environment='USER=mediadrop'" >> /etc/systemd/system/mediadrop.service
  9032. echo "WorkingDirectory=${MEDIA_SERVER_WORKING_DIRECTORY}" >> /etc/systemd/system/searx.service
  9033. echo 'ExecStart=/usr/bin/start-mediadrop' >> /etc/systemd/system/mediadrop.service
  9034. echo 'Restart=on-failure' >> /etc/systemd/system/mediadrop.service
  9035. echo 'SuccessExitStatus=3 4' >> /etc/systemd/system/mediadrop.service
  9036. echo 'RestartForceExitStatus=3 4' >> /etc/systemd/system/mediadrop.service
  9037. echo '' >> /etc/systemd/system/mediadrop.service
  9038. echo '[Install]' >> /etc/systemd/system/mediadrop.service
  9039. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/mediadrop.service
  9040. systemctl enable mediadrop
  9041. systemctl daemon-reload
  9042. systemctl start mediadrop
  9043. # onion address
  9044. MEDIA_SERVER_ONION_HOSTNAME=$(add_onion_service mediadrop 80 ${MEDIA_SERVER_ONION_PORT})
  9045. if ! grep -q "Media server onion domain" $COMPLETION_FILE; then
  9046. echo "Media server onion domain:${MEDIA_SERVER_ONION_HOSTNAME}" >> $COMPLETION_FILE
  9047. else
  9048. sed -i "s|Media server onion domain.*|Media server onion domain:${MEDIA_SERVER_ONION_HOSTNAME}|g" $COMPLETION_FILE
  9049. fi
  9050. if [[ $MEDIA_SERVER_ONION_HOSTNAME == *"not found"* ]]; then
  9051. echo $'Problem creating onion address for mediadrop'
  9052. exit 72963
  9053. fi
  9054. if [[ $ONION_ONLY == 'no' ]]; then
  9055. nginx_http_redirect $MEDIA_SERVER_DOMAIN_NAME
  9056. echo 'server {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9057. echo ' listen 443;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9058. echo " server_name $MEDIA_SERVER_DOMAIN_NAME;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9059. echo " access_log /var/log/nginx/${MEDIA_SERVER_DOMAIN_NAME}.log;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9060. echo " error_log /var/log/nginx/${MEDIA_SERVER_DOMAIN_NAME}.log;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9061. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9062. nginx_ssl $MEDIA_SERVER_DOMAIN_NAME
  9063. nginx_disable_sniffing $MEDIA_SERVER_DOMAIN_NAME
  9064. nginx_limits $MEDIA_SERVER_DOMAIN_NAME '15m'
  9065. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9066. echo " root ${MEDIA_SERVER_WORKING_DIRECTORY}/public;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9067. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9068. echo ' location ~* ^/(appearance)/ {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9069. echo " root ${MEDIA_SERVER_WORKING_DIRECTORY}/data ;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9070. echo ' break;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9071. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9072. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9073. echo ' location ~* ^(/images\/media|images\/podcasts) {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9074. echo " root ${MEDIA_SERVER_WORKING_DIRECTORY}/data ;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9075. echo ' break;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9076. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9077. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9078. echo ' location ~* ^/(styles|scripts|images)/ {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9079. echo ' expires max;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9080. echo ' add_header Cache-Control "public";' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9081. echo ' break;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9082. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9083. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9084. echo ' location /__mediacore_serve__ {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9085. echo " alias ${MEDIA_SERVER_WORKING_DIRECTORY}/data/media;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9086. echo ' internal;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9087. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9088. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9089. echo ' location / {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9090. echo ' uwsgi_pass unix:///tmp/uwsgi-mediadrop.soc;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9091. echo ' include uwsgi_params;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9092. echo " uwsgi_param SCRIPT_NAME '';" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9093. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9094. echo '}' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9095. create_site_certificate $MEDIA_SERVER_DOMAIN_NAME
  9096. add_ddns_domain $MEDIA_SERVER_DOMAIN_NAME
  9097. else
  9098. echo -n '' > /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9099. fi
  9100. echo 'server {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9101. echo " listen 127.0.0.1:${MEDIA_SERVER_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9102. echo " server_name $MEDIA_SERVER_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9103. echo " access_log /var/log/nginx/${MEDIA_SERVER_DOMAIN_NAME}.log;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9104. echo " error_log /var/log/nginx/${MEDIA_SERVER_DOMAIN_NAME}.log;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9105. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9106. nginx_disable_sniffing $MEDIA_SERVER_DOMAIN_NAME
  9107. nginx_limits $MEDIA_SERVER_DOMAIN_NAME '15m'
  9108. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9109. echo " root ${MEDIA_SERVER_WORKING_DIRECTORY}/public;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9110. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9111. echo ' location ~* ^/(appearance)/ {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9112. echo " root ${MEDIA_SERVER_WORKING_DIRECTORY}/data ;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9113. echo ' break;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9114. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9115. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9116. echo ' location ~* ^(/images\/media|images\/podcasts) {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9117. echo " root ${MEDIA_SERVER_WORKING_DIRECTORY}/data ;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9118. echo ' break;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9119. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9120. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9121. echo ' location ~* ^/(styles|scripts|images)/ {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9122. echo ' expires max;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9123. echo ' add_header Cache-Control "public";' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9124. echo ' break;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9125. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9126. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9127. echo ' location /__mediacore_serve__ {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9128. echo " alias ${MEDIA_SERVER_WORKING_DIRECTORY}/data/media;" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9129. echo ' internal;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9130. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9131. echo '' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9132. echo ' location / {' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9133. echo ' uwsgi_pass unix:///tmp/uwsgi-mediadrop.soc;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9134. echo ' include uwsgi_params;' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9135. echo " uwsgi_param SCRIPT_NAME '';" >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9136. echo ' }' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9137. echo '}' >> /etc/nginx/sites-available/$MEDIA_SERVER_DOMAIN_NAME
  9138. nginx_ensite $MEDIA_SERVER_DOMAIN_NAME
  9139. systemctl restart php5-fpm
  9140. systemctl restart nginx
  9141. if ! grep -q "Media server domain" $COMPLETION_FILE; then
  9142. echo "Media server domain:$MEDIA_SERVER_DOMAIN_NAME" >> $COMPLETION_FILE
  9143. else
  9144. sed -i "s/Media server domain.*/Media server domain:$MEDIA_SERVER_DOMAIN_NAME/g" $COMPLETION_FILE
  9145. fi
  9146. if ! grep -q $"Media Server" /home/$MY_USERNAME/README; then
  9147. echo '' >> /home/$MY_USERNAME/README
  9148. echo '' >> /home/$MY_USERNAME/README
  9149. echo $'Media Server' >> /home/$MY_USERNAME/README
  9150. echo '============' >> /home/$MY_USERNAME/README
  9151. echo $"Media server administrator nickname: mediadropadmin" >> /home/$MY_USERNAME/README
  9152. echo $"Media server administrator password: $MEDIA_SERVER_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  9153. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  9154. chmod 600 /home/$MY_USERNAME/README
  9155. fi
  9156. echo 'install_media_server' >> $COMPLETION_FILE
  9157. }
  9158. function install_mediagoblin {
  9159. 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" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  9160. return
  9161. fi
  9162. if [ ! $MEDIAGOBLIN_DOMAIN_NAME ]; then
  9163. return
  9164. fi
  9165. MEDIAGOBLIN_WORKING_DIRECTORY=/var/www/$MEDIAGOBLIN_DOMAIN_NAME/htdocs
  9166. # update to a new commit if needed
  9167. set_repo_commit $MEDIAGOBLIN_WORKING_DIRECTORY "Mediagoblin commit" "$MEDIAGOBLIN_COMMIT" $MEDIAGOBLIN_REPO
  9168. if [ -d $MEDIAGOBLIN_WORKING_DIRECTORY ]; then
  9169. chown -hR mediagoblin:www-data $MEDIAGOBLIN_WORKING_DIRECTORY
  9170. fi
  9171. if grep -Fxq "install_mediagoblin" $COMPLETION_FILE; then
  9172. return
  9173. fi
  9174. apt-get -y install git-core python python-dev python-lxml python-pil
  9175. apt-get -y install python-virtualenv npm nodejs-legacy automake
  9176. apt-get -y install fcgiwrap
  9177. #apt-get -y install postgresql postgresql-client python-psycopg2
  9178. #apt-get -y install python-gst-1.0 libjpeg62-turbo-dev gstreamer1.0-plugins-base python-gobject
  9179. #apt-get -y install gstreamer1.0-plugins-good gstreamer1.0-libav libav-tools gstreamer0.10-tools
  9180. #apt-get -y install python-numpy python-scipy libsndfile1-dev python-gst0.10-dev
  9181. #apt-get -y install gstreamer0.10-plugins-base gstreamer0.10-plugins-good gstreamer1.0-tools
  9182. #su -c "createuser -A -D mediagoblin" - postgres
  9183. #su -c "createdb -E UNICODE -O mediagoblin mediagoblin" - postgres
  9184. useradd -c "GNU MediaGoblin system account" -d /var/lib/mediagoblin -m -r -g www-data mediagoblin
  9185. groupadd mediagoblin
  9186. usermod --append -G mediagoblin mediagoblin
  9187. if [ ! -d $MEDIAGOBLIN_WORKING_DIRECTORY ]; then
  9188. mkdir -p $MEDIAGOBLIN_WORKING_DIRECTORY
  9189. fi
  9190. git_clone $MEDIAGOBLIN_REPO $MEDIAGOBLIN_WORKING_DIRECTORY
  9191. cd $MEDIAGOBLIN_WORKING_DIRECTORY
  9192. git checkout $MEDIAGOBLIN_COMMIT -b $MEDIAGOBLIN_COMMIT
  9193. git submodule init
  9194. git submodule update
  9195. if ! grep -q "Mediagoblin commit" $COMPLETION_FILE; then
  9196. echo "Mediagoblin commit:$MEDIAGOBLIN_COMMIT" >> $COMPLETION_FILE
  9197. else
  9198. sed -i "s/Mediagoblin commit.*/Mediagoblin commit:$MEDIAGOBLIN_COMMIT/g" $COMPLETION_FILE
  9199. fi
  9200. chown -hR mediagoblin:www-data $MEDIAGOBLIN_WORKING_DIRECTORY
  9201. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bootstrap.sh" - mediagoblin
  9202. if [ ! "$?" = "0" ]; then
  9203. exit 278826
  9204. fi
  9205. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./configure" - mediagoblin
  9206. if [ ! "$?" = "0" ]; then
  9207. exit 462826
  9208. fi
  9209. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && make" - mediagoblin
  9210. if [ ! "$?" = "0" ]; then
  9211. exit 738229
  9212. fi
  9213. if [ ! -d $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev ]; then
  9214. mkdir $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev
  9215. fi
  9216. chmod 750 $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev
  9217. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install flup==1.0.3.dev-20110405" - mediagoblin
  9218. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade billiard" - mediagoblin
  9219. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade Paste" - mediagoblin
  9220. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade amqp" - mediagoblin
  9221. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade anyjson" - mediagoblin
  9222. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade py-bcrypt" - mediagoblin
  9223. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade wtforms" - mediagoblin
  9224. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade python-dateutil" - mediagoblin
  9225. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade alembic" - mediagoblin
  9226. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade waitress" - mediagoblin
  9227. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade imagesize" - mediagoblin
  9228. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade alabaster" - mediagoblin
  9229. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade snowballstemmer" - mediagoblin
  9230. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade docutils" - mediagoblin
  9231. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade Pygments" - mediagoblin
  9232. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade beautifulsoup4" - mediagoblin
  9233. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade WebOb" - mediagoblin
  9234. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade py" - mediagoblin
  9235. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade execnet" - mediagoblin
  9236. # create some directories
  9237. mkdir /var/log/mediagoblin
  9238. chown -hR mediagoblin:www-data /var/log/mediagoblin
  9239. mkdir /var/run/mediagoblin
  9240. chown -hR mediagoblin:www-data /var/run/mediagoblin
  9241. if [ ! -f $MEDIAGOBLIN_WORKING_DIRECTORY/mediagoblin.ini ]; then
  9242. echo $'mediagoblin.ini not found'
  9243. exit 737529
  9244. fi
  9245. if [ ! -f $MEDIAGOBLIN_WORKING_DIRECTORY/paste.ini ]; then
  9246. echo $'paste.ini not found'
  9247. exit 52762
  9248. fi
  9249. cp -av mediagoblin.ini mediagoblin_local.ini
  9250. cp -av paste.ini paste_local.ini
  9251. chown -hR mediagoblin:www-data $MEDIAGOBLIN_WORKING_DIRECTORY
  9252. # init with systemd
  9253. echo '[Unit]' > /etc/systemd/system/mediagoblin-celeryd.service
  9254. echo 'Description=Mediagoblin Celeryd' >> /etc/systemd/system/mediagoblin-celeryd.service
  9255. echo 'After=syslog.target' >> /etc/systemd/system/mediagoblin-celeryd.service
  9256. echo 'After=network.target' >> /etc/systemd/system/mediagoblin-celeryd.service
  9257. echo '' >> /etc/systemd/system/mediagoblin-celeryd.service
  9258. echo '[Service]' >> /etc/systemd/system/mediagoblin-celeryd.service
  9259. echo 'User=mediagoblin' >> /etc/systemd/system/mediagoblin-celeryd.service
  9260. echo 'Group=mediagoblin' >> /etc/systemd/system/mediagoblin-celeryd.service
  9261. echo 'Type=simple' >> /etc/systemd/system/mediagoblin-celeryd.service
  9262. echo "WorkingDirectory=$MEDIAGOBLIN_WORKING_DIRECTORY" >> /etc/systemd/system/mediagoblin-celeryd.service
  9263. echo "Environment=MEDIAGOBLIN_CONFIG=$MEDIAGOBLIN_WORKING_DIRECTORY/mediagoblin_local.ini \\" >> /etc/systemd/system/mediagoblin-celeryd.service
  9264. echo ' CELERY_CONFIG_MODULE=mediagoblin.init.celery.from_celery' >> /etc/systemd/system/mediagoblin-celeryd.service
  9265. echo "ExecStart=$MEDIAGOBLIN_WORKING_DIRECTORY/bin/celery worker \\" >> /etc/systemd/system/mediagoblin-celeryd.service
  9266. echo ' --logfile=/var/log/mediagoblin/celery.log \' >> /etc/systemd/system/mediagoblin-celeryd.service
  9267. echo ' --loglevel=INFO' >> /etc/systemd/system/mediagoblin-celeryd.service
  9268. echo 'PIDFile=/var/run/mediagoblin/mediagoblin-celeryd.pid' >> /etc/systemd/system/mediagoblin-celeryd.service
  9269. echo '' >> /etc/systemd/system/mediagoblin-celeryd.service
  9270. echo '[Install]' >> /etc/systemd/system/mediagoblin-celeryd.service
  9271. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/mediagoblin-celeryd.service
  9272. echo '[Unit]' > /etc/systemd/system/mediagoblin-paster.service
  9273. echo 'Description=Mediagoblin' >> /etc/systemd/system/mediagoblin-paster.service
  9274. echo 'After=syslog.target' >> /etc/systemd/system/mediagoblin-paster.service
  9275. echo 'After=network.target' >> /etc/systemd/system/mediagoblin-paster.service
  9276. echo '' >> /etc/systemd/system/mediagoblin-paster.service
  9277. echo '[Service]' >> /etc/systemd/system/mediagoblin-paster.service
  9278. echo 'Type=forking' >> /etc/systemd/system/mediagoblin-paster.service
  9279. echo 'User=mediagoblin' >> /etc/systemd/system/mediagoblin-paster.service
  9280. echo 'Group=mediagoblin' >> /etc/systemd/system/mediagoblin-paster.service
  9281. echo 'Environment=CELERY_ALWAYS_EAGER=false' >> /etc/systemd/system/mediagoblin-paster.service
  9282. echo "WorkingDirectory=$MEDIAGOBLIN_WORKING_DIRECTORY" >> /etc/systemd/system/mediagoblin-paster.service
  9283. echo "ExecStart=$MEDIAGOBLIN_WORKING_DIRECTORY/bin/paster serve \\" >> /etc/systemd/system/mediagoblin-paster.service
  9284. echo " $MEDIAGOBLIN_WORKING_DIRECTORY/paste_local.ini \\" >> /etc/systemd/system/mediagoblin-paster.service
  9285. echo ' --pid-file=/var/run/mediagoblin/mediagoblin.pid \' >> /etc/systemd/system/mediagoblin-paster.service
  9286. echo ' --log-file=/var/log/mediagoblin/mediagoblin.log \' >> /etc/systemd/system/mediagoblin-paster.service
  9287. echo ' --daemon \' >> /etc/systemd/system/mediagoblin-paster.service
  9288. echo ' --server-name=fcgi fcgi_host=127.0.0.1 fcgi_port=26543' >> /etc/systemd/system/mediagoblin-paster.service
  9289. echo "ExecStop=$MEDIAGOBLIN_WORKING_DIRECTORY/bin/paster serve \\" >> /etc/systemd/system/mediagoblin-paster.service
  9290. echo ' --pid-file=/var/run/mediagoblin/mediagoblin.pid \' >> /etc/systemd/system/mediagoblin-paster.service
  9291. echo " $MEDIAGOBLIN_WORKING_DIRECTORY/paste_local.ini stop" >> /etc/systemd/system/mediagoblin-paster.service
  9292. echo 'PIDFile=/var/run/mediagoblin/mediagoblin.pid' >> /etc/systemd/system/mediagoblin-paster.service
  9293. echo '' >> /etc/systemd/system/mediagoblin-paster.service
  9294. echo '[Install]' >> /etc/systemd/system/mediagoblin-paster.service
  9295. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/mediagoblin-paster.service
  9296. systemctl daemon-reload
  9297. systemctl enable mediagoblin-celeryd
  9298. systemctl enable mediagoblin-paster
  9299. systemctl daemon-reload
  9300. systemctl start mediagoblin-celeryd
  9301. systemctl start mediagoblin-paster
  9302. MEDIAGOBLIN_ONION_HOSTNAME=$(add_onion_service mediagoblin 80 ${MEDIAGOBLIN_ONION_PORT})
  9303. if ! grep -q "Mediagoblin onion domain" $COMPLETION_FILE; then
  9304. echo "Mediagoblin onion domain:${MEDIAGOBLIN_ONION_HOSTNAME}" >> $COMPLETION_FILE
  9305. else
  9306. sed -i "s|Mediagoblin onion domain.*|Mediagoblin onion domain:${MEDIAGOBLIN_ONION_HOSTNAME}|g" $COMPLETION_FILE
  9307. fi
  9308. if [[ $MEDIAGOBLIN_ONION_HOSTNAME == *"not found"* ]]; then
  9309. echo $'Problem creating onion address for mediagoblin'
  9310. exit 672652
  9311. fi
  9312. # web config
  9313. MEDIAGOBLIN_VIRTUAL_HOST=/etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  9314. nginx_http_redirect $MEDIAGOBLIN_DOMAIN_NAME
  9315. if [[ $ONION_ONLY == 'no' ]]; then
  9316. echo 'server {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9317. echo ' listen 443 ssl;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9318. echo ' #################################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9319. echo ' # Stock useful config options, but ignore them :)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9320. echo ' #################################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9321. echo ' include /etc/nginx/mime.types;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9322. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9323. echo ' autoindex off;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9324. echo ' default_type application/octet-stream;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9325. echo ' sendfile on;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9326. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9327. nginx_limits $MEDIAGOBLIN_DOMAIN_NAME '20m'
  9328. nginx_ssl $MEDIAGOBLIN_DOMAIN_NAME
  9329. nginx_disable_sniffing $MEDIAGOBLIN_DOMAIN_NAME
  9330. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9331. echo ' # Gzip' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9332. echo ' gzip on;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9333. echo ' gzip_min_length 1024;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9334. echo ' gzip_buffers 4 32k;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9335. echo ' gzip_types text/plain application/x-javascript text/javascript text/xml text/css;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9336. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9337. echo ' #####################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9338. echo ' # Mounting MediaGoblin stuff' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9339. echo ' # This is the section you should read' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9340. echo ' #####################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9341. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9342. echo " server_name $MEDIAGOBLIN_DOMAIN_NAME;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9343. echo ' access_log /var/log/nginx/mediagoblin.log;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9344. echo ' error_log /var/log/nginx/mediagoblin.error.log;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9345. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9346. echo ' # MediaGoblins stock static files: CSS, JS, etc.' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9347. echo ' location /mgoblin_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9348. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/mediagoblin/static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9349. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9350. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9351. echo ' # Instance specific media:' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9352. echo ' location /mgoblin_media/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9353. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/media/public/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9354. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9355. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9356. echo ' # Theme static files (usually symlinked in)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9357. echo ' location /theme_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9358. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/theme_static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9359. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9360. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9361. echo ' # Plugin static files (usually symlinked in)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9362. echo ' location /plugin_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9363. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/plugin_static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9364. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9365. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9366. echo ' # Mounting MediaGoblin itself via FastCGI.' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9367. echo ' location / {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9368. echo ' fastcgi_pass 127.0.0.1:26543;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9369. echo ' include /etc/nginx/fastcgi_params;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9370. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9371. echo ' # our understanding vs nginxs handling of script_name vs' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9372. echo ' # path_info dont match :)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9373. echo ' fastcgi_param PATH_INFO $fastcgi_script_name;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9374. echo ' fastcgi_param SCRIPT_NAME "";' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9375. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9376. echo '}' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9377. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9378. else
  9379. echo -n '' > $MEDIAGOBLIN_VIRTUAL_HOST
  9380. fi
  9381. echo 'server {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9382. echo " listen 127.0.0.1:${MEDIAGOBLIN_ONION_PORT} default_server;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9383. echo ' #################################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9384. echo ' # Stock useful config options, but ignore them :)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9385. echo ' #################################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9386. echo ' include /etc/nginx/mime.types;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9387. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9388. echo ' autoindex off;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9389. echo ' default_type application/octet-stream;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9390. echo ' sendfile on;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9391. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9392. nginx_limits $MEDIAGOBLIN_DOMAIN_NAME '20m'
  9393. nginx_disable_sniffing $MEDIAGOBLIN_DOMAIN_NAME
  9394. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9395. echo ' # Gzip' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9396. echo ' gzip on;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9397. echo ' gzip_min_length 1024;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9398. echo ' gzip_buffers 4 32k;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9399. echo ' gzip_types text/plain application/x-javascript text/javascript text/xml text/css;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9400. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9401. echo ' #####################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9402. echo ' # Mounting MediaGoblin stuff' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9403. echo ' # This is the section you should read' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9404. echo ' #####################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9405. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9406. echo " server_name $MEDIAGOBLIN_ONION_HOSTNAME;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9407. echo ' access_log /var/log/nginx/mediagoblin.log;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9408. echo ' error_log /var/log/nginx/mediagoblin.error.log;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9409. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9410. echo ' # MediaGoblins stock static files: CSS, JS, etc.' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9411. echo ' location /mgoblin_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9412. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/mediagoblin/static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9413. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9414. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9415. echo ' # Instance specific media:' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9416. echo ' location /mgoblin_media/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9417. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/media/public/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9418. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9419. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9420. echo ' # Theme static files (usually symlinked in)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9421. echo ' location /theme_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9422. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/theme_static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9423. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9424. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9425. echo ' # Plugin static files (usually symlinked in)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9426. echo ' location /plugin_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9427. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/plugin_static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  9428. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9429. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9430. echo ' # Mounting MediaGoblin itself via FastCGI.' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9431. echo ' location / {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9432. echo ' fastcgi_pass 127.0.0.1:26543;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9433. echo ' include /etc/nginx/fastcgi_params;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9434. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9435. echo ' # our understanding vs nginxs handling of script_name vs' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9436. echo ' # path_info dont match :)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9437. echo ' fastcgi_param PATH_INFO $fastcgi_script_name;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9438. echo ' fastcgi_param SCRIPT_NAME "";' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9439. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9440. echo '}' >> $MEDIAGOBLIN_VIRTUAL_HOST
  9441. create_site_certificate $MEDIAGOBLIN_DOMAIN_NAME
  9442. nginx_ensite $MEDIAGOBLIN_DOMAIN_NAME
  9443. systemctl restart php5-fpm
  9444. systemctl restart nginx
  9445. add_ddns_domain $MEDIAGOBLIN_DOMAIN_NAME
  9446. if ! grep -q "Mediagoblin domain" $COMPLETION_FILE; then
  9447. echo "Mediagoblin domain:$MEDIAGOBLIN_DOMAIN_NAME" >> $COMPLETION_FILE
  9448. else
  9449. sed -i "s/Mediagoblin domain.*/Mediagoblin domain:$MEDIAGOBLIN_DOMAIN_NAME/g" $COMPLETION_FILE
  9450. fi
  9451. echo 'install_mediagoblin' >> $COMPLETION_FILE
  9452. }
  9453. function create_upgrade_script {
  9454. if [ -f /usr/local/bin/${PROJECT_NAME}-upgrade ]; then
  9455. cp /usr/local/bin/${PROJECT_NAME}-upgrade /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  9456. else
  9457. cp /usr/bin/${PROJECT_NAME}-upgrade /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  9458. fi
  9459. if grep -Fxq "create_upgrade_script" $COMPLETION_FILE; then
  9460. return
  9461. fi
  9462. apt-get -y install unattended-upgrades
  9463. echo 'create_upgrade_script' >> $COMPLETION_FILE
  9464. }
  9465. function intrusion_detection {
  9466. if grep -Fxq "intrusion_detection" $COMPLETION_FILE; then
  9467. return
  9468. fi
  9469. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  9470. return
  9471. fi
  9472. apt-get -y install tripwire
  9473. apt-get -y autoremove
  9474. cd /etc/tripwire
  9475. cp site.key $DEFAULT_DOMAIN_NAME-site.key
  9476. echo '*** Installing intrusion detection ***'
  9477. echo '
  9478. ' | tripwire --init
  9479. # make a script for easy resetting of the tripwire
  9480. echo '#!/bin/sh' > /usr/bin/reset-tripwire
  9481. echo 'tripwire --update-policy --secure-mode low /etc/tripwire/twpol.txt' >> /usr/bin/reset-tripwire
  9482. chmod +x /usr/bin/reset-tripwire
  9483. sed -i 's/SYSLOGREPORTING.*/SYSLOGREPORTING =false/g' /etc/tripwire/twcfg.txt
  9484. # only send emails if something has changed
  9485. sed -i 's|MAILNOVIOLATIONS.*|MAILNOVIOLATIONS = false|g' /etc/tripwire/twcfg.txt
  9486. sed -i '/# These files change the behavior of the root account/,/}/ s/.*//g' /etc/tripwire/twpol.txt
  9487. sed -i 's|/etc/rc.boot.*||g' /etc/tripwire/twpol.txt
  9488. # Don't show any changes to /proc
  9489. sed -i 's|/proc.*||g' /etc/tripwire/twpol.txt
  9490. # Don't report log changes
  9491. sed -i 's|/var/log.*||g' /etc/tripwire/twpol.txt
  9492. # Ignore /etc/tripwire
  9493. if ! grep -q '!/etc/tripwire' /etc/tripwire/twpol.txt; then
  9494. sed -i '\|/etc\t\t->.*|a\ !/etc/tripwire ;' /etc/tripwire/twpol.txt
  9495. fi
  9496. # ignore tt-rss cache
  9497. if ! grep -q '!/etc/share/tt-rss/cache' /etc/tripwire/twpol.txt; then
  9498. sed -i '\|/etc\t\t->.*|a\ !/etc/share/tt-rss/cache ;' /etc/tripwire/twpol.txt
  9499. fi
  9500. if ! grep -q '!/etc/share/tt-rss/lock' /etc/tripwire/twpol.txt; then
  9501. sed -i '\|/etc\t\t->.*|a\ !/etc/share/tt-rss/lock ;' /etc/tripwire/twpol.txt
  9502. fi
  9503. # Avoid logging the changed database
  9504. sed -i 's|$(TWETC)/tw.pol.*||g' /etc/tripwire/twpol.txt
  9505. # recreate the configuration
  9506. echo '
  9507. ' | twadmin --create-cfgfile -S /etc/tripwire/site.key /etc/tripwire/twcfg.txt
  9508. # reset
  9509. echo '
  9510. ' | reset-tripwire
  9511. echo 'intrusion_detection' >> $COMPLETION_FILE
  9512. }
  9513. # see https://trac.torproject.org/projects/tor/wiki/doc/TransparentProxy
  9514. # Local Redirection and Anonymizing Middlebox
  9515. function route_outgoing_traffic_through_tor {
  9516. if grep -Fxq "route_outgoing_traffic_through_tor" $COMPLETION_FILE; then
  9517. return
  9518. fi
  9519. if [[ $ROUTE_THROUGH_TOR != "yes" ]]; then
  9520. return
  9521. fi
  9522. apt-get -y install tor tor-arm
  9523. ### set variables
  9524. # Destinations you don't want routed through Tor
  9525. _non_tor="192.168.1.0/24 192.168.0.0/24"
  9526. # The user that Tor runs as
  9527. _tor_uid="debian-tor"
  9528. # Tor's TransPort
  9529. _trans_port="9040"
  9530. # Your internal interface
  9531. _int_if="eth0"
  9532. ### Set iptables *nat
  9533. iptables -t nat -A OUTPUT -o lo -j RETURN
  9534. iptables -t nat -A OUTPUT -m owner --uid-owner $_tor_uid -j RETURN
  9535. iptables -t nat -A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 53
  9536. # Allow clearnet access for hosts in $_non_tor
  9537. for _clearnet in $_non_tor; do
  9538. iptables -t nat -A OUTPUT -d $_clearnet -j RETURN
  9539. iptables -t nat -A PREROUTING -i $_int_if -d $_clearnet -j RETURN
  9540. done
  9541. # Redirect all other pre-routing and output to Tor
  9542. iptables -t nat -A OUTPUT -p tcp --syn -j REDIRECT --to-ports $_trans_port
  9543. iptables -t nat -A PREROUTING -i $_int_if -p udp --dport 53 -j REDIRECT --to-ports 53
  9544. iptables -t nat -A PREROUTING -i $_int_if -p tcp --syn -j REDIRECT --to-ports $_trans_port
  9545. ### set iptables *filter
  9546. iptables -A OUTPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
  9547. # Allow clearnet access for hosts in $_non_tor
  9548. for _clearnet in $_non_tor 127.0.0.0/8; do
  9549. iptables -A OUTPUT -d $_clearnet -j ACCEPT
  9550. done
  9551. # Allow only Tor output
  9552. iptables -A OUTPUT -m owner --uid-owner $_tor_uid -j ACCEPT
  9553. iptables -A OUTPUT -j REJECT
  9554. save_firewall_settings
  9555. if ! grep -q "fs.file-max" /etc/sysctl.conf; then
  9556. echo "fs.file-max=100000" >> /etc/sysctl.conf
  9557. /sbin/sysctl -p
  9558. fi
  9559. echo 'domain localdomain' > /etc/resolv.conf
  9560. echo 'search localdomain' >> /etc/resolv.conf
  9561. echo 'nameserver 127.0.0.1' >> /etc/resolv.conf
  9562. if ! grep -q "VirtualAddrNetworkIPv4" /etc/tor/torrc; then
  9563. echo 'VirtualAddrNetworkIPv4 10.192.0.0/10' >> /etc/tor/torrc
  9564. fi
  9565. if ! grep -q "AutomapHostsOnResolve" /etc/tor/torrc; then
  9566. echo 'AutomapHostsOnResolve 1' >> /etc/tor/torrc
  9567. fi
  9568. if ! grep -q "TransPort" /etc/tor/torrc; then
  9569. echo 'TransPort 9040' >> /etc/tor/torrc
  9570. fi
  9571. if ! grep -q "TransListenAddress 127.0.0.1" /etc/tor/torrc; then
  9572. echo 'TransListenAddress 127.0.0.1' >> /etc/tor/torrc
  9573. fi
  9574. if ! grep -q "TransListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" /etc/tor/torrc; then
  9575. echo "TransListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/tor/torrc
  9576. fi
  9577. if ! grep -q "DNSPort" /etc/tor/torrc; then
  9578. echo 'DNSPort 53' >> /etc/tor/torrc
  9579. fi
  9580. if ! grep -q "DNSListenAddress 127.0.0.1" /etc/tor/torrc; then
  9581. echo 'DNSListenAddress 127.0.0.1' >> /etc/tor/torrc
  9582. fi
  9583. if ! grep -q "DNSListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" /etc/tor/torrc; then
  9584. echo "DNSListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/tor/torrc
  9585. fi
  9586. echo 'route_outgoing_traffic_through_tor' >> $COMPLETION_FILE
  9587. }
  9588. # A command to create a git repository for a project
  9589. function create_git_project {
  9590. if grep -Fxq "create_git_project" $COMPLETION_FILE; then
  9591. return
  9592. fi
  9593. apt-get -y install git
  9594. echo '#!/bin/bash' > /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9595. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9596. echo 'GIT_PROJECT_NAME=$1' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9597. echo 'if [ ! $GIT_PROJECT_NAME ]; then' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9598. echo ' echo "Please specify a project name, without any spaces"' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9599. echo ' exit 1' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9600. echo 'fi' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9601. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9602. echo 'if [ ! -d /home/$USER/projects/$GIT_PROJECT_NAME ]; then' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9603. echo ' mkdir -p /home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9604. echo 'fi' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9605. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9606. echo 'cd /home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9607. echo 'git init --bare' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9608. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9609. echo -n 'echo "Your project has been created, ' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9610. echo 'use the following command to clone the repository"' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9611. echo -n " git clone ssh://$MY_USERNAME@$DEFAULT_DOMAIN_NAME:$SSH_PORT" >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9612. echo '/home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9613. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9614. echo 'exit 0' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9615. chmod +x /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  9616. echo 'create_git_project' >> $COMPLETION_FILE
  9617. }
  9618. function check_date {
  9619. curr_date=$(date)
  9620. if [[ $curr_date == *"1970"* ]]; then
  9621. apt-get -y install ntp
  9622. fi
  9623. }
  9624. function install_dynamicdns {
  9625. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  9626. return
  9627. fi
  9628. if [[ $ONION_ONLY != "no" ]]; then
  9629. return
  9630. fi
  9631. # update to the next commit
  9632. set_repo_commit $INSTALL_DIR/inadyn "inadyn commit" "$INADYN_COMMIT" $INADYN_REPO
  9633. if grep -Fxq "install_dynamicdns" $COMPLETION_FILE; then
  9634. return
  9635. fi
  9636. # Here we compile from source because the current package
  9637. # doesn't support https, which could result in passwords
  9638. # being leaked
  9639. # Debian version 1.99.4-1
  9640. # https version 1.99.8
  9641. apt-get -y install build-essential curl libgnutls28-dev automake1.11
  9642. if [ ! -d $INSTALL_DIR/inadyn ]; then
  9643. git_clone $INADYN_REPO $INSTALL_DIR/inadyn
  9644. fi
  9645. if [ ! -d $INSTALL_DIR/inadyn ]; then
  9646. echo 'inadyn repo not cloned'
  9647. echo -n | openssl s_client -showcerts -connect github.com:443 -CApath /etc/ssl/certs
  9648. exit 6785
  9649. fi
  9650. cd $INSTALL_DIR/inadyn
  9651. git checkout $INADYN_COMMIT -b $INADYN_COMMIT
  9652. if ! grep -q "inadyn commit" $COMPLETION_FILE; then
  9653. echo "inadyn commit:$INADYN_COMMIT" >> $COMPLETION_FILE
  9654. else
  9655. sed -i "s/inadyn commit.*/inadyn commit:$INADYN_COMMIT/g" $COMPLETION_FILE
  9656. fi
  9657. ./configure
  9658. if [ ! "$?" = "0" ]; then
  9659. exit 74890
  9660. fi
  9661. USE_OPENSSL=1 make
  9662. if [ ! "$?" = "0" ]; then
  9663. exit 74858
  9664. fi
  9665. make install
  9666. if [ ! "$?" = "0" ]; then
  9667. exit 3785
  9668. fi
  9669. # create an unprivileged user
  9670. #useradd -r -s /bin/false debian-inadyn
  9671. # create a configuration file
  9672. echo 'background' > /etc/inadyn.conf
  9673. echo 'verbose 1' >> /etc/inadyn.conf
  9674. echo 'period 300' >> /etc/inadyn.conf
  9675. echo 'startup-delay 60' >> /etc/inadyn.conf
  9676. echo 'cache-dir /run/inadyn' >> /etc/inadyn.conf
  9677. echo 'logfile /dev/null' >> /etc/inadyn.conf
  9678. chmod 600 /etc/inadyn.conf
  9679. echo '[Unit]' > /etc/systemd/system/inadyn.service
  9680. echo 'Description=inadyn (DynDNS updater)' >> /etc/systemd/system/inadyn.service
  9681. echo 'After=network.target' >> /etc/systemd/system/inadyn.service
  9682. echo '' >> /etc/systemd/system/inadyn.service
  9683. echo '[Service]' >> /etc/systemd/system/inadyn.service
  9684. echo 'ExecStart=/usr/local/sbin/inadyn --config /etc/inadyn.conf' >> /etc/systemd/system/inadyn.service
  9685. echo 'Restart=always' >> /etc/systemd/system/inadyn.service
  9686. echo 'Type=forking' >> /etc/systemd/system/inadyn.service
  9687. echo '' >> /etc/systemd/system/inadyn.service
  9688. echo '[Install]' >> /etc/systemd/system/inadyn.service
  9689. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/inadyn.service
  9690. systemctl enable inadyn
  9691. systemctl start inadyn
  9692. systemctl daemon-reload
  9693. echo 'install_dynamicdns' >> $COMPLETION_FILE
  9694. }
  9695. function get_voip_server_password {
  9696. if [ -f /home/$MY_USERNAME/README ]; then
  9697. if grep -q "VoIP server password" /home/$MY_USERNAME/README; then
  9698. if [ ! $VOIP_SERVER_PASSWORD ]; then
  9699. VOIP_SERVER_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "VoIP server password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  9700. fi
  9701. fi
  9702. fi
  9703. }
  9704. function get_sip_server_password {
  9705. if [ -f /home/$MY_USERNAME/README ]; then
  9706. if grep -q "SIP server password" /home/$MY_USERNAME/README; then
  9707. if [ ! $SIP_SERVER_PASSWORD ]; then
  9708. SIP_SERVER_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "SIP server password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  9709. fi
  9710. fi
  9711. fi
  9712. }
  9713. function install_ipfs {
  9714. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  9715. return
  9716. fi
  9717. select_go_version
  9718. # update to the next commit
  9719. set_repo_commit $GOPATH/src/github.com/ipfs/go-ipfs "ipfs commit" "$IPFS_COMMIT" $IPFS_REPO
  9720. if grep -Fxq "install_ipfs" $COMPLETION_FILE; then
  9721. return
  9722. fi
  9723. apt-get -y install golang libpam0g-dev fuse
  9724. if [ ! -d /home/git ]; then
  9725. # add a gogs user account
  9726. adduser --disabled-login --gecos 'Gogs' git
  9727. # install Go
  9728. if ! grep -q "export GOPATH=" ~/.bashrc; then
  9729. echo "export GOPATH=$GOPATH" >> ~/.bashrc
  9730. else
  9731. sed -i "s|export GOPATH=.*|export GOPATH=$GOPATH|g" ~/.bashrc
  9732. fi
  9733. systemctl set-environment GOPATH=$GOPATH
  9734. if ! grep -q "systemctl set-environment GOPATH=" ~/.bashrc; then
  9735. echo "systemctl set-environment GOPATH=$GOPATH" >> ~/.bashrc
  9736. else
  9737. sed -i "s|systemctl set-environment GOPATH=.*|systemctl set-environment GOPATH=$GOPATH|g" ~/.bashrc
  9738. fi
  9739. if [ ! -d $GOPATH ]; then
  9740. mkdir -p $GOPATH
  9741. fi
  9742. fi
  9743. IPFS_PATH=$GOPATH/bin
  9744. export PATH="$GOPATH/bin:$PATH:"
  9745. if ! grep -q 'GOPATH/bin' ~/.bashrc; then
  9746. echo 'export PATH="$GOPATH/bin:$PATH:";' >> ~/.bashrc
  9747. else
  9748. sed -i "s|systemctl set-environment GOPATH=.*|systemctl set-environment GOPATH=$GOPATH|g" ~/.bashrc
  9749. fi
  9750. # set gopath for the user
  9751. if ! grep -q "GOPATH=" /home/$MY_USERNAME/.bashrc; then
  9752. echo "export GOPATH=$GOPATH" >> /home/$MY_USERNAME/.bashrc
  9753. echo 'export PATH="$GOPATH/bin:$PATH:";' >> /home/$MY_USERNAME/.bashrc
  9754. else
  9755. sed -i "s|export GOPATH=.*|export GOPATH=$GOPATH|g" /home/$MY_USERNAME/.bashrc
  9756. fi
  9757. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.bashrc
  9758. IPFS_GO_REPO2=$(echo "$IPFS_GO_REPO" | sed 's|https://||g')
  9759. go get -u ${IPFS_GO_REPO2}/cmd/ipfs
  9760. if [ ! "$?" = "0" ]; then
  9761. exit 8242
  9762. fi
  9763. cd $GOPATH/src/$IPFS_GO_REPO2
  9764. git checkout $IPFS_COMMIT -b $IPFS_COMMIT
  9765. if ! grep -q "ipfs commit" $COMPLETION_FILE; then
  9766. echo "ipfs commit:$IPFS_COMMIT" >> $COMPLETION_FILE
  9767. else
  9768. sed -i "s/ipfs commit.*/ipfs commit:$IPFS_COMMIT/g" $COMPLETION_FILE
  9769. fi
  9770. # initialise
  9771. su -c "$IPFS_PATH/ipfs init -b 4096" - $MY_USERNAME
  9772. if [ ! -d /home/$MY_USERNAME/.ipfs ]; then
  9773. echo "IPFS could not be initialised for user $MY_USERNAME"
  9774. exit 7358
  9775. fi
  9776. # directories to mount to
  9777. if [ ! -d /ipfs ]; then
  9778. mkdir /ipfs
  9779. mkdir /ipns
  9780. chown $MY_USERNAME:$MY_USERNAME /ipfs
  9781. chown $MY_USERNAME:$MY_USERNAME /ipns
  9782. fi
  9783. if [ -f /etc/fuse.conf ]; then
  9784. chown $MY_USERNAME:$MY_USERNAME /etc/fuse.conf
  9785. fi
  9786. if [ -f /dev/fuse ]; then
  9787. chown $MY_USERNAME:$MY_USERNAME /dev/fuse
  9788. fi
  9789. echo '[Unit]' > /etc/systemd/system/ipfs.service
  9790. echo 'Description=IPFS daemon' >> /etc/systemd/system/ipfs.service
  9791. echo 'After=syslog.target' >> /etc/systemd/system/ipfs.service
  9792. echo 'After=network.target' >> /etc/systemd/system/ipfs.service
  9793. echo '' >> /etc/systemd/system/ipfs.service
  9794. echo '[Service]' >> /etc/systemd/system/ipfs.service
  9795. echo 'Type=simple' >> /etc/systemd/system/ipfs.service
  9796. echo "User=$MY_USERNAME" >> /etc/systemd/system/ipfs.service
  9797. echo "Group=$MY_USERNAME" >> /etc/systemd/system/ipfs.service
  9798. echo "WorkingDirectory=/home/$MY_USERNAME" >> /etc/systemd/system/ipfs.service
  9799. echo "ExecStart=$IPFS_PATH/ipfs daemon --mount" >> /etc/systemd/system/ipfs.service
  9800. echo 'Restart=on-failure' >> /etc/systemd/system/ipfs.service
  9801. echo "Environment=\"USER=$MY_USERNAME\" \"HOME=/home/$MY_USERNAME\" \"GOPATH=$GOPATH\" \"GVM_ROOT=$GVM_HOME\"" >> /etc/systemd/system/ipfs.service
  9802. echo '' >> /etc/systemd/system/ipfs.service
  9803. echo '[Install]' >> /etc/systemd/system/ipfs.service
  9804. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/ipfs.service
  9805. systemctl enable ipfs
  9806. systemctl daemon-reload
  9807. systemctl restart ipfs
  9808. if [ -d /etc/avahi ]; then
  9809. su -c "echo $($IPFS_PATH/ipfs id | grep '\"ID\":' | awk -F '\"' '{print $4}') > /tmp/ipfsid" - $MY_USERNAME
  9810. if [ ! -f /tmp/ipfsid ]; then
  9811. echo 'No IPFS identity was created'
  9812. exit 37895
  9813. fi
  9814. IPFS_PEER_ID=$(cat /tmp/ipfsid)
  9815. if [ ${#IPFS_PEER_ID} -lt 10 ]; then
  9816. echo 'Invalid IPFS peer ID'
  9817. echo "$IPFS_PEER_ID"
  9818. exit 74782
  9819. fi
  9820. # Add an avahi service
  9821. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/ipfs.service
  9822. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/ipfs.service
  9823. echo '<service-group>' >> /etc/avahi/services/ipfs.service
  9824. echo ' <name replace-wildcards="yes">%h IPFS</name>' >> /etc/avahi/services/ipfs.service
  9825. echo ' <service>' >> /etc/avahi/services/ipfs.service
  9826. echo ' <type>_ipfs._tcp</type>' >> /etc/avahi/services/ipfs.service
  9827. echo " <port>$IPFS_PORT</port>" >> /etc/avahi/services/ipfs.service
  9828. echo " <txt-record>$IPFS_PEER_ID</txt-record>" >> /etc/avahi/services/ipfs.service
  9829. echo ' </service>' >> /etc/avahi/services/ipfs.service
  9830. echo '</service-group>' >> /etc/avahi/services/ipfs.service
  9831. rm /tmp/ipfsid
  9832. fi
  9833. echo 'install_ipfs' >> $COMPLETION_FILE
  9834. }
  9835. function install_voip {
  9836. 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
  9837. return
  9838. fi
  9839. if grep -Fxq "install_voip" $COMPLETION_FILE; then
  9840. return
  9841. fi
  9842. apt-get -y install mumble-server
  9843. get_voip_server_password
  9844. if [ ! $VOIP_SERVER_PASSWORD ]; then
  9845. if [ -f $IMAGE_PASSWORD_FILE ]; then
  9846. VOIP_SERVER_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  9847. else
  9848. VOIP_SERVER_PASSWORD="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  9849. if [ ${#VOIP_SERVER_PASSWORD} -lt $MINIMUM_PASSWORD_LENGTH ]; then
  9850. VOIP_SERVER_PASSWORD="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  9851. fi
  9852. fi
  9853. fi
  9854. # Make an ssl cert for the server
  9855. if [ ! -f /etc/ssl/certs/mumble.dhparam ]; then
  9856. ${PROJECT_NAME}-addcert -h mumble --dhkey $DH_KEYLENGTH
  9857. check_certificates mumble
  9858. fi
  9859. # Check that the cert was created
  9860. if [ ! -f /etc/ssl/certs/mumble.crt ]; then
  9861. echo $'VoIP server certificate not created'
  9862. exit 57892
  9863. fi
  9864. if [ ! -f /etc/ssl/private/mumble.key ]; then
  9865. echo $'VoIP server key not created'
  9866. exit 57893
  9867. fi
  9868. if [ ! -d /var/lib/mumble-server ]; then
  9869. mkdir /var/lib/mumble-server
  9870. fi
  9871. cp /etc/ssl/certs/mumble.* /var/lib/mumble-server
  9872. cp /etc/ssl/private/mumble.key /var/lib/mumble-server
  9873. chown -R mumble-server:mumble-server /var/lib/mumble-server
  9874. sed -i "s|welcometext=.*|welcometext=\"<br />Welcome to $DEFAULT_DOMAIN_NAME <b>VoIP</b>.<br />Chat freely!<br />\"|g" /etc/mumble-server.ini
  9875. if [[ $VOIP_SERVER_PASSWORD && $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  9876. sed -i "s|serverpassword=.*|serverpassword=$VOIP_SERVER_PASSWORD|g" /etc/mumble-server.ini
  9877. fi
  9878. sed -i 's|#autobanAttempts.*|autobanAttempts = 10|g' /etc/mumble-server.ini
  9879. sed -i 's|#autobanTimeframe.*|autobanTimeframe = 120|g' /etc/mumble-server.ini
  9880. sed -i 's|#autobanTime.*|autobanTime = 300|g' /etc/mumble-server.ini
  9881. sed -i 's|#sendversion=.*|sendversion=False|g' /etc/mumble-server.ini
  9882. sed -i 's|sendversion=.*|sendversion=False|g' /etc/mumble-server.ini
  9883. if ! grep -q "allowping" /etc/mumble-server.ini; then
  9884. echo 'allowping=False' >> /etc/mumble-server.ini
  9885. fi
  9886. sed -i 's|allowping=.*|allowping=False|g' /etc/mumble-server.ini
  9887. sed -i 's|#sslCert=.*|sslCert=/var/lib/mumble-server/mumble.crt|g' /etc/mumble-server.ini
  9888. sed -i 's|#sslKey=.*|sslKey=/var/lib/mumble-server/mumble.key|g' /etc/mumble-server.ini
  9889. sed -i 's|#certrequired=.*|certrequired=True|g' /etc/mumble-server.ini
  9890. sed -i 's|users=100|users=10|g' /etc/mumble-server.ini
  9891. sed -i 's|#channelnestinglimit=10|channelnestinglimit=10|g' /etc/mumble-server.ini
  9892. sed -i 's|#textmessagelength=.*|textmessagelength=1000|g' /etc/mumble-server.ini
  9893. sed -i 's|textmessagelength=.*|textmessagelength=1000|g' /etc/mumble-server.ini
  9894. sed -i 's|#imagemessagelength=.*|imagemessagelength=131072|g' /etc/mumble-server.ini
  9895. sed -i 's|#allowhtml=.*|allowhtml=False|g' /etc/mumble-server.ini
  9896. sed -i 's|allowhtml=.*|allowhtml=False|g' /etc/mumble-server.ini
  9897. sed -i "s|port=.*|port=${VOIP_PORT}|g" /etc/mumble-server.ini
  9898. VOIP_ONION_HOSTNAME=$(add_onion_service voip ${VOIP_PORT} ${VOIP_PORT})
  9899. if ! grep -q $"VoIP onion domain" $COMPLETION_FILE; then
  9900. echo "VoIP onion domain:$VOIP_ONION_HOSTNAME" >> $COMPLETION_FILE
  9901. fi
  9902. systemctl restart mumble-server
  9903. if ! grep -q $"VoIP Server" /home/$MY_USERNAME/README; then
  9904. echo '' >> /home/$MY_USERNAME/README
  9905. echo '' >> /home/$MY_USERNAME/README
  9906. echo $'VoIP Server' >> /home/$MY_USERNAME/README
  9907. echo '===========' >> /home/$MY_USERNAME/README
  9908. echo $"VoIP onion domain:$VOIP_ONION_HOSTNAME" >> /home/$MY_USERNAME/README
  9909. echo $'VoIP server username: mumble-server' >> /home/$MY_USERNAME/README
  9910. if [[ $SYSTEM_TYPE != "VARIANT_MESH" ]]; then
  9911. echo $"VoIP server password: $VOIP_SERVER_PASSWORD" >> /home/$MY_USERNAME/README
  9912. fi
  9913. echo '' >> /home/$MY_USERNAME/README
  9914. echo $'To connect to the VoIP server use your username and the server password shown above.' >> /home/$MY_USERNAME/README
  9915. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  9916. chmod 600 /home/$MY_USERNAME/README
  9917. fi
  9918. echo 'install_voip' >> $COMPLETION_FILE
  9919. }
  9920. function update_sipwitch_daemon {
  9921. if [ ! -f /etc/init.d/sipwitch ]; then
  9922. return
  9923. fi
  9924. service sipwitch stop
  9925. # remove the original sipwitch daemon if it exists
  9926. if [ -f /etc/init.d/sipwitch ]; then
  9927. rm -f /etc/init.d/sipwitch
  9928. fi
  9929. # daemon
  9930. echo '[Unit]' > /etc/systemd/system/sipwitch.service
  9931. echo 'Description=GNU SIP Witch, a SIP telephony service daemon.' >> /etc/systemd/system/sipwitch.service
  9932. echo 'After=network.target' >> /etc/systemd/system/sipwitch.service
  9933. echo '' >> /etc/systemd/system/sipwitch.service
  9934. echo '[Service]' >> /etc/systemd/system/sipwitch.service
  9935. echo 'Type=simple' >> /etc/systemd/system/sipwitch.service
  9936. echo 'Group=sipwitch' >> /etc/systemd/system/sipwitch.service
  9937. echo 'PIDFile=/var/run/sipwitch/pidfile' >> /etc/systemd/system/sipwitch.service
  9938. echo 'EnvironmentFile=-/etc/conf.d/sipwitch' >> /etc/systemd/system/sipwitch.service
  9939. echo 'EnvironmentFile=-/etc/sipwitch.conf' >> /etc/systemd/system/sipwitch.service
  9940. echo 'EnvironmentFile=-/etc/default/sipwitch' >> /etc/systemd/system/sipwitch.service
  9941. echo 'ExecStartPre=-/bin/rm -f /var/run/sipwitch/control' >> /etc/systemd/system/sipwitch.service
  9942. echo "ExecStart=/usr/sbin/sipw -f \$OPTIONS -P$SIP_PORT" >> /etc/systemd/system/sipwitch.service
  9943. echo 'Restart=always' >> /etc/systemd/system/sipwitch.service
  9944. echo 'NotifyAccess=main' >> /etc/systemd/system/sipwitch.service
  9945. echo '' >> /etc/systemd/system/sipwitch.service
  9946. echo '[Install]' >> /etc/systemd/system/sipwitch.service
  9947. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/sipwitch.service
  9948. systemctl enable sipwitch
  9949. systemctl daemon-reload
  9950. systemctl start sipwitch
  9951. }
  9952. function install_sip {
  9953. 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
  9954. return
  9955. fi
  9956. if grep -Fxq "install_sip" $COMPLETION_FILE; then
  9957. return
  9958. fi
  9959. apt-get -y install sipwitch
  9960. get_sip_server_password
  9961. if [ ! $SIP_SERVER_PASSWORD ]; then
  9962. if [ -f $IMAGE_PASSWORD_FILE ]; then
  9963. SIP_SERVER_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  9964. else
  9965. SIP_SERVER_PASSWORD="$(openssl rand -base64 30 | cut -c1-${MINIMUM_PASSWORD_LENGTH})"
  9966. fi
  9967. fi
  9968. echo '<?xml version="1.0"?>' > /etc/sipwitch.conf
  9969. echo '<sipwitch>' >> /etc/sipwitch.conf
  9970. echo '<provision>' >> /etc/sipwitch.conf
  9971. echo "<user id=\"$MY_USERNAME\">" >> /etc/sipwitch.conf
  9972. echo '<extension>201</extension>' >> /etc/sipwitch.conf
  9973. echo "<secret>$SIP_SERVER_PASSWORD</secret>" >> /etc/sipwitch.conf
  9974. echo "<display>$MY_USERNAME 201</display>" >> /etc/sipwitch.conf
  9975. echo '</user>' >> /etc/sipwitch.conf
  9976. echo '</provision>' >> /etc/sipwitch.conf
  9977. echo '<access>' >> /etc/sipwitch.conf
  9978. echo '</access>' >> /etc/sipwitch.conf
  9979. echo '<stack>' >> /etc/sipwitch.conf
  9980. echo " <localnames>$DEFAULT_DOMAIN_NAME</localnames>" >> /etc/sipwitch.conf
  9981. echo ' <mapped>200</mapped>' >> /etc/sipwitch.conf
  9982. echo ' <threading>2</threading>' >> /etc/sipwitch.conf
  9983. echo ' <interface>*</interface>' >> /etc/sipwitch.conf
  9984. echo ' <dumping>false</dumping>' >> /etc/sipwitch.conf
  9985. echo ' <system>system</system>' >> /etc/sipwitch.conf
  9986. echo ' <anon>anonymous</anon>' >> /etc/sipwitch.conf
  9987. echo '</stack>' >> /etc/sipwitch.conf
  9988. echo '<timers>' >> /etc/sipwitch.conf
  9989. echo ' <!-- ring every 4 seconds -->' >> /etc/sipwitch.conf
  9990. echo ' <ring>4</ring>' >> /etc/sipwitch.conf
  9991. echo ' <!-- call forward no answer after x rings -->' >> /etc/sipwitch.conf
  9992. echo ' <cfna>4</cfna>' >> /etc/sipwitch.conf
  9993. echo ' <!-- call reset to clear cid in stack, 6 seconds -->' >> /etc/sipwitch.conf
  9994. echo ' <reset>6</reset>' >> /etc/sipwitch.conf
  9995. echo '</timers>' >> /etc/sipwitch.conf
  9996. echo '<!-- we have 2xx numbers plus space for external users -->' >> /etc/sipwitch.conf
  9997. echo '<registry>' >> /etc/sipwitch.conf
  9998. echo ' <prefix>200</prefix>' >> /etc/sipwitch.conf
  9999. echo ' <range>100</range>' >> /etc/sipwitch.conf
  10000. echo ' <keysize>77</keysize>' >> /etc/sipwitch.conf
  10001. echo ' <mapped>200</mapped>' >> /etc/sipwitch.conf
  10002. echo ' <!-- <realm>GNU Telephony</realm> -->' >> /etc/sipwitch.conf
  10003. echo '</registry>' >> /etc/sipwitch.conf
  10004. echo '<routing>' >> /etc/sipwitch.conf
  10005. echo '</routing>' >> /etc/sipwitch.conf
  10006. echo '</sipwitch>' >> /etc/sipwitch.conf
  10007. sed -i 's|#PLUGINS=|PLUGINS=|g' /etc/default/sipwitch
  10008. sed -i 's|PLUGINS=.*|PLUGINS="zeroconf subscriber forward"|g' /etc/default/sipwitch
  10009. groupadd sipwitch
  10010. usermod -aG sipwitch $MY_USERNAME
  10011. SIP_ONION_HOSTNAME=$(add_onion_service sip ${SIP_PORT} ${SIP_PORT})
  10012. if ! grep -q $"SIP onion domain" $COMPLETION_FILE; then
  10013. echo "SIP onion domain:$SIP_ONION_HOSTNAME" >> $COMPLETION_FILE
  10014. fi
  10015. if ! grep -q $"SIP Server" /home/$MY_USERNAME/README; then
  10016. echo '' >> /home/$MY_USERNAME/README
  10017. echo '' >> /home/$MY_USERNAME/README
  10018. echo $'SIP Server' >> /home/$MY_USERNAME/README
  10019. echo '==========' >> /home/$MY_USERNAME/README
  10020. echo $"SIP onion_domain: $SIP_ONION_HOSTNAME" >> /home/$MY_USERNAME/README
  10021. echo $"SIP server username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  10022. echo $"SIP server extension: 201" >> /home/$MY_USERNAME/README
  10023. echo $"SIP server password: $SIP_SERVER_PASSWORD" >> /home/$MY_USERNAME/README
  10024. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  10025. chmod 600 /home/$MY_USERNAME/README
  10026. fi
  10027. echo 'install_sip' >> $COMPLETION_FILE
  10028. }
  10029. function install_sip_turn {
  10030. 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
  10031. return
  10032. fi
  10033. if grep -Fxq "install_sip_turn" $COMPLETION_FILE; then
  10034. return
  10035. fi
  10036. apt-get -y install turnserver
  10037. # create a nonce if needed
  10038. if [ ! $VOIP_TURN_NONCE ]; then
  10039. VOIP_TURN_NONCE="$(openssl rand -base64 32 | cut -c1-30)"
  10040. fi
  10041. create_site_certificate $DEFAULT_DOMAIN_NAME
  10042. echo '##' > /etc/turnserver/turnserver.conf
  10043. echo '# TurnServer configuration file.' >> /etc/turnserver/turnserver.conf
  10044. echo '#' >> /etc/turnserver/turnserver.conf
  10045. echo '' >> /etc/turnserver/turnserver.conf
  10046. echo '## Public IPv4 address of any relayed address (if not set, no relay for IPv4).' >> /etc/turnserver/turnserver.conf
  10047. echo '## To have multiple address, separate addresses with a comma' >> /etc/turnserver/turnserver.conf
  10048. echo '## (i.e. listen_address = { "172.16.0.1", "172.17.0.1" }).' >> /etc/turnserver/turnserver.conf
  10049. echo "listen_address = { \"192.168.0.1\" }" >> /etc/turnserver/turnserver.conf
  10050. echo '' >> /etc/turnserver/turnserver.conf
  10051. echo '## Public IPv6 address of any relayed address (if not set, no relay for IPv6).' >> /etc/turnserver/turnserver.conf
  10052. echo '## To have multiple address, separate address with a comma' >> /etc/turnserver/turnserver.conf
  10053. echo '## (i.e. listen_addressv6 = { "2001:db8:1::1", "2001:db8:2::1" }).' >> /etc/turnserver/turnserver.conf
  10054. echo "#listen_addressv6 = { \"2001:db8::1\" }" >> /etc/turnserver/turnserver.conf
  10055. echo '' >> /etc/turnserver/turnserver.conf
  10056. echo '## UDP listening port.' >> /etc/turnserver/turnserver.conf
  10057. echo "udp_port = $VOIP_TURN_PORT" >> /etc/turnserver/turnserver.conf
  10058. echo '' >> /etc/turnserver/turnserver.conf
  10059. echo '## TCP listening port.' >> /etc/turnserver/turnserver.conf
  10060. echo "tcp_port = $VOIP_TURN_PORT" >> /etc/turnserver/turnserver.conf
  10061. echo '' >> /etc/turnserver/turnserver.conf
  10062. echo '## TLS listening port.' >> /etc/turnserver/turnserver.conf
  10063. echo "tls_port = $VOIP_TURN_TLS_PORT" >> /etc/turnserver/turnserver.conf
  10064. echo '' >> /etc/turnserver/turnserver.conf
  10065. echo '## TLS support.' >> /etc/turnserver/turnserver.conf
  10066. echo 'tls = true' >> /etc/turnserver/turnserver.conf
  10067. echo '' >> /etc/turnserver/turnserver.conf
  10068. echo '## DTLS support. It is an experimental feature and is not defined in TURN' >> /etc/turnserver/turnserver.conf
  10069. echo '## standard.' >> /etc/turnserver/turnserver.conf
  10070. echo 'dtls = false' >> /etc/turnserver/turnserver.conf
  10071. echo '' >> /etc/turnserver/turnserver.conf
  10072. echo '## Maximum allocation port number.' >> /etc/turnserver/turnserver.conf
  10073. echo 'max_port = 65535' >> /etc/turnserver/turnserver.conf
  10074. echo '' >> /etc/turnserver/turnserver.conf
  10075. echo '## Minimum allocation port number.' >> /etc/turnserver/turnserver.conf
  10076. echo '' >> /etc/turnserver/turnserver.conf
  10077. echo 'min_port = 49152' >> /etc/turnserver/turnserver.conf
  10078. echo '' >> /etc/turnserver/turnserver.conf
  10079. echo '## TURN-TCP support.' >> /etc/turnserver/turnserver.conf
  10080. echo '' >> /etc/turnserver/turnserver.conf
  10081. echo 'turn_tcp = true' >> /etc/turnserver/turnserver.conf
  10082. echo '' >> /etc/turnserver/turnserver.conf
  10083. echo '## TURN-TCP buffering mode:' >> /etc/turnserver/turnserver.conf
  10084. echo '## - true, use userspace buffering;' >> /etc/turnserver/turnserver.conf
  10085. echo '## - false, use kernel buffering.' >> /etc/turnserver/turnserver.conf
  10086. echo 'tcp_buffer_userspace = true' >> /etc/turnserver/turnserver.conf
  10087. echo '' >> /etc/turnserver/turnserver.conf
  10088. echo '## TURN-TCP maximum buffer size.' >> /etc/turnserver/turnserver.conf
  10089. echo 'tcp_buffer_size = 32768' >> /etc/turnserver/turnserver.conf
  10090. echo '' >> /etc/turnserver/turnserver.conf
  10091. echo '## Daemon mode.' >> /etc/turnserver/turnserver.conf
  10092. echo 'daemon = true' >> /etc/turnserver/turnserver.conf
  10093. echo '' >> /etc/turnserver/turnserver.conf
  10094. echo '## Unprivileged user.' >> /etc/turnserver/turnserver.conf
  10095. echo '## If you want to use this feature create a system user.' >> /etc/turnserver/turnserver.conf
  10096. echo '## On Linux: adduser --system --group turnserver' >> /etc/turnserver/turnserver.conf
  10097. echo 'unpriv_user = turnserver' >> /etc/turnserver/turnserver.conf
  10098. echo '' >> /etc/turnserver/turnserver.conf
  10099. echo '## Realm value.' >> /etc/turnserver/turnserver.conf
  10100. echo "realm = \"$DEFAULT_DOMAIN_NAME\"" >> /etc/turnserver/turnserver.conf
  10101. echo '' >> /etc/turnserver/turnserver.conf
  10102. echo '## Nonce key.' >> /etc/turnserver/turnserver.conf
  10103. echo "nonce_key = \"$VOIP_TURN_NONCE\"" >> /etc/turnserver/turnserver.conf
  10104. echo '' >> /etc/turnserver/turnserver.conf
  10105. echo '## Max relay per username.' >> /etc/turnserver/turnserver.conf
  10106. echo 'max_relay_per_username = 5' >> /etc/turnserver/turnserver.conf
  10107. echo '' >> /etc/turnserver/turnserver.conf
  10108. echo '## Allocation lifetime.' >> /etc/turnserver/turnserver.conf
  10109. echo 'allocation_lifetime = 1800' >> /etc/turnserver/turnserver.conf
  10110. echo '' >> /etc/turnserver/turnserver.conf
  10111. echo '## Allocation bandwidth limitation (in KBytes/s).' >> /etc/turnserver/turnserver.conf
  10112. echo '## 0 value means bandwidth quota disabled.' >> /etc/turnserver/turnserver.conf
  10113. echo 'bandwidth_per_allocation = 150' >> /etc/turnserver/turnserver.conf
  10114. echo '' >> /etc/turnserver/turnserver.conf
  10115. echo '## Restricted user bandwidth (in KBytes/s).' >> /etc/turnserver/turnserver.conf
  10116. echo '## 0 value means bandwidth limitation disabled.' >> /etc/turnserver/turnserver.conf
  10117. echo 'restricted_bandwidth = 10' >> /etc/turnserver/turnserver.conf
  10118. echo '' >> /etc/turnserver/turnserver.conf
  10119. echo '## Denied addresses.' >> /etc/turnserver/turnserver.conf
  10120. echo '' >> /etc/turnserver/turnserver.conf
  10121. echo '# disallow relaying to localhost' >> /etc/turnserver/turnserver.conf
  10122. echo 'denied_address {' >> /etc/turnserver/turnserver.conf
  10123. echo ' address = "127.0.0.1"' >> /etc/turnserver/turnserver.conf
  10124. echo ' mask = "8"' >> /etc/turnserver/turnserver.conf
  10125. echo ' port = 0' >> /etc/turnserver/turnserver.conf
  10126. echo '}' >> /etc/turnserver/turnserver.conf
  10127. echo '' >> /etc/turnserver/turnserver.conf
  10128. echo '# disallow relaying to ip6-localhost' >> /etc/turnserver/turnserver.conf
  10129. echo 'denied_address {' >> /etc/turnserver/turnserver.conf
  10130. echo ' address = "::1"' >> /etc/turnserver/turnserver.conf
  10131. echo ' mask = "128"' >> /etc/turnserver/turnserver.conf
  10132. echo ' port = 0' >> /etc/turnserver/turnserver.conf
  10133. echo '}' >> /etc/turnserver/turnserver.conf
  10134. echo '' >> /etc/turnserver/turnserver.conf
  10135. echo '## Certification Authority file.' >> /etc/turnserver/turnserver.conf
  10136. echo "ca_file = \"/etc/ssl/certs/ca-certificates.crt\"" >> /etc/turnserver/turnserver.conf
  10137. echo '' >> /etc/turnserver/turnserver.conf
  10138. echo '## Server certificate file.' >> /etc/turnserver/turnserver.conf
  10139. if [ -f /etc/ssl/certs/$DEFAULT_DOMAIN_NAME.pem ]; then
  10140. echo "cert_file = \"/etc/ssl/certs/$DEFAULT_DOMAIN_NAME.pem\"" >> /etc/turnserver/turnserver.conf
  10141. else
  10142. if [ -f /etc/ssl/certs/$DEFAULT_DOMAIN_NAME.crt ]; then
  10143. echo "cert_file = \"/etc/ssl/certs/$DEFAULT_DOMAIN_NAME.crt\"" >> /etc/turnserver/turnserver.conf
  10144. fi
  10145. fi
  10146. echo '' >> /etc/turnserver/turnserver.conf
  10147. echo '## Private key file.' >> /etc/turnserver/turnserver.conf
  10148. echo "private_key_file = \"/etc/ssl/certs/$DEFAULT_DOMAIN_NAME.key\"" >> /etc/turnserver/turnserver.conf
  10149. echo '' >> /etc/turnserver/turnserver.conf
  10150. echo '## Account method.' >> /etc/turnserver/turnserver.conf
  10151. echo "account_method = \"file\"" >> /etc/turnserver/turnserver.conf
  10152. echo '' >> /etc/turnserver/turnserver.conf
  10153. echo '## Account file (if account_method = file).' >> /etc/turnserver/turnserver.conf
  10154. echo "account_file = \"/etc/turnserver/turnusers.txt\"" >> /etc/turnserver/turnserver.conf
  10155. echo '' >> /etc/turnserver/turnserver.conf
  10156. echo '## mod_tmpuser.' >> /etc/turnserver/turnserver.conf
  10157. echo 'mod_tmpuser = false' >> /etc/turnserver/turnserver.conf
  10158. echo "${MY_USERNAME}:password:${DEFAULT_DOMAIN_NAME}:authorized" > /etc/turnserver/turnusers.txt
  10159. systemctl restart turnserver
  10160. echo 'install_sip_turn' >> $COMPLETION_FILE
  10161. }
  10162. function install_final {
  10163. if grep -Fxq "install_final" $COMPLETION_FILE; then
  10164. return
  10165. fi
  10166. # unmount any attached usb drive
  10167. if [ -d $USB_MOUNT ]; then
  10168. umount $USB_MOUNT
  10169. rm -rf $USB_MOUNT
  10170. fi
  10171. split_gpg_key_into_fragments
  10172. echo 'install_final' >> $COMPLETION_FILE
  10173. clear
  10174. echo ''
  10175. echo $"
  10176. *** ${PROJECT_NAME} installation is complete. Rebooting... ***
  10177. Now forward these ports from your internet router
  10178. HTTP 80
  10179. HTTPS 443
  10180. SSH 2222
  10181. DLNA 1900
  10182. DLNA 8200
  10183. XMPP 5222-5223
  10184. XMPP 5269
  10185. XMPP 5280-5281
  10186. IRC 6697
  10187. Git 9418
  10188. Email 25
  10189. Email 587
  10190. Email 465
  10191. Email 993
  10192. VoIP 64738
  10193. VoIP 5060
  10194. Tox 33445
  10195. "
  10196. if [ -f "/home/$MY_USERNAME/README" ]; then
  10197. echo $"See /home/$MY_USERNAME/README for post-installation instructions."
  10198. echo ''
  10199. fi
  10200. # add user menu on ssh login
  10201. if ! grep -q 'control' /home/$MY_USERNAME/.bashrc; then
  10202. echo 'control' >> /home/$MY_USERNAME/.bashrc
  10203. fi
  10204. if [ ! -f $IMAGE_PASSWORD_FILE ]; then
  10205. reboot
  10206. fi
  10207. }
  10208. read_configuration
  10209. set_default_onion_domains
  10210. locale_setup
  10211. parse_args
  10212. check_domains
  10213. install_not_on_BBB
  10214. remove_default_user
  10215. configure_firewall
  10216. configure_firewall_ping
  10217. configure_firewall_for_ssh
  10218. configure_firewall_for_dns
  10219. configure_firewall_for_ftp
  10220. configure_firewall_for_web_access
  10221. configure_firewall_for_voip
  10222. configure_firewall_for_voip_turn
  10223. configure_firewall_for_sip4
  10224. configure_firewall_for_avahi
  10225. configure_firewall_for_zeronet
  10226. configure_firewall_for_ipfs
  10227. create_repo_sources
  10228. configure_dns
  10229. initial_setup
  10230. install_tor
  10231. #resolve_dns_via_tor
  10232. install_command_line_browser
  10233. enable_ssh_via_onion
  10234. check_date
  10235. install_dynamicdns
  10236. randomize_cron
  10237. create_freedns_updater
  10238. mark_admin_user_account
  10239. enforce_good_passwords
  10240. install_editor
  10241. change_login_message
  10242. enable_zram
  10243. random_number_generator
  10244. set_your_domain_name
  10245. time_synchronisation
  10246. configure_internet_protocol
  10247. create_git_project
  10248. setup_wifi
  10249. configure_ssh
  10250. configure_ssh_onion
  10251. allow_ssh_to_onion_address
  10252. remove_instructions_from_motd
  10253. check_hwrng
  10254. search_for_attached_usb_drive
  10255. regenerate_ssh_keys
  10256. create_mirrors
  10257. create_upgrade_script
  10258. letsencrypt_renewals
  10259. install_zeronet
  10260. install_watchdog_script
  10261. configure_avahi
  10262. create_avahi_onion_domains
  10263. install_zeronet_blog
  10264. install_zeronet_mail
  10265. install_zeronet_forum
  10266. #install_atheros_wifi
  10267. configure_firewall_for_cjdns
  10268. mesh_cjdns
  10269. mesh_cjdns_tools
  10270. configure_firewall_for_batman
  10271. mesh_batman
  10272. configure_firewall_for_babel
  10273. mesh_babel
  10274. route_outgoing_traffic_through_tor
  10275. configure_email
  10276. create_procmail
  10277. handle_admin_emails
  10278. spam_filtering
  10279. configure_imap
  10280. #configure_imap_client_certs
  10281. configure_gpg
  10282. refresh_gpg_keys
  10283. configure_backup_key
  10284. install_monkeysphere
  10285. encrypt_incoming_email
  10286. encrypt_outgoing_email
  10287. email_client
  10288. email_archiving
  10289. email_from_address
  10290. configure_firewall_for_email
  10291. create_public_mailing_list
  10292. #create_private_mailing_list
  10293. encrypt_all_email
  10294. import_email
  10295. script_for_attaching_usb_drive
  10296. install_web_server
  10297. install_web_server_access_control
  10298. configure_firewall_for_web_server
  10299. configure_firewall_for_syncthing
  10300. install_syncthing
  10301. upgrade_golang
  10302. install_gogs
  10303. install_xmpp
  10304. install_xmpp_client
  10305. install_tox_node
  10306. install_tox_client
  10307. tox_avahi
  10308. configure_firewall_for_xmpp
  10309. install_irc_server
  10310. configure_firewall_for_irc
  10311. install_irc_client
  10312. install_voip
  10313. install_sip
  10314. update_sipwitch_daemon
  10315. install_wiki
  10316. install_sip_turn
  10317. install_blog
  10318. mark_blog_domain
  10319. install_gnu_social
  10320. expire_gnu_social_posts
  10321. install_gnu_social_theme
  10322. install_gnu_social_markdown
  10323. install_gnu_social_plugin_sharings
  10324. install_gnu_social_plugin_sharings_theme
  10325. install_rss_reader
  10326. install_rss_reader_gnusocial
  10327. install_rss_mobile_reader
  10328. install_hubzilla
  10329. #install_webmail
  10330. #install_search_engine
  10331. install_dlna_server
  10332. configure_firewall_for_dlna
  10333. #install_media_server
  10334. #install_mediagoblin
  10335. #install_ipfs
  10336. repair_databases_script
  10337. backup_to_friends_servers
  10338. intrusion_detection
  10339. install_final
  10340. echo "${PROJECT_NAME} installation is complete"
  10341. exit 0