freedombone 493KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983598459855986598759885989599059915992599359945995599659975998599960006001600260036004600560066007600860096010601160126013601460156016601760186019602060216022602360246025602660276028602960306031603260336034603560366037603860396040604160426043604460456046604760486049605060516052605360546055605660576058605960606061606260636064606560666067606860696070607160726073607460756076607760786079608060816082608360846085608660876088608960906091609260936094609560966097609860996100610161026103610461056106610761086109611061116112611361146115611661176118611961206121612261236124612561266127612861296130613161326133613461356136613761386139614061416142614361446145614661476148614961506151615261536154615561566157615861596160616161626163616461656166616761686169617061716172617361746175617661776178617961806181618261836184618561866187618861896190619161926193619461956196619761986199620062016202620362046205620662076208620962106211621262136214621562166217621862196220622162226223622462256226622762286229623062316232623362346235623662376238623962406241624262436244624562466247624862496250625162526253625462556256625762586259626062616262626362646265626662676268626962706271627262736274627562766277627862796280628162826283628462856286628762886289629062916292629362946295629662976298629963006301630263036304630563066307630863096310631163126313631463156316631763186319632063216322632363246325632663276328632963306331633263336334633563366337633863396340634163426343634463456346634763486349635063516352635363546355635663576358635963606361636263636364636563666367636863696370637163726373637463756376637763786379638063816382638363846385638663876388638963906391639263936394639563966397639863996400640164026403640464056406640764086409641064116412641364146415641664176418641964206421642264236424642564266427642864296430643164326433643464356436643764386439644064416442644364446445644664476448644964506451645264536454645564566457645864596460646164626463646464656466646764686469647064716472647364746475647664776478647964806481648264836484648564866487648864896490649164926493649464956496649764986499650065016502650365046505650665076508650965106511651265136514651565166517651865196520652165226523652465256526652765286529653065316532653365346535653665376538653965406541654265436544654565466547654865496550655165526553655465556556655765586559656065616562656365646565656665676568656965706571657265736574657565766577657865796580658165826583658465856586658765886589659065916592659365946595659665976598659966006601660266036604660566066607660866096610661166126613661466156616661766186619662066216622662366246625662666276628662966306631663266336634663566366637663866396640664166426643664466456646664766486649665066516652665366546655665666576658665966606661666266636664666566666667666866696670667166726673667466756676667766786679668066816682668366846685668666876688668966906691669266936694669566966697669866996700670167026703670467056706670767086709671067116712671367146715671667176718671967206721672267236724672567266727672867296730673167326733673467356736673767386739674067416742674367446745674667476748674967506751675267536754675567566757675867596760676167626763676467656766676767686769677067716772677367746775677667776778677967806781678267836784678567866787678867896790679167926793679467956796679767986799680068016802680368046805680668076808680968106811681268136814681568166817681868196820682168226823682468256826682768286829683068316832683368346835683668376838683968406841684268436844684568466847684868496850685168526853685468556856685768586859686068616862686368646865686668676868686968706871687268736874687568766877687868796880688168826883688468856886688768886889689068916892689368946895689668976898689969006901690269036904690569066907690869096910691169126913691469156916691769186919692069216922692369246925692669276928692969306931693269336934693569366937693869396940694169426943694469456946694769486949695069516952695369546955695669576958695969606961696269636964696569666967696869696970697169726973697469756976697769786979698069816982698369846985698669876988698969906991699269936994699569966997699869997000700170027003700470057006700770087009701070117012701370147015701670177018701970207021702270237024702570267027702870297030703170327033703470357036703770387039704070417042704370447045704670477048704970507051705270537054705570567057705870597060706170627063706470657066706770687069707070717072707370747075707670777078707970807081708270837084708570867087708870897090709170927093709470957096709770987099710071017102710371047105710671077108710971107111711271137114711571167117711871197120712171227123712471257126712771287129713071317132713371347135713671377138713971407141714271437144714571467147714871497150715171527153715471557156715771587159716071617162716371647165716671677168716971707171717271737174717571767177717871797180718171827183718471857186718771887189719071917192719371947195719671977198719972007201720272037204720572067207720872097210721172127213721472157216721772187219722072217222722372247225722672277228722972307231723272337234723572367237723872397240724172427243724472457246724772487249725072517252725372547255725672577258725972607261726272637264726572667267726872697270727172727273727472757276727772787279728072817282728372847285728672877288728972907291729272937294729572967297729872997300730173027303730473057306730773087309731073117312731373147315731673177318731973207321732273237324732573267327732873297330733173327333733473357336733773387339734073417342734373447345734673477348734973507351735273537354735573567357735873597360736173627363736473657366736773687369737073717372737373747375737673777378737973807381738273837384738573867387738873897390739173927393739473957396739773987399740074017402740374047405740674077408740974107411741274137414741574167417741874197420742174227423742474257426742774287429743074317432743374347435743674377438743974407441744274437444744574467447744874497450745174527453745474557456745774587459746074617462746374647465746674677468746974707471747274737474747574767477747874797480748174827483748474857486748774887489749074917492749374947495749674977498749975007501750275037504750575067507750875097510751175127513751475157516751775187519752075217522752375247525752675277528752975307531753275337534753575367537753875397540754175427543754475457546754775487549755075517552755375547555755675577558755975607561756275637564756575667567756875697570757175727573757475757576757775787579758075817582758375847585758675877588758975907591759275937594759575967597759875997600760176027603760476057606760776087609761076117612761376147615761676177618761976207621762276237624762576267627762876297630763176327633763476357636763776387639764076417642764376447645764676477648764976507651765276537654765576567657765876597660766176627663766476657666766776687669767076717672767376747675767676777678767976807681768276837684768576867687768876897690769176927693769476957696769776987699770077017702770377047705770677077708770977107711771277137714771577167717771877197720772177227723772477257726772777287729773077317732773377347735773677377738773977407741774277437744774577467747774877497750775177527753775477557756775777587759776077617762776377647765776677677768776977707771777277737774777577767777777877797780778177827783778477857786778777887789779077917792779377947795779677977798779978007801780278037804780578067807780878097810781178127813781478157816781778187819782078217822782378247825782678277828782978307831783278337834783578367837783878397840784178427843784478457846784778487849785078517852785378547855785678577858785978607861786278637864786578667867786878697870787178727873787478757876787778787879788078817882788378847885788678877888788978907891789278937894789578967897789878997900790179027903790479057906790779087909791079117912791379147915791679177918791979207921792279237924792579267927792879297930793179327933793479357936793779387939794079417942794379447945794679477948794979507951795279537954795579567957795879597960796179627963796479657966796779687969797079717972797379747975797679777978797979807981798279837984798579867987798879897990799179927993799479957996799779987999800080018002800380048005800680078008800980108011801280138014801580168017801880198020802180228023802480258026802780288029803080318032803380348035803680378038803980408041804280438044804580468047804880498050805180528053805480558056805780588059806080618062806380648065806680678068806980708071807280738074807580768077807880798080808180828083808480858086808780888089809080918092809380948095809680978098809981008101810281038104810581068107810881098110811181128113811481158116811781188119812081218122812381248125812681278128812981308131813281338134813581368137813881398140814181428143814481458146814781488149815081518152815381548155815681578158815981608161816281638164816581668167816881698170817181728173817481758176817781788179818081818182818381848185818681878188818981908191819281938194819581968197819881998200820182028203820482058206820782088209821082118212821382148215821682178218821982208221822282238224822582268227822882298230823182328233823482358236823782388239824082418242824382448245824682478248824982508251825282538254825582568257825882598260826182628263826482658266826782688269827082718272827382748275827682778278827982808281828282838284828582868287828882898290829182928293829482958296829782988299830083018302830383048305830683078308830983108311831283138314831583168317831883198320832183228323832483258326832783288329833083318332833383348335833683378338833983408341834283438344834583468347834883498350835183528353835483558356835783588359836083618362836383648365836683678368836983708371837283738374837583768377837883798380838183828383838483858386838783888389839083918392839383948395839683978398839984008401840284038404840584068407840884098410841184128413841484158416841784188419842084218422842384248425842684278428842984308431843284338434843584368437843884398440844184428443844484458446844784488449845084518452845384548455845684578458845984608461846284638464846584668467846884698470847184728473847484758476847784788479848084818482848384848485848684878488848984908491849284938494849584968497849884998500850185028503850485058506850785088509851085118512851385148515851685178518851985208521852285238524852585268527852885298530853185328533853485358536853785388539854085418542854385448545854685478548854985508551855285538554855585568557855885598560856185628563856485658566856785688569857085718572857385748575857685778578857985808581858285838584858585868587858885898590859185928593859485958596859785988599860086018602860386048605860686078608860986108611861286138614861586168617861886198620862186228623862486258626862786288629863086318632863386348635863686378638863986408641864286438644864586468647864886498650865186528653865486558656865786588659866086618662866386648665866686678668866986708671867286738674867586768677867886798680868186828683868486858686868786888689869086918692869386948695869686978698869987008701870287038704870587068707870887098710871187128713871487158716871787188719872087218722872387248725872687278728872987308731873287338734873587368737873887398740874187428743874487458746874787488749875087518752875387548755875687578758875987608761876287638764876587668767876887698770877187728773877487758776877787788779878087818782878387848785878687878788878987908791879287938794879587968797879887998800880188028803880488058806880788088809881088118812881388148815881688178818881988208821882288238824882588268827882888298830883188328833883488358836883788388839884088418842884388448845884688478848884988508851885288538854885588568857885888598860886188628863886488658866886788688869887088718872887388748875887688778878887988808881888288838884888588868887888888898890889188928893889488958896889788988899890089018902890389048905890689078908890989108911891289138914891589168917891889198920892189228923892489258926892789288929893089318932893389348935893689378938893989408941894289438944894589468947894889498950895189528953895489558956895789588959896089618962896389648965896689678968896989708971897289738974897589768977897889798980898189828983898489858986898789888989899089918992899389948995899689978998899990009001900290039004900590069007900890099010901190129013901490159016901790189019902090219022902390249025902690279028902990309031903290339034903590369037903890399040904190429043904490459046904790489049905090519052905390549055905690579058905990609061906290639064906590669067906890699070907190729073907490759076907790789079908090819082908390849085908690879088908990909091909290939094909590969097909890999100910191029103910491059106910791089109911091119112911391149115911691179118911991209121912291239124912591269127912891299130913191329133913491359136913791389139914091419142914391449145914691479148914991509151915291539154915591569157915891599160916191629163916491659166916791689169917091719172917391749175917691779178917991809181918291839184918591869187918891899190919191929193919491959196919791989199920092019202920392049205920692079208920992109211921292139214921592169217921892199220922192229223922492259226922792289229923092319232923392349235923692379238923992409241924292439244924592469247924892499250925192529253925492559256925792589259926092619262926392649265926692679268926992709271927292739274927592769277927892799280928192829283928492859286928792889289929092919292929392949295929692979298929993009301930293039304930593069307930893099310931193129313931493159316931793189319932093219322932393249325932693279328932993309331933293339334933593369337933893399340934193429343934493459346934793489349935093519352935393549355935693579358935993609361936293639364936593669367936893699370937193729373937493759376937793789379938093819382938393849385938693879388938993909391939293939394939593969397939893999400940194029403940494059406940794089409941094119412941394149415941694179418941994209421942294239424942594269427942894299430943194329433943494359436943794389439944094419442944394449445944694479448944994509451945294539454945594569457945894599460946194629463946494659466946794689469947094719472947394749475947694779478947994809481948294839484948594869487948894899490949194929493949494959496949794989499950095019502950395049505950695079508950995109511951295139514951595169517951895199520952195229523952495259526952795289529953095319532953395349535953695379538953995409541954295439544954595469547954895499550955195529553955495559556955795589559956095619562956395649565956695679568956995709571957295739574957595769577957895799580958195829583958495859586958795889589959095919592959395949595959695979598959996009601960296039604960596069607960896099610961196129613961496159616961796189619962096219622962396249625962696279628962996309631963296339634963596369637963896399640964196429643964496459646964796489649965096519652965396549655965696579658965996609661966296639664966596669667966896699670967196729673967496759676967796789679968096819682968396849685968696879688968996909691969296939694969596969697969896999700970197029703970497059706970797089709971097119712971397149715971697179718971997209721972297239724972597269727972897299730973197329733973497359736973797389739974097419742974397449745974697479748974997509751975297539754975597569757975897599760976197629763976497659766976797689769977097719772977397749775977697779778977997809781978297839784978597869787978897899790979197929793979497959796979797989799980098019802980398049805980698079808980998109811981298139814981598169817981898199820982198229823982498259826982798289829983098319832983398349835983698379838983998409841984298439844984598469847984898499850985198529853985498559856985798589859986098619862986398649865986698679868986998709871987298739874987598769877987898799880988198829883988498859886988798889889989098919892989398949895989698979898989999009901990299039904990599069907990899099910991199129913991499159916991799189919992099219922992399249925992699279928992999309931993299339934993599369937993899399940994199429943994499459946994799489949995099519952995399549955995699579958995999609961996299639964996599669967996899699970997199729973997499759976997799789979998099819982998399849985998699879988998999909991999299939994999599969997999899991000010001100021000310004100051000610007100081000910010100111001210013100141001510016100171001810019100201002110022100231002410025100261002710028100291003010031100321003310034100351003610037100381003910040100411004210043100441004510046100471004810049100501005110052100531005410055100561005710058100591006010061100621006310064100651006610067100681006910070100711007210073100741007510076100771007810079100801008110082100831008410085100861008710088100891009010091100921009310094100951009610097100981009910100101011010210103101041010510106101071010810109101101011110112101131011410115101161011710118101191012010121101221012310124101251012610127101281012910130101311013210133101341013510136101371013810139101401014110142101431014410145101461014710148101491015010151101521015310154101551015610157101581015910160101611016210163101641016510166101671016810169101701017110172101731017410175101761017710178101791018010181101821018310184101851018610187101881018910190101911019210193101941019510196101971019810199102001020110202102031020410205102061020710208102091021010211102121021310214102151021610217102181021910220102211022210223102241022510226102271022810229102301023110232102331023410235102361023710238102391024010241102421024310244102451024610247102481024910250102511025210253102541025510256102571025810259102601026110262102631026410265102661026710268102691027010271102721027310274102751027610277102781027910280102811028210283102841028510286102871028810289102901029110292102931029410295102961029710298102991030010301103021030310304103051030610307103081030910310103111031210313103141031510316103171031810319103201032110322103231032410325103261032710328103291033010331103321033310334103351033610337103381033910340103411034210343103441034510346103471034810349103501035110352103531035410355103561035710358103591036010361103621036310364103651036610367103681036910370103711037210373103741037510376103771037810379103801038110382103831038410385103861038710388103891039010391103921039310394103951039610397103981039910400104011040210403104041040510406104071040810409104101041110412104131041410415104161041710418104191042010421104221042310424104251042610427104281042910430104311043210433104341043510436104371043810439104401044110442104431044410445104461044710448104491045010451104521045310454104551045610457104581045910460104611046210463104641046510466104671046810469104701047110472104731047410475104761047710478104791048010481104821048310484104851048610487104881048910490104911049210493104941049510496104971049810499
  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. # Contact details
  42. PROJECT_BITMESSAGE="BM-2cWuhmBvVdfrHhLoZTdspCkKeiTorUesSL"
  43. # default search engine for command line browser
  44. DEFAULT_SEARCH='https://searx.laquadrature.net'
  45. # Are we installing on a Beaglebone Black (BBB) or some other system?
  46. INSTALLING_ON_BBB="no"
  47. # Version number of this script
  48. VERSION="1.01"
  49. # if yes then this minimises the number of descisions presented during install
  50. MINIMAL_INSTALL="yes"
  51. # Whether web sites will be .onion addresses only
  52. ONION_ONLY="no"
  53. # Different system variants which may be specified within
  54. # the SYSTEM_TYPE option
  55. VARIANT_FULL="full"
  56. VARIANT_WRITER="writer"
  57. VARIANT_CLOUD="cloud"
  58. VARIANT_CHAT="chat"
  59. VARIANT_MAILBOX="mailbox"
  60. VARIANT_NONMAILBOX="nonmailbox"
  61. VARIANT_SOCIAL="social"
  62. VARIANT_MEDIA="media"
  63. VARIANT_DEVELOPER="developer"
  64. VARIANT_MESH="mesh"
  65. DEFAULT_DOMAIN_NAME=
  66. DEFAULT_DOMAIN_CODE=
  67. MY_USERNAME=
  68. SYSTEM_TYPE=$VARIANT_FULL
  69. # whether the system is being installed from a pre-created configuration file
  70. INSTALLING_FROM_CONFIGURATION_FILE="no"
  71. # An optional configuration file which overrides some of these variables
  72. CONFIGURATION_FILE="${PROJECT_NAME}.cfg"
  73. SSH_PORT=2222
  74. IRC_PORT=6697
  75. IRC_ONION_PORT=8093
  76. # password used for accessing your repo mirrors
  77. MY_MIRRORS_PASSWORD=
  78. # friend's repo mirrors
  79. FRIENDS_MIRRORS_PASSWORD=
  80. FRIENDS_MIRRORS_SERVER=
  81. FRIENDS_MIRRORS_SSH_PORT=2222
  82. # This isn't used here, but is included for mirrors creation purposes
  83. LETSENCRYPT_REPO="https://github.com/letsencrypt/letsencrypt"
  84. # An optional password to log into IRC. This applies to all users
  85. IRC_PASSWORD=
  86. # If this file exists it contains a global password used with
  87. # disk image installs. This simplifies password management for
  88. # deployment at scale
  89. IMAGE_PASSWORD_FILE=/root/login.txt
  90. # parameters used when adding a new domain
  91. DDNS_PROVIDER="default@freedns.afraid.org"
  92. DDNS_USERNAME=
  93. DDNS_PASSWORD=
  94. EXIM_ONION_REPO="https://github.com/petterreinholdtsen/exim4-smtorp"
  95. NGINX_ENSITE_REPO="https://github.com/perusio/nginx_ensite"
  96. NGINX_ENSITE_COMMIT='fa4d72ce1c0a490442c8474e9c8dc21ed52c93d0'
  97. CLEANUP_MAILDIR_REPO="https://github.com/bashrc/cleanup-maildir"
  98. CLEANUP_MAILDIR_COMMIT='33241d2e3861f901ba17f5c77ada007e1ec06a86'
  99. INADYN_REPO="https://github.com/bashrc/inadyn"
  100. INADYN_COMMIT='fadbe17f520d337dfb8d69ee4bf1fcaa23fce0d6'
  101. # Minimum number of characters in a password
  102. MINIMUM_PASSWORD_LENGTH=10
  103. # number of CPU cores
  104. CPU_CORES=1
  105. # If the system is on an IPv6 network
  106. IPV6_NETWORK='2001:470:26:307'
  107. # The static IP address of the system within the local network
  108. # By default the IP address is dynamic within your LAN
  109. LOCAL_NETWORK_STATIC_IP_ADDRESS=
  110. # IP address of the router (gateway)
  111. ROUTER_IP_ADDRESS="192.168.1.254"
  112. # DNS
  113. NAMESERVER1='213.73.91.35'
  114. NAMESERVER2='85.214.20.141'
  115. # whether to route outgoing traffic through Tor
  116. ROUTE_THROUGH_TOR="no"
  117. # Why use Google as a time source?
  118. # The thinking here is that it's likely to be reliable and fast.
  119. # The ping doesn't reveal any information other than that the server
  120. # is running, and if anyone maliciously alters the time on Google's
  121. # servers then that would certainly be newsworthy and they'd be
  122. # likely to do something about it quickly.
  123. # If you have better time sources then change them here.
  124. TLS_TIME_SOURCE1="google.com"
  125. TLS_TIME_SOURCE2="www.ptb.de"
  126. # The type of hardware random number generator being used
  127. # This can be empty, "beaglebone" or "onerng"
  128. HWRNG_TYPE=
  129. # Download location for OneRNG driver
  130. ONERNG_PACKAGE="onerng_3.4-1_all.deb"
  131. ONERNG_PACKAGE_DOWNLOAD="https://github.com/OneRNG/onerng.github.io/blob/master/sw/$ONERNG_PACKAGE?raw=true"
  132. # Hash for OneRNG driver
  133. ONERNG_PACKAGE_HASH='78f1c2f52ae573e3b398a695ece7ab9f41868252657ea269f0d5cf0bd4f2eb59'
  134. # device name for OneRNG
  135. ONERNG_DEVICE='ttyACM0'
  136. # Whether this system is being installed within a docker container
  137. INSTALLED_WITHIN_DOCKER="no"
  138. # If you want to run a public mailing list specify its name here.
  139. # There should be no spaces in the name
  140. PUBLIC_MAILING_LIST=
  141. # Optional different domain name for the public mailing list
  142. PUBLIC_MAILING_LIST_DOMAIN_NAME=
  143. # Directory where the public mailing list data is stored
  144. PUBLIC_MAILING_LIST_DIRECTORY="/var/spool/mlmmj"
  145. # If you want to run an encrypted mailing list specify its name here.
  146. # There should be no spaces in the name
  147. PRIVATE_MAILING_LIST=
  148. # Domain name for mediagoblin installation
  149. MEDIAGOBLIN_DOMAIN_NAME=
  150. MEDIAGOBLIN_CODE=
  151. MEDIAGOBLIN_REPO="git://git.savannah.gnu.org/mediagoblin.git"
  152. MEDIAGOBLIN_COMMIT='d1ac2d52fd8859c3f32fa38e4836ffe9615e5bba'
  153. MEDIAGOBLIN_ADMIN_PASSWORD=
  154. MEDIAGOBLIN_ONION_PORT=8096
  155. # Domain name for microblog installation
  156. MICROBLOG_DOMAIN_NAME=
  157. MICROBLOG_CODE=
  158. MICROBLOG_ONION_PORT=8087
  159. MICROBLOG_REPO="https://git.gnu.io/gnu/gnu-social.git"
  160. MICROBLOG_COMMIT='c67b89e56bf0f90730a9e22beca7e1bd41fc26c3'
  161. MICROBLOG_ADMIN_PASSWORD=
  162. MICROBLOG_THEME_REPO="https://git.gnu.io/h2p/Qvitter.git"
  163. MICROBLOG_THEME_COMMIT='e933ff9510fb3ff8a7a856b5a88002859c43b237'
  164. MICROBLOG_WELCOME_MESSAGE=$'<h1>Welcome to GNU Social – a federated microblog</h1><p>Another Freedombone site</p>'
  165. MICROBLOG_BACKGROUND_IMAGE_URL=
  166. MICROBLOG_MARKDOWN_REPO="https://git.gnu.io/chimo/markdown.git"
  167. MICROBLOG_MARKDOWN_COMMIT='03c53942f94b3376f0946e6e1fe566cc21ccf232'
  168. # Domain name for hubzilla installation
  169. HUBZILLA_DOMAIN_NAME=
  170. HUBZILLA_CODE=
  171. HUBZILLA_ONION_PORT=8085
  172. HUBZILLA_REPO="https://github.com/redmatrix/hubzilla.git"
  173. HUBZILLA_THEMES_REPO="https://github.com/DeadSuperHero/redmatrix-themes"
  174. HUBZILLA_ADDONS_REPO="https://github.com/redmatrix/hubzilla-addons.git"
  175. HUBZILLA_ADMIN_PASSWORD=
  176. HUBZILLA_COMMIT='b6ae2bff01f8a4dfc057ef2971b3d988b1028b3e'
  177. HUBZILLA_ADDONS_COMMIT='48725235777e2088fe109b722a5fc9141b6840ec'
  178. # Domain name for git hosting installation
  179. GIT_DOMAIN_NAME=
  180. GIT_CODE=
  181. GIT_ONION_PORT=8090
  182. GIT_DOMAIN_REPO="https://github.com/gogits/gogs"
  183. GIT_ADMIN_PASSWORD=
  184. GOGS_COMMIT='3fb4f7f4980b4339fd9ef6a3ba5b0acab83d264d'
  185. GO_PACKAGE_MANAGER_REPO="https://github.com/gpmgo/gopm"
  186. GVM_REPO="https://github.com/moovweb/gvm"
  187. GVM_COMMIT='25ea8ae158e2861c92e2b22c458e60840157832f'
  188. # Syncthing
  189. SYNCTHING_ID=
  190. SYNCTHING_CONFIG_PATH=/root/.config/syncthing
  191. SYNCTHING_CONFIG_FILE=$SYNCTHING_CONFIG_PATH/config.xml
  192. SYNCTHING_RELAY_SERVER='https://relays.syncthing.net/endpoint'
  193. SYNCTHING_RELEASES='https://api.github.com/repos/syncthing/syncthing/releases?per_page=30'
  194. SYNCTHING_PORT=22000
  195. SYNCTHING_SHARED_DATA=/var/lib/syncthing/SyncShared
  196. SYNCTHING_USER_IDS_FILE='.syncthingids'
  197. # Domain name for your wiki
  198. WIKI_DOMAIN_NAME=
  199. WIKI_ADMIN_PASSWORD=
  200. WIKI_TITLE="${PROJECT_NAME} Wiki"
  201. WIKI_CODE=
  202. WIKI_ONION_PORT=8089
  203. # Domain name for your blog
  204. FULLBLOG_DOMAIN_NAME=
  205. FULLBLOG_CODE=
  206. FULLBLOG_ONION_PORT=8086
  207. FULLBLOG_REPO="https://github.com/danpros/htmly"
  208. FULLBLOG_COMMIT='bf5fe9486160be4da86d8987d3e5c977e1dc6d32'
  209. MY_BLOG_TITLE="My Blog"
  210. MY_BLOG_SUBTITLE="Another ${PROJECT_NAME} Blog"
  211. # search engine
  212. SEARCH_ENGINE_REPO="https://github.com/asciimoo/searx"
  213. SEARCH_ENGINE_COMMIT='fee556c9904637051a9ba874ba7e71cd9f10789f'
  214. SEARCH_ENGINE_PATH=/etc
  215. SEARCH_ENGINE_ONION_PORT=8094
  216. SEARCH_ENGINE_ONION_HOSTNAME=
  217. SEARCH_ENGINE_LOGIN_TEXT=$"Search engine login"
  218. SEARCH_ENGINE_PASSWORD=
  219. GPG_KEYSERVER="hkp://keys.gnupg.net"
  220. # whether to encrypt all incoming email with your public key
  221. GPG_ENCRYPT_STORED_EMAIL="yes"
  222. # gets set to yes if gpg keys are imported from usb
  223. GPG_KEYS_IMPORTED="no"
  224. # optionally you can provide your exported GPG key pair here
  225. # Note that the private key file will be deleted after use
  226. # If these are unspecified then a new GPG key will be created
  227. MY_GPG_PUBLIC_KEY=
  228. MY_GPG_PRIVATE_KEY=
  229. # optionally specify your public key ID
  230. MY_GPG_PUBLIC_KEY_ID=
  231. # If you have existing mail within a Maildir
  232. # you can specify the directory here and the files
  233. # will be imported
  234. IMPORT_MAILDIR=
  235. # The Debian package repository to use.
  236. DEBIAN_REPO="ftp.us.debian.org"
  237. DEBIAN_VERSION="jessie"
  238. # Directory where source code is downloaded and compiled
  239. INSTALL_DIR=$HOME/build
  240. # device name for an attached usb drive
  241. USB_DRIVE=/dev/sda1
  242. # Location where the USB drive is mounted to
  243. USB_MOUNT=/mnt/usb
  244. # name of a script used to upgrade the system
  245. UPGRADE_SCRIPT_NAME="${PROJECT_NAME}-upgrade"
  246. # name of a script which keeps running processes going even if they crash
  247. WATCHDOG_SCRIPT_NAME="keepon"
  248. # Number of days to keep backups for
  249. BACKUP_MAX_DAYS=30
  250. # memory limit for php in MB
  251. MAX_PHP_MEMORY=64
  252. # default MariaDB password
  253. MARIADB_PASSWORD=
  254. # Directory where XMPP settings are stored
  255. XMPP_DIRECTORY="/var/lib/prosody"
  256. XMPP_PASSWORD=
  257. # file containing a list of remote locations to backup to
  258. # Format: [username@friendsdomain//home/username] [ssh_password]
  259. # With the only space character being between the server and the password
  260. FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
  261. # list of encryption protocols
  262. SSL_PROTOCOLS="TLSv1 TLSv1.1 TLSv1.2"
  263. # list of ciphers to use. See bettercrypto.org recommendations
  264. 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"
  265. # ssh (from https://stribika.github.io/2015/01/04/secure-secure-shell.html)
  266. SSH_CIPHERS="chacha20-poly1305@openssh.com,aes256-gcm@openssh.com,aes128-gcm@openssh.com,aes256-ctr,aes192-ctr,aes128-ctr"
  267. 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"
  268. SSH_KEX="curve25519-sha256@libssh.org,diffie-hellman-group-exchange-sha256"
  269. 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"
  270. # xmpp ciphers and curve
  271. 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"'
  272. XMPP_ECC_CURVE='"secp384r1"'
  273. # the default email address
  274. MY_EMAIL_ADDRESS=$MY_USERNAME@$DEFAULT_DOMAIN_NAME
  275. # optionally specify your name to appear on the blog
  276. MY_NAME=$DEFAULT_DOMAIN_NAME
  277. export DEBIAN_FRONTEND=noninteractive
  278. # logging level for Nginx
  279. WEBSERVER_LOG_LEVEL='warn'
  280. # used to limit CPU usage
  281. CPULIMIT='/usr/bin/cpulimit -l 20 -e'
  282. # command to create a git repository
  283. CREATE_GIT_PROJECT_COMMAND='create-project'
  284. # File which keeps track of what has already been installed
  285. COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt
  286. # Used to indicate whether the backup contains MariaDB databases or not
  287. BACKUP_INCLUDES_DATABASES="no"
  288. # contains the mysql root password which
  289. # is used for backups and repair
  290. DATABASE_PASSWORD_FILE=/root/dbpass
  291. # log file where details of remote backups are stored
  292. REMOTE_BACKUPS_LOG=/var/log/remotebackups.log
  293. # message if something fails to install
  294. 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."
  295. # web site used to obtain the external IP address of the system
  296. GET_IP_ADDRESS_URL="checkip.two-dns.de"
  297. # Password used for VoIP server
  298. VOIP_SERVER_PASSWORD=
  299. # Port on which VoIP server listens
  300. VOIP_PORT=64738
  301. SIP_SERVER_PASSWORD=
  302. SIP_PORT=5060
  303. SIP_TLS_PORT=5061
  304. VOIP_TURN_PORT=3478
  305. VOIP_TURN_TLS_PORT=5349
  306. VOIP_TURN_NONCE=
  307. # Location of VoIP database and configuration
  308. VOIP_DATABASE="mumble-server.sqlite"
  309. VOIP_CONFIG_FILE="mumble-server.ini"
  310. # other possible services to obtain the external IP address
  311. EXTERNAL_IP_SERVICES=( \
  312. 'https://check.torproject.org/' \
  313. 'https://www.whatsmydns.net/whats-my-ip-address.html' \
  314. 'https://www.privateinternetaccess.com/pages/whats-my-ip/' \
  315. 'http://checkip.two-dns.de' \
  316. 'http://ip.dnsexit.com' \
  317. 'http://ifconfig.me/ip' \
  318. 'http://ipecho.net/plain' \
  319. 'http://checkip.dyndns.org/plain' \
  320. 'http://ipogre.com/linux.php' \
  321. 'http://whatismyipaddress.com/' \
  322. 'http://ip.my-proxy.com/' \
  323. 'http://websiteipaddress.com/WhatIsMyIp' \
  324. 'http://getmyipaddress.org/' \
  325. 'http://www.my-ip-address.net/' \
  326. 'http://myexternalip.com/raw' \
  327. 'http://www.canyouseeme.org/' \
  328. 'http://www.trackip.net/' \
  329. 'http://icanhazip.com/' \
  330. 'http://www.iplocation.net/' \
  331. 'http://www.howtofindmyipaddress.com/' \
  332. 'http://www.ipchicken.com/' \
  333. 'http://whatsmyip.net/' \
  334. 'http://www.ip-adress.com/' \
  335. 'http://checkmyip.com/' \
  336. 'http://www.tracemyip.org/' \
  337. 'http://checkmyip.net/' \
  338. 'http://www.lawrencegoetz.com/programs/ipinfo/' \
  339. 'http://www.findmyip.co/' \
  340. 'http://ip-lookup.net/' \
  341. 'http://www.dslreports.com/whois' \
  342. 'http://www.mon-ip.com/en/my-ip/' \
  343. 'http://www.myip.ru' \
  344. 'http://ipgoat.com/' \
  345. 'http://www.myipnumber.com/my-ip-address.asp' \
  346. 'http://www.whatsmyipaddress.net/' \
  347. 'http://formyip.com/' \
  348. 'http://www.displaymyip.com/' \
  349. 'http://www.bobborst.com/tools/whatsmyip/' \
  350. 'http://www.geoiptool.com/' \
  351. 'http://checkip.dyndns.com/' \
  352. 'http://myexternalip.com/' \
  353. 'http://www.ip-adress.eu/' \
  354. 'http://www.infosniper.net/' \
  355. 'http://wtfismyip.com/' \
  356. 'http://ipinfo.io/' \
  357. 'http://httpbin.org/ip')
  358. WIFI_CHANNEL=2
  359. WIFI_INTERFACE=wlan0
  360. # cjdns settings
  361. ENABLE_CJDNS="no"
  362. CJDNS_PRIVATE_KEY=
  363. CJDNS_PUBLIC_KEY=
  364. CJDNS_IPV6=
  365. CJDNS_PASSWORD=
  366. CJDNS_PORT=
  367. CJDNS_REPO="https://github.com/cjdelisle/cjdns.git"
  368. CJDNS_COMMIT='13189fde111d0500427a7a0ce06a970753527bca'
  369. CJDCMD_REPO="https://github.com/inhies/cjdcmd"
  370. CJDCMD_COMMIT='973cca6ed0eecf9041c3403a40193c0b1291b808'
  371. # B.A.T.M.A.N settings
  372. ENABLE_BATMAN="no"
  373. BATMAN_CELLID='any'
  374. ESSID='mesh'
  375. # Babel mesh
  376. ENABLE_BABEL="no"
  377. BABEL_PORT=6696
  378. # social key management
  379. ENABLE_SOCIAL_KEY_MANAGEMENT="no"
  380. TOX_PORT=33445
  381. TOX_REPO="git://github.com/irungentoo/toxcore.git"
  382. TOXID_REPO="https://github.com/bashrc/toxid"
  383. TOX_COMMIT='532629d486e3361c7d8d95b38293cc7d61dc4ee5'
  384. TOX_BOOTSTRAP_ID_FILE=/var/lib/tox-bootstrapd/pubkey.txt
  385. # These are some default nodes, but you can replace them with trusted nodes
  386. # as you prefer. See https://wiki.tox.im/Nodes
  387. TOX_NODES=
  388. #TOX_NODES=(
  389. # '192.254.75.102,2607:5600:284::2,33445,951C88B7E75C867418ACDB5D273821372BB5BD652740BCDF623A4FA293E75D2F,Tox RELENG,US'
  390. # '144.76.60.215,2a01:4f8:191:64d6::1,33445,04119E835DF3E78BACF0F84235B300546AF8B936F035185E2A8E9E0A67C8924F,sonOfRa,DE'
  391. #)
  392. TOXIC_REPO="https://github.com/Tox/toxic"
  393. TOXIC_COMMIT='4e0e322e32b0d7b5d1692f72876ac7f9ae2e610a'
  394. TOXIC_FILE=/usr/local/bin/toxic
  395. ZERONET_REPO="https://github.com/HelloZeroNet/ZeroNet.git"
  396. ZERONET_COMMIT='675bd462556c541d65e2d95f91f899146a373aad'
  397. ZERONET_BLOG_REPO="https://github.com/HelloZeroNet/ZeroBlog"
  398. ZERONET_BLOG_COMMIT='bbb0d6c36465fed2e6df71f1aab45fcc9c6ad609'
  399. ZERONET_MAIL_REPO="https://github.com/HelloZeroNet/ZeroMail"
  400. ZERONET_MAIL_COMMIT='955af09d643c72b02e4983d71eca5c0c93a6c131'
  401. ZERONET_FORUM_REPO="https://github.com/HelloZeroNet/ZeroTalk"
  402. ZERONET_FORUM_COMMIT='e2d2c9cb1cfbfef91b244935efb5c14c2ad95faa'
  403. ZERONET_URL=http://127.0.0.1:43110
  404. ZERONET_PORT=15441
  405. TRACKER_PORT=6969
  406. ZERONET_DEFAULT_BLOG_TAGLINE="Blogging on the Mesh"
  407. ZERONET_DEFAULT_FORUM_TAGLINE="A decentralized discussion group"
  408. ZERONET_DEFAULT_MAIL_TAGLINE="Mail for the Mesh"
  409. # https://github.com/ipfs/go-ipfs
  410. IPFS_GO_REPO="https://github.com/ipfs/go-ipfs"
  411. IPFS_COMMIT='20b06a4cbce8884f5b194da6e98cb11f2c77f166'
  412. IPFS_PORT=4001
  413. GPGIT_REPO="https://github.com/mikecardwell/gpgit"
  414. GPGIT_COMMIT='583dc76119f19420f8a33f606744faa7c8922738'
  415. # Default diffie-hellman key length in bits
  416. DH_KEYLENGTH=2048
  417. # repo for atheros AR9271 wifi driver
  418. ATHEROS_WIFI_REPO="https://github.com/qca/open-ath9k-htc-firmware.git"
  419. # Whether Let's Encrypt is enabled for all sites
  420. LETSENCRYPT_ENABLED="no"
  421. LETSENCRYPT_SERVER='https://acme-v01.api.letsencrypt.org/directory'
  422. RSS_READER_REPO="https://tt-rss.org/git/tt-rss.git"
  423. RSS_READER_COMMIT='9e84bab449f9ed55e02e60378b0af1521026f3b8'
  424. RSS_READER_ADMIN_PASSWORD=
  425. RSS_READER_ONION_PORT=8092
  426. RSS_MOBILE_READER_ONION_PORT=8095
  427. RSS_READER_DOMAIN_NAME=ttrss
  428. RSS_MOBILE_READER_REPO="https://github.com/mboinet/ttrss-mobile"
  429. RSS_MOBILE_READER_COMMIT='d5242e1c269e9480ab3b66b7a38da3c892dfb326'
  430. RSS_READER_PATH=/etc/share/tt-rss
  431. RSS_READER_GNUSOCIAL_REPO="https://github.com/bashrc/ttrss-gnusocial"
  432. RSS_READER_GNUSOCIAL_COMMIT='8b92b8f5db7b0d12459c7bd86a50f48815efe642'
  433. function show_help {
  434. echo ''
  435. echo $"${PROJECT_NAME} -c [configuration file]"
  436. echo ''
  437. echo $' -h --help Show help'
  438. echo $' menuconfig Easy interactive installation'
  439. echo $' menuconfig-full Full interactive installation'
  440. echo $' menuconfig-onion Interactive installation for onion-only sites'
  441. echo $' -c --config Installing from a configuration file'
  442. echo $' --bbb Installing on Beaglebone Black'
  443. echo $' -u --user User to install the system as'
  444. echo $' -d --domain Default domain name'
  445. echo $' -s --system System type'
  446. echo $' --ip Static LAN IP address of the system'
  447. echo $' --iprouter LAN IP address of the internet router'
  448. echo $' --ddns Dynamic DNS provider domain'
  449. echo $' --ddnsuser Dynamic DNS provider username'
  450. echo $' --ddnspass Dynamic DNS provider password'
  451. echo ''
  452. echo $' --microblogdomain Microblog domain name'
  453. echo $' --wikidomain Wiki domain name'
  454. echo $' --blogdomain Blog domain name'
  455. echo $' --hubzilladomain Hubzilla domain name'
  456. echo $' --gitdomain Git hosting domain name'
  457. echo $' -t --time Domain used as a TLS time source'
  458. echo $' --ssh ssh port number'
  459. echo $' --list Public mailing list name'
  460. echo $' --cores Number of CPU cores'
  461. echo $' --name Your name'
  462. echo $' --email Your email address'
  463. echo $' --usb Path for the USB drive (eg. /dev/sdb1)'
  464. echo $' --cjdns Enable CJDNS'
  465. echo $' --vpass VoIP server password'
  466. echo $' --vport VoIP server port'
  467. echo $' --ns1 First DNS nameserver'
  468. echo $' --ns2 Second DNS nameserver'
  469. echo $' --repo Debian repository'
  470. echo ''
  471. echo $'system types'
  472. echo '------------'
  473. echo $'This can either be blank if you wish to install the full system,'
  474. echo $"or for more specialised variants you can specify '$VARIANT_MAILBOX', '$VARIANT_CLOUD',"
  475. echo $"'$VARIANT_CHAT', '$VARIANT_SOCIAL', '$VARIANT_MEDIA', '$VARIANT_WRITER', '$VARIANT_DEVELOPER'"
  476. echo $"or '$VARIANT_MESH'."
  477. echo ''
  478. echo $"If you wish to install everything except email then use the '$VARIANT_NONMAILBOX' variaint."
  479. echo ''
  480. exit 0
  481. }
  482. function git_clone {
  483. repo_url="$1"
  484. destination_dir="$2"
  485. if [[ "$repo_url" == "ssh:"* ]]; then
  486. if [ "${FRIENDS_MIRRORS_SERVER}" ]; then
  487. if [ ${#FRIENDS_MIRRORS_SERVER} -gt 2 ]; then
  488. if [ "$FRIENDS_MIRRORS_PASSWORD" ]; then
  489. if [ ${#FRIENDS_MIRRORS_PASSWORD} -gt 2 ]; then
  490. sshpass -p "$FRIENDS_MIRRORS_PASSWORD" git clone "$repo_url" "$destination_dir"
  491. return
  492. fi
  493. fi
  494. fi
  495. fi
  496. fi
  497. git clone "$repo_url" "$destination_dir"
  498. }
  499. function git_pull {
  500. if [ ! $1 ]; then
  501. echo $'git_pull no repo specified'
  502. fi
  503. git stash
  504. git remote set-url origin $1
  505. git checkout master
  506. if [ "${FRIENDS_MIRRORS_SERVER}" ]; then
  507. if [ ${#FRIENDS_MIRRORS_SERVER} -gt 2 ]; then
  508. if [ "$FRIENDS_MIRRORS_PASSWORD" ]; then
  509. if [ ${#FRIENDS_MIRRORS_PASSWORD} -gt 2 ]; then
  510. sshpass -p "$FRIENDS_MIRRORS_PASSWORD" git pull
  511. if [ $2 ]; then
  512. git checkout $2 -b $2
  513. fi
  514. return
  515. fi
  516. fi
  517. fi
  518. fi
  519. git pull
  520. if [ $2 ]; then
  521. git checkout $2 -b $2
  522. fi
  523. }
  524. function remove_database {
  525. app_name="$1"
  526. if [ ! -d $INSTALL_DIR ]; then
  527. mkdir $INSTALL_DIR
  528. fi
  529. echo "drop database ${app_name};
  530. quit" > $INSTALL_DIR/batch.sql
  531. chmod 600 $INSTALL_DIR/batch.sql
  532. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  533. shred -zu $INSTALL_DIR/batch.sql
  534. }
  535. function create_database {
  536. app_name="$1"
  537. app_admin_password="$2"
  538. app_admin_username=$3
  539. if [ ! -d $INSTALL_DIR ]; then
  540. mkdir $INSTALL_DIR
  541. fi
  542. if [ ! $app_admin_username ]; then
  543. app_admin_username=${app_name}admin
  544. fi
  545. echo "create database ${app_name};
  546. CREATE USER '$app_admin_username@localhost' IDENTIFIED BY '${app_admin_password}';
  547. GRANT ALL PRIVILEGES ON ${app_name}.* TO '$app_admin_username@localhost';
  548. quit" > $INSTALL_DIR/batch.sql
  549. chmod 600 $INSTALL_DIR/batch.sql
  550. mysql -u root --password="$MARIADB_PASSWORD" < $INSTALL_DIR/batch.sql
  551. shred -zu $INSTALL_DIR/batch.sql
  552. }
  553. function locale_setup {
  554. if grep -Fxq "locale_setup" $COMPLETION_FILE; then
  555. return
  556. fi
  557. apt-get -y install locales locales-all debconf
  558. if [ ! "$DEFAULT_LANGUAGE" ]; then
  559. DEFAULT_LANGUAGE='en_GB.UTF-8'
  560. fi
  561. if [ ${#DEFAULT_LANGUAGE} -lt 2 ]; then
  562. DEFAULT_LANGUAGE='en_GB.UTF-8'
  563. fi
  564. update-locale LANG=${DEFAULT_LANGUAGE}
  565. update-locale LANGUAGE=${DEFAULT_LANGUAGE}
  566. update-locale LC_MESSAGES=${DEFAULT_LANGUAGE}
  567. update-locale LC_ALL=${DEFAULT_LANGUAGE}
  568. update-locale LC_CTYPE=${DEFAULT_LANGUAGE}
  569. echo 'locale_setup' >> $COMPLETION_FILE
  570. }
  571. function interactive_configuration_remote_backups {
  572. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  573. return
  574. fi
  575. if [ ! -f /usr/local/bin/${PROJECT_NAME}-remote ]; then
  576. if [ ! -f /usr/bin/${PROJECT_NAME}-remote ]; then
  577. echo $"The command ${PROJECT_NAME}-remote was not found"
  578. exit 87354
  579. fi
  580. fi
  581. ${PROJECT_NAME}-remote -u $MY_USERNAME -l $FRIENDS_SERVERS_LIST -m $MINIMUM_PASSWORD_LENGTH -r yes
  582. if [ ! "$?" = "0" ]; then
  583. echo $'Command failed:'
  584. echo ''
  585. echo $" ${PROJECT_NAME}-remote -u $MY_USERNAME -l $FRIENDS_SERVERS_LIST -m $MINIMUM_PASSWORD_LENGTH -r yes"
  586. echo ''
  587. exit 65892
  588. fi
  589. }
  590. # test a domain name to see if it's valid
  591. function validate_domain_name {
  592. # count the number of dots in the domain name
  593. dots=${TEST_DOMAIN_NAME//[^.]}
  594. no_of_dots=${#dots}
  595. if (( $no_of_dots > 3 )); then
  596. 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"
  597. fi
  598. if (( $no_of_dots == 0 )); then
  599. 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"
  600. fi
  601. }
  602. function interactive_configuration {
  603. if [ ! -f /usr/local/bin/${PROJECT_NAME}-config ]; then
  604. if [ ! -f /usr/bin/${PROJECT_NAME}-config ]; then
  605. echo $"The command ${PROJECT_NAME}-config was not found"
  606. exit 63935
  607. fi
  608. fi
  609. if [ -f /tmp/meshuserdevice ]; then
  610. rm -f /tmp/meshuserdevice
  611. fi
  612. if [[ $ONION_ONLY == "no" ]]; then
  613. if [[ $MINIMAL_INSTALL == "no" ]]; then
  614. ${PROJECT_NAME}-config \
  615. -f $CONFIGURATION_FILE \
  616. -w $PROJECT_WEBSITE \
  617. -b $PROJECT_BITMESSAGE \
  618. -m $MINIMUM_PASSWORD_LENGTH
  619. else
  620. ${PROJECT_NAME}-config \
  621. -f $CONFIGURATION_FILE \
  622. -w $PROJECT_WEBSITE \
  623. -b $PROJECT_BITMESSAGE \
  624. -m $MINIMUM_PASSWORD_LENGTH \
  625. --minimal "yes"
  626. fi
  627. else
  628. ${PROJECT_NAME}-config \
  629. -f $CONFIGURATION_FILE \
  630. -w $PROJECT_WEBSITE \
  631. -b $PROJECT_BITMESSAGE \
  632. -m $MINIMUM_PASSWORD_LENGTH \
  633. --onion "yes"
  634. fi
  635. if [ -f /tmp/meshuserdevice ]; then
  636. # mesh network user device installation
  637. rm -f /tmp/meshuserdevice
  638. exit 0
  639. fi
  640. if [ ! "$?" = "0" ]; then
  641. echo $'Command failed:'
  642. echo ''
  643. echo $" ${PROJECT_NAME}-config -u $MY_USERNAME -f $CONFIGURATION_FILE -w $PROJECT_WEBSITE -b $PROJECT_BITMESSAGE -m $MINIMUM_PASSWORD_LENGTH --minimal [yes|no]"
  644. echo ''
  645. exit 73594
  646. fi
  647. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  648. FRIENDS_SERVERS_LIST=/home/$MY_USERNAME/backup.list
  649. dialog --title $"Encrypted backup to other servers" \
  650. --backtitle $"${PROJECT_NAME} Configuration" \
  651. --defaultno \
  652. --yesno $"\nDo you wish to configure some remote backup locations?" 7 60
  653. sel=$?
  654. case $sel in
  655. 0) interactive_configuration_remote_backups;;
  656. esac
  657. fi
  658. }
  659. command_options=$1
  660. if [[ $command_options == "menuconfig-full" ]]; then
  661. MINIMAL_INSTALL="no"
  662. command_options="menuconfig"
  663. fi
  664. if [[ $command_options == "menuconfig-onion" ]]; then
  665. MINIMAL_INSTALL="yes"
  666. ONION_ONLY="yes"
  667. command_options="menuconfig"
  668. fi
  669. if [[ $command_options == "menuconfig" ]]; then
  670. interactive_configuration
  671. else
  672. while [[ $# > 1 ]]
  673. do
  674. key="$1"
  675. case $key in
  676. -h|--help)
  677. show_help
  678. ;;
  679. # load a configuration file
  680. -c|--config)
  681. shift
  682. CONFIGURATION_FILE="$1"
  683. INSTALLING_FROM_CONFIGURATION_FILE="yes"
  684. break
  685. ;;
  686. # username within /home
  687. -u|--user)
  688. shift
  689. MY_USERNAME="$1"
  690. ;;
  691. # microblog domain name
  692. --microblogdomain)
  693. shift
  694. MICROBLOG_DOMAIN_NAME="$1"
  695. ;;
  696. # wiki domain name
  697. --wikidomain)
  698. shift
  699. WIKI_DOMAIN_NAME="$1"
  700. ;;
  701. # blog domain name
  702. --blogdomain)
  703. shift
  704. FULLBLOG_DOMAIN_NAME="$1"
  705. ;;
  706. # hubzilla domain name
  707. --hubzilladomain)
  708. shift
  709. HUBZILLA_DOMAIN_NAME="$1"
  710. ;;
  711. # git hosting domain name
  712. --gitdomain)
  713. shift
  714. GIT_DOMAIN_NAME="$1"
  715. ;;
  716. # default domain name
  717. -d|--domain)
  718. shift
  719. DEFAULT_DOMAIN_NAME="$1"
  720. ;;
  721. # The type of system
  722. -s|--system)
  723. shift
  724. SYSTEM_TYPE="$1"
  725. ;;
  726. # The dynamic DNS provider
  727. --ddns)
  728. shift
  729. DDNS_PROVIDER="$1"
  730. ;;
  731. # Username for the synamic DNS provider
  732. --ddnsuser)
  733. shift
  734. DDNS_USERNAME="$1"
  735. ;;
  736. # Password for the synamic DNS provider
  737. --ddnspass)
  738. shift
  739. DDNS_PASSWORD="$1"
  740. ;;
  741. # Whether this installation is on a Beaglebone Black
  742. --bbb)
  743. INSTALLING_ON_BBB="yes"
  744. ;;
  745. # Domain name to use as a TLS time source
  746. -t|--time)
  747. shift
  748. TLS_TIME_SOURCE1="$1"
  749. ;;
  750. # Static IP address for the system
  751. --ip)
  752. shift
  753. LOCAL_NETWORK_STATIC_IP_ADDRESS=$1
  754. ;;
  755. # IP address for the internet router
  756. --iprouter)
  757. shift
  758. ROUTER_IP_ADDRESS=$1
  759. ;;
  760. # ssh port
  761. --ssh)
  762. shift
  763. SSH_PORT=$1
  764. ;;
  765. # public mailing list name
  766. --list)
  767. shift
  768. PUBLIC_MAILING_LIST="$1"
  769. ;;
  770. # Number of CPU cores
  771. --cores)
  772. shift
  773. CPU_CORES=$1
  774. ;;
  775. # my name
  776. --name)
  777. shift
  778. MY_NAME="$1"
  779. ;;
  780. # my email address
  781. --email)
  782. shift
  783. MY_EMAIL_ADDRESS="$1"
  784. ;;
  785. # USB drive
  786. --usb)
  787. shift
  788. USB_DRIVE=$1
  789. ;;
  790. # Enable CJDNS
  791. --cjdns)
  792. shift
  793. ENABLE_CJDNS="yes"
  794. ;;
  795. # Enable B.A.T.M.A.N
  796. --batman)
  797. shift
  798. ENABLE_BATMAN="yes"
  799. ;;
  800. # Enable Babel
  801. --babel)
  802. shift
  803. ENABLE_BABEL="yes"
  804. ;;
  805. # VoIP server password
  806. --vpass)
  807. shift
  808. VOIP_SERVER_PASSWORD=$1
  809. ;;
  810. # VoIP server port
  811. --vport)
  812. shift
  813. VOIP_PORT=$1
  814. ;;
  815. # DNS Nameserver 1
  816. --ns1)
  817. shift
  818. NAMESERVER1=$1
  819. ;;
  820. # DNS Nameserver 2
  821. --ns2)
  822. shift
  823. NAMESERVER2=$1
  824. ;;
  825. # Debian repository
  826. --repo)
  827. shift
  828. DEBIAN_REPO=$1
  829. ;;
  830. # minimal install
  831. --minimal)
  832. shift
  833. MINIMAL_INSTALL=$1
  834. ;;
  835. *)
  836. # unknown option
  837. ;;
  838. esac
  839. shift
  840. done
  841. fi
  842. function parse_args {
  843. if [[ $NO_OF_ARGS == 0 ]]; then
  844. echo 'no_of_args = 0'
  845. show_help
  846. exit 0
  847. fi
  848. if [ ! -d /home/$MY_USERNAME ]; then
  849. echo $"There is no user '$MY_USERNAME' on the system. Use 'adduser $MY_USERNAME' to create the user."
  850. exit 1
  851. fi
  852. if [ ! "$DEFAULT_DOMAIN_NAME" ]; then
  853. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  854. echo 'No default domain specified'
  855. show_help
  856. exit 2
  857. fi
  858. fi
  859. if [ ! $MY_USERNAME ]; then
  860. echo 'No username specified'
  861. show_help
  862. exit 3
  863. fi
  864. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  865. if [[ $ONION_ONLY == "no" ]]; then
  866. if [ ! $DDNS_USERNAME ]; then
  867. echo $'Please provide the username for your dynamic DNS provider with the --ddnsuser option'
  868. exit 7823
  869. fi
  870. if [ ! $DDNS_PASSWORD ]; then
  871. echo $'Please provide the password for your dynamic DNS provider with the --ddnspass option'
  872. exit 6382
  873. fi
  874. fi
  875. fi
  876. if [ ! $SYSTEM_TYPE ]; then
  877. SYSTEM_TYPE=$VARIANT_FULL
  878. fi
  879. 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
  880. echo $"'$SYSTEM_TYPE' is an unrecognised ${PROJECT_NAME} variant."
  881. exit 30
  882. fi
  883. }
  884. function read_repo_servers {
  885. if [ -f $CONFIGURATION_FILE ]; then
  886. if grep -q "FRIENDS_MIRRORS_SERVER" $CONFIGURATION_FILE; then
  887. FRIENDS_MIRRORS_SERVER=$(grep "FRIENDS_MIRRORS_SERVER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  888. fi
  889. if grep -q "FRIENDS_MIRRORS_SSH_PORT" $CONFIGURATION_FILE; then
  890. FRIENDS_MIRRORS_SSH_PORT=$(grep "FRIENDS_MIRRORS_SSH_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  891. fi
  892. if grep -q "MY_MIRRORS_PASSWORD" $CONFIGURATION_FILE; then
  893. MY_MIRRORS_PASSWORD=$(grep "MY_MIRRORS_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  894. fi
  895. if grep -q "FRIENDS_MIRRORS_PASSWORD" $CONFIGURATION_FILE; then
  896. FRIENDS_MIRRORS_PASSWORD=$(grep "FRIENDS_MIRRORS_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  897. fi
  898. fi
  899. if [ ! $FRIENDS_MIRRORS_SERVER ]; then
  900. return
  901. fi
  902. if [ ${#FRIENDS_MIRRORS_SERVER} -lt 2 ]; then
  903. return
  904. fi
  905. MAIN_COMMAND=/usr/local/bin/${PROJECT_NAME}
  906. if [ ! -f $MAIN_COMMAND ]; then
  907. MAIN_COMMAND=/usr/bin/${PROJECT_NAME}
  908. fi
  909. REPOS=($(cat ${MAIN_COMMAND} | grep "_REPO=\"" | uniq -u | sed 's|${PROJECT_NAME}|'"${PROJECT_NAME}"'|g'))
  910. for line in "${REPOS[@]}"
  911. do
  912. repo_name=$(echo "$line" | awk -F '=' '{print $1}')
  913. mirrors_name=$(echo "$repo_name" | sed "s|_REPO||g" | awk '{print tolower($0)}')
  914. friends_repo_url="ssh://mirrors@${FRIENDS_MIRRORS_SERVER}:${FRIENDS_MIRRORS_SSH_PORT}/home/mirrors/${mirrors_name}"
  915. ${repo_name}="${friends_repo_url}"
  916. done
  917. }
  918. function read_configuration {
  919. # if not installing on a Beaglebone then use sdb as the USB drive by default
  920. if [ ! $INSTALLING_ON_BBB ]; then
  921. if [[ $USB_DRIVE == /dev/sda1 ]]; then
  922. USB_DRIVE=/dev/sdb1
  923. fi
  924. fi
  925. if [[ $INSTALLING_FROM_CONFIGURATION_FILE == "yes" ]]; then
  926. if [ ! -f $CONFIGURATION_FILE ]; then
  927. echo $"The configuration file $CONFIGURATION_FILE was not found"
  928. exit 8935
  929. fi
  930. fi
  931. if [ -f $CONFIGURATION_FILE ]; then
  932. read_repo_servers
  933. # Ensure that a copy of the config exists for upgrade purposes
  934. if [[ $CONFIGURATION_FILE != "/root/${PROJECT_NAME}.cfg" ]]; then
  935. cp $CONFIGURATION_FILE /root/${PROJECT_NAME}.cfg
  936. fi
  937. if grep -q "SYNCTHING_ID" $CONFIGURATION_FILE; then
  938. SYNCTHING_ID=$(grep "SYNCTHING_ID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  939. fi
  940. if grep -q "SYNCTHING_CONFIG_PATH" $CONFIGURATION_FILE; then
  941. SYNCTHING_CONFIG_PATH=$(grep "SYNCTHING_CONFIG_PATH" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  942. fi
  943. if grep -q "SYNCTHING_CONFIG_FILE" $CONFIGURATION_FILE; then
  944. SYNCTHING_CONFIG_FILE=$(grep "SYNCTHING_CONFIG_FILE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  945. fi
  946. if grep -q "SYNCTHING_RELAY_SERVER" $CONFIGURATION_FILE; then
  947. SYNCTHING_RELAY_SERVER=$(grep "SYNCTHING_RELAY_SERVER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  948. fi
  949. if grep -q "SYNCTHING_RELEASES" $CONFIGURATION_FILE; then
  950. SYNCTHING_RELEASES=$(grep "SYNCTHING_RELEASES" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  951. fi
  952. if grep -q "SYNCTHING_PORT" $CONFIGURATION_FILE; then
  953. SYNCTHING_PORT=$(grep "SYNCTHING_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  954. fi
  955. if grep -q "SYNCTHING_SHARED_DATA" $CONFIGURATION_FILE; then
  956. SYNCTHING_SHARED_DATA=$(grep "SYNCTHING_SHARED_DATA" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  957. fi
  958. if grep -q "VOIP_TURN_PORT" $CONFIGURATION_FILE; then
  959. VOIP_TURN_PORT=$(grep "VOIP_TURN_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  960. fi
  961. if grep -q "VOIP_TURN_TLS_PORT" $CONFIGURATION_FILE; then
  962. VOIP_TURN_TLS_PORT=$(grep "VOIP_TURN_TLS_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  963. fi
  964. if grep -q "VOIP_TURN_NONCE" $CONFIGURATION_FILE; then
  965. VOIP_TURN_NONCE=$(grep "VOIP_TURN_NONCE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  966. fi
  967. if grep -q "DEFAULT_SEARCH" $CONFIGURATION_FILE; then
  968. DEFAULT_SEARCH=$(grep "DEFAULT_SEARCH" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  969. fi
  970. if grep -q "SEARCH_ENGINE_PASSWORD" $CONFIGURATION_FILE; then
  971. SEARCH_ENGINE_PASSWORD=$(grep "SEARCH_ENGINE_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  972. fi
  973. if grep -q "XMPP_PASSWORD" $CONFIGURATION_FILE; then
  974. XMPP_PASSWORD=$(grep "XMPP_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  975. fi
  976. if grep -q "RSS_READER_REPO" $CONFIGURATION_FILE; then
  977. RSS_READER_REPO=$(grep "RSS_READER_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  978. fi
  979. if grep -q "RSS_MOBILE_READER_REPO" $CONFIGURATION_FILE; then
  980. RSS_MOBILE_READER_REPO=$(grep "RSS_MOBILE_READER_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  981. fi
  982. if grep -q "RSS_READER_COMMIT" $CONFIGURATION_FILE; then
  983. RSS_READER_COMMIT=$(grep "RSS_READER_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  984. fi
  985. if grep -q "RSS_MOBILE_READER_COMMIT" $CONFIGURATION_FILE; then
  986. RSS_MOBILE_READER_COMMIT=$(grep "RSS_MOBILE_READER_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  987. fi
  988. if grep -q "RSS_READER_ADMIN_PASSWORD" $CONFIGURATION_FILE; then
  989. RSS_READER_ADMIN_PASSWORD=$(grep "RSS_READER_ADMIN_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  990. fi
  991. if grep -q "RSS_READER_DOMAIN_NAME" $CONFIGURATION_FILE; then
  992. RSS_READER_DOMAIN_NAME=$(grep "RSS_READER_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  993. fi
  994. if grep -q "MICROBLOG_BACKGROUND_IMAGE_URL" $CONFIGURATION_FILE; then
  995. MICROBLOG_BACKGROUND_IMAGE_URL=$(grep "MICROBLOG_BACKGROUND_IMAGE_URL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  996. fi
  997. if grep -q "MICROBLOG_WELCOME_MESSAGE" $CONFIGURATION_FILE; then
  998. MICROBLOG_WELCOME_MESSAGE=$(grep "MICROBLOG_WELCOME_MESSAGE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  999. fi
  1000. if grep -q "PROJECT_WEBSITE" $CONFIGURATION_FILE; then
  1001. PROJECT_WEBSITE=$(grep "PROJECT_WEBSITE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1002. fi
  1003. if grep -q "PROJECT_REPO" $CONFIGURATION_FILE; then
  1004. PROJECT_REPO=$(grep "PROJECT_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1005. fi
  1006. if grep -q "ONION_ONLY" $CONFIGURATION_FILE; then
  1007. ONION_ONLY=$(grep "ONION_ONLY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1008. fi
  1009. if grep -q "IRC_PASSWORD" $CONFIGURATION_FILE; then
  1010. IRC_PASSWORD=$(grep "IRC_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1011. fi
  1012. if grep -q "DEFAULT_LANGUAGE" $CONFIGURATION_FILE; then
  1013. DEFAULT_LANGUAGE=$(grep "DEFAULT_LANGUAGE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1014. fi
  1015. if grep -q "MINIMAL_INSTALL" $CONFIGURATION_FILE; then
  1016. MINIMAL_INSTALL=$(grep "MINIMAL_INSTALL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1017. fi
  1018. if grep -q "LETSENCRYPT_SERVER" $CONFIGURATION_FILE; then
  1019. LETSENCRYPT_SERVER=$(grep "LETSENCRYPT_SERVER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1020. fi
  1021. if grep -q "FULLBLOG_REPO" $CONFIGURATION_FILE; then
  1022. FULLBLOG_REPO=$(grep "FULLBLOG_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1023. fi
  1024. if grep -q "FULLBLOG_COMMIT" $CONFIGURATION_FILE; then
  1025. FULLBLOG_COMMIT=$(grep "FULLBLOG_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1026. fi
  1027. if grep -q "GOGS_COMMIT" $CONFIGURATION_FILE; then
  1028. GOGS_COMMIT=$(grep "GOGS_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1029. fi
  1030. if grep -q "TOX_COMMIT" $CONFIGURATION_FILE; then
  1031. TOX_COMMIT=$(grep "TOX_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1032. fi
  1033. if grep -q "TOXIC_COMMIT" $CONFIGURATION_FILE; then
  1034. TOXIC_COMMIT=$(grep "TOXIC_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1035. fi
  1036. if grep -q "GPGIT_REPO" $CONFIGURATION_FILE; then
  1037. GPGIT_REPO=$(grep "GPGIT_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1038. fi
  1039. if grep -q "GPGIT_COMMIT" $CONFIGURATION_FILE; then
  1040. GPGIT_COMMIT=$(grep "GPGIT_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1041. fi
  1042. if grep -q "HUBZILLA_REPO" $CONFIGURATION_FILE; then
  1043. HUBZILLA_REPO=$(grep "HUBZILLA_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1044. fi
  1045. if grep -q "HUBZILLA_COMMIT" $CONFIGURATION_FILE; then
  1046. HUBZILLA_COMMIT=$(grep "HUBZILLA_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1047. fi
  1048. if grep -q "IPFS_COMMIT" $CONFIGURATION_FILE; then
  1049. IPFS_COMMIT=$(grep "IPFS_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1050. fi
  1051. if grep -q "ZERONET_BLOG_COMMIT" $CONFIGURATION_FILE; then
  1052. ZERONET_BLOG_COMMIT=$(grep "ZERONET_BLOG_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1053. fi
  1054. if grep -q "ZERONET_MAIL_COMMIT" $CONFIGURATION_FILE; then
  1055. ZERONET_MAIL_COMMIT=$(grep "ZERONET_MAIL_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1056. fi
  1057. if grep -q "ZERONET_FORUM_COMMIT" $CONFIGURATION_FILE; then
  1058. ZERONET_FORUM_COMMIT=$(grep "ZERONET_FORUM_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1059. fi
  1060. if grep -q "MICROBLOG_COMMIT" $CONFIGURATION_FILE; then
  1061. MICROBLOG_COMMIT=$(grep "MICROBLOG_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1062. fi
  1063. if grep -q "NGINX_ENSITE_REPO" $CONFIGURATION_FILE; then
  1064. NGINX_ENSITE_REPO=$(grep "NGINX_ENSITE_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1065. fi
  1066. if grep -q "NGINX_ENSITE_COMMIT" $CONFIGURATION_FILE; then
  1067. NGINX_ENSITE_COMMIT=$(grep "NGINX_ENSITE_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1068. fi
  1069. if grep -q "CLEANUP_MAILDIR_COMMIT" $CONFIGURATION_FILE; then
  1070. CLEANUP_MAILDIR_COMMIT=$(grep "CLEANUP_MAILDIR_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1071. fi
  1072. if grep -q "CLEANUP_MAILDIR_REPO" $CONFIGURATION_FILE; then
  1073. CLEANUP_MAILDIR_REPO=$(grep "CLEANUP_MAILDIR_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1074. fi
  1075. if grep -q "ZERONET_COMMIT" $CONFIGURATION_FILE; then
  1076. ZERONET_COMMIT=$(grep "ZERONET_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1077. fi
  1078. if grep -q "INADYN_REPO" $CONFIGURATION_FILE; then
  1079. INADYN_REPO=$(grep "INADYN_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1080. fi
  1081. if grep -q "INADYN_COMMIT" $CONFIGURATION_FILE; then
  1082. INADYN_COMMIT=$(grep "INADYN_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1083. fi
  1084. if grep -q "GPG_KEYSERVER" $CONFIGURATION_FILE; then
  1085. GPG_KEYSERVER=$(grep "GPG_KEYSERVER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1086. fi
  1087. if grep -q "IPFS_PORT" $CONFIGURATION_FILE; then
  1088. IPFS_PORT=$(grep "IPFS_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1089. fi
  1090. if grep -q "TRACKER_PORT" $CONFIGURATION_FILE; then
  1091. TRACKER_PORT=$(grep "TRACKER_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1092. fi
  1093. if grep -q "ZERONET_PORT" $CONFIGURATION_FILE; then
  1094. ZERONET_PORT=$(grep "ZERONET_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1095. fi
  1096. if grep -q "DH_KEYLENGTH" $CONFIGURATION_FILE; then
  1097. DH_KEYLENGTH=$(grep "DH_KEYLENGTH" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1098. fi
  1099. if grep -q "WIFI_INTERFACE" $CONFIGURATION_FILE; then
  1100. WIFI_INTERFACE=$(grep "WIFI_INTERFACE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1101. fi
  1102. if grep -q "IRC_PORT" $CONFIGURATION_FILE; then
  1103. IRC_PORT=$(grep "IRC_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1104. fi
  1105. if grep -q "WIFI_CHANNEL" $CONFIGURATION_FILE; then
  1106. WIFI_CHANNEL=$(grep "WIFI_CHANNEL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1107. fi
  1108. if grep -q "BATMAN_CELLID" $CONFIGURATION_FILE; then
  1109. BATMAN_CELLID=$(grep "BATMAN_CELLID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1110. fi
  1111. if grep -q "ESSID" $CONFIGURATION_FILE; then
  1112. ESSID=$(grep "ESSID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1113. fi
  1114. if grep -q "TOX_PORT" $CONFIGURATION_FILE; then
  1115. TOX_PORT=$(grep "TOX_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1116. fi
  1117. if grep -q "TOX_NODES" $CONFIGURATION_FILE; then
  1118. TOX_NODES=$(grep "TOX_NODES" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1119. fi
  1120. if grep -q "TOX_REPO" $CONFIGURATION_FILE; then
  1121. TOX_REPO=$(grep "TOX_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1122. fi
  1123. if grep -q "ENABLE_SOCIAL_KEY_MANAGEMENT" $CONFIGURATION_FILE; then
  1124. ENABLE_SOCIAL_KEY_MANAGEMENT=$(grep "ENABLE_SOCIAL_KEY_MANAGEMENT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1125. fi
  1126. if grep -q "IPV6_NETWORK" $CONFIGURATION_FILE; then
  1127. IPV6_NETWORK=$(grep "IPV6_NETWORK" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1128. fi
  1129. if grep -q "HWRNG_TYPE" $CONFIGURATION_FILE; then
  1130. HWRNG_TYPE=$(grep "HWRNG_TYPE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1131. fi
  1132. if grep -q "MEDIAGOBLIN_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1133. MEDIAGOBLIN_DOMAIN_NAME=$(grep "MEDIAGOBLIN_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1134. fi
  1135. if grep -q "MEDIAGOBLIN_CODE" $CONFIGURATION_FILE; then
  1136. MEDIAGOBLIN_CODE=$(grep "MEDIAGOBLIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1137. fi
  1138. if grep -q "MEDIAGOBLIN_REPO" $CONFIGURATION_FILE; then
  1139. MEDIAGOBLIN_REPO=$(grep "MEDIAGOBLIN_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1140. fi
  1141. if grep -q "MEDIAGOBLIN_COMMIT" $CONFIGURATION_FILE; then
  1142. MEDIAGOBLIN_COMMIT=$(grep "MEDIAGOBLIN_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1143. fi
  1144. if grep -q "GIT_ADMIN_PASSWORD" $CONFIGURATION_FILE; then
  1145. GIT_ADMIN_PASSWORD=$(grep "GIT_ADMIN_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1146. fi
  1147. if grep -q "GIT_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1148. GIT_DOMAIN_NAME=$(grep "GIT_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1149. fi
  1150. if grep -q "GIT_CODE" $CONFIGURATION_FILE; then
  1151. GIT_CODE=$(grep "GIT_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1152. fi
  1153. if grep -q "SYSTEM_TYPE" $CONFIGURATION_FILE; then
  1154. SYSTEM_TYPE=$(grep "SYSTEM_TYPE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1155. fi
  1156. if grep -q "SSL_PROTOCOLS" $CONFIGURATION_FILE; then
  1157. SSL_PROTOCOLS=$(grep "SSL_PROTOCOLS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1158. fi
  1159. if grep -q "SSL_CIPHERS" $CONFIGURATION_FILE; then
  1160. SSL_CIPHERS=$(grep "SSL_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1161. fi
  1162. if grep -q "SSH_CIPHERS" $CONFIGURATION_FILE; then
  1163. SSH_CIPHERS=$(grep "SSH_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1164. fi
  1165. if grep -q "SSH_MACS" $CONFIGURATION_FILE; then
  1166. SSH_MACS=$(grep "SSH_MACS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1167. fi
  1168. if grep -q "SSH_KEX" $CONFIGURATION_FILE; then
  1169. SSH_KEX=$(grep "SSH_KEX" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1170. fi
  1171. if grep -q "SSH_HOST_KEY_ALGORITHMS" $CONFIGURATION_FILE; then
  1172. SSH_HOST_KEY_ALGORITHMS=$(grep "SSH_HOST_KEY_ALGORITHMS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1173. fi
  1174. if grep -q "SSH_PASSWORDS" $CONFIGURATION_FILE; then
  1175. SSH_PASSWORDS=$(grep "SSH_PASSWORDS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1176. fi
  1177. if grep -q "XMPP_CIPHERS" $CONFIGURATION_FILE; then
  1178. XMPP_CIPHERS=$(grep "XMPP_CIPHERS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1179. fi
  1180. if grep -q "XMPP_ECC_CURVE" $CONFIGURATION_FILE; then
  1181. XMPP_ECC_CURVE=$(grep "XMPP_ECC_CURVE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1182. fi
  1183. if grep -q "MY_USERNAME" $CONFIGURATION_FILE; then
  1184. MY_USERNAME=$(grep "MY_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1185. fi
  1186. if grep -q "DOMAIN_NAME" $CONFIGURATION_FILE; then
  1187. # for backwards compatability
  1188. DEFAULT_DOMAIN_NAME=$(grep "DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1189. fi
  1190. if grep -q "DEFAULT_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1191. DEFAULT_DOMAIN_NAME=$(grep "DEFAULT_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1192. fi
  1193. if grep -q "DEFAULT_DOMAIN_CODE" $CONFIGURATION_FILE; then
  1194. DEFAULT_DOMAIN_CODE=$(grep "DEFAULT_DOMAIN_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1195. fi
  1196. if grep -q "NAMESERVER1" $CONFIGURATION_FILE; then
  1197. NAMESERVER1=$(grep "NAMESERVER1" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1198. fi
  1199. if grep -q "NAMESERVER2" $CONFIGURATION_FILE; then
  1200. NAMESERVER2=$(grep "NAMESERVER2" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1201. fi
  1202. if grep -q "DEBIAN_REPO" $CONFIGURATION_FILE; then
  1203. DEBIAN_REPO=$(grep "DEBIAN_REPO" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1204. 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."
  1205. fi
  1206. if grep -q "VOIP_PORT" $CONFIGURATION_FILE; then
  1207. VOIP_PORT=$(grep "VOIP_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1208. fi
  1209. if grep -q "VOIP_SERVER_PASSWORD" $CONFIGURATION_FILE; then
  1210. VOIP_SERVER_PASSWORD=$(grep "VOIP_SERVER_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1211. fi
  1212. if grep -q "SIP_PORT" $CONFIGURATION_FILE; then
  1213. SIP_PORT=$(grep "SIP_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1214. fi
  1215. if grep -q "SIP_TLS_PORT" $CONFIGURATION_FILE; then
  1216. SIP_TLS_PORT=$(grep "SIP_TLS_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1217. fi
  1218. if grep -q "SIP_SERVER_PASSWORD" $CONFIGURATION_FILE; then
  1219. SIP_SERVER_PASSWORD=$(grep "SIP_SERVER_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1220. fi
  1221. if grep -q "GET_IP_ADDRESS_URL" $CONFIGURATION_FILE; then
  1222. GET_IP_ADDRESS_URL=$(grep "GET_IP_ADDRESS_URL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1223. fi
  1224. if grep -q "DDNS_PROVIDER" $CONFIGURATION_FILE; then
  1225. DDNS_PROVIDER=$(grep "DDNS_PROVIDER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1226. fi
  1227. if grep -q "DDNS_USERNAME" $CONFIGURATION_FILE; then
  1228. DDNS_USERNAME=$(grep "DDNS_USERNAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1229. fi
  1230. if grep -q "DDNS_PASSWORD" $CONFIGURATION_FILE; then
  1231. DDNS_PASSWORD=$(grep "DDNS_PASSWORD" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1232. fi
  1233. if grep -q "LOCAL_NETWORK_STATIC_IP_ADDRESS" $CONFIGURATION_FILE; then
  1234. LOCAL_NETWORK_STATIC_IP_ADDRESS=$(grep "LOCAL_NETWORK_STATIC_IP_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1235. fi
  1236. if grep -q "ENABLE_BABEL" $CONFIGURATION_FILE; then
  1237. ENABLE_BABEL=$(grep "ENABLE_BABEL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1238. fi
  1239. if grep -q "ENABLE_BATMAN" $CONFIGURATION_FILE; then
  1240. ENABLE_BATMAN=$(grep "ENABLE_BATMAN" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1241. fi
  1242. if grep -q "ENABLE_CJDNS" $CONFIGURATION_FILE; then
  1243. ENABLE_CJDNS=$(grep "ENABLE_CJDNS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1244. fi
  1245. if grep -q "CJDNS_COMMIT" $CONFIGURATION_FILE; then
  1246. CJDNS_COMMIT=$(grep "CJDNS_COMMIT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1247. fi
  1248. if grep -q "CJDNS_IPV6" $CONFIGURATION_FILE; then
  1249. CJDNS_IPV6=$(grep "CJDNS_IPV6" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1250. fi
  1251. if grep -q "CJDNS_PUBLIC_KEY" $CONFIGURATION_FILE; then
  1252. CJDNS_PUBLIC_KEY=$(grep "CJDNS_PUBLIC_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1253. fi
  1254. if grep -q "CJDNS_PRIVATE_KEY" $CONFIGURATION_FILE; then
  1255. CJDNS_PRIVATE_KEY=$(grep "CJDNS_PRIVATE_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1256. fi
  1257. if grep -q "ROUTER_IP_ADDRESS" $CONFIGURATION_FILE; then
  1258. ROUTER_IP_ADDRESS=$(grep "ROUTER_IP_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1259. fi
  1260. if grep -q "CPU_CORES" $CONFIGURATION_FILE; then
  1261. CPU_CORES=$(grep "CPU_CORES" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1262. fi
  1263. if grep -q "WEBSERVER_LOG_LEVEL" $CONFIGURATION_FILE; then
  1264. WEBSERVER_LOG_LEVEL=$(grep "WEBSERVER_LOG_LEVEL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1265. fi
  1266. if grep -q "ROUTE_THROUGH_TOR" $CONFIGURATION_FILE; then
  1267. ROUTE_THROUGH_TOR=$(grep "ROUTE_THROUGH_TOR" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1268. fi
  1269. if grep -q "WIKI_TITLE" $CONFIGURATION_FILE; then
  1270. WIKI_TITLE=$(grep "WIKI_TITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1271. fi
  1272. if grep -q "MY_NAME" $CONFIGURATION_FILE; then
  1273. MY_NAME=$(grep "MY_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1274. fi
  1275. if grep -q "MY_EMAIL_ADDRESS" $CONFIGURATION_FILE; then
  1276. MY_EMAIL_ADDRESS=$(grep "MY_EMAIL_ADDRESS" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1277. fi
  1278. if grep -q "INSTALLING_ON_BBB" $CONFIGURATION_FILE; then
  1279. INSTALLING_ON_BBB=$(grep "INSTALLING_ON_BBB" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1280. fi
  1281. if grep -q "SSH_PORT" $CONFIGURATION_FILE; then
  1282. SSH_PORT=$(grep "SSH_PORT" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1283. fi
  1284. if grep -q "INSTALLED_WITHIN_DOCKER" $CONFIGURATION_FILE; then
  1285. INSTALLED_WITHIN_DOCKER=$(grep "INSTALLED_WITHIN_DOCKER" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1286. fi
  1287. if grep -q "PUBLIC_MAILING_LIST" $CONFIGURATION_FILE; then
  1288. PUBLIC_MAILING_LIST=$(grep "PUBLIC_MAILING_LIST" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1289. fi
  1290. if grep -q "MICROBLOG_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1291. MICROBLOG_DOMAIN_NAME=$(grep "MICROBLOG_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1292. fi
  1293. if grep -q "MICROBLOG_CODE" $CONFIGURATION_FILE; then
  1294. MICROBLOG_CODE=$(grep "MICROBLOG_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1295. fi
  1296. if grep -q "HUBZILLA_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1297. HUBZILLA_DOMAIN_NAME=$(grep "HUBZILLA_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1298. fi
  1299. if grep -q "HUBZILLA_CODE" $CONFIGURATION_FILE; then
  1300. HUBZILLA_CODE=$(grep "HUBZILLA_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1301. fi
  1302. if grep -q "WIKI_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1303. WIKI_DOMAIN_NAME=$(grep "WIKI_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1304. fi
  1305. if grep -q "WIKI_CODE" $CONFIGURATION_FILE; then
  1306. WIKI_CODE=$(grep "WIKI_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1307. fi
  1308. if grep -q "FULLBLOG_DOMAIN_NAME" $CONFIGURATION_FILE; then
  1309. FULLBLOG_DOMAIN_NAME=$(grep "FULLBLOG_DOMAIN_NAME" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1310. fi
  1311. if grep -q "FULLBLOG_CODE" $CONFIGURATION_FILE; then
  1312. FULLBLOG_CODE=$(grep "FULLBLOG_CODE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1313. fi
  1314. if grep -q "MY_BLOG_TITLE" $CONFIGURATION_FILE; then
  1315. MY_BLOG_TITLE=$(grep "MY_BLOG_TITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1316. fi
  1317. if grep -q "MY_BLOG_SUBTITLE" $CONFIGURATION_FILE; then
  1318. MY_BLOG_SUBTITLE=$(grep "MY_BLOG_SUBTITLE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1319. fi
  1320. if grep -q "GPG_ENCRYPT_STORED_EMAIL" $CONFIGURATION_FILE; then
  1321. GPG_ENCRYPT_STORED_EMAIL=$(grep "GPG_ENCRYPT_STORED_EMAIL" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1322. fi
  1323. if grep -q "MY_GPG_PUBLIC_KEY" $CONFIGURATION_FILE; then
  1324. MY_GPG_PUBLIC_KEY=$(grep "MY_GPG_PUBLIC_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1325. fi
  1326. if grep -q "MY_GPG_PRIVATE_KEY" $CONFIGURATION_FILE; then
  1327. MY_GPG_PRIVATE_KEY=$(grep "MY_GPG_PRIVATE_KEY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1328. fi
  1329. if grep -q "MY_GPG_PUBLIC_KEY_ID" $CONFIGURATION_FILE; then
  1330. MY_GPG_PUBLIC_KEY_ID=$(grep "MY_GPG_PUBLIC_KEY_ID" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1331. fi
  1332. if grep -q "USB_DRIVE" $CONFIGURATION_FILE; then
  1333. USB_DRIVE=$(grep "USB_DRIVE" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1334. fi
  1335. if grep -q "MAX_PHP_MEMORY" $CONFIGURATION_FILE; then
  1336. MAX_PHP_MEMORY=$(grep "MAX_PHP_MEMORY" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1337. fi
  1338. if grep -q "TLS_TIME_SOURCE1" $CONFIGURATION_FILE; then
  1339. TLS_TIME_SOURCE1=$(grep "TLS_TIME_SOURCE1" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1340. fi
  1341. if grep -q "TLS_TIME_SOURCE2" $CONFIGURATION_FILE; then
  1342. TLS_TIME_SOURCE2=$(grep "TLS_TIME_SOURCE2" $CONFIGURATION_FILE | awk -F '=' '{print $2}')
  1343. fi
  1344. fi
  1345. echo "System type: $SYSTEM_TYPE"
  1346. }
  1347. function set_default_onion_domains {
  1348. # If sites are only visible via Tor then for installation
  1349. # purposes assign them some default domain names
  1350. if [[ $ONION_ONLY == "no" ]]; then
  1351. return
  1352. fi
  1353. if [ ${#MICROBLOG_DOMAIN_NAME} -gt 1 ]; then
  1354. MICROBLOG_DOMAIN_NAME='microblog.local'
  1355. fi
  1356. if [ ${#FULLBLOG_DOMAIN_NAME} -gt 1 ]; then
  1357. FULLBLOG_DOMAIN_NAME='blog.local'
  1358. fi
  1359. if [ ${#WIKI_DOMAIN_NAME} -gt 1 ]; then
  1360. WIKI_DOMAIN_NAME='wiki.local'
  1361. fi
  1362. if [ ${#DEFAULT_DOMAIN_NAME} -gt 1 ]; then
  1363. DEFAULT_DOMAIN_NAME="${PROJECT_NAME}.local"
  1364. fi
  1365. if [ ${#GIT_DOMAIN_NAME} -gt 1 ]; then
  1366. GIT_DOMAIN_NAME='git.local'
  1367. fi
  1368. if [ ${#MEDIAGOBLIN_DOMAIN_NAME} -gt 1 ]; then
  1369. MEDIAGOBLIN_DOMAIN_NAME='media.local'
  1370. fi
  1371. }
  1372. function nginx_disable_sniffing {
  1373. domain_name=$1
  1374. filename=/etc/nginx/sites-available/$domain_name
  1375. echo ' add_header X-Frame-Options DENY;' >> $filename
  1376. echo ' add_header X-Content-Type-Options nosniff;' >> $filename
  1377. echo '' >> $filename
  1378. }
  1379. function nginx_limits {
  1380. domain_name=$1
  1381. max_body='20m'
  1382. if [ $2 ]; then
  1383. max_body=$2
  1384. fi
  1385. filename=/etc/nginx/sites-available/$domain_name
  1386. echo " client_max_body_size ${max_body};" >> $filename
  1387. echo ' client_body_buffer_size 128k;' >> $filename
  1388. echo '' >> $filename
  1389. echo ' limit_conn conn_limit_per_ip 10;' >> $filename
  1390. echo ' limit_req zone=req_limit_per_ip burst=10 nodelay;' >> $filename
  1391. echo '' >> $filename
  1392. }
  1393. function nginx_http_redirect {
  1394. # redirect port 80 to https
  1395. domain_name=$1
  1396. filename=/etc/nginx/sites-available/$domain_name
  1397. echo 'server {' > $filename
  1398. echo ' listen 80;' >> $filename
  1399. echo ' listen [::]:80;' >> $filename
  1400. echo " server_name ${domain_name};" >> $filename
  1401. echo " root /var/www/${domain_name}/htdocs;" >> $filename
  1402. echo ' access_log off;' >> $filename
  1403. echo " error_log /var/log/nginx/${domain_name}_error.log $WEBSERVER_LOG_LEVEL;" >> $filename
  1404. nginx_limits $domain_name
  1405. echo ' rewrite ^ https://$server_name$request_uri? permanent;' >> $filename
  1406. echo '}' >> $filename
  1407. echo '' >> $filename
  1408. }
  1409. function nginx_ssl {
  1410. # creates the SSL/TLS section for a website
  1411. domain_name=$1
  1412. filename=/etc/nginx/sites-available/$domain_name
  1413. echo ' ssl on;' >> $filename
  1414. echo " ssl_certificate /etc/ssl/certs/${domain_name}.crt;" >> $filename
  1415. echo " ssl_certificate_key /etc/ssl/private/${domain_name}.key;" >> $filename
  1416. echo " ssl_dhparam /etc/ssl/certs/${domain_name}.dhparam;" >> $filename
  1417. echo '' >> $filename
  1418. echo ' ssl_session_timeout 60m;' >> $filename
  1419. echo ' ssl_prefer_server_ciphers on;' >> $filename
  1420. echo " ssl_protocols $SSL_PROTOCOLS;" >> $filename
  1421. echo " ssl_ciphers '$SSL_CIPHERS';" >> $filename
  1422. }
  1423. function rss_reader_modifications {
  1424. # modify the rss reader to use a socks5 proxy rather than a http proxy
  1425. if [ ! -d $RSS_READER_PATH ]; then
  1426. return
  1427. fi
  1428. # ensure that socks5 proxy is used
  1429. if ! grep -q "CURLOPT_PROXYTYPE" $RSS_READER_PATH/plugins/af_unburn/init.php; then
  1430. 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
  1431. fi
  1432. if ! grep -q "CURLOPT_PROXYTYPE" $RSS_READER_PATH/include/functions.php; then
  1433. 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
  1434. fi
  1435. chown -R www-data:www-data $RSS_READER_PATH
  1436. chmod a+x $RSS_READER_PATH
  1437. }
  1438. function set_repo_commit {
  1439. repo_dir=$1
  1440. repo_commit_name=$2
  1441. repo_commit=$3
  1442. repo_url=$4
  1443. if [ -d $repo_dir ]; then
  1444. if grep -q "$repo_commit_name" $COMPLETION_FILE; then
  1445. CURRENT_REPO_COMMIT=$(grep "$repo_commit_name" $COMPLETION_FILE | awk -F ':' '{print $2}')
  1446. if [[ "$CURRENT_REPO_COMMIT" != "$repo_commit" ]]; then
  1447. cd $repo_dir
  1448. git_pull $repo_url $repo_commit
  1449. sed -i "s/${repo_commit_name}.*/${repo_commit_name}:$repo_commit/g" $COMPLETION_FILE
  1450. # application specific stuff after updating the repo
  1451. if [[ $repo_dir == *"www"* ]]; then
  1452. chown -R www-data:www-data $repo_dir
  1453. fi
  1454. if [[ $repo_dir == *"cjdns" ]]; then
  1455. ./do
  1456. fi
  1457. if [[ $repo_dir == *"gpgit" ]]; then
  1458. cp gpgit.pl /usr/bin/gpgit.pl
  1459. fi
  1460. if [[ $repo_dir == *"cleanup-maildir" ]]; then
  1461. cp $INSTALL_DIR/cleanup-maildir/cleanup-maildir /usr/bin
  1462. fi
  1463. if [[ $repo_dir == *"nginx_ensite" ]]; then
  1464. make install
  1465. fi
  1466. if [[ $repo_dir == *"gogs" ]]; then
  1467. git checkout master
  1468. go get -u ./...
  1469. if [ ! "$?" = "0" ]; then
  1470. echo $'Failed to get gogs'
  1471. exit 52792
  1472. fi
  1473. git checkout $repo_commit
  1474. go build
  1475. if [ ! "$?" = "0" ]; then
  1476. echo $'Failed to build gogs'
  1477. exit 36226
  1478. fi
  1479. systemctl restart gogs
  1480. fi
  1481. if [[ $repo_dir == *"toxcore" ]]; then
  1482. sed -i 's|ExecStart=.*|ExecStart=/usr/local/bin/tox-bootstrapd --config /etc/tox-bootstrapd.conf|g' $rootdir/etc/systemd/system/tox-bootstrapd.service
  1483. autoreconf -i
  1484. ./configure --enable-daemon
  1485. make
  1486. make install
  1487. systemctl daemon-reload
  1488. systemctl restart tox-bootstrapd.service
  1489. fi
  1490. if [[ $repo_dir == *"toxic" ]]; then
  1491. make
  1492. make install
  1493. fi
  1494. if [[ $repo_dir == $RSS_READER_PATH ]]; then
  1495. rss_reader_modifications
  1496. fi
  1497. if [[ $repo_dir == *"inadyn" ]]; then
  1498. ./configure
  1499. USE_OPENSSL=1 make
  1500. make install
  1501. systemctl restart inadyn
  1502. fi
  1503. if [[ $repo_dir == *"ipfs" ]]; then
  1504. chown -R git:git /home/git
  1505. systemctl restart ipfs
  1506. systemctl daemon-reload
  1507. fi
  1508. fi
  1509. else
  1510. echo "${repo_commit_name}:${repo_commit}" >> $COMPLETION_FILE
  1511. fi
  1512. fi
  1513. }
  1514. function wait_for_onion_service {
  1515. onion_service_name="$1"
  1516. sleep_ctr=0
  1517. while [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; do
  1518. sleep 1
  1519. sleep_ctr=$((sleep_ctr + 1))
  1520. if [ $sleep_ctr -gt 10 ]; then
  1521. break
  1522. fi
  1523. done
  1524. if [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  1525. # restart and try a second time
  1526. systemctl restart tor
  1527. sleep_ctr=0
  1528. while [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; do
  1529. sleep 1
  1530. sleep_ctr=$((sleep_ctr + 1))
  1531. if [ $sleep_ctr -gt 10 ]; then
  1532. break
  1533. fi
  1534. done
  1535. fi
  1536. }
  1537. function add_onion_service {
  1538. onion_service_name="$1"
  1539. onion_service_port_from=$2
  1540. onion_service_port_to=$3
  1541. if [ -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  1542. echo $(cat /var/lib/tor/hidden_service_${onion_service_name}/hostname)
  1543. return
  1544. fi
  1545. if [ ! -d /var/lib/tor ]; then
  1546. echo $"No Tor installation found. ${onion_service_name} onion site cannot be configured."
  1547. exit 877367
  1548. fi
  1549. if ! grep -q "hidden_service_${onion_service_name}" /etc/tor/torrc; then
  1550. echo "HiddenServiceDir /var/lib/tor/hidden_service_${onion_service_name}/" >> /etc/tor/torrc
  1551. echo "HiddenServicePort ${onion_service_port_from} 127.0.0.1:${onion_service_port_to}" >> /etc/tor/torrc
  1552. fi
  1553. systemctl restart tor
  1554. wait_for_onion_service ${onion_service_name}
  1555. if [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  1556. echo $"${onion_service_name} onion site hostname not found"
  1557. exit 76362
  1558. fi
  1559. echo $(cat /var/lib/tor/hidden_service_${onion_service_name}/hostname)
  1560. }
  1561. function create_avahi_onion_domains {
  1562. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  1563. return
  1564. fi
  1565. if [ ! -d /etc/avahi/services ]; then
  1566. return
  1567. fi
  1568. if [ $MICROBLOG_DOMAIN_NAME ]; then
  1569. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/microblog.service
  1570. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/microblog.service
  1571. echo '<service-group>' >> /etc/avahi/services/microblog.service
  1572. echo ' <name replace-wildcards="yes">%h HTTP</name>' >> /etc/avahi/services/microblog.service
  1573. echo ' <service>' >> /etc/avahi/services/microblog.service
  1574. echo ' <type>_http._tcp</type>' >> /etc/avahi/services/microblog.service
  1575. echo " <port>$MICROBLOG_ONION_PORT</port>" >> /etc/avahi/services/microblog.service
  1576. echo ' </service>' >> /etc/avahi/services/microblog.service
  1577. echo '</service-group>' >> /etc/avahi/services/microblog.service
  1578. fi
  1579. if [ $FULLBLOG_DOMAIN_NAME ]; then
  1580. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/blog.service
  1581. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/blog.service
  1582. echo '<service-group>' >> /etc/avahi/services/blog.service
  1583. echo ' <name replace-wildcards="yes">%h HTTP</name>' >> /etc/avahi/services/blog.service
  1584. echo ' <service>' >> /etc/avahi/services/blog.service
  1585. echo ' <type>_http._tcp</type>' >> /etc/avahi/services/blog.service
  1586. echo " <port>$BLOG_ONION_PORT</port>" >> /etc/avahi/services/blog.service
  1587. echo ' </service>' >> /etc/avahi/services/blog.service
  1588. echo '</service-group>' >> /etc/avahi/services/blog.service
  1589. fi
  1590. if [ $GIT_DOMAIN_NAME ]; then
  1591. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/git.service
  1592. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/git.service
  1593. echo '<service-group>' >> /etc/avahi/services/git.service
  1594. echo ' <name replace-wildcards="yes">%h HTTP</name>' >> /etc/avahi/services/git.service
  1595. echo ' <service>' >> /etc/avahi/services/git.service
  1596. echo ' <type>_http._tcp</type>' >> /etc/avahi/services/git.service
  1597. echo " <port>$GIT_ONION_PORT</port>" >> /etc/avahi/services/git.service
  1598. echo ' </service>' >> /etc/avahi/services/git.service
  1599. echo '</service-group>' >> /etc/avahi/services/git.service
  1600. fi
  1601. if [ $WIKI_DOMAIN_NAME ]; then
  1602. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/wiki.service
  1603. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/wiki.service
  1604. echo '<service-group>' >> /etc/avahi/services/wiki.service
  1605. echo ' <name replace-wildcards="yes">%h HTTP</name>' >> /etc/avahi/services/wiki.service
  1606. echo ' <service>' >> /etc/avahi/services/wiki.service
  1607. echo ' <type>_http._tcp</type>' >> /etc/avahi/services/wiki.service
  1608. echo " <port>$WIKI_ONION_PORT</port>" >> /etc/avahi/services/wiki.service
  1609. echo ' </service>' >> /etc/avahi/services/wiki.service
  1610. echo '</service-group>' >> /etc/avahi/services/wiki.service
  1611. fi
  1612. }
  1613. # check an individual domain name
  1614. function test_domain_name {
  1615. if [ $1 ]; then
  1616. TEST_DOMAIN_NAME=$1
  1617. validate_domain_name
  1618. if [[ $TEST_DOMAIN_NAME != $1 ]]; then
  1619. echo $TEST_DOMAIN_NAME
  1620. exit 8528
  1621. fi
  1622. fi
  1623. }
  1624. # check that domain names are sensible
  1625. function check_domains {
  1626. if [ ${#WIKI_DOMAIN_NAME} -gt 1 ]; then
  1627. test_domain_name "$WIKI_DOMAIN_NAME"
  1628. if [[ "$test_domain_name" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  1629. echo $'Wiki domain name is the same as blog domain name. They must be different'
  1630. exit 97326
  1631. fi
  1632. if [[ "$test_domain_name" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  1633. echo $'Wiki domain name is the same as microblog domain name. They must be different'
  1634. exit 36827
  1635. fi
  1636. if [[ "$test_domain_name" == "$HUBZILLA_DOMAIN_NAME" ]]; then
  1637. echo $'Wiki domain name is the same as hubzilla domain name. They must be different'
  1638. exit 65848
  1639. fi
  1640. if [ ${#GIT_DOMAIN_NAME} -gt 1 ]; then
  1641. if [[ "$test_domain_name" == "$GIT_DOMAIN_NAME" ]]; then
  1642. echo $'Wiki domain name is the same as Gogs domain name. They must be different'
  1643. exit 73529
  1644. fi
  1645. fi
  1646. fi
  1647. if [ ${#FULLBLOG_DOMAIN_NAME} -gt 1 ]; then
  1648. test_domain_name "$FULLBLOG_DOMAIN_NAME"
  1649. if [[ "$test_domain_name" == "$WIKI_DOMAIN_NAME" ]]; then
  1650. echo $'Blog domain name is the same as wiki domain name. They must be different'
  1651. exit 62348
  1652. fi
  1653. if [[ "$test_domain_name" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  1654. echo $'Blog domain name is the same as microblog domain name. They must be different'
  1655. exit 38236
  1656. fi
  1657. if [[ "$test_domain_name" == "$HUBZILLA_DOMAIN_NAME" ]]; then
  1658. echo $'Blog domain name is the same as hubzilla domain name. They must be different'
  1659. exit 35483
  1660. fi
  1661. if [ $GIT_DOMAIN_NAME ]; then
  1662. if [[ "$test_domain_name" == "$GIT_DOMAIN_NAME" ]]; then
  1663. echo $'Blog domain name is the same as Gogs domain name. They must be different'
  1664. exit 84695
  1665. fi
  1666. fi
  1667. fi
  1668. if [ ${#MICROBLOG_DOMAIN_NAME} -gt 1 ]; then
  1669. test_domain_name "$MICROBLOG_DOMAIN_NAME"
  1670. if [[ "$test_domain_name" == "$WIKI_DOMAIN_NAME" ]]; then
  1671. echo $'Microblog domain name is the same as wiki domain name. They must be different'
  1672. exit 73924
  1673. fi
  1674. if [[ "$test_domain_name" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  1675. echo $'Microblog domain name is the same as blog domain name. They must be different'
  1676. exit 26832
  1677. fi
  1678. if [[ "$test_domain_name" == "$HUBZILLA_DOMAIN_NAME" ]]; then
  1679. echo $'Microblog domain name is the same as hubzilla domain name. They must be different'
  1680. exit 678382
  1681. fi
  1682. if [ $GIT_DOMAIN_NAME ]; then
  1683. if [[ "$test_domain_name" == "$GIT_DOMAIN_NAME" ]]; then
  1684. echo $'Microblog domain name is the same as Gogs domain name. They must be different'
  1685. exit 684325
  1686. fi
  1687. fi
  1688. fi
  1689. if [ $HUBZILLA_DOMAIN_NAME ]; then
  1690. test_domain_name "$HUBZILLA_DOMAIN_NAME"
  1691. if [[ "$test_domain_name" == "$WIKI_DOMAIN_NAME" ]]; then
  1692. echo $'Hubzilla domain name is the same as wiki domain name. They must be different'
  1693. exit 83682
  1694. fi
  1695. if [[ "$test_domain_name" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  1696. echo $'Hubzilla domain name is the same as blog domain name. They must be different'
  1697. exit 74817
  1698. fi
  1699. if [[ "$test_domain_name" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  1700. echo $'Hubzilla domain name is the same as microblog domain name. They must be different'
  1701. exit 83683
  1702. fi
  1703. if [ ${#GIT_DOMAIN_NAME} -gt 1 ]; then
  1704. if [[ "$test_domain_name" == "$GIT_DOMAIN_NAME" ]]; then
  1705. echo $'Hubzilla domain name is the same as Gogs domain name. They must be different'
  1706. exit 135523
  1707. fi
  1708. fi
  1709. fi
  1710. if [ ${#GIT_DOMAIN_NAME} -gt 1 ]; then
  1711. test_domain_name "$GIT_DOMAIN_NAME"
  1712. if [[ "$test_domain_name" == "$WIKI_DOMAIN_NAME" ]]; then
  1713. echo $'Hubzilla domain name is the same as wiki domain name. They must be different'
  1714. exit 83682
  1715. fi
  1716. if [[ "$test_domain_name" == "$FULLBLOG_DOMAIN_NAME" ]]; then
  1717. echo $'Hubzilla domain name is the same as blog domain name. They must be different'
  1718. exit 74817
  1719. fi
  1720. if [[ "$test_domain_name" == "$MICROBLOG_DOMAIN_NAME" ]]; then
  1721. echo $'Hubzilla domain name is the same as microblog domain name. They must be different'
  1722. exit 83683
  1723. fi
  1724. if [[ "$test_domain_name" == "$HUBZILLA_DOMAIN_NAME" ]]; then
  1725. echo $'Microblog domain name is the same as hubzilla domain name. They must be different'
  1726. exit 678382
  1727. fi
  1728. fi
  1729. }
  1730. # Checks whether certificates were generated for the given hostname
  1731. function check_certificates {
  1732. if [ ! $1 ]; then
  1733. return
  1734. fi
  1735. USE_LETSENCRYPT='no'
  1736. if [ $2 ]; then
  1737. USE_LETSENCRYPT=$2
  1738. fi
  1739. if [[ $USE_LETSENCRYPT == 'no' ]]; then
  1740. if [ ! -f /etc/ssl/private/$1.key ]; then
  1741. echo $"Private certificate for $CHECK_HOSTNAME was not created"
  1742. exit 63959
  1743. fi
  1744. if [ ! -f /etc/ssl/certs/$1.crt ]; then
  1745. echo $"Public certificate for $CHECK_HOSTNAME was not created"
  1746. exit 7679
  1747. fi
  1748. else
  1749. if [ ! -f /etc/letsencrypt/live/${1}/privkey.pem ]; then
  1750. echo $"Private certificate for $CHECK_HOSTNAME was not created"
  1751. exit 6282
  1752. fi
  1753. if [ ! -f /etc/letsencrypt/live/${1}/fullchain.pem ]; then
  1754. echo $"Public certificate for $CHECK_HOSTNAME was not created"
  1755. exit 5328
  1756. fi
  1757. fi
  1758. if [ ! -f /etc/ssl/certs/$1.dhparam ]; then
  1759. echo $"Diffie–Hellman parameters for $CHECK_HOSTNAME were not created"
  1760. exit 5989
  1761. fi
  1762. }
  1763. function create_site_certificate {
  1764. SITE_DOMAIN_NAME="$1"
  1765. # if yes then only "valid" certs are allowed, not self-signed
  1766. NO_SELF_SIGNED='no'
  1767. if [ $2 ]; then
  1768. NO_SELF_SIGNED="$2"
  1769. fi
  1770. if [[ $ONION_ONLY == "no" ]]; then
  1771. if [ ! -f /etc/ssl/certs/$SITE_DOMAIN_NAME.dhparam ]; then
  1772. if [[ $LETSENCRYPT_ENABLED != "yes" ]]; then
  1773. ${PROJECT_NAME}-addcert -h $SITE_DOMAIN_NAME --dhkey $DH_KEYLENGTH
  1774. check_certificates $SITE_DOMAIN_NAME
  1775. else
  1776. ${PROJECT_NAME}-addcert -e $SITE_DOMAIN_NAME -s $LETSENCRYPT_SERVER --dhkey $DH_KEYLENGTH --email $MY_EMAIL_ADDRESS
  1777. if [ ! "$?" = "0" ]; then
  1778. if [[ $NO_SELF_SIGNED == 'no' ]]; then
  1779. echo $"Lets Encrypt failed for $SITE_DOMAIN_NAME, so try making a self-signed cert"
  1780. ${PROJECT_NAME}-addcert -h $SITE_DOMAIN_NAME --dhkey $DH_KEYLENGTH
  1781. check_certificates $SITE_DOMAIN_NAME
  1782. else
  1783. echo $"Lets Encrypt failed for $SITE_DOMAIN_NAME"
  1784. exit 682529
  1785. fi
  1786. else
  1787. check_certificates $SITE_DOMAIN_NAME 'yes'
  1788. fi
  1789. fi
  1790. fi
  1791. fi
  1792. }
  1793. function backup_database_local {
  1794. # Makes local backups of databases which can then be automatically rolled
  1795. # back if corruption is detected
  1796. database_name=$1
  1797. backup_databases_script=/usr/bin/backupdatabases
  1798. echo '' >> $backup_databases_script
  1799. echo "# Backup the ${database_name} database" >> $backup_databases_script
  1800. echo "TEMPFILE=/root/${database_name}.sql" >> $backup_databases_script
  1801. echo 'DAILYFILE=/var/backups/${database_name}_daily.sql' >> $backup_databases_script
  1802. echo "mysqldump --password=\"\$MYSQL_PASSWORD\" ${database_name} > \$TEMPFILE" >> $backup_databases_script
  1803. echo 'FILESIZE=$(stat -c%s $TEMPFILE)' >> $backup_databases_script
  1804. echo 'if [ "$FILESIZE" -eq "0" ]; then' >> $backup_databases_script
  1805. echo ' if [ -f $DAILYFILE ]; then' >> $backup_databases_script
  1806. echo ' cp $DAILYFILE $TEMPFILE' >> $backup_databases_script
  1807. echo '' >> $backup_databases_script
  1808. echo ' # try to restore yesterdays database' >> $backup_databases_script
  1809. echo " mysql -u root --password=\"\$MYSQL_PASSWORD\" ${database_name} -o < \$DAILYFILE" >> $backup_databases_script
  1810. echo '' >> $backup_databases_script
  1811. echo ' # Send a warning email' >> $backup_databases_script
  1812. 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
  1813. echo ' else' >> $backup_databases_script
  1814. echo ' # Send a warning email' >> $backup_databases_script
  1815. echo " echo \"Unable to create a backup of the ${database_name} database.\" | mail -s \"${database_name} backup\" \$EMAIL" >> $backup_databases_script
  1816. echo ' fi' >> $backup_databases_script
  1817. echo 'else' >> $backup_databases_script
  1818. echo ' chmod 600 $TEMPFILE' >> $backup_databases_script
  1819. echo ' mv $TEMPFILE $DAILYFILE' >> $backup_databases_script
  1820. echo '' >> $backup_databases_script
  1821. echo ' # Make the backup readable only by root' >> $backup_databases_script
  1822. echo ' chmod 600 $DAILYFILE' >> $backup_databases_script
  1823. echo 'fi' >> $backup_databases_script
  1824. weekly_backup_script=/etc/cron.weekly/backupdatabasesweekly
  1825. if ! grep -q "${database_name}" ${weekly_backup_script}; then
  1826. echo '' >> ${weekly_backup_script}
  1827. echo "# ${database_name}" >> ${weekly_backup_script}
  1828. echo "if [ -f /var/backups/${database_name}_weekly.sql ]; then" >> ${weekly_backup_script}
  1829. echo " cp -f /var/backups/${database_name}_weekly.sql /var/backups/${database_name}_2weekly.sql" >> ${weekly_backup_script}
  1830. echo 'fi' >> ${weekly_backup_script}
  1831. echo "if [ -f /var/backups/${database_name}_daily.sql ]; then" >> ${weekly_backup_script}
  1832. echo " cp -f /var/backups/${database_name}_daily.sql /var/backups/${database_name}_weekly.sql" >> ${weekly_backup_script}
  1833. echo 'fi' >> ${weekly_backup_script}
  1834. fi
  1835. monthly_backup_script=/etc/cron.monthly/backupdatabasesmonthly
  1836. if ! grep -q "${database_name}" ${monthly_backup_script}; then
  1837. echo '' >> ${monthly_backup_script}
  1838. echo "# ${database_name}" >> ${monthly_backup_script}
  1839. echo "if [ -f /var/backups/${database_name}_monthly.sql ]; then" >> ${monthly_backup_script}
  1840. echo " cp -f /var/backups/${database_name}_monthly.sql /var/backups/${database_name}_2monthly.sql" >> ${monthly_backup_script}
  1841. echo 'fi' >> ${monthly_backup_script}
  1842. echo "if [ -f /var/backups/${database_name}_weekly.sql ]; then" >> ${monthly_backup_script}
  1843. echo " cp -f /var/backups/${database_name}_weekly.sql /var/backups/${database_name}_monthly.sql" >> ${monthly_backup_script}
  1844. echo 'fi' >> ${monthly_backup_script}
  1845. fi
  1846. if ! grep -q "${database_name}" /etc/cron.hourly/repair; then
  1847. echo "${PROJECT_NAME}-repair-database ${database_name}" >> /etc/cron.hourly/repair
  1848. # remove legacy stuff
  1849. sed -i 's|/usr/bin/repairdatabase redmatrix||g' /etc/cron.hourly/repair
  1850. fi
  1851. }
  1852. function install_not_on_BBB {
  1853. if grep -Fxq "install_not_on_BBB" $COMPLETION_FILE; then
  1854. return
  1855. fi
  1856. if [[ INSTALLING_ON_BBB == "yes" ]]; then
  1857. return
  1858. fi
  1859. if [ ! $LOCAL_NETWORK_STATIC_IP_ADDRESS ]; then
  1860. return
  1861. fi
  1862. echo '# The loopback network interface' > /etc/network/interfaces
  1863. echo 'auto lo' >> /etc/network/interfaces
  1864. echo 'iface lo inet loopback' >> /etc/network/interfaces
  1865. echo '' >> /etc/network/interfaces
  1866. echo '# The primary network interface' >> /etc/network/interfaces
  1867. echo 'auto eth0' >> /etc/network/interfaces
  1868. echo 'iface eth0 inet static' >> /etc/network/interfaces
  1869. echo " address $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/network/interfaces
  1870. echo ' netmask 255.255.255.0' >> /etc/network/interfaces
  1871. echo " gateway $ROUTER_IP_ADDRESS" >> /etc/network/interfaces
  1872. echo " dns-nameservers $NAMESERVER1 $NAMESERVER2" >> /etc/network/interfaces
  1873. echo '# Example to keep MAC address between reboots' >> /etc/network/interfaces
  1874. echo '#hwaddress ether DE:AD:BE:EF:CA:FE' >> /etc/network/interfaces
  1875. echo '' >> /etc/network/interfaces
  1876. echo '# The secondary network interface' >> /etc/network/interfaces
  1877. echo '#auto eth1' >> /etc/network/interfaces
  1878. echo '#iface eth1 inet dhcp' >> /etc/network/interfaces
  1879. echo '' >> /etc/network/interfaces
  1880. echo '# WiFi Example' >> /etc/network/interfaces
  1881. echo "#auto $WIFI_INTERFACE" >> /etc/network/interfaces
  1882. echo "#iface $WIFI_INTERFACE inet dhcp" >> /etc/network/interfaces
  1883. echo '# wpa-ssid "essid"' >> /etc/network/interfaces
  1884. echo '# wpa-psk "password"' >> /etc/network/interfaces
  1885. echo '' >> /etc/network/interfaces
  1886. echo '# Ethernet/RNDIS gadget (g_ether)' >> /etc/network/interfaces
  1887. echo '# ... or on host side, usbnet and random hwaddr' >> /etc/network/interfaces
  1888. echo '# Note on some boards, usb0 is automaticly setup with an init script' >> /etc/network/interfaces
  1889. echo '#iface usb0 inet static' >> /etc/network/interfaces
  1890. echo '# address 192.168.7.2' >> /etc/network/interfaces
  1891. echo '# netmask 255.255.255.0' >> /etc/network/interfaces
  1892. echo '# network 192.168.7.0' >> /etc/network/interfaces
  1893. echo '# gateway 192.168.7.1' >> /etc/network/interfaces
  1894. echo 'install_not_on_BBB' >> $COMPLETION_FILE
  1895. }
  1896. function mark_admin_user_account {
  1897. if ! grep -q "Admin user:" $COMPLETION_FILE; then
  1898. echo "Admin user:$MY_USERNAME" >> $COMPLETION_FILE
  1899. fi
  1900. }
  1901. function mark_blog_domain {
  1902. 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
  1903. return
  1904. fi
  1905. if ! grep -q "Blog domain:" $COMPLETION_FILE; then
  1906. echo "Blog domain:$FULLBLOG_DOMAIN_NAME" >> $COMPLETION_FILE
  1907. fi
  1908. }
  1909. function randomize_cron {
  1910. # The predictable default timing of Debian cron jobs might
  1911. # be exploitable knowledge. Avoid too much predictability
  1912. # by randomizing the times when cron jobs run
  1913. if grep -Fxq "randomize_cron" $COMPLETION_FILE; then
  1914. return
  1915. fi
  1916. # randomize the day on which the weekly cron job runs
  1917. randdow=$(($RANDOM%6+1))
  1918. sed -i "s|\* \* 7|* * $randdow|g" /etc/crontab
  1919. # randomize the time when the weekly cron job runs
  1920. randmin=$(($RANDOM%60))
  1921. randhr=$(($RANDOM%3+1))
  1922. sed -i "s|47 6|$randmin $randhr|g" /etc/crontab
  1923. # randomize the time when the daily cron job runs
  1924. randmin=$(($RANDOM%60))
  1925. randhr=$(($RANDOM%3+4))
  1926. sed -i "s|25 6\t\* \* \*|$randmin $randhr\t* * *|g" /etc/crontab
  1927. # randomize the time when the hourly cron job runs
  1928. randmin=$(($RANDOM%60))
  1929. sed -i "s|17 \*\t|$randmin *\t|g" /etc/crontab
  1930. # randomize monthly cron job time and day
  1931. randmin=$(($RANDOM%60))
  1932. randhr=$(($RANDOM%22+1))
  1933. randdom=$(($RANDOM%27+1))
  1934. sed -i "s|52 6\t|$randmin $randhr\t|g" /etc/crontab
  1935. sed -i "s|\t1 \* \*|\t$randdom * *|g" /etc/crontab
  1936. systemctl restart cron
  1937. echo 'randomize_cron' >> $COMPLETION_FILE
  1938. }
  1939. function get_cjdns_public_key {
  1940. if [ -f /home/$MY_USERNAME/README ]; then
  1941. if grep -q "cjdns public key" /home/$MY_USERNAME/README; then
  1942. if [ ! $CJDNS_PUBLIC_KEY ]; then
  1943. CJDNS_PUBLIC_KEY=$(cat /home/$MY_USERNAME/README | grep "cjdns public key" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1944. fi
  1945. fi
  1946. fi
  1947. }
  1948. function get_cjdns_private_key {
  1949. if [ -f /home/$MY_USERNAME/README ]; then
  1950. if grep -q "cjdns private key" /home/$MY_USERNAME/README; then
  1951. if [ ! $CJDNS_PRIVATE_KEY ]; then
  1952. CJDNS_PRIVATE_KEY=$(cat /home/$MY_USERNAME/README | grep "cjdns private key" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1953. fi
  1954. fi
  1955. fi
  1956. }
  1957. function get_cjdns_ipv6_address {
  1958. if [ -f /home/$MY_USERNAME/README ]; then
  1959. if grep -q "cjdns IPv6 address" /home/$MY_USERNAME/README; then
  1960. if [ ! $CJDNS_IPV6 ]; then
  1961. CJDNS_IPV6=$(cat /home/$MY_USERNAME/README | grep "cjdns IPv6 address" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1962. fi
  1963. fi
  1964. fi
  1965. }
  1966. function get_cjdns_port {
  1967. if [ -f /home/$MY_USERNAME/README ]; then
  1968. if grep -q "cjdns port" /home/$MY_USERNAME/README; then
  1969. if [ ! $CJDNS_PORT ]; then
  1970. CJDNS_PORT=$(cat /home/$MY_USERNAME/README | grep "cjdns port" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1971. fi
  1972. fi
  1973. fi
  1974. }
  1975. function get_cjdns_password {
  1976. if [ -f /home/$MY_USERNAME/README ]; then
  1977. if grep -q "cjdns password" /home/$MY_USERNAME/README; then
  1978. if [ ! $CJDNS_PASSWORD ]; then
  1979. CJDNS_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "cjdns password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  1980. fi
  1981. fi
  1982. fi
  1983. }
  1984. # script to automatically renew any Let's Encrypt certificates
  1985. function letsencrypt_renewals {
  1986. if [[ $ONION_ONLY != "no" ]]; then
  1987. return
  1988. fi
  1989. renewals_script=/etc/cron.monthly/letsencrypt
  1990. renewals_retry_script=/etc/cron.daily/letsencrypt
  1991. renewal_failure_msg=$'The certificate for $LETSENCRYPT_DOMAIN could not be renewed'
  1992. renewal_email_title=$'${PROJECT_NAME} Lets Encrypt certificate renewal'
  1993. # the main script tries to renew once per month
  1994. echo '#!/bin/bash' > $renewals_script
  1995. echo '' >> $renewals_script
  1996. echo "PROJECT_NAME='${PROJECT_NAME}'" >> $renewals_script
  1997. echo 'COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt' >> $renewals_script
  1998. echo '' >> $renewals_script
  1999. echo 'if [ -d /etc/letsencrypt ]; then' >> $renewals_script
  2000. echo ' if [ -f ~/letsencrypt_failed ]; then' >> $renewals_script
  2001. echo ' rm ~/letsencrypt_failed' >> $renewals_script
  2002. echo ' fi' >> $renewals_script
  2003. echo -n ' ADMIN_USERNAME=$(cat $COMPLETION_FILE | grep "Admin user" | ' >> $renewals_script
  2004. echo -n "awk -F ':' '{print " >> $renewals_script
  2005. echo -n '$2' >> $renewals_script
  2006. echo "}')" >> $renewals_script
  2007. echo ' ADMIN_EMAIL_ADDRESS=$ADMIN_USERNAME@$HOSTNAME' >> $renewals_script
  2008. echo ' for d in /etc/letsencrypt/live/*/ ; do' >> $renewals_script
  2009. echo -n ' LETSENCRYPT_DOMAIN=$(echo "$d" | ' >> $renewals_script
  2010. echo -n "awk -F '/' '{print " >> $renewals_script
  2011. echo -n '$5' >> $renewals_script
  2012. echo "}')" >> $renewals_script
  2013. echo ' if [ -f /etc/nginx/sites-available/$LETSENCRYPT_DOMAIN ]; then' >> $renewals_script
  2014. echo ' ${PROJECT_NAME}-renew-cert -h $LETSENCRYPT_DOMAIN -p letsencrypt' >> $renewals_script
  2015. echo ' if [ ! "$?" = "0" ]; then' >> $renewals_script
  2016. echo " echo \"${renewal_failure_msg}\" > ~/temp_renewletsencrypt.txt" >> $renewals_script
  2017. echo ' echo "" >> ~/temp_renewletsencrypt.txt' >> $renewals_script
  2018. echo ' ${PROJECT_NAME}-renew-cert -h $LETSENCRYPT_DOMAIN -p letsencrypt 2>> ~/temp_renewletsencrypt.txt' >> $renewals_script
  2019. echo -n " cat ~/temp_renewletsencrypt.txt | mail -s \"${renewal_email_title}\" " >> $renewals_script
  2020. echo '$ADMIN_EMAIL_ADDRESS' >> $renewals_script
  2021. echo ' rm ~/temp_renewletsencrypt.txt' >> $renewals_script
  2022. echo ' if [ ! -f ~/letsencrypt_failed ]; then' >> $renewals_script
  2023. echo ' touch ~/letsencrypt_failed' >> $renewals_script
  2024. echo ' fi' >> $renewals_script
  2025. echo ' fi' >> $renewals_script
  2026. echo ' fi' >> $renewals_script
  2027. echo ' done' >> $renewals_script
  2028. echo 'fi' >> $renewals_script
  2029. chmod +x $renewals_script
  2030. # a secondary script keeps trying to renew after a failure
  2031. echo '#!/bin/bash' > $renewals_retry_script
  2032. echo '' >> $renewals_retry_script
  2033. echo "PROJECT_NAME='${PROJECT_NAME}'" >> $renewals_retry_script
  2034. echo 'COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt' >> $renewals_retry_script
  2035. echo '' >> $renewals_retry_script
  2036. echo 'if [ -d /etc/letsencrypt ]; then' >> $renewals_retry_script
  2037. echo ' if [ -f ~/letsencrypt_failed ]; then' >> $renewals_retry_script
  2038. echo ' rm ~/letsencrypt_failed' >> $renewals_retry_script
  2039. echo -n ' ADMIN_USERNAME=$(cat $COMPLETION_FILE | grep "Admin user" | ' >> $renewals_retry_script
  2040. echo -n "awk -F ':' '{print " >> $renewals_retry_script
  2041. echo -n '$2' >> $renewals_retry_script
  2042. echo "}')" >> $renewals_retry_script
  2043. echo ' ADMIN_EMAIL_ADDRESS=$ADMIN_USERNAME@$HOSTNAME' >> $renewals_retry_script
  2044. echo ' for d in /etc/letsencrypt/live/*/ ; do' >> $renewals_retry_script
  2045. echo -n ' LETSENCRYPT_DOMAIN=$(echo "$d" | ' >> $renewals_retry_script
  2046. echo -n "awk -F '/' '{print " >> $renewals_retry_script
  2047. echo -n '$5' >> $renewals_retry_script
  2048. echo "}')" >> $renewals_retry_script
  2049. echo ' if [ -f /etc/nginx/sites-available/$LETSENCRYPT_DOMAIN ]; then' >> $renewals_retry_script
  2050. echo ' ${PROJECT_NAME}-renew-cert -h $LETSENCRYPT_DOMAIN -p letsencrypt' >> $renewals_retry_script
  2051. echo ' if [ ! "$?" = "0" ]; then' >> $renewals_retry_script
  2052. echo " echo \"${renewal_failure_msg}\" > ~/temp_renewletsencrypt.txt" >> $renewals_retry_script
  2053. echo ' echo "" >> ~/temp_renewletsencrypt.txt' >> $renewals_retry_script
  2054. echo ' ${PROJECT_NAME}-renew-cert -h $LETSENCRYPT_DOMAIN -p letsencrypt 2>> ~/temp_renewletsencrypt.txt' >> $renewals_retry_script
  2055. echo -n " cat ~/temp_renewletsencrypt.txt | mail -s \"${renewal_email_title}\" " >> $renewals_retry_script
  2056. echo '$ADMIN_EMAIL_ADDRESS' >> $renewals_retry_script
  2057. echo ' rm ~/temp_renewletsencrypt.txt' >> $renewals_retry_script
  2058. echo ' if [ ! -f ~/letsencrypt_failed ]; then' >> $renewals_retry_script
  2059. echo ' touch ~/letsencrypt_failed' >> $renewals_retry_script
  2060. echo ' fi' >> $renewals_retry_script
  2061. echo ' fi' >> $renewals_retry_script
  2062. echo ' fi' >> $renewals_retry_script
  2063. echo ' done' >> $renewals_retry_script
  2064. echo ' fi' >> $renewals_retry_script
  2065. echo 'fi' >> $renewals_retry_script
  2066. chmod +x $renewals_retry_script
  2067. }
  2068. function save_firewall_settings {
  2069. iptables-save > /etc/firewall.conf
  2070. ip6tables-save > /etc/firewall6.conf
  2071. printf '#!/bin/sh\n' > /etc/network/if-up.d/iptables
  2072. printf 'iptables-restore < /etc/firewall.conf\n' >> /etc/network/if-up.d/iptables
  2073. printf 'ip6tables-restore < /etc/firewall6.conf\n' >> /etc/network/if-up.d/iptables
  2074. chmod +x /etc/network/if-up.d/iptables
  2075. }
  2076. function enable_ipv6 {
  2077. # endure that ipv6 is enabled and can route
  2078. sed -i 's/net.ipv6.conf.all.disable_ipv6.*/net.ipv6.conf.all.disable_ipv6 = 0/g' /etc/sysctl.conf
  2079. #sed -i "s/net.ipv6.conf.all.accept_redirects.*/net.ipv6.conf.all.accept_redirects = 1/g" /etc/sysctl.conf
  2080. #sed -i "s/net.ipv6.conf.all.accept_source_route.*/net.ipv6.conf.all.accept_source_route = 1/g" /etc/sysctl.conf
  2081. sed -i "s/net.ipv6.conf.all.forwarding.*/net.ipv6.conf.all.forwarding=1/g" /etc/sysctl.conf
  2082. echo 1 > /proc/sys/net/ipv6/conf/all/forwarding
  2083. }
  2084. function mesh_cjdns {
  2085. if [[ $ENABLE_CJDNS != "yes" ]]; then
  2086. return
  2087. fi
  2088. # update to the next commit
  2089. set_repo_commit /etc/cjdns "cjdns commit" "$CJDNS_COMMIT" $CJDNS_REPO
  2090. if grep -Fxq "mesh_cjdns" $COMPLETION_FILE; then
  2091. return
  2092. fi
  2093. apt-get -y install nodejs git build-essential nmap
  2094. # if a README exists then obtain the cjdns parameters
  2095. get_cjdns_ipv6_address
  2096. get_cjdns_public_key
  2097. get_cjdns_private_key
  2098. get_cjdns_port
  2099. get_cjdns_password
  2100. # special compile settings for running ./do on the Beaglebone Black
  2101. if [[ $INSTALLING_ON_BBB == "yes" ]]; then
  2102. CFLAGS="-O2 -march=armv7-a -mtune=cortex-a8 -mfpu=neon -ftree-vectorize -ffast-math -mfloat-abi=hard -marm -Wno-error=maybe-uninitialized"
  2103. export LDFLAGS="$CFLAGS"
  2104. fi
  2105. if [ ! -d /etc/cjdns ]; then
  2106. git_clone $CJDNS_REPO /etc/cjdns
  2107. cd /etc/cjdns
  2108. git checkout $CJDNS_COMMIT -b $CJDNS_COMMIT
  2109. if ! grep -q "cjdns commit" $COMPLETION_FILE; then
  2110. echo "cjdns commit:$CJDNS_COMMIT" >> $COMPLETION_FILE
  2111. else
  2112. sed -i "s/cjdns commit.*/cjdns commit:$CJDNS_COMMIT/g" $COMPLETION_FILE
  2113. fi
  2114. ./do
  2115. if [ ! "$?" = "0" ]; then
  2116. exit 7439
  2117. fi
  2118. # create a configuration
  2119. if [ ! -f /etc/cjdns/cjdroute.conf ]; then
  2120. ./cjdroute --genconf > /etc/cjdns/cjdroute.conf
  2121. if [ ! "$?" = "0" ]; then
  2122. exit 5922
  2123. fi
  2124. fi
  2125. # create a user to run as
  2126. useradd cjdns
  2127. else
  2128. cd /etc/cjdns
  2129. git_pull $CJDNS_REPO
  2130. ./do
  2131. if [ ! "$?" = "0" ]; then
  2132. exit 9926
  2133. fi
  2134. fi
  2135. # set permissions
  2136. chown -R cjdns:cjdns /etc/cjdns
  2137. chmod 600 /etc/cjdns/cjdroute.conf
  2138. /sbin/ip tuntap add mode tun user cjdns dev cjdroute0
  2139. # insert values into the configuration file
  2140. if [ $CJDNS_PRIVATE_KEY ]; then
  2141. sed -i "s/\"privateKey\":.*/\"privateKey\": \"$CJDNS_PRIVATE_KEY\",/g" /etc/cjdns/cjdroute.conf
  2142. else
  2143. CJDNS_PRIVATE_KEY=$(cat /etc/cjdns/cjdroute.conf | grep '"privateKey"' | awk -F '"' '{print $4}' | sed -n 1p)
  2144. fi
  2145. if [ $CJDNS_PUBLIC_KEY ]; then
  2146. sed -i "s/\"publicKey\":.*/\"publicKey\": \"$CJDNS_PUBLIC_KEY\",/g" /etc/cjdns/cjdroute.conf
  2147. else
  2148. CJDNS_PUBLIC_KEY=$(cat /etc/cjdns/cjdroute.conf | grep '"publicKey"' | awk -F '"' '{print $4}' | sed -n 1p)
  2149. fi
  2150. if [ $CJDNS_IPV6 ]; then
  2151. sed -i "s/\"ipv6\":.*/\"ipv6\": \"$CJDNS_IPV6\",/g" /etc/cjdns/cjdroute.conf
  2152. else
  2153. CJDNS_IPV6=$(cat /etc/cjdns/cjdroute.conf | grep '"ipv6"' | awk -F '"' '{print $4}' | sed -n 1p)
  2154. fi
  2155. if [ $CJDNS_PASSWORD ]; then
  2156. sed -i "0,/{\"password\":.*/s//{\"password\": \"$CJDNS_PASSWORD\"}/g" /etc/cjdns/cjdroute.conf
  2157. else
  2158. CJDNS_PASSWORD=$(cat /etc/cjdns/cjdroute.conf | grep '"password"' | awk -F '"' '{print $4}' | sed -n 1p)
  2159. fi
  2160. if [ $CJDNS_PORT ]; then
  2161. sed -i "s/\"bind\": \"0.0.0.0:.*/\"bind\": \"0.0.0.0:$CJDNS_PORT\",/g" /etc/cjdns/cjdroute.conf
  2162. else
  2163. CJDNS_PORT=$(cat /etc/cjdns/cjdroute.conf | grep '"bind": "0.0.0.0:' | awk -F '"' '{print $4}' | awk -F ':' '{print $2}' | sed -n 1p)
  2164. fi
  2165. enable_ipv6
  2166. echo '#!/bin/sh -e' > /etc/init.d/cjdns
  2167. echo '### BEGIN INIT INFO' >> /etc/init.d/cjdns
  2168. echo '# hyperboria.sh - An init script (/etc/init.d/) for cjdns' >> /etc/init.d/cjdns
  2169. echo '# Provides: cjdroute' >> /etc/init.d/cjdns
  2170. echo '# Required-Start: $remote_fs $network' >> /etc/init.d/cjdns
  2171. echo '# Required-Stop: $remote_fs $network' >> /etc/init.d/cjdns
  2172. echo '# Default-Start: 2 3 4 5' >> /etc/init.d/cjdns
  2173. echo '# Default-Stop: 0 1 6' >> /etc/init.d/cjdns
  2174. echo '# Short-Description: Cjdns router' >> /etc/init.d/cjdns
  2175. echo '# Description: A routing engine designed for security, scalability, speed and ease of use.' >> /etc/init.d/cjdns
  2176. echo '# cjdns git repo: https://github.com/cjdelisle/cjdns/' >> /etc/init.d/cjdns
  2177. echo '### END INIT INFO' >> /etc/init.d/cjdns
  2178. echo '' >> /etc/init.d/cjdns
  2179. echo 'PROG="cjdroute"' >> /etc/init.d/cjdns
  2180. echo 'GIT_PATH="/etc/cjdns"' >> /etc/init.d/cjdns
  2181. echo 'PROG_PATH="/etc/cjdns"' >> /etc/init.d/cjdns
  2182. echo 'CJDNS_CONFIG="cjdroute.conf"' >> /etc/init.d/cjdns
  2183. echo 'CJDNS_USER="cjdns"' >> /etc/init.d/cjdns
  2184. echo "CJDNS_IP='$CJDNS_IPV6'" >> /etc/init.d/cjdns
  2185. echo '' >> /etc/init.d/cjdns
  2186. echo 'start() {' >> /etc/init.d/cjdns
  2187. echo ' # Start it up with the user cjdns' >> /etc/init.d/cjdns
  2188. echo ' if [ $(pgrep cjdroute | wc -l) != 0 ];' >> /etc/init.d/cjdns
  2189. echo ' then' >> /etc/init.d/cjdns
  2190. echo ' echo "cjdroute is already running. Doing nothing..."' >> /etc/init.d/cjdns
  2191. echo ' else' >> /etc/init.d/cjdns
  2192. echo ' echo " * Starting cjdroute"' >> /etc/init.d/cjdns
  2193. echo ' su -c "$PROG_PATH/$PROG < $PROG_PATH/$CJDNS_CONFIG" - $CJDNS_USER' >> /etc/init.d/cjdns
  2194. echo ' /sbin/ip addr add $CJDNS_IP/8 dev tun0' >> /etc/init.d/cjdns
  2195. echo ' /sbin/ip link set mtu 1312 dev tun0' >> /etc/init.d/cjdns
  2196. echo ' /sbin/ip link set tun0 up' >> /etc/init.d/cjdns
  2197. echo ' /sbin/ip tuntap add mode tun user cjdns dev tun0' >> /etc/init.d/cjdns
  2198. echo ' fi' >> /etc/init.d/cjdns
  2199. echo '}' >> /etc/init.d/cjdns
  2200. echo '' >> /etc/init.d/cjdns
  2201. echo 'stop() {' >> /etc/init.d/cjdns
  2202. echo '' >> /etc/init.d/cjdns
  2203. echo ' if [ $(pgrep cjdroute | wc -l) != 2 ];' >> /etc/init.d/cjdns
  2204. echo ' then' >> /etc/init.d/cjdns
  2205. echo ' echo "cjdns isnt running."' >> /etc/init.d/cjdns
  2206. echo ' else' >> /etc/init.d/cjdns
  2207. echo ' echo "Killing cjdroute"' >> /etc/init.d/cjdns
  2208. echo ' killall cjdroute' >> /etc/init.d/cjdns
  2209. echo ' fi' >> /etc/init.d/cjdns
  2210. echo '}' >> /etc/init.d/cjdns
  2211. echo '' >> /etc/init.d/cjdns
  2212. echo 'status() {' >> /etc/init.d/cjdns
  2213. echo ' if [ $(pgrep cjdroute | wc -l) != 0 ];' >> /etc/init.d/cjdns
  2214. echo ' then' >> /etc/init.d/cjdns
  2215. echo ' echo "Cjdns is running"' >> /etc/init.d/cjdns
  2216. echo ' else' >> /etc/init.d/cjdns
  2217. echo ' echo "Cjdns is not running"' >> /etc/init.d/cjdns
  2218. echo ' fi' >> /etc/init.d/cjdns
  2219. echo '}' >> /etc/init.d/cjdns
  2220. echo '' >> /etc/init.d/cjdns
  2221. echo ' update() {' >> /etc/init.d/cjdns
  2222. echo ' cd $GIT_PATH' >> /etc/init.d/cjdns
  2223. echo ' echo "Updating..."' >> /etc/init.d/cjdns
  2224. echo ' git pull' >> /etc/init.d/cjdns
  2225. echo ' ./do' >> /etc/init.d/cjdns
  2226. echo '}' >> /etc/init.d/cjdns
  2227. echo '' >> /etc/init.d/cjdns
  2228. echo '## Check to see if we are running as root first.' >> /etc/init.d/cjdns
  2229. echo 'if [ "$(id -u)" != "0" ]; then' >> /etc/init.d/cjdns
  2230. echo ' echo "This script must be run as root" 1>&2' >> /etc/init.d/cjdns
  2231. echo ' exit 1' >> /etc/init.d/cjdns
  2232. echo 'fi' >> /etc/init.d/cjdns
  2233. echo '' >> /etc/init.d/cjdns
  2234. echo 'case $1 in' >> /etc/init.d/cjdns
  2235. echo ' start)' >> /etc/init.d/cjdns
  2236. echo ' start' >> /etc/init.d/cjdns
  2237. echo ' exit 0' >> /etc/init.d/cjdns
  2238. echo ' ;;' >> /etc/init.d/cjdns
  2239. echo ' stop)' >> /etc/init.d/cjdns
  2240. echo ' stop' >> /etc/init.d/cjdns
  2241. echo ' exit 0' >> /etc/init.d/cjdns
  2242. echo ' ;;' >> /etc/init.d/cjdns
  2243. echo ' reload|restart|force-reload)' >> /etc/init.d/cjdns
  2244. echo ' stop' >> /etc/init.d/cjdns
  2245. echo ' sleep 1' >> /etc/init.d/cjdns
  2246. echo ' start' >> /etc/init.d/cjdns
  2247. echo ' exit 0' >> /etc/init.d/cjdns
  2248. echo ' ;;' >> /etc/init.d/cjdns
  2249. echo ' status)' >> /etc/init.d/cjdns
  2250. echo ' status' >> /etc/init.d/cjdns
  2251. echo ' exit 0' >> /etc/init.d/cjdns
  2252. echo ' ;;' >> /etc/init.d/cjdns
  2253. echo ' update|upgrade)' >> /etc/init.d/cjdns
  2254. echo ' update' >> /etc/init.d/cjdns
  2255. echo ' stop' >> /etc/init.d/cjdns
  2256. echo ' sleep 2' >> /etc/init.d/cjdns
  2257. echo ' start' >> /etc/init.d/cjdns
  2258. echo ' exit 0' >> /etc/init.d/cjdns
  2259. echo ' ;;' >> /etc/init.d/cjdns
  2260. echo ' **)' >> /etc/init.d/cjdns
  2261. echo ' echo "Usage: $0 (start|stop|restart|status|update)" 1>&2' >> /etc/init.d/cjdns
  2262. echo ' exit 1' >> /etc/init.d/cjdns
  2263. echo ' ;;' >> /etc/init.d/cjdns
  2264. echo 'esac' >> /etc/init.d/cjdns
  2265. chmod +x /etc/init.d/cjdns
  2266. update-rc.d cjdns defaults
  2267. service cjdns start
  2268. if [ ! "$?" = "0" ]; then
  2269. systemctl status cjdns.service
  2270. exit 8260
  2271. fi
  2272. apt-get -y install radvd
  2273. echo 'interface eth0' > /etc/radvd.conf
  2274. echo '{' >> /etc/radvd.conf
  2275. echo ' AdvSendAdvert on;' >> /etc/radvd.conf
  2276. echo ' prefix fdfc::1/64' >> /etc/radvd.conf
  2277. echo ' {' >> /etc/radvd.conf
  2278. echo ' AdvRouterAddr on;' >> /etc/radvd.conf
  2279. echo ' };' >> /etc/radvd.conf
  2280. echo '};' >> /etc/radvd.conf
  2281. systemctl restart radvd
  2282. if [ ! "$?" = "0" ]; then
  2283. systemctl status radvd.service
  2284. exit 4395
  2285. fi
  2286. if ! grep -q "# Mesh Networking (cjdns)" /etc/network/interfaces; then
  2287. echo '' >> /etc/network/interfaces
  2288. echo '# Mesh Networking (cjdns)' >> /etc/network/interfaces
  2289. echo 'iface eth0 inet6 static' >> /etc/network/interfaces
  2290. echo ' pre-up modprobe ipv6' >> /etc/network/interfaces
  2291. echo ' address fdfc:0000:0000:0000:0000:0000:0000:0001' >> /etc/network/interfaces
  2292. echo ' netmask 64' >> /etc/network/interfaces
  2293. service network-manager restart
  2294. if [ ! "$?" = "0" ]; then
  2295. systemctl status networking.service
  2296. exit 6949
  2297. fi
  2298. fi
  2299. ip6tables -A INPUT -p udp --dport $CJDNS_PORT -j ACCEPT
  2300. ip6tables -A INPUT -p tcp --dport $CJDNS_PORT -j ACCEPT
  2301. save_firewall_settings
  2302. if ! grep -q $"Mesh Networking (cjdns)" /home/$MY_USERNAME/README; then
  2303. CURRENT_IP_ADDRESS=$(ip addr show | grep "inet " | sed -n 2p | awk -F ' ' '{print $2}' | awk -F '/' '{print $1}')
  2304. echo '' >> /home/$MY_USERNAME/README
  2305. echo '' >> /home/$MY_USERNAME/README
  2306. echo $'Mesh Networking (cjdns)' >> /home/$MY_USERNAME/README
  2307. echo '=======================' >> /home/$MY_USERNAME/README
  2308. echo $"cjdns IPv6 address: $CJDNS_IPV6" >> /home/$MY_USERNAME/README
  2309. echo $"cjdns public key: $CJDNS_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  2310. echo $"cjdns private key: $CJDNS_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  2311. echo $"cjdns password: $CJDNS_PASSWORD" >> /home/$MY_USERNAME/README
  2312. echo $"cjdns port: $CJDNS_PORT" >> /home/$MY_USERNAME/README
  2313. echo '' >> /home/$MY_USERNAME/README
  2314. echo $"Forward port $CJDNS_PORT from your internet router to the ${PROJECT_NAME}" >> /home/$MY_USERNAME/README
  2315. echo '' >> /home/$MY_USERNAME/README
  2316. echo $'Below is an example of your connection credentials' >> /home/$MY_USERNAME/README
  2317. echo $'that you can give to other people so they can connect' >> /home/$MY_USERNAME/README
  2318. echo $'to you using your default password' >> /home/$MY_USERNAME/README
  2319. echo $'Adding a unique password for each user is advisable' >> /home/$MY_USERNAME/README
  2320. echo $'so that leaks can be isolated.' >> /home/$MY_USERNAME/README
  2321. echo '' >> /home/$MY_USERNAME/README
  2322. echo "\"$CURRENT_IP_ADDRESS:$CJDNS_PORT\":{\"password\":\"$CJDNS_PASSWORD\",\"publicKey\":\"$CJDNS_PUBLIC_KEY\"}" >> /home/$MY_USERNAME/README
  2323. echo '' >> /home/$MY_USERNAME/README
  2324. echo $'More is not better. 3-5 cjdns peers is good. 30 peers is bad.' >> /home/$MY_USERNAME/README
  2325. echo '' >> /home/$MY_USERNAME/README
  2326. echo $'NEVER USE A PUBLIC PEER. These degrade the network and make it centralized.' >> /home/$MY_USERNAME/README
  2327. echo $'Each node can handle many peers, but no node can handle the entire internet.' >> /home/$MY_USERNAME/README
  2328. echo $'As this network grows any public peer will simply become saturated and' >> /home/$MY_USERNAME/README
  2329. echo $'useless causing issues for the entire network.' >> /home/$MY_USERNAME/README
  2330. echo $'Please report anyone offering you a public peer as they are promoting shared' >> /home/$MY_USERNAME/README
  2331. echo $'passwords which could lead to people pretending to be you. A peering pass' >> /home/$MY_USERNAME/README
  2332. echo $'should not contain someone elses nickname or info but should contain yours' >> /home/$MY_USERNAME/README
  2333. echo $'to ensure it is not shared. It also helps when editing the conf to know who' >> /home/$MY_USERNAME/README
  2334. echo $'each password is for.' >> /home/$MY_USERNAME/README
  2335. echo '' >> /home/$MY_USERNAME/README
  2336. echo $'Possible cjdns destinations of interest:' >> /home/$MY_USERNAME/README
  2337. echo ' http://transitiontech.ca/faq' >> /home/$MY_USERNAME/README
  2338. echo ' http://cjdns.ca/hypeirc.txt' >> /home/$MY_USERNAME/README
  2339. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  2340. chmod 600 /home/$MY_USERNAME/README
  2341. fi
  2342. echo 'mesh_cjdns' >> $COMPLETION_FILE
  2343. }
  2344. function create_mirrors {
  2345. if [ -d /home/trove ]; then
  2346. userdel -r trove
  2347. fi
  2348. if grep -Fxq "create_mirrors" $COMPLETION_FILE; then
  2349. return
  2350. fi
  2351. ${PROJECT_NAME}-mirrors
  2352. echo 'create_mirrors' >> $COMPLETION_FILE
  2353. }
  2354. function mesh_cjdns_tools {
  2355. if grep -Fxq "mesh_cjdns_tools" $COMPLETION_FILE; then
  2356. return
  2357. fi
  2358. if [[ $ENABLE_CJDNS != "yes" ]]; then
  2359. return
  2360. fi
  2361. if [ ! -d /etc/cjdns ]; then
  2362. mesh_cjdns
  2363. fi
  2364. apt-get -y install golang mercurial
  2365. if [ ! -f ~/.bashrc ]; then
  2366. touch ~/.bashrc
  2367. fi
  2368. export GOPATH=/home/git/go
  2369. if [ ! -d /home/git ]; then
  2370. # add a gogs user account
  2371. adduser --disabled-login --gecos 'Gogs' git
  2372. # install Go
  2373. if ! grep -q "export GOPATH=/home/git/go" ~/.bashrc; then
  2374. echo 'export GOPATH=/home/git/go' >> ~/.bashrc
  2375. echo 'systemctl set-environment GOPATH=/home/git/go' >> ~/.bashrc
  2376. fi
  2377. if [ ! -d $GOPATH ]; then
  2378. mkdir -p $GOPATH
  2379. fi
  2380. fi
  2381. if ! grep -q "export GOPATH=" ~/.bashrc; then
  2382. echo "export GOPATH=$GOPATH" >> ~/.bashrc
  2383. fi
  2384. expected_go_path='export PATH=$PATH:'${GOPATH}'/bin'
  2385. if ! grep -q "$expected_go_path" ~/.bashrc; then
  2386. export PATH=$PATH:${GOPATH}/bin
  2387. echo "$expected_go_path" >> ~/.bashrc
  2388. fi
  2389. export PATH=$PATH:$GOPATH/bin
  2390. CJDCMD_REPO2=$(echo "$CJDCMD_REPO" | sed 's|https://||g')
  2391. go get $CJDCMD_REPO2
  2392. if [ ! -f $GOPATH/bin/cjdcmd ]; then
  2393. echo $'cjdcmd was not compiled. Check your golang installation'
  2394. exit 7439
  2395. fi
  2396. cp $GOPATH/bin/cjdcmd /usr/bin
  2397. # initialise from the cjdns config
  2398. /usr/bin/cjdcmd cjdnsadmin -file /etc/cjdns/cjdroute.conf
  2399. echo 'mesh_cjdns_tools' >> $COMPLETION_FILE
  2400. }
  2401. function install_zeronet_blog {
  2402. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  2403. return
  2404. fi
  2405. set_repo_commit /opt/zeronet/ZeroBlog "ZeroNet Blog commit" "$ZERONET_BLOG_COMMIT" $ZERONET_BLOG_REPO
  2406. if grep -Fxq "install_zeronet_blog" $COMPLETION_FILE; then
  2407. return
  2408. fi
  2409. if [ ! -f /home/$MY_USERNAME/README ]; then
  2410. touch /home/$MY_USERNAME/README
  2411. fi
  2412. if grep -q "ZeroNet Blog address" /home/$MY_USERNAME/README; then
  2413. return
  2414. fi
  2415. if [ ! -d /etc/avahi ]; then
  2416. echo $'Avahi is not installed'
  2417. exit 736
  2418. fi
  2419. ZERONET_DEFAULT_BLOG_TITLE="${MY_USERNAME}'s Blog"
  2420. cd /opt/zeronet
  2421. python zeronet.py --batch siteCreate 2> /opt/zeronet/blog.txt
  2422. if [ ! -f /opt/zeronet/blog.txt ]; then
  2423. echo $'Unable to create blog'
  2424. exit 479
  2425. fi
  2426. blog_address=$(cat blog.txt | grep "Site address" | awk -F ':' '{print $2}')
  2427. blog_private_key=$(cat blog.txt | grep "Site private key" | awk -F ':' '{print $2}')
  2428. ZERONET_BLOG_ADDRESS=${blog_address//[[:blank:]]/}
  2429. ZERONET_BLOG_PRIVATE_KEY=${blog_private_key//[[:blank:]]/}
  2430. if [ ${#ZERONET_BLOG_ADDRESS} -lt 20 ]; then
  2431. echo $"Address: $ZERONET_BLOG_ADDRESS"
  2432. echo $"Public key: $ZERONET_BLOG_PRIVATE_KEY"
  2433. echo $'Unable to create zeronet blog address'
  2434. exit 7358
  2435. fi
  2436. if [ ${#ZERONET_BLOG_PRIVATE_KEY} -lt 20 ]; then
  2437. echo $"Address: $ZERONET_BLOG_ADDRESS"
  2438. echo $"Public key: $ZERONET_BLOG_PRIVATE_KEY"
  2439. echo $'Unable to create zeronet blog private key'
  2440. exit 1639
  2441. fi
  2442. if [ ! -d "/opt/zeronet/data/$ZERONET_BLOG_ADDRESS" ]; then
  2443. echo $"Unable to find site directory: /opt/zeronet/data/$ZERONET_BLOG_ADDRESS"
  2444. exit 7638
  2445. fi
  2446. git_clone $ZERONET_BLOG_REPO ZeroBlog
  2447. if [ ! -d /opt/zeronet/ZeroBlog ]; then
  2448. echo $'ZeroBlog repo could not be cloned'
  2449. exit 6739
  2450. fi
  2451. cd /opt/zeronet/ZeroBlog
  2452. git checkout $ZERONET_BLOG_COMMIT -b $ZERONET_BLOG_COMMIT
  2453. if ! grep -q "ZeroNet Blog commit" $COMPLETION_FILE; then
  2454. echo "ZeroNet Blog commit:$ZERONET_BLOG_COMMIT" >> $COMPLETION_FILE
  2455. else
  2456. sed -i "s/ZeroNet Blog commit.*/ZeroNet Blog commit:$ZERONET_BLOG_COMMIT/g" $COMPLETION_FILE
  2457. fi
  2458. echo $"ZeroNet Blog address: $ZERONET_BLOG_ADDRESS"
  2459. echo $"ZeroNet Blog private key: $ZERONET_BLOG_PRIVATE_KEY"
  2460. cp -r /opt/zeronet/ZeroBlog/* /opt/zeronet/data/$ZERONET_BLOG_ADDRESS
  2461. if [ ! -d /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data ]; then
  2462. mkdir /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data
  2463. fi
  2464. cp /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data-default/data.json /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data
  2465. sed -i "s/MyZeroBlog/$ZERONET_DEFAULT_BLOG_TITLE/g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data/data.json
  2466. sed -i "s/My ZeroBlog./$ZERONET_DEFAULT_BLOG_TAGLINE/g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/data/data.json
  2467. sed -i "s/ZeroBlog Demo/$ZERONET_DEFAULT_BLOG_TITLE/g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/index.html
  2468. sed -i "s|<h3 class=\"description\">.*|<h3 class=\"description\">$ZERONET_DEFAULT_BLOG_TAGLINE</h3>|g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/index.html
  2469. sed -i "s/Blogging platform Demo/Blogging platform/g" /opt/zeronet/data/$ZERONET_BLOG_ADDRESS/content.json
  2470. python zeronet.py siteSign $ZERONET_BLOG_ADDRESS $ZERONET_BLOG_PRIVATE_KEY
  2471. # Add an avahi service
  2472. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /tmp/zeronet-blog.service
  2473. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /tmp/zeronet-blog.service
  2474. echo '<service-group>' >> /tmp/zeronet-blog.service
  2475. echo ' <name replace-wildcards="yes">%h ZeroNet Blog</name>' >> /tmp/zeronet-blog.service
  2476. echo ' <service>' >> /tmp/zeronet-blog.service
  2477. echo ' <type>_zeronet._udp</type>' >> /tmp/zeronet-blog.service
  2478. echo " <port>$ZERONET_PORT</port>" >> /tmp/zeronet-blog.service
  2479. echo " <txt-record>$ZERONET_URL/$ZERONET_BLOG_ADDRESS</txt-record>" >> /tmp/zeronet-blog.service
  2480. echo ' </service>' >> /tmp/zeronet-blog.service
  2481. echo '</service-group>' >> /tmp/zeronet-blog.service
  2482. cp /tmp/zeronet-blog.service /etc/avahi/services/zeronet-blog.service
  2483. if [ ! -d /home/$MY_USERNAME/.config/zeronet ]; then
  2484. mkdir -p /home/$MY_USERNAME/.config/zeronet
  2485. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.config
  2486. fi
  2487. echo "$ZERONET_URL/$ZERONET_BLOG_ADDRESS" > /home/$MY_USERNAME/.config/zeronet/myblog
  2488. if ! grep -q "ZeroNet Blog address" /home/$MY_USERNAME/README; then
  2489. echo '' >> /home/$MY_USERNAME/README
  2490. echo "ZeroNet Blog address: $ZERONET_BLOG_ADDRESS" >> /home/$MY_USERNAME/README
  2491. echo "ZeroNet Blog private key: $ZERONET_BLOG_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  2492. fi
  2493. echo 'install_zeronet_blog' >> $COMPLETION_FILE
  2494. }
  2495. function install_zeronet_mail {
  2496. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  2497. return
  2498. fi
  2499. set_repo_commit /opt/zeronet/ZeroMail "ZeroNet Mail commit" "$ZERONET_MAIL_COMMIT" $ZERONET_MAIL_REPO
  2500. if grep -Fxq "install_zeronet_mail" $COMPLETION_FILE; then
  2501. return
  2502. fi
  2503. if [ ! -f /home/$MY_USERNAME/README ]; then
  2504. touch /home/$MY_USERNAME/README
  2505. fi
  2506. if grep -q "ZeroNet Mail address" /home/$MY_USERNAME/README; then
  2507. return
  2508. fi
  2509. if [ ! -d /etc/avahi ]; then
  2510. echo 'Avahi is not installed'
  2511. exit 736
  2512. fi
  2513. ZERONET_DEFAULT_MAIL_TITLE="${MY_USERNAME}'s Mail"
  2514. cd /opt/zeronet
  2515. python zeronet.py --batch siteCreate 2> /opt/zeronet/mail.txt
  2516. if [ ! -f /opt/zeronet/mail.txt ]; then
  2517. echo $'Unable to create mail'
  2518. exit 479
  2519. fi
  2520. mail_address=$(cat mail.txt | grep "Site address" | awk -F ':' '{print $2}')
  2521. mail_private_key=$(cat mail.txt | grep "Site private key" | awk -F ':' '{print $2}')
  2522. ZERONET_MAIL_ADDRESS=${mail_address//[[:blank:]]/}
  2523. ZERONET_MAIL_PRIVATE_KEY=${mail_private_key//[[:blank:]]/}
  2524. if [ ${#ZERONET_MAIL_ADDRESS} -lt 20 ]; then
  2525. echo $"Address: $ZERONET_MAIL_ADDRESS"
  2526. echo $"Public key: $ZERONET_MAIL_PRIVATE_KEY"
  2527. echo $'Unable to create zeronet mail address'
  2528. exit 7358
  2529. fi
  2530. if [ ${#ZERONET_MAIL_PRIVATE_KEY} -lt 20 ]; then
  2531. echo $"Address: $ZERONET_MAIL_ADDRESS"
  2532. echo $"Public key: $ZERONET_MAIL_PRIVATE_KEY"
  2533. echo $'Unable to create zeronet mail private key'
  2534. exit 1639
  2535. fi
  2536. if [ ! -d "/opt/zeronet/data/$ZERONET_MAIL_ADDRESS" ]; then
  2537. echo $"Unable to find site directory: /opt/zeronet/data/$ZERONET_MAIL_ADDRESS"
  2538. exit 7638
  2539. fi
  2540. git_clone $ZERONET_MAIL_REPO ZeroMail
  2541. if [ ! -d /opt/zeronet/ZeroMail ]; then
  2542. echo $'ZeroMail repo could not be cloned'
  2543. exit 6739
  2544. fi
  2545. cd /opt/zeronet/ZeroMail
  2546. git checkout $ZERONET_MAIL_COMMIT -b $ZERONET_MAIL_COMMIT
  2547. if ! grep -q "ZeroNet Mail commit" $COMPLETION_FILE; then
  2548. echo "ZeroNet Mail commit:$ZERONET_MAIL_COMMIT" >> $COMPLETION_FILE
  2549. else
  2550. sed -i "s/ZeroNet Mail commit.*/ZeroNet Mail commit:$ZERONET_MAIL_COMMIT/g" $COMPLETION_FILE
  2551. fi
  2552. echo $"ZeroNet Mail address: $ZERONET_MAIL_ADDRESS"
  2553. echo $"ZeroNet Mail private key: $ZERONET_MAIL_PRIVATE_KEY"
  2554. cp -r /opt/zeronet/ZeroMail/* /opt/zeronet/data/$ZERONET_MAIL_ADDRESS
  2555. if [ ! -d /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data ]; then
  2556. mkdir /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data
  2557. fi
  2558. cp /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data-default/data.json /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data
  2559. sed -i "s/MyZeroMail/$ZERONET_DEFAULT_MAIL_TITLE/g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data/data.json
  2560. sed -i "s/My ZeroMail./$ZERONET_DEFAULT_MAIL_TAGLINE/g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/data/data.json
  2561. sed -i "s/ZeroMail Demo/$ZERONET_DEFAULT_MAIL_TITLE/g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/index.html
  2562. sed -i "s|<h3 class=\"description\">.*|<h3 class=\"description\">$ZERONET_DEFAULT_MAIL_TAGLINE</h3>|g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/index.html
  2563. sed -i "s/Mailging platform Demo/Mailging platform/g" /opt/zeronet/data/$ZERONET_MAIL_ADDRESS/content.json
  2564. python zeronet.py siteSign $ZERONET_MAIL_ADDRESS $ZERONET_MAIL_PRIVATE_KEY
  2565. # Add an avahi service
  2566. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /tmp/zeronet-mail.service
  2567. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /tmp/zeronet-mail.service
  2568. echo '<service-group>' >> /tmp/zeronet-mail.service
  2569. echo ' <name replace-wildcards="yes">%h ZeroNet Mail</name>' >> /tmp/zeronet-mail.service
  2570. echo ' <service>' >> /tmp/zeronet-mail.service
  2571. echo ' <type>_zeronet._udp</type>' >> /tmp/zeronet-mail.service
  2572. echo " <port>$ZERONET_PORT</port>" >> /tmp/zeronet-mail.service
  2573. echo " <txt-record>$ZERONET_URL/$ZERONET_MAIL_ADDRESS</txt-record>" >> /tmp/zeronet-mail.service
  2574. echo ' </service>' >> /tmp/zeronet-mail.service
  2575. echo '</service-group>' >> /tmp/zeronet-mail.service
  2576. cp /tmp/zeronet-mail.service /etc/avahi/services/zeronet-mail.service
  2577. if [ ! -d /home/$MY_USERNAME/.config/zeronet ]; then
  2578. mkdir -p /home/$MY_USERNAME/.config/zeronet
  2579. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.config
  2580. fi
  2581. echo "$ZERONET_URL/$ZERONET_MAIL_ADDRESS" > /home/$MY_USERNAME/.config/zeronet/mymail
  2582. if ! grep -q $"ZeroNet Mail address" /home/$MY_USERNAME/README; then
  2583. echo '' >> /home/$MY_USERNAME/README
  2584. echo $"ZeroNet Mail address: $ZERONET_MAIL_ADDRESS" >> /home/$MY_USERNAME/README
  2585. echo $"ZeroNet Mail private key: $ZERONET_MAIL_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  2586. fi
  2587. echo 'install_zeronet_mail' >> $COMPLETION_FILE
  2588. }
  2589. function install_zeronet_forum {
  2590. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  2591. return
  2592. fi
  2593. # update to the next commit
  2594. set_repo_commit /opt/zeronet/ZeroTalk "ZeroNet Forum commit" "$ZERONET_FORUM_COMMIT" $ZERONET_FORUM_REPO
  2595. if grep -Fxq "install_zeronet_forum" $COMPLETION_FILE; then
  2596. return
  2597. fi
  2598. if [ ! -f /home/$MY_USERNAME/README ]; then
  2599. touch /home/$MY_USERNAME/README
  2600. fi
  2601. if grep -q "ZeroNet Forum address" /home/$MY_USERNAME/README; then
  2602. return
  2603. fi
  2604. if [ ! -d /etc/avahi ]; then
  2605. echo $'Avahi is not installed'
  2606. exit 736
  2607. fi
  2608. ZERONET_DEFAULT_FORUM_TITLE=$"${MY_USERNAME}'s Forum"
  2609. cd /opt/zeronet
  2610. python zeronet.py --batch siteCreate 2> /opt/zeronet/forum.txt
  2611. if [ ! -f /opt/zeronet/forum.txt ]; then
  2612. echo $'Unable to create forum'
  2613. exit 479
  2614. fi
  2615. forum_address=$(cat forum.txt | grep "Site address" | awk -F ':' '{print $2}')
  2616. forum_private_key=$(cat forum.txt | grep "Site private key" | awk -F ':' '{print $2}')
  2617. ZERONET_FORUM_ADDRESS=${forum_address//[[:blank:]]/}
  2618. ZERONET_FORUM_PRIVATE_KEY=${forum_private_key//[[:blank:]]/}
  2619. if [ ${#ZERONET_FORUM_ADDRESS} -lt 20 ]; then
  2620. echo $"Address: $ZERONET_FORUM_ADDRESS"
  2621. echo $"Public key: $ZERONET_FORUM_PRIVATE_KEY"
  2622. echo $'Unable to create zeronet forum address'
  2623. exit 76352
  2624. fi
  2625. if [ ${#ZERONET_FORUM_PRIVATE_KEY} -lt 20 ]; then
  2626. echo $"Address: $ZERONET_FORUM_ADDRESS"
  2627. echo $"Public key: $ZERONET_FORUM_PRIVATE_KEY"
  2628. echo $'Unable to create zeronet forum private key'
  2629. exit 87356
  2630. fi
  2631. if [ ! -d "/opt/zeronet/data/$ZERONET_FORUM_ADDRESS" ]; then
  2632. echo $"Unable to find site directory: /opt/zeronet/data/$ZERONET_FORUM_ADDRESS"
  2633. exit 7638
  2634. fi
  2635. git_clone $ZERONET_FORUM_REPO ZeroTalk
  2636. if [ ! -d /opt/zeronet/ZeroTalk ]; then
  2637. echo $'ZeroTalk repo could not be cloned'
  2638. exit 6739
  2639. fi
  2640. git checkout $ZERONET_FORUM_COMMIT -b $ZERONET_FORUM_COMMIT
  2641. if ! grep -q "ZeroNet Forum commit" $COMPLETION_FILE; then
  2642. echo "ZeroNet Forum commit:$ZERONET_FORUM_COMMIT" >> $COMPLETION_FILE
  2643. else
  2644. sed -i "s/ZeroNet Forum commit.*/ZeroNet Forum commit:$ZERONET_FORUM_COMMIT/g" $COMPLETION_FILE
  2645. fi
  2646. echo $"Forum address: $ZERONET_FORUM_ADDRESS"
  2647. echo $"Forum private key: $ZERONET_FORUM_PRIVATE_KEY"
  2648. cp -r /opt/zeronet/ZeroTalk/* /opt/zeronet/data/$ZERONET_FORUM_ADDRESS
  2649. sed -i "s/ZeroBoard/$ZERONET_DEFAULT_FORUM_TITLE/g" /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/index.html
  2650. sed -i "s/ZeroTalk/$ZERONET_DEFAULT_FORUM_TITLE/g" /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/index.html
  2651. sed -i "s|Demo for dynamic, decentralized content publishing.|$ZERONET_DEFAULT_FORUM_TAGLINE|g" /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/index.html
  2652. sed -i 's/Messaging Board Demo/Messaging Board/g' /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/content.json
  2653. sed -i "s/ZeroBoard/$ZERONET_DEFAULT_FORUM_TITLE/g" /opt/zeronet/data/$ZERONET_FORUM_ADDRESS/content.json
  2654. python zeronet.py siteSign $ZERONET_FORUM_ADDRESS $ZERONET_FORUM_PRIVATE_KEY --inner_path data/users/content.json
  2655. # Add an avahi service
  2656. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /tmp/zeronet-forum.service
  2657. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /tmp/zeronet-forum.service
  2658. echo '<service-group>' >> /tmp/zeronet-forum.service
  2659. echo ' <name replace-wildcards="yes">%h ZeroNet Forum</name>' >> /tmp/zeronet-forum.service
  2660. echo ' <service>' >> /tmp/zeronet-forum.service
  2661. echo ' <type>_zeronet._udp</type>' >> /tmp/zeronet-forum.service
  2662. echo " <port>$ZERONET_PORT</port>" >> /tmp/zeronet-forum.service
  2663. echo " <txt-record>$ZERONET_URL/$ZERONET_FORUM_ADDRESS</txt-record>" >> /tmp/zeronet-forum.service
  2664. echo ' </service>' >> /tmp/zeronet-forum.service
  2665. echo '</service-group>' >> /tmp/zeronet-forum.service
  2666. sudo cp /tmp/zeronet-forum.service /etc/avahi/services/zeronet-forum.service
  2667. if [ ! -d /home/$MY_USERNAME/.config/zeronet ]; then
  2668. mkdir -p /home/$MY_USERNAME/.config/zeronet
  2669. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.config
  2670. fi
  2671. echo "$ZERONET_URL/$ZERONET_FORUM_ADDRESS" > /home/$MY_USERNAME/.config/zeronet/myforum
  2672. if ! grep -q $"ZeroNet Forum address" /home/$MY_USERNAME/README; then
  2673. echo '' >> /home/$MY_USERNAME/README
  2674. echo $"ZeroNet Forum address: $ZERONET_FORUM_ADDRESS" >> /home/$MY_USERNAME/README
  2675. echo $"ZeroNet Forum private key: $ZERONET_FORUM_PRIVATE_KEY" >> /home/$MY_USERNAME/README
  2676. fi
  2677. echo 'install_zeronet_forum' >> $COMPLETION_FILE
  2678. }
  2679. function install_zeronet {
  2680. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  2681. return
  2682. fi
  2683. # update to the next commit
  2684. set_repo_commit /opt/zeronet "ZeroNet commit" "$ZERONET_COMMIT" $ZERONET_REPO
  2685. if grep -Fxq "install_zeronet" $COMPLETION_FILE; then
  2686. return
  2687. fi
  2688. ${PROJECT_NAME}=mesh-install zeronet
  2689. systemctl daemon-reload
  2690. systemctl start tracker.service
  2691. systemctl start zeronet.service
  2692. echo 'mesh_zeronet' >> $COMPLETION_FILE
  2693. }
  2694. function install_vpn_tunnel {
  2695. if ! grep -q "repo.universe-factory.net" /etc/apt/sources.list; then
  2696. echo 'deb http://repo.universe-factory.net/debian/ sid main' >> /etc/apt/sources.list
  2697. gpg --keyserver pgpkeys.mit.edu --recv-key 16EF3F64CB201D9C
  2698. if [ ! "$?" = "0" ]; then
  2699. exit 76272
  2700. fi
  2701. gpg -a --export 16EF3F64CB201D9C | sudo apt-key add -
  2702. apt-get update
  2703. apt-get -y install fastd
  2704. if [ ! "$?" = "0" ]; then
  2705. exit 52026
  2706. fi
  2707. fi
  2708. }
  2709. # ath9k_htc driver
  2710. function install_atheros_wifi {
  2711. if grep -Fxq "install_atheros_wifi" $COMPLETION_FILE; then
  2712. return
  2713. fi
  2714. if [ $INSTALLING_ON_BBB != "yes" ]; then
  2715. return
  2716. fi
  2717. if [[ $ENABLE_BABEL != "yes" && $ENABLE_BATMAN != "yes" && $ENABLE_CJDNS != "yes" ]]; then
  2718. return
  2719. fi
  2720. if [ -d $INSTALL_DIR/open-ath9k-htc-firmware ]; then
  2721. return
  2722. fi
  2723. # have drivers already been installed ?
  2724. if [ -f /lib/firmware/htc_9271.fw ]; then
  2725. return
  2726. fi
  2727. apt-get -y install build-essential cmake git m4 texinfo
  2728. if [ ! -d $INSTALL_DIR ]; then
  2729. mkdir -p $INSTALL_DIR
  2730. fi
  2731. cd $INSTALL_DIR
  2732. if [ ! -d $INSTALL_DIR/open-ath9k-htc-firmware ]; then
  2733. git_clone $ATHEROS_WIFI_REPO $INSTALL_DIR/open-ath9k-htc-firmware
  2734. if [ ! "$?" = "0" ]; then
  2735. rm -rf $INSTALL_DIR/open-ath9k-htc-firmware
  2736. exit 74283
  2737. fi
  2738. fi
  2739. cd $INSTALL_DIR/open-ath9k-htc-firmware
  2740. git checkout 1.4.0
  2741. make toolchain
  2742. if [ ! "$?" = "0" ]; then
  2743. rm -rf $INSTALL_DIR/open-ath9k-htc-firmware
  2744. exit 24820
  2745. fi
  2746. make firmware
  2747. if [ ! "$?" = "0" ]; then
  2748. rm -rf $INSTALL_DIR/open-ath9k-htc-firmware
  2749. exit 63412
  2750. fi
  2751. cp target_firmware/*.fw /lib/firmware/
  2752. if [ ! "$?" = "0" ]; then
  2753. exit 74681
  2754. fi
  2755. echo 'install_atheros_wifi' >> $COMPLETION_FILE
  2756. }
  2757. function configure_avahi {
  2758. if grep -Fxq "configure_avahi" $COMPLETION_FILE; then
  2759. return
  2760. fi
  2761. # only enable avahi if we're doing mesh networking
  2762. if [[ $ENABLE_BABEL != "yes" && $ENABLE_BATMAN != "yes" && $ENABLE_CJDNS != "yes" ]]; then
  2763. return
  2764. fi
  2765. ${PROJECT_NAME}-mesh-install avahi
  2766. if [ ! "$?" = "0" ]; then
  2767. echo $'Failed to install avahi'
  2768. exit 68442
  2769. fi
  2770. if [ $DEFAULT_DOMAIN_NAME ]; then
  2771. sed -i "s|#host-name=.*|host-name=$DEFAULT_DOMAIN_NAME|g" /etc/avahi/avahi-daemon.conf
  2772. sed -i "s|host-name=.*|host-name=$DEFAULT_DOMAIN_NAME|g" /etc/avahi/avahi-daemon.conf
  2773. else
  2774. decarray=( 1 2 3 4 5 6 7 8 9 0 )
  2775. 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]}
  2776. sed -i "s|#host-name=.*|host-name=P$PEER_ID|g" /etc/avahi/avahi-daemon.conf
  2777. sed -i "s|host-name=.*|host-name=P$PEER_ID|g" /etc/avahi/avahi-daemon.conf
  2778. fi
  2779. echo 'configure_avahi' >> $COMPLETION_FILE
  2780. }
  2781. function mesh_babel {
  2782. if grep -Fxq "mesh_babel" $COMPLETION_FILE; then
  2783. return
  2784. fi
  2785. if [[ $ENABLE_BABEL != "yes" ]]; then
  2786. return
  2787. fi
  2788. ${PROJECT_NAME}-mesh-install babel
  2789. if [ ! "$?" = "0" ]; then
  2790. echo $'Failed to install babel'
  2791. exit 67242
  2792. fi
  2793. echo 'mesh_babel' >> $COMPLETION_FILE
  2794. }
  2795. function mesh_batman {
  2796. if grep -Fxq "mesh_batman" $COMPLETION_FILE; then
  2797. return
  2798. fi
  2799. if [[ $ENABLE_BATMAN != "yes" ]]; then
  2800. return
  2801. fi
  2802. ${PROJECT_NAME}-mesh-install -f batman
  2803. if [ ! "$?" = "0" ]; then
  2804. echo $'Failed to install batman'
  2805. exit 72524
  2806. fi
  2807. if ! grep -q "Mesh Networking (B.A.T.M.A.N)" /home/$MY_USERNAME/README; then
  2808. echo '' >> /home/$MY_USERNAME/README
  2809. echo '' >> /home/$MY_USERNAME/README
  2810. echo 'Mesh Networking (B.A.T.M.A.N)' >> /home/$MY_USERNAME/README
  2811. echo '=============================' >> /home/$MY_USERNAME/README
  2812. echo "Mesh ESSID: $ESSID" >> /home/$MY_USERNAME/README
  2813. echo "Mesh cell ID: $BATMAN_CELLID" >> /home/$MY_USERNAME/README
  2814. echo "Mesh wifi channel: $WIFI_CHANNEL" >> /home/$MY_USERNAME/README
  2815. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  2816. chmod 600 /home/$MY_USERNAME/README
  2817. fi
  2818. echo 'mesh_batman' >> $COMPLETION_FILE
  2819. }
  2820. function remove_instructions_from_motd {
  2821. sed -i '/## /d' /etc/motd
  2822. }
  2823. function check_hwrng {
  2824. if [[ $HWRNG_TYPE == "beaglebone" ]]; then
  2825. # If hardware random number generation was enabled then make sure that the device exists.
  2826. # if /dev/hwrng is not found then any subsequent cryptographic key generation would
  2827. # suffer from low entropy and might be insecure
  2828. if [ ! -e /dev/hwrng ]; then
  2829. ls /dev/hw*
  2830. echo $'The hardware random number generator is enabled but could not be detected on'
  2831. echo $'/dev/hwrng. There may be a problem with the installation or the Beaglebone hardware.'
  2832. exit 75
  2833. fi
  2834. fi
  2835. # If a OneRNG device was installed then verify its firmware
  2836. #check_onerng_verification
  2837. }
  2838. function get_mariadb_password {
  2839. if [ -f /home/$MY_USERNAME/README ]; then
  2840. if grep -q "MariaDB password" /home/$MY_USERNAME/README; then
  2841. if [ -f $DATABASE_PASSWORD_FILE ]; then
  2842. MARIADB_PASSWORD=$(cat $DATABASE_PASSWORD_FILE)
  2843. else
  2844. MARIADB_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2845. echo "$MARIADB_PASSWORD" > $DATABASE_PASSWORD_FILE
  2846. chmod 600 $DATABASE_PASSWORD_FILE
  2847. fi
  2848. fi
  2849. fi
  2850. }
  2851. function get_mariadb_gnusocial_admin_password {
  2852. if [ -f /home/$MY_USERNAME/README ]; then
  2853. if grep -q "MariaDB gnusocial admin password" /home/$MY_USERNAME/README; then
  2854. MICROBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB gnusocial admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2855. fi
  2856. if grep -q "Microblog administrator password" /home/$MY_USERNAME/README; then
  2857. MICROBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Microblog administrator password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2858. fi
  2859. fi
  2860. }
  2861. function get_mariadb_rss_reader_admin_password {
  2862. if [ -f /home/$MY_USERNAME/README ]; then
  2863. if grep -q "RSS reader admin password" /home/$MY_USERNAME/README; then
  2864. RSS_READER_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "RSS reader admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2865. fi
  2866. fi
  2867. }
  2868. function get_mariadb_git_admin_password {
  2869. if [ -f /home/$MY_USERNAME/README ]; then
  2870. if grep -q "Gogs admin user password" /home/$MY_USERNAME/README; then
  2871. GIT_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Gogs admin user password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2872. fi
  2873. fi
  2874. }
  2875. function get_mariadb_hubzilla_admin_password {
  2876. if [ -f /home/$MY_USERNAME/README ]; then
  2877. if grep -q "MariaDB Hubzilla admin password" /home/$MY_USERNAME/README; then
  2878. HUBZILLA_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "MariaDB Hubzilla admin password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  2879. fi
  2880. fi
  2881. }
  2882. function create_freedns_updater {
  2883. if [[ $ONION_ONLY != "no" ]]; then
  2884. return
  2885. fi
  2886. # currently inadyn doesn't work as expected with freeDNS, so this is a workaround
  2887. if grep -Fxq "create_freedns_updater" $COMPLETION_FILE; then
  2888. return
  2889. fi
  2890. if [[ $DDNS_PROVIDER != "default@freedns.afraid.org" ]]; then
  2891. return
  2892. fi
  2893. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  2894. return
  2895. fi
  2896. FREEDNS_WGET='wget -q --read-timeout=0.0 --waitretry=5 --tries=4 https://freedns.afraid.org/dynamic/update.php?'
  2897. echo '#!/bin/bash' > /usr/bin/dynamicdns
  2898. echo 'cd /tmp' >> /usr/bin/dynamicdns
  2899. if [ $DEFAULT_DOMAIN_CODE ]; then
  2900. echo "# $DEFAULT_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2901. echo "$FREEDNS_WGET$DEFAULT_DOMAIN_CODE=" >> /usr/bin/dynamicdns
  2902. fi
  2903. if [ $WIKI_CODE ]; then
  2904. if [[ $WIKI_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2905. echo "# $WIKI_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2906. echo "$FREEDNS_WGET$WIKI_CODE=" >> /usr/bin/dynamicdns
  2907. fi
  2908. fi
  2909. if [ $FULLBLOG_CODE ]; then
  2910. if [[ $FULLBLOG_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2911. echo "# $FULLBLOG_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2912. echo "$FREEDNS_WGET$FULLBLOG_CODE=" >> /usr/bin/dynamicdns
  2913. fi
  2914. fi
  2915. if [ $HUBZILLA_CODE ]; then
  2916. if [[ $HUBZILLA_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2917. echo "# $HUBZILLA_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2918. echo "$FREEDNS_WGET$HUBZILLA_CODE=" >> /usr/bin/dynamicdns
  2919. fi
  2920. fi
  2921. if [ $MICROBLOG_CODE ]; then
  2922. if [[ $MICROBLOG_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2923. echo "# $MICROBLOG_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2924. echo "$FREEDNS_WGET$MICROBLOG_CODE=" >> /usr/bin/dynamicdns
  2925. fi
  2926. fi
  2927. if [ $GIT_CODE ]; then
  2928. if [[ $GIT_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2929. echo "# $GIT_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2930. echo "$FREEDNS_WGET$GIT_CODE=" >> /usr/bin/dynamicdns
  2931. fi
  2932. fi
  2933. if [ $MEDIAGOBLIN_CODE ]; then
  2934. if [[ $MEDIAGOBLIN_CODE != "$DEFAULT_DOMAIN_CODE" ]]; then
  2935. echo "# $MEDIAGOBLIN_DOMAIN_NAME" >> /usr/bin/dynamicdns
  2936. echo "$FREEDNS_WGET$MEDIAGOBLIN_CODE=" >> /usr/bin/dynamicdns
  2937. fi
  2938. fi
  2939. echo 'exit 0' >> /usr/bin/dynamicdns
  2940. chmod 600 /usr/bin/dynamicdns
  2941. chmod +x /usr/bin/dynamicdns
  2942. if ! grep -q "/usr/bin/dynamicdns" /etc/crontab; then
  2943. echo '*/3 * * * * root /usr/bin/dynamicdns' >> /etc/crontab
  2944. systemctl restart cron
  2945. fi
  2946. echo 'create_freedns_updater' >> $COMPLETION_FILE
  2947. }
  2948. function backup_to_friends_servers {
  2949. # update crontab
  2950. echo '#!/bin/bash' > /etc/cron.daily/backuptofriends
  2951. echo "if [ -f /usr/local/bin/${PROJECT_NAME}-backup-remote ]; then" >> /etc/cron.daily/backuptofriends
  2952. echo " /usr/local/bin/${PROJECT_NAME}-backup-remote" >> /etc/cron.daily/backuptofriends
  2953. echo 'else' >> /etc/cron.daily/backuptofriends
  2954. echo " /usr/bin/${PROJECT_NAME}-backup-remote" >> /etc/cron.daily/backuptofriends
  2955. echo 'fi' >> /etc/cron.daily/backuptofriends
  2956. chmod +x /etc/cron.daily/backuptofriends
  2957. }
  2958. function remove_default_user {
  2959. # make sure you don't use the default user account
  2960. if [[ $MY_USERNAME == "debian" ]]; then
  2961. echo 'Do not use the default debian user account. Create a different user with: adduser [username]'
  2962. exit 68
  2963. fi
  2964. # remove the default debian user to prevent it from becoming an attack vector
  2965. if [ -d /home/debian ]; then
  2966. userdel -r debian
  2967. echo 'Default debian user account removed'
  2968. fi
  2969. }
  2970. function enforce_good_passwords {
  2971. # because humans are generally bad at choosing passwords
  2972. if grep -Fxq "enforce_good_passwords" $COMPLETION_FILE; then
  2973. return
  2974. fi
  2975. apt-get -y install libpam-cracklib
  2976. 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
  2977. echo 'enforce_good_passwords' >> $COMPLETION_FILE
  2978. }
  2979. function change_login_message {
  2980. if grep -Fxq "change_login_message" $COMPLETION_FILE; then
  2981. return
  2982. fi
  2983. # remove automatic motd creator if it exists
  2984. if [ -f /etc/init.d/motd ]; then
  2985. rm -f /etc/init.d/motd
  2986. fi
  2987. echo '' > /etc/motd
  2988. echo ".---. . . " >> /etc/motd
  2989. echo "| | | " >> /etc/motd
  2990. echo "|--- .--. .-. .-. .-.| .-. .--.--. |.-. .-. .--. .-. " >> /etc/motd
  2991. echo "| | (.-' (.-' ( | ( )| | | | )( )| | (.-' " >> /etc/motd
  2992. echo "' ' --' --' -' - -' ' ' -' -' -' ' - --'" >> /etc/motd
  2993. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  2994. echo $' M A I L B O X E D I T I O N' >> /etc/motd
  2995. fi
  2996. if [[ $SYSTEM_TYPE == "$VARIANT_SOCIAL" ]]; then
  2997. echo $' S O C I A L E D I T I O N' >> /etc/motd
  2998. fi
  2999. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  3000. echo $' C H A T E D I T I O N' >> /etc/motd
  3001. fi
  3002. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" ]]; then
  3003. echo $' C L O U D E D I T I O N' >> /etc/motd
  3004. fi
  3005. if [[ $SYSTEM_TYPE == "$VARIANT_WRITER" ]]; then
  3006. echo $' W R I T E R E D I T I O N ' >> /etc/motd
  3007. fi
  3008. if [[ $SYSTEM_TYPE == "$VARIANT_MEDIA" ]]; then
  3009. echo $' M E D I A E D I T I O N' >> /etc/motd
  3010. fi
  3011. if [[ $SYSTEM_TYPE == "$VARIANT_DEVELOPER" ]]; then
  3012. echo $' D E V E L O P E R E D I T I O N' >> /etc/motd
  3013. fi
  3014. echo '' >> /etc/motd
  3015. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  3016. echo $' Freedom in the Cloud' >> /etc/motd
  3017. else
  3018. echo $' Freedom in the Mesh' >> /etc/motd
  3019. fi
  3020. echo '' >> /etc/motd
  3021. echo 'change_login_message' >> $COMPLETION_FILE
  3022. }
  3023. function search_for_attached_usb_drive {
  3024. # If a USB drive is attached then search for email,
  3025. # gpg, ssh keys and emacs configuration
  3026. if grep -Fxq "search_for_attached_usb_drive" $COMPLETION_FILE; then
  3027. return
  3028. fi
  3029. if [ -b $USB_DRIVE ]; then
  3030. if [ ! -d $USB_MOUNT ]; then
  3031. echo $'Mounting USB drive'
  3032. mkdir $USB_MOUNT
  3033. mount $USB_DRIVE $USB_MOUNT
  3034. fi
  3035. 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
  3036. if [ -d $USB_MOUNT/Maildir ]; then
  3037. echo $'Maildir found on USB drive'
  3038. IMPORT_MAILDIR=$USB_MOUNT/Maildir
  3039. fi
  3040. if [ -d $USB_MOUNT/.gnupg ]; then
  3041. echo $'Importing GPG keyring'
  3042. cp -r $USB_MOUNT/.gnupg /home/$MY_USERNAME
  3043. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.gnupg
  3044. GPG_KEYS_IMPORTED="yes"
  3045. if [ ! -f /home/$MY_USERNAME/.gnupg/secring.gpg ]; then
  3046. echo $'GPG files did not copy'
  3047. exit 73529
  3048. fi
  3049. fi
  3050. if [ -f $USB_MOUNT/.procmailrc ]; then
  3051. echo $'Importing procmail settings'
  3052. cp $USB_MOUNT/.procmailrc /home/$MY_USERNAME
  3053. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  3054. fi
  3055. if [ -f $USB_MOUNT/private_key.gpg ]; then
  3056. echo $'GPG private key found on USB drive'
  3057. MY_GPG_PRIVATE_KEY=$USB_MOUNT/private_key.gpg
  3058. fi
  3059. if [ -f $USB_MOUNT/public_key.gpg ]; then
  3060. echo $'GPG public key found on USB drive'
  3061. MY_GPG_PUBLIC_KEY=$USB_MOUNT/public_key.gpg
  3062. fi
  3063. fi
  3064. if [ -d $USB_MOUNT/prosody ]; then
  3065. if [ ! -d $XMPP_DIRECTORY ]; then
  3066. mkdir $XMPP_DIRECTORY
  3067. fi
  3068. cp -r $USB_MOUNT/prosody/* $XMPP_DIRECTORY
  3069. chown -R prosody:prosody $XMPP_DIRECTORY
  3070. fi
  3071. if [ -d $USB_MOUNT/.ssh ]; then
  3072. echo $'Importing ssh keys'
  3073. cp -r $USB_MOUNT/.ssh /home/$MY_USERNAME
  3074. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.ssh
  3075. # for security delete the ssh keys from the usb drive
  3076. if [ ! -f /home/$MY_USERNAME/.ssh/id_rsa ]; then
  3077. echo $'ssh files did not copy'
  3078. exit 8
  3079. fi
  3080. fi
  3081. if [ -f $USB_MOUNT/.emacs ]; then
  3082. echo $'Importing .emacs file'
  3083. cp -f $USB_MOUNT/.emacs /home/$MY_USERNAME/.emacs
  3084. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs
  3085. fi
  3086. if [ -d $USB_MOUNT/.emacs.d ]; then
  3087. echo $'Importing .emacs.d directory'
  3088. cp -r $USB_MOUNT/.emacs.d /home/$MY_USERNAME
  3089. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs.d
  3090. fi
  3091. if [ -d $USB_MOUNT/ssl ]; then
  3092. echo $'Importing SSL certificates'
  3093. cp -r $USB_MOUNT/ssl/* /etc/ssl
  3094. chmod 640 /etc/ssl/certs/*
  3095. chmod 400 /etc/ssl/private/*
  3096. # change ownership of some certificates
  3097. if [ -d /etc/prosody ]; then
  3098. chown prosody:prosody /etc/ssl/private/xmpp.*
  3099. chown prosody:prosody /etc/ssl/certs/xmpp.*
  3100. fi
  3101. if [ -d /etc/dovecot ]; then
  3102. chown root:dovecot /etc/ssl/certs/dovecot.*
  3103. chown root:dovecot /etc/ssl/private/dovecot.*
  3104. fi
  3105. if [ -f /etc/ssl/private/exim.key ]; then
  3106. cp /etc/ssl/private/exim.key /etc/exim4
  3107. cp /etc/ssl/certs/exim.crt /etc/exim4
  3108. cp /etc/ssl/certs/exim.dhparam /etc/exim4
  3109. chown root:Debian-exim /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  3110. chmod 640 /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  3111. fi
  3112. fi
  3113. if [ -d $USB_MOUNT/personal ]; then
  3114. echo $'Importing personal directory'
  3115. cp -r $USB_MOUNT/personal /home/$MY_USERNAME
  3116. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/personal
  3117. fi
  3118. else
  3119. if [ -d $USB_MOUNT ]; then
  3120. umount $USB_MOUNT
  3121. rm -rf $USB_MOUNT
  3122. fi
  3123. echo $'No USB drive attached'
  3124. fi
  3125. echo 'search_for_attached_usb_drive' >> $COMPLETION_FILE
  3126. }
  3127. function create_repo_sources {
  3128. if grep -Fxq "create_repo_sources" $COMPLETION_FILE; then
  3129. return
  3130. fi
  3131. rm -rf /var/lib/apt/lists/*
  3132. apt-get clean
  3133. echo "deb http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION} main" > /etc/apt/sources.list
  3134. echo "deb-src http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION} main" >> /etc/apt/sources.list
  3135. echo '' >> /etc/apt/sources.list
  3136. echo "deb http://security.debian.org/ ${DEBIAN_VERSION}/updates main" >> /etc/apt/sources.list
  3137. echo "deb-src http://security.debian.org/ ${DEBIAN_VERSION}/updates main" >> /etc/apt/sources.list
  3138. echo '' >> /etc/apt/sources.list
  3139. echo "deb http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION}-updates main" >> /etc/apt/sources.list
  3140. echo "deb-src http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION}-updates main" >> /etc/apt/sources.list
  3141. echo '' >> /etc/apt/sources.list
  3142. echo "deb http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION}-backports main" >> /etc/apt/sources.list
  3143. echo "deb-src http://${DEBIAN_REPO}/debian/ ${DEBIAN_VERSION}-backports main" >> /etc/apt/sources.list
  3144. apt-get update
  3145. apt-get -y install apt-transport-https
  3146. echo 'create_repo_sources' >> $COMPLETION_FILE
  3147. }
  3148. function initial_setup {
  3149. if grep -Fxq "initial_setup" $COMPLETION_FILE; then
  3150. return
  3151. fi
  3152. apt-get -y remove --purge apache*
  3153. apt-get -y dist-upgrade
  3154. apt-get -y install ca-certificates emacs24 cpulimit
  3155. apt-get -y install cryptsetup libgfshare-bin obnam sshpass wget
  3156. apt-get -y install avahi-daemon avahi-utils avahi-discover
  3157. apt-get -y install connect-proxy
  3158. if [ ! -d $INSTALL_DIR ]; then
  3159. mkdir -p $INSTALL_DIR
  3160. fi
  3161. echo 'initial_setup' >> $COMPLETION_FILE
  3162. }
  3163. function allow_ssh_to_onion_address {
  3164. if [ ! -d /home/$MY_USERNAME/.ssh ]; then
  3165. mkdir /home/$MY_USERNAME/.ssh
  3166. fi
  3167. if [ ! -d /etc/tor ]; then
  3168. echo $'Tor not found when updating ssh'
  3169. exit 528257
  3170. fi
  3171. if ! grep -q "onion" /home/$MY_USERNAME/.ssh/config; then
  3172. echo 'Host *.onion' >> /home/$MY_USERNAME/.ssh/config
  3173. echo 'ProxyCommand connect -R remote -5 -S 127.0.0.1:9050 %h %p' >> /home/$MY_USERNAME/.ssh/config
  3174. fi
  3175. }
  3176. function install_tor {
  3177. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3178. return
  3179. fi
  3180. if grep -Fxq "install_tor" $COMPLETION_FILE; then
  3181. return
  3182. fi
  3183. apt-get -y install tor
  3184. if [ ! -f /etc/tor/torrc ]; then
  3185. echo 'Tor failed to install'
  3186. exit 38259
  3187. fi
  3188. echo 'install_tor' >> $COMPLETION_FILE
  3189. }
  3190. function resolve_dns_via_tor {
  3191. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3192. return
  3193. fi
  3194. if grep -Fxq "resolve_dns_via_tor" $COMPLETION_FILE; then
  3195. return
  3196. fi
  3197. if [ ! -f /etc/tor/torrc ]; then
  3198. echo $'tor was not installed'
  3199. exit 52952
  3200. fi
  3201. # resolve DNS via tor
  3202. if ! grep 'DNSPort 53' /etc/tor/torrc; then
  3203. echo 'DNSPort 53' >> /etc/tor/torrc
  3204. echo 'AutomapHostsOnResolve 1' >> /etc/tor/torrc
  3205. echo 'AutomapHostsSuffixes .exit,.onion' >> /etc/tor/torrc
  3206. systemctl restart tor
  3207. fi
  3208. # don't change resolv.conf
  3209. sed -i 's|, domain-name-servers||g' /etc/dhcp/dhclient.conf
  3210. # point resolv.conf to tor
  3211. echo 'nameserver 127.0.0.1:53' > /etc/resolv.conf
  3212. echo 'resolve_dns_via_tor' >> $COMPLETION_FILE
  3213. }
  3214. function enable_ssh_via_onion {
  3215. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3216. return
  3217. fi
  3218. if grep -Fxq "enable_ssh_via_onion" $COMPLETION_FILE; then
  3219. return
  3220. fi
  3221. apt-get -y install tor connect-proxy
  3222. if ! grep -q 'Host *.onion' /home/$MY_USERNAME/.ssh/config; then
  3223. if [ ! -d /home/$MY_USERNAME/.ssh ]; then
  3224. mkdir /home/$MY_USERNAME/.ssh
  3225. fi
  3226. echo 'Host *.onion' >> /home/$MY_USERNAME/.ssh/config
  3227. echo 'ProxyCommand connect -R remote -5 -S 127.0.0.1:9050 %h %p' >> /home/$MY_USERNAME/.ssh/config
  3228. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.ssh
  3229. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.ssh/config
  3230. fi
  3231. if ! grep -q 'Host *.onion' /root/.ssh/config; then
  3232. if [ ! -d /root/.ssh ]; then
  3233. mkdir /root/.ssh
  3234. fi
  3235. echo 'Host *.onion' >> /root/.ssh/config
  3236. echo 'ProxyCommand connect -R remote -5 -S 127.0.0.1:9050 %h %p' >> /root/.ssh/config
  3237. fi
  3238. echo 'enable_ssh_via_onion' >> $COMPLETION_FILE
  3239. }
  3240. function install_editor {
  3241. if grep -Fxq "install_editor" $COMPLETION_FILE; then
  3242. return
  3243. fi
  3244. update-alternatives --set editor /usr/bin/emacs24
  3245. # A minimal emacs configuration
  3246. #echo -n "(add-to-list 'load-path " > /home/$MY_USERNAME/.emacs
  3247. #echo '"~/.emacs.d/")' >> /home/$MY_USERNAME/.emacs
  3248. #echo '' >> /home/$MY_USERNAME/.emacs
  3249. echo $';; ===== Remove trailing whitepace ======================================' >> /home/$MY_USERNAME/.emacs
  3250. echo '' >> /home/$MY_USERNAME/.emacs
  3251. echo ";;(add-hook 'before-save-hook 'delete-trailing-whitespace)" >> /home/$MY_USERNAME/.emacs
  3252. echo '' >> /home/$MY_USERNAME/.emacs
  3253. echo ';; Goto a line number with CTRL-l' >> /home/$MY_USERNAME/.emacs
  3254. echo -n '(global-set-key "\C-l" ' >> /home/$MY_USERNAME/.emacs
  3255. echo "'goto-line)" >> /home/$MY_USERNAME/.emacs
  3256. echo '' >> /home/$MY_USERNAME/.emacs
  3257. echo $';; ===== Show line numbers ==============================================' >> /home/$MY_USERNAME/.emacs
  3258. echo '' >> /home/$MY_USERNAME/.emacs
  3259. echo "(add-hook 'find-file-hook (lambda () (linum-mode 1)))" >> /home/$MY_USERNAME/.emacs
  3260. echo '' >> /home/$MY_USERNAME/.emacs
  3261. echo $';; ===== Enable line wrapping in org-mode ===============================' >> /home/$MY_USERNAME/.emacs
  3262. echo '' >> /home/$MY_USERNAME/.emacs
  3263. echo " (add-hook 'org-mode-hook" >> /home/$MY_USERNAME/.emacs
  3264. echo " '(lambda ()" >> /home/$MY_USERNAME/.emacs
  3265. echo " (visual-line-mode 1)))" >> /home/$MY_USERNAME/.emacs
  3266. echo '' >> /home/$MY_USERNAME/.emacs
  3267. echo $';; ===== Enable shift select in org mode ================================' >> /home/$MY_USERNAME/.emacs
  3268. echo '' >> /home/$MY_USERNAME/.emacs
  3269. echo '(setq org-support-shift-select t)' >> /home/$MY_USERNAME/.emacs
  3270. echo '' >> /home/$MY_USERNAME/.emacs
  3271. echo $';; ===== Set standard indent to 4 rather that 4 =========================' >> /home/$MY_USERNAME/.emacs
  3272. echo '' >> /home/$MY_USERNAME/.emacs
  3273. echo '(setq standard-indent 4)' >> /home/$MY_USERNAME/.emacs
  3274. echo '(setq-default tab-width 4)' >> /home/$MY_USERNAME/.emacs
  3275. echo '(setq c-basic-offset 4)' >> /home/$MY_USERNAME/.emacs
  3276. echo '' >> /home/$MY_USERNAME/.emacs
  3277. echo $';; ===== Support Wheel Mouse Scrolling ==================================' >> /home/$MY_USERNAME/.emacs
  3278. echo '' >> /home/$MY_USERNAME/.emacs
  3279. echo '(mouse-wheel-mode t)' >> /home/$MY_USERNAME/.emacs
  3280. echo '' >> /home/$MY_USERNAME/.emacs
  3281. echo $';; ===== Place Backup Files in Specific Directory =======================' >> /home/$MY_USERNAME/.emacs
  3282. echo '' >> /home/$MY_USERNAME/.emacs
  3283. echo '(setq make-backup-files t)' >> /home/$MY_USERNAME/.emacs
  3284. echo '(setq version-control t)' >> /home/$MY_USERNAME/.emacs
  3285. echo '(setq backup-directory-alist (quote ((".*" . "~/.emacs_backups/"))))' >> /home/$MY_USERNAME/.emacs
  3286. echo '' >> /home/$MY_USERNAME/.emacs
  3287. echo $';; ===== Make Text mode the default mode for new buffers ================' >> /home/$MY_USERNAME/.emacs
  3288. echo '' >> /home/$MY_USERNAME/.emacs
  3289. echo "(setq default-major-mode 'text-mode)" >> /home/$MY_USERNAME/.emacs
  3290. echo '' >> /home/$MY_USERNAME/.emacs
  3291. echo $';; ===== Line length ====================================================' >> /home/$MY_USERNAME/.emacs
  3292. echo '' >> /home/$MY_USERNAME/.emacs
  3293. echo '(setq-default fill-column 72)' >> /home/$MY_USERNAME/.emacs
  3294. echo '' >> /home/$MY_USERNAME/.emacs
  3295. echo $';; ===== Enable Line and Column Numbering ===============================' >> /home/$MY_USERNAME/.emacs
  3296. echo '' >> /home/$MY_USERNAME/.emacs
  3297. echo '(line-number-mode 1)' >> /home/$MY_USERNAME/.emacs
  3298. echo '(column-number-mode 1)' >> /home/$MY_USERNAME/.emacs
  3299. echo '' >> /home/$MY_USERNAME/.emacs
  3300. echo $';; ===== Turn on Auto Fill mode automatically in all modes ==============' >> /home/$MY_USERNAME/.emacs
  3301. echo '' >> /home/$MY_USERNAME/.emacs
  3302. echo ';; Auto-fill-mode the the automatic wrapping of lines and insertion of' >> /home/$MY_USERNAME/.emacs
  3303. echo ';; newlines when the cursor goes over the column limit.' >> /home/$MY_USERNAME/.emacs
  3304. echo '' >> /home/$MY_USERNAME/.emacs
  3305. echo ';; This should actually turn on auto-fill-mode by default in all major' >> /home/$MY_USERNAME/.emacs
  3306. echo ';; modes. The other way to do this is to turn on the fill for specific modes' >> /home/$MY_USERNAME/.emacs
  3307. echo ';; via hooks.' >> /home/$MY_USERNAME/.emacs
  3308. echo '' >> /home/$MY_USERNAME/.emacs
  3309. echo '(setq auto-fill-mode 1)' >> /home/$MY_USERNAME/.emacs
  3310. echo '' >> /home/$MY_USERNAME/.emacs
  3311. echo $';; ===== Enable GPG encryption =========================================' >> /home/$MY_USERNAME/.emacs
  3312. echo '' >> /home/$MY_USERNAME/.emacs
  3313. echo "(require 'epa)" >> /home/$MY_USERNAME/.emacs
  3314. echo '(epa-file-enable)' >> /home/$MY_USERNAME/.emacs
  3315. cp /home/$MY_USERNAME/.emacs /root/.emacs
  3316. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs
  3317. echo 'install_editor' >> $COMPLETION_FILE
  3318. }
  3319. function enable_zram {
  3320. if grep -Fxq "enable_zram" $COMPLETION_FILE; then
  3321. return
  3322. fi
  3323. if [[ $INSTALLED_WITHIN_DOCKER == "yes" || $INSTALLING_ON_BBB != "yes" ]]; then
  3324. ${PROJECT_NAME}-zram off
  3325. return
  3326. fi
  3327. ${PROJECT_NAME}-zram on
  3328. echo 'enable_zram' >> $COMPLETION_FILE
  3329. }
  3330. function check_onerng_verification {
  3331. if grep -Fxq "check_onerng_verification" $COMPLETION_FILE; then
  3332. return
  3333. fi
  3334. if [[ $HWRNG_TYPE != "onerng" ]]; then
  3335. return
  3336. fi
  3337. echo $'Checking OneRNG firmware verification'
  3338. last_onerng_validation=$(cat /var/log/syslog.1 | grep "OneRNG: firmware verification" | awk '/./{line=$0} END{print line}')
  3339. if [[ $last_onerng_validation != *"passed OK"* ]]; then
  3340. last_onerng_validation=$(cat /var/log/syslog | grep "OneRNG: firmware verification" | awk '/./{line=$0} END{print line}')
  3341. if [[ $last_onerng_validation != *"passed OK"* ]]; then
  3342. echo $last_onerng_validation
  3343. echo $'OneRNG firmware verification failed'
  3344. exit 735026
  3345. fi
  3346. fi
  3347. echo $'OneRNG firmware verification passed'
  3348. # if haveged was previously installed then remove it
  3349. apt-get -y remove haveged
  3350. echo 'check_onerng_verification' >> $COMPLETION_FILE
  3351. }
  3352. function install_onerng {
  3353. apt-get -y install rng-tools at python-gnupg
  3354. # Move to the installation directory
  3355. if [ ! -d $INSTALL_DIR ]; then
  3356. mkdir $INSTALL_DIR
  3357. fi
  3358. cd $INSTALL_DIR
  3359. # Download the package
  3360. if [ ! -f $ONERNG_PACKAGE ]; then
  3361. wget $ONERNG_PACKAGE_DOWNLOAD
  3362. mv "$ONERNG_PACKAGE?raw=true" $ONERNG_PACKAGE
  3363. fi
  3364. if [ ! -f $ONERNG_PACKAGE ]; then
  3365. echo $"OneRNG package could not be downloaded"
  3366. exit 59249
  3367. fi
  3368. # Check the hash
  3369. hash=$(sha256sum $ONERNG_PACKAGE | awk -F ' ' '{print $1}')
  3370. if [[ $hash != $ONERNG_PACKAGE_HASH ]]; then
  3371. echo $"OneRNG package: $ONERNG_PACKAGE"
  3372. echo $"Hash does not match. This could indicate that the package has been tampered with."
  3373. echo $"OneRNG expected package hash: $ONERNG_PACKAGE_HASH"
  3374. echo $"OneRNG actual hash: $hash"
  3375. exit 25934
  3376. fi
  3377. # install the package
  3378. dpkg -i $ONERNG_PACKAGE
  3379. # Check that the install worked
  3380. if [ ! -f /etc/onerng.conf ]; then
  3381. echo $'OneRNG configuration file not found. The package may not have installed successfully.'
  3382. exit 42904
  3383. fi
  3384. dialog --title $"OneRNG Device" \
  3385. --msgbox $"Please plug in the OneRNG device" 6 40
  3386. # check rng-tools configuration
  3387. if ! grep -q "/dev/$ONERNG_DEVICE" /etc/default/rng-tools; then
  3388. echo "HRNGDEVICE=/dev/$ONERNG_DEVICE" >> /etc/default/rng-tools
  3389. fi
  3390. systemctl restart rng-tools
  3391. }
  3392. function random_number_generator {
  3393. if grep -Fxq "random_number_generator" $COMPLETION_FILE; then
  3394. return
  3395. fi
  3396. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3397. # it is assumed that docker uses the random number
  3398. # generator of the host system
  3399. return
  3400. fi
  3401. # if the hrng type has not been set but /dev/hwrng is detected
  3402. if [[ $HWRNG_TYPE != "beaglebone" ]]; then
  3403. if [ -e /dev/hwrng ]; then
  3404. HWRNG_TYPE="beaglebone"
  3405. fi
  3406. fi
  3407. case $HWRNG_TYPE in
  3408. beaglebone)
  3409. apt-get -y install rng-tools
  3410. sed -i 's|#HRNGDEVICE=/dev/hwrng|HRNGDEVICE=/dev/hwrng|g' /etc/default/rng-tools
  3411. ;;
  3412. onerng)
  3413. install_onerng
  3414. ;;
  3415. *)
  3416. apt-get -y install haveged
  3417. ;;
  3418. esac
  3419. echo 'random_number_generator' >> $COMPLETION_FILE
  3420. }
  3421. function configure_ssh {
  3422. if grep -Fxq "configure_ssh" $COMPLETION_FILE; then
  3423. return
  3424. fi
  3425. sed -i "s/Port .*/Port $SSH_PORT/g" /etc/ssh/sshd_config
  3426. sed -i 's/PermitRootLogin.*/PermitRootLogin no/g' /etc/ssh/sshd_config
  3427. sed -i 's/X11Forwarding.*/X11Forwarding no/g' /etc/ssh/sshd_config
  3428. sed -i 's/ServerKeyBits.*/ServerKeyBits 4096/g' /etc/ssh/sshd_config
  3429. sed -i 's/TCPKeepAlive.*/TCPKeepAlive no/g' /etc/ssh/sshd_config
  3430. sed -i 's|HostKey /etc/ssh/ssh_host_dsa_key|#HostKey /etc/ssh/ssh_host_dsa_key|g' /etc/ssh/sshd_config
  3431. sed -i 's|HostKey /etc/ssh/ssh_host_ecdsa_key|#HostKey /etc/ssh/ssh_host_ecdsa_key|g' /etc/ssh/sshd_config
  3432. if ! grep -q 'DebianBanner' /etc/ssh/sshd_config; then
  3433. echo 'DebianBanner no' >> /etc/ssh/sshd_config
  3434. else
  3435. sed -i 's|DebianBanner.*|DebianBanner no|g' /etc/ssh/sshd_config
  3436. fi
  3437. if grep -q 'ClientAliveInterval' /etc/ssh/sshd_config; then
  3438. sed -i 's/ClientAliveInterval.*/ClientAliveInterval 60/g' /etc/ssh/sshd_config
  3439. else
  3440. echo 'ClientAliveInterval 60' >> /etc/ssh/sshd_config
  3441. fi
  3442. if grep -q 'ClientAliveCountMax' /etc/ssh/sshd_config; then
  3443. sed -i 's/ClientAliveCountMax.*/ClientAliveCountMax 3/g' /etc/ssh/sshd_config
  3444. else
  3445. echo 'ClientAliveCountMax 3' >> /etc/ssh/sshd_config
  3446. fi
  3447. if grep -q 'Ciphers' /etc/ssh/sshd_config; then
  3448. sed -i "s|Ciphers.*|Ciphers $SSH_CIPHERS|g" /etc/ssh/sshd_config
  3449. else
  3450. echo "Ciphers $SSH_CIPHERS" >> /etc/ssh/sshd_config
  3451. fi
  3452. if grep -q 'MACs' /etc/ssh/sshd_config; then
  3453. sed -i "s|MACs.*|MACs $SSH_MACS|g" /etc/ssh/sshd_config
  3454. else
  3455. echo "MACs $SSH_MACS" >> /etc/ssh/sshd_config
  3456. fi
  3457. if grep -q 'KexAlgorithms' /etc/ssh/sshd_config; then
  3458. sed -i "s|KexAlgorithms.*|KexAlgorithms $SSH_KEX|g" /etc/ssh/sshd_config
  3459. else
  3460. echo "KexAlgorithms $SSH_KEX" >> /etc/ssh/sshd_config
  3461. fi
  3462. apt-get -y install fail2ban
  3463. echo 'configure_ssh' >> $COMPLETION_FILE
  3464. }
  3465. function configure_ssh_onion {
  3466. if grep -Fxq "configure_ssh_onion" $COMPLETION_FILE; then
  3467. return
  3468. fi
  3469. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3470. return
  3471. fi
  3472. SSH_ONION_HOSTNAME=$(add_onion_service ssh ${SSH_PORT} ${SSH_PORT})
  3473. if ! grep -q "ssh onion domain" $COMPLETION_FILE; then
  3474. echo "ssh onion domain:${SSH_ONION_HOSTNAME}" >> $COMPLETION_FILE
  3475. else
  3476. sed -i "s|ssh onion domain.*|ssh onion domain:${SSH_ONION_HOSTNAME}|g" $COMPLETION_FILE
  3477. fi
  3478. echo 'configure_ssh_onion' >> $COMPLETION_FILE
  3479. }
  3480. # see https://stribika.github.io/2015/01/04/secure-secure-shell.html
  3481. function ssh_remove_small_moduli {
  3482. awk '$5 > 2000' /etc/ssh/moduli > ~/moduli
  3483. mv ~/moduli /etc/ssh/moduli
  3484. }
  3485. function configure_ssh_client {
  3486. if grep -Fxq "configure_ssh_client" $COMPLETION_FILE; then
  3487. return
  3488. fi
  3489. #sed -i 's/# PasswordAuthentication.*/ PasswordAuthentication no/g' /etc/ssh/ssh_config
  3490. #sed -i 's/# ChallengeResponseAuthentication.*/ ChallengeResponseAuthentication no/g' /etc/ssh/ssh_config
  3491. sed -i "s/# HostKeyAlgorithms.*/ HostKeyAlgorithms $SSH_HOST_KEY_ALGORITHMS/g" /etc/ssh/ssh_config
  3492. sed -i "s/# Ciphers.*/ Ciphers $SSH_CIPHERS/g" /etc/ssh/ssh_config
  3493. sed -i "s/# MACs.*/ MACs $SSH_MACS/g" /etc/ssh/ssh_config
  3494. if ! grep -q "HostKeyAlgorithms" /etc/ssh/ssh_config; then
  3495. echo " HostKeyAlgorithms $SSH_HOST_KEY_ALGORITHMS" >> /etc/ssh/ssh_config
  3496. fi
  3497. sed -i "s/Ciphers.*/Ciphers $SSH_CIPHERS/g" /etc/ssh/ssh_config
  3498. if ! grep -q "Ciphers " /etc/ssh/ssh_config; then
  3499. echo " Ciphers $SSH_CIPHERS" >> /etc/ssh/ssh_config
  3500. fi
  3501. sed -i "s/MACs.*/MACs $SSH_MACS/g" /etc/ssh/ssh_config
  3502. if ! grep -q "MACs " /etc/ssh/ssh_config; then
  3503. echo " MACs $SSH_MACS" >> /etc/ssh/ssh_config
  3504. fi
  3505. # Create ssh keys
  3506. if [ ! -f ~/.ssh/id_ed25519 ]; then
  3507. ssh-keygen -t ed25519 -o -a 100
  3508. fi
  3509. if [ ! -f ~/.ssh/id_rsa ]; then
  3510. ssh-keygen -t rsa -b 4096 -o -a 100
  3511. fi
  3512. ssh_remove_small_moduli
  3513. echo 'configure_ssh_client' >> $COMPLETION_FILE
  3514. }
  3515. function regenerate_ssh_keys {
  3516. if grep -Fxq "regenerate_ssh_keys" $COMPLETION_FILE; then
  3517. return
  3518. fi
  3519. rm -f /etc/ssh/ssh_host_*
  3520. dpkg-reconfigure openssh-server
  3521. ssh_remove_small_moduli
  3522. systemctl restart ssh
  3523. echo 'regenerate_ssh_keys' >> $COMPLETION_FILE
  3524. }
  3525. function configure_dns {
  3526. if grep -Fxq "configure_dns" $COMPLETION_FILE; then
  3527. return
  3528. fi
  3529. echo 'domain localdomain' > /etc/resolv.conf
  3530. echo 'search localdomain' >> /etc/resolv.conf
  3531. echo "nameserver $NAMESERVER1" >> /etc/resolv.conf
  3532. echo "nameserver $NAMESERVER2" >> /etc/resolv.conf
  3533. echo 'configure_dns' >> $COMPLETION_FILE
  3534. }
  3535. function set_hostname {
  3536. DEFAULT_DOMAIN_NAME="$1"
  3537. echo "$DEFAULT_DOMAIN_NAME" > /etc/hostname
  3538. hostname $DEFAULT_DOMAIN_NAME
  3539. if grep -q "127.0.1.1" /etc/hosts; then
  3540. sed -i "s/127.0.1.1.*/127.0.1.1 $DEFAULT_DOMAIN_NAME/g" /etc/hosts
  3541. else
  3542. echo "127.0.1.1 $DEFAULT_DOMAIN_NAME" >> /etc/hosts
  3543. fi
  3544. }
  3545. function set_your_domain_name {
  3546. if grep -Fxq "set_your_domain_name" $COMPLETION_FILE; then
  3547. return
  3548. fi
  3549. set_hostname $DEFAULT_DOMAIN_NAME
  3550. echo 'set_your_domain_name' >> $COMPLETION_FILE
  3551. }
  3552. function time_synchronisation {
  3553. # mesh peers typically don't sync over the internet
  3554. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3555. return
  3556. fi
  3557. if [ -f /usr/local/bin/${PROJECT_NAME}-update-date ]; then
  3558. cp /usr/local/bin/${PROJECT_NAME}-update-date /usr/bin/updatedate
  3559. else
  3560. cp /usr/bin/${PROJECT_NAME}-update-date /usr/bin/updatedate
  3561. fi
  3562. chmod +x /usr/bin/updatedate
  3563. if grep -Fxq "time_synchronisation" $COMPLETION_FILE; then
  3564. return
  3565. fi
  3566. apt-get -y install tlsdate
  3567. apt-get -y remove ntpdate
  3568. echo '*/15 * * * * root /usr/bin/updatedate' >> /etc/crontab
  3569. systemctl restart cron
  3570. echo 'time_synchronisation' >> $COMPLETION_FILE
  3571. }
  3572. function configure_firewall {
  3573. if grep -Fxq "configure_firewall" $COMPLETION_FILE; then
  3574. return
  3575. fi
  3576. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3577. # docker does its own firewalling
  3578. return
  3579. fi
  3580. iptables -P INPUT ACCEPT
  3581. ip6tables -P INPUT ACCEPT
  3582. iptables -F
  3583. ip6tables -F
  3584. iptables -t nat -F
  3585. ip6tables -t nat -F
  3586. iptables -X
  3587. ip6tables -X
  3588. iptables -P INPUT DROP
  3589. ip6tables -P INPUT DROP
  3590. iptables -A INPUT -i lo -j ACCEPT
  3591. iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT
  3592. # Make sure incoming tcp connections are SYN packets
  3593. iptables -A INPUT -p tcp ! --syn -m state --state NEW -j DROP
  3594. # Drop packets with incoming fragments
  3595. iptables -A INPUT -f -j DROP
  3596. # Drop bogons
  3597. iptables -A INPUT -p tcp --tcp-flags ALL ALL -j DROP
  3598. iptables -A INPUT -p tcp --tcp-flags ALL FIN,PSH,URG -j DROP
  3599. iptables -A INPUT -p tcp --tcp-flags ALL SYN,RST,ACK,FIN,URG -j DROP
  3600. # Incoming malformed NULL packets:
  3601. iptables -A INPUT -p tcp --tcp-flags ALL NONE -j DROP
  3602. echo 'configure_firewall' >> $COMPLETION_FILE
  3603. }
  3604. function configure_firewall_ping {
  3605. if grep -Fxq "configure_firewall_ping" $COMPLETION_FILE; then
  3606. return
  3607. fi
  3608. # Only allow ping for mesh installs
  3609. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  3610. return
  3611. fi
  3612. iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
  3613. iptables -A OUTPUT -p icmp --icmp-type echo-reply -j ACCEPT
  3614. save_firewall_settings
  3615. echo 'configure_firewall_ping' >> $COMPLETION_FILE
  3616. }
  3617. function configure_firewall_for_voip {
  3618. 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
  3619. return
  3620. fi
  3621. if grep -Fxq "configure_firewall_for_voip" $COMPLETION_FILE; then
  3622. return
  3623. fi
  3624. if [[ $ONION_ONLY != "no" ]]; then
  3625. return
  3626. fi
  3627. iptables -A INPUT -p udp --dport $VOIP_PORT -j ACCEPT
  3628. iptables -A INPUT -p tcp --dport $VOIP_PORT -j ACCEPT
  3629. save_firewall_settings
  3630. echo 'configure_firewall_for_voip' >> $COMPLETION_FILE
  3631. }
  3632. function configure_firewall_for_voip_turn {
  3633. 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
  3634. return
  3635. fi
  3636. if grep -Fxq "configure_firewall_for_voip_turn" $COMPLETION_FILE; then
  3637. return
  3638. fi
  3639. if [[ $ONION_ONLY != "no" ]]; then
  3640. return
  3641. fi
  3642. iptables -A INPUT -p udp --dport $VOIP_TURN_PORT -j ACCEPT
  3643. iptables -A INPUT -p tcp --dport $VOIP_TURN_PORT -j ACCEPT
  3644. iptables -A INPUT -p tcp --dport $VOIP_TURN_TLS_PORT -j ACCEPT
  3645. save_firewall_settings
  3646. echo 'configure_firewall_for_voip_turn' >> $COMPLETION_FILE
  3647. }
  3648. function configure_firewall_for_sip4 {
  3649. 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
  3650. return
  3651. fi
  3652. if grep -Fxq "configure_firewall_for_sip4" $COMPLETION_FILE; then
  3653. return
  3654. fi
  3655. if [[ $ONION_ONLY != "no" ]]; then
  3656. return
  3657. fi
  3658. iptables -A INPUT -p udp --dport $SIP_PORT -j ACCEPT
  3659. iptables -A INPUT -p tcp --dport $SIP_PORT -j ACCEPT
  3660. iptables -A INPUT -p udp --dport $SIP_TLS_PORT -j ACCEPT
  3661. iptables -A INPUT -p tcp --dport $SIP_TLS_PORT -j ACCEPT
  3662. save_firewall_settings
  3663. echo 'configure_firewall_for_sip4' >> $COMPLETION_FILE
  3664. }
  3665. function configure_firewall_for_ipfs {
  3666. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  3667. return
  3668. fi
  3669. if grep -Fxq "configure_firewall_for_ipfs" $COMPLETION_FILE; then
  3670. return
  3671. fi
  3672. if [[ $ONION_ONLY != "no" ]]; then
  3673. return
  3674. fi
  3675. iptables -A INPUT -p tcp --dport $IPFS_PORT -j ACCEPT
  3676. save_firewall_settings
  3677. echo 'configure_firewall_for_ipfs' >> $COMPLETION_FILE
  3678. }
  3679. function configure_firewall_for_avahi {
  3680. if grep -Fxq "configure_firewall_for_avahi" $COMPLETION_FILE; then
  3681. return
  3682. fi
  3683. iptables -A INPUT -p tcp --dport 548 -j ACCEPT
  3684. iptables -A INPUT -p udp --dport 548 -j ACCEPT
  3685. iptables -A INPUT -p tcp --dport 5353 -j ACCEPT
  3686. iptables -A INPUT -p udp --dport 5353 -j ACCEPT
  3687. iptables -A INPUT -p tcp --dport 5354 -j ACCEPT
  3688. iptables -A INPUT -p udp --dport 5354 -j ACCEPT
  3689. save_firewall_settings
  3690. echo 'configure_firewall_for_avahi' >> $COMPLETION_FILE
  3691. }
  3692. function configure_firewall_for_cjdns {
  3693. if grep -Fxq "configure_firewall_for_cjdns" $COMPLETION_FILE; then
  3694. return
  3695. fi
  3696. if [[ $ENABLE_CJDNS != "yes" ]]; then
  3697. return
  3698. fi
  3699. ip6tables -t nat -A POSTROUTING -o tun0 -j MASQUERADE
  3700. ip6tables -A FORWARD -i tun0 -o eth0 -m state --state RELATED,ESTABLISHED -j ACCEPT
  3701. save_firewall_settings
  3702. echo 'configure_firewall_for_cjdns' >> $COMPLETION_FILE
  3703. }
  3704. function configure_firewall_for_batman {
  3705. if grep -Fxq "configure_firewall_for_batman" $COMPLETION_FILE; then
  3706. return
  3707. fi
  3708. if [[ $ENABLE_BATMAN != "yes" ]]; then
  3709. return
  3710. fi
  3711. save_firewall_settings
  3712. echo 'configure_firewall_for_batman' >> $COMPLETION_FILE
  3713. }
  3714. function configure_firewall_for_babel {
  3715. if grep -Fxq "configure_firewall_for_babel" $COMPLETION_FILE; then
  3716. return
  3717. fi
  3718. if [[ $ENABLE_BABEL != "yes" ]]; then
  3719. return
  3720. fi
  3721. iptables -A INPUT -i $WIFI_INTERFACE -p udp --dport $BABEL_PORT -j ACCEPT
  3722. save_firewall_settings
  3723. echo 'configure_firewall_for_babel' >> $COMPLETION_FILE
  3724. }
  3725. function configure_firewall_for_zeronet {
  3726. if grep -Fxq "configure_firewall_for_zeronet" $COMPLETION_FILE; then
  3727. return
  3728. fi
  3729. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  3730. return
  3731. fi
  3732. iptables -A INPUT -i $WIFI_INTERFACE -p udp --dport $ZERONET_PORT -j ACCEPT
  3733. iptables -A INPUT -i $WIFI_INTERFACE -p tcp --dport $ZERONET_PORT -j ACCEPT
  3734. iptables -A INPUT -i $WIFI_INTERFACE -p udp --dport $TRACKER_PORT -j ACCEPT
  3735. iptables -A INPUT -i $WIFI_INTERFACE -p tcp --dport $TRACKER_PORT -j ACCEPT
  3736. iptables -A INPUT -i $WIFI_INTERFACE -p udp --dport 1900 -j ACCEPT
  3737. save_firewall_settings
  3738. echo 'configure_firewall_for_zeronet' >> $COMPLETION_FILE
  3739. }
  3740. function configure_firewall_for_dlna {
  3741. if grep -Fxq "configure_firewall_for_dlna" $COMPLETION_FILE; then
  3742. return
  3743. fi
  3744. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3745. # docker does its own firewalling
  3746. return
  3747. fi
  3748. if [[ $SYSTEM_TYPE == "$VARIANT_CLOUD" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_WRITER" || $SYSTEM_TYPE == "$VARIANT_SOCIAL" ]]; then
  3749. return
  3750. fi
  3751. iptables -A INPUT -p udp --dport 1900 -j ACCEPT
  3752. iptables -A INPUT -p tcp --dport 8200 -j ACCEPT
  3753. save_firewall_settings
  3754. echo 'configure_firewall_for_dlna' >> $COMPLETION_FILE
  3755. }
  3756. function configure_firewall_for_dns {
  3757. if grep -Fxq "configure_firewall_for_dns" $COMPLETION_FILE; then
  3758. return
  3759. fi
  3760. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3761. # docker does its own firewalling
  3762. return
  3763. fi
  3764. iptables -A INPUT -p udp -m udp --dport 1024:65535 --sport 53 -j ACCEPT
  3765. save_firewall_settings
  3766. echo 'configure_firewall_for_dns' >> $COMPLETION_FILE
  3767. }
  3768. function configure_firewall_for_xmpp {
  3769. if [ ! -d /etc/prosody ]; then
  3770. return
  3771. fi
  3772. if grep -Fxq "configure_firewall_for_xmpp" $COMPLETION_FILE; then
  3773. return
  3774. fi
  3775. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3776. # docker does its own firewalling
  3777. return
  3778. fi
  3779. if [[ $ONION_ONLY != "no" ]]; then
  3780. return
  3781. fi
  3782. iptables -A INPUT -p tcp --dport 5222:5223 -j ACCEPT
  3783. iptables -A INPUT -p tcp --dport 5269 -j ACCEPT
  3784. iptables -A INPUT -p tcp --dport 5280:5281 -j ACCEPT
  3785. save_firewall_settings
  3786. echo 'configure_firewall_for_xmpp' >> $COMPLETION_FILE
  3787. }
  3788. function configure_firewall_for_irc {
  3789. if [ ! -d /etc/ngircd ]; then
  3790. return
  3791. fi
  3792. if grep -Fxq "configure_firewall_for_irc" $COMPLETION_FILE; then
  3793. return
  3794. fi
  3795. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3796. # docker does its own firewalling
  3797. return
  3798. fi
  3799. if [[ $ONION_ONLY != "no" ]]; then
  3800. return
  3801. fi
  3802. iptables -A INPUT -p tcp --dport $IRC_PORT -j ACCEPT
  3803. iptables -I INPUT -p tcp --dport 1024:65535 --sport $IRC_PORT -j ACCEPT
  3804. save_firewall_settings
  3805. echo 'configure_firewall_for_irc' >> $COMPLETION_FILE
  3806. }
  3807. function configure_firewall_for_ftp {
  3808. if grep -Fxq "configure_firewall_for_ftp" $COMPLETION_FILE; then
  3809. return
  3810. fi
  3811. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3812. # docker does its own firewalling
  3813. return
  3814. fi
  3815. if [[ $ONION_ONLY != "no" ]]; then
  3816. return
  3817. fi
  3818. iptables -I INPUT -p tcp --dport 1024:65535 --sport 20:21 -j ACCEPT
  3819. save_firewall_settings
  3820. echo 'configure_firewall_for_ftp' >> $COMPLETION_FILE
  3821. }
  3822. function configure_firewall_for_web_access {
  3823. if grep -Fxq "configure_firewall_for_web_access" $COMPLETION_FILE; then
  3824. return
  3825. fi
  3826. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3827. # docker does its own firewalling
  3828. return
  3829. fi
  3830. if [[ $ONION_ONLY != "no" ]]; then
  3831. return
  3832. fi
  3833. iptables -A INPUT -p tcp --dport 32768:61000 --sport 80 -j ACCEPT
  3834. iptables -A INPUT -p tcp --dport 32768:61000 --sport 443 -j ACCEPT
  3835. save_firewall_settings
  3836. echo 'configure_firewall_for_web_access' >> $COMPLETION_FILE
  3837. }
  3838. function configure_firewall_for_web_server {
  3839. if grep -Fxq "configure_firewall_for_web_server" $COMPLETION_FILE; then
  3840. return
  3841. fi
  3842. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3843. # docker does its own firewalling
  3844. return
  3845. fi
  3846. if [[ $ONION_ONLY != "no" ]]; then
  3847. return
  3848. fi
  3849. iptables -A INPUT -p tcp --dport 80 -j ACCEPT
  3850. iptables -A INPUT -p tcp --dport 443 -j ACCEPT
  3851. save_firewall_settings
  3852. echo 'configure_firewall_for_web_server' >> $COMPLETION_FILE
  3853. }
  3854. function configure_firewall_for_tox {
  3855. if grep -Fxq "configure_firewall_for_tox" $COMPLETION_FILE; then
  3856. return
  3857. fi
  3858. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3859. # docker does its own firewalling
  3860. return
  3861. fi
  3862. if [[ $ONION_ONLY != "no" ]]; then
  3863. return
  3864. fi
  3865. iptables -A INPUT -p tcp --dport $TOX_PORT -j ACCEPT
  3866. save_firewall_settings
  3867. echo 'configure_firewall_for_tox' >> $COMPLETION_FILE
  3868. }
  3869. function configure_firewall_for_ssh {
  3870. if grep -Fxq "configure_firewall_for_ssh" $COMPLETION_FILE; then
  3871. return
  3872. fi
  3873. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3874. # docker does its own firewalling
  3875. return
  3876. fi
  3877. iptables -A INPUT -p tcp --dport 22 -j ACCEPT
  3878. iptables -A INPUT -p tcp --dport $SSH_PORT -j ACCEPT
  3879. save_firewall_settings
  3880. echo 'configure_firewall_for_ssh' >> $COMPLETION_FILE
  3881. }
  3882. function configure_firewall_for_git {
  3883. if grep -Fxq "configure_firewall_for_git" $COMPLETION_FILE; then
  3884. return
  3885. fi
  3886. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3887. # docker does its own firewalling
  3888. return
  3889. fi
  3890. if [[ $ONION_ONLY != "no" ]]; then
  3891. return
  3892. fi
  3893. iptables -A INPUT -p tcp --dport 9418 -j ACCEPT
  3894. save_firewall_settings
  3895. echo 'configure_firewall_for_git' >> $COMPLETION_FILE
  3896. }
  3897. function configure_firewall_for_email {
  3898. 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
  3899. return
  3900. fi
  3901. if grep -Fxq "configure_firewall_for_email" $COMPLETION_FILE; then
  3902. return
  3903. fi
  3904. if [[ $INSTALLED_WITHIN_DOCKER == "yes" ]]; then
  3905. # docker does its own firewalling
  3906. return
  3907. fi
  3908. if [[ $ONION_ONLY != "no" ]]; then
  3909. return
  3910. fi
  3911. iptables -A INPUT -p tcp --dport 25 -j ACCEPT
  3912. iptables -A INPUT -p tcp --dport 587 -j ACCEPT
  3913. iptables -A INPUT -p tcp --dport 465 -j ACCEPT
  3914. iptables -A INPUT -p tcp --dport 993 -j ACCEPT
  3915. save_firewall_settings
  3916. echo 'configure_firewall_for_email' >> $COMPLETION_FILE
  3917. }
  3918. function configure_internet_protocol {
  3919. if grep -Fxq "configure_internet_protocol" $COMPLETION_FILE; then
  3920. return
  3921. fi
  3922. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3923. return
  3924. fi
  3925. sed -i "s/#net.ipv4.tcp_syncookies=1/net.ipv4.tcp_syncookies=1/g" /etc/sysctl.conf
  3926. sed -i "s/#net.ipv4.conf.all.accept_redirects = 0/net.ipv4.conf.all.accept_redirects = 0/g" /etc/sysctl.conf
  3927. sed -i "s/#net.ipv6.conf.all.accept_redirects = 0/net.ipv6.conf.all.accept_redirects = 0/g" /etc/sysctl.conf
  3928. sed -i "s/#net.ipv4.conf.all.send_redirects = 0/net.ipv4.conf.all.send_redirects = 0/g" /etc/sysctl.conf
  3929. sed -i "s/#net.ipv4.conf.all.accept_source_route = 0/net.ipv4.conf.all.accept_source_route = 0/g" /etc/sysctl.conf
  3930. sed -i "s/#net.ipv6.conf.all.accept_source_route = 0/net.ipv6.conf.all.accept_source_route = 0/g" /etc/sysctl.conf
  3931. sed -i "s/#net.ipv4.conf.default.rp_filter=1/net.ipv4.conf.default.rp_filter=1/g" /etc/sysctl.conf
  3932. sed -i "s/#net.ipv4.conf.all.rp_filter=1/net.ipv4.conf.all.rp_filter=1/g" /etc/sysctl.conf
  3933. sed -i "s/#net.ipv4.ip_forward=1/net.ipv4.ip_forward=0/g" /etc/sysctl.conf
  3934. sed -i "s/#net.ipv6.conf.all.forwarding=1/net.ipv6.conf.all.forwarding=0/g" /etc/sysctl.conf
  3935. if ! grep -q "ignore pings" /etc/sysctl.conf; then
  3936. echo '# ignore pings' >> /etc/sysctl.conf
  3937. echo 'net.ipv4.icmp_echo_ignore_all = 1' >> /etc/sysctl.conf
  3938. echo 'net.ipv6.icmp_echo_ignore_all = 1' >> /etc/sysctl.conf
  3939. fi
  3940. if ! grep -q "disable ipv6" /etc/sysctl.conf; then
  3941. echo '# disable ipv6' >> /etc/sysctl.conf
  3942. echo 'net.ipv6.conf.all.disable_ipv6 = 1' >> /etc/sysctl.conf
  3943. fi
  3944. if ! grep -q "net.ipv4.tcp_synack_retries" /etc/sysctl.conf; then
  3945. echo 'net.ipv4.tcp_synack_retries = 2' >> /etc/sysctl.conf
  3946. echo 'net.ipv4.tcp_syn_retries = 1' >> /etc/sysctl.conf
  3947. fi
  3948. if ! grep -q "keepalive" /etc/sysctl.conf; then
  3949. echo '# keepalive' >> /etc/sysctl.conf
  3950. echo 'net.ipv4.tcp_keepalive_probes = 9' >> /etc/sysctl.conf
  3951. echo 'net.ipv4.tcp_keepalive_intvl = 75' >> /etc/sysctl.conf
  3952. echo 'net.ipv4.tcp_keepalive_time = 7200' >> /etc/sysctl.conf
  3953. fi
  3954. echo 'configure_internet_protocol' >> $COMPLETION_FILE
  3955. }
  3956. function install_command_line_browser {
  3957. if grep -Fxq "install_command_line_browser" $COMPLETION_FILE; then
  3958. return
  3959. fi
  3960. apt-get -y install elinks
  3961. # set the home page
  3962. if ! grep -q "WWW_HOME" /home/$MY_USERNAME/.bashrc; then
  3963. if ! grep -q 'control' /home/$MY_USERNAME/.bashrc; then
  3964. echo "export WWW_HOME=$DEFAULT_SEARCH" >> /home/$MY_USERNAME/.bashrc
  3965. else
  3966. sed -i "/control/i export WWW_HOME=$DEFAULT_SEARCH" /home/$MY_USERNAME/.bashrc
  3967. fi
  3968. fi
  3969. echo 'install_command_line_browser' >> $COMPLETION_FILE
  3970. }
  3971. function configure_email {
  3972. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  3973. return
  3974. fi
  3975. if grep -Fxq "configure_email" $COMPLETION_FILE; then
  3976. return
  3977. fi
  3978. apt-get -y remove postfix
  3979. apt-get -y install exim4 sasl2-bin swaks libnet-ssleay-perl procmail xinetd
  3980. if [ ! -d /etc/exim4 ]; then
  3981. echo $"ERROR: Exim does not appear to have installed. $CHECK_MESSAGE"
  3982. exit 48
  3983. fi
  3984. onion_service_name='email'
  3985. if [ ! -d /var/lib/tor ]; then
  3986. echo $"No Tor installation found. ${onion_service_name} onion site cannot be configured."
  3987. exit 877367
  3988. fi
  3989. if ! grep -q "hidden_service_${onion_service_name}" /etc/tor/torrc; then
  3990. echo "HiddenServiceDir /var/lib/tor/hidden_service_${onion_service_name}/" >> /etc/tor/torrc
  3991. echo 'HiddenServicePort 25 127.0.0.1:25' >> /etc/tor/torrc
  3992. echo 'HiddenServicePort 587 127.0.0.1:587' >> /etc/tor/torrc
  3993. echo 'HiddenServicePort 465 127.0.0.1:465' >> /etc/tor/torrc
  3994. echo 'HiddenServicePort 993 127.0.0.1:993' >> /etc/tor/torrc
  3995. echo $"Added onion site for ${onion_service_name}"
  3996. fi
  3997. systemctl restart tor
  3998. wait_for_onion_service ${onion_service_name}
  3999. if [ ! -f /var/lib/tor/hidden_service_${onion_service_name}/hostname ]; then
  4000. echo $"${onion_service_name} onion site hostname not found"
  4001. exit 76362
  4002. fi
  4003. EMAIL_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_${onion_service_name}/hostname)
  4004. if [[ $ONION_ONLY != "no" ]]; then
  4005. set_hostname ${EMAIL_ONION_HOSTNAME}
  4006. MY_EMAIL_ADDRESS=${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}
  4007. fi
  4008. if ! grep -q "Email onion domain" $COMPLETION_FILE; then
  4009. echo "Email onion domain:${EMAIL_ONION_HOSTNAME}" >> $COMPLETION_FILE
  4010. else
  4011. sed -i "s|Email onion domain.*|Email onion domain:${EMAIL_ONION_HOSTNAME}|g" $COMPLETION_FILE
  4012. fi
  4013. # see https://github.com/petterreinholdtsen/exim4-smtorp
  4014. echo '# tor stuff first' > /etc/exim4/conf.d/router/100_exim4-smtorp
  4015. echo '#' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4016. echo '# if were submitting mail *from* a .tor/.onion address,' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4017. echo '# make sure any header lines that may give us away is' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4018. echo '# stripped out, and add a new, cryptic Message-ID.' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4019. echo '# In address_data we store the name we should HELO as.' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4020. echo 'tor_to_any:' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4021. echo ' debug_print = "R: manualroute from .onion to $local_part@$domain"' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4022. echo ' driver = manualroute' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4023. echo ' domains = ! +local_domains' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4024. echo ' condition = ${if match {$sender_address_domain}{\N.*\.(onion|tor)$\N}}' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4025. echo ' address_data = $sender_address_domain' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4026. echo ' transport = remote_smtp_onion' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4027. echo ' self = send' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4028. echo ' route_list = * localhost' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4029. echo ' headers_remove = Received:Message-ID:X-Mailer:User-Agent' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4030. echo ' headers_add = Message-ID: <${lc:${sha1:$message_id}}@$sender_address_domain>' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4031. echo '' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4032. echo '# this catches the case where were submitting mail' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4033. echo '# from a regular email address where we dont need to' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4034. echo '# rewrite any headers' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4035. echo 'any_to_tor:' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4036. echo ' debug_print = "R: manualroute for $local_part@$domain"' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4037. echo ' driver = manualroute' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4038. echo ' domains = ! +local_domains' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4039. echo ' transport = remote_smtp_onion' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4040. echo ' self = send' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4041. echo ' route_list = *.onion localhost ; *.tor localhost' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4042. echo ' address_data = $smtp_active_hostname' >> /etc/exim4/conf.d/router/100_exim4-smtorp
  4043. echo 'remote_smtp_onion:' > /etc/exim4/conf.d/transport/100_exim4-smtorp
  4044. echo ' debug_print = "T: remote_smtp_onion for $local_part@$original_domain"' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4045. echo ' driver = smtp' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4046. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4047. echo ' # set helo_data to where we want to connect to,' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4048. echo ' # for the proxy program tor-smtp' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4049. echo ' helo_data = "$address_data $original_domain"' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4050. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4051. echo ' # wherever we configured our script at' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4052. echo ' port = 12668' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4053. echo '' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4054. echo ' # cannot use TLS otherwise it will EHLO again!!' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4055. echo ' hosts_avoid_tls = *' >> /etc/exim4/conf.d/transport/100_exim4-smtorp
  4056. if [ ! -d $INSTALL_DIR ]; then
  4057. mkdir -p $INSTALL_DIR
  4058. fi
  4059. cd $INSTALL_DIR
  4060. git_clone $EXIM_ONION_REPO $INSTALL_DIR/exim4-smtorp
  4061. cd $INSTALL_DIR/exim4-smtorp/tor-smtp
  4062. make
  4063. if [ ! -f $INSTALL_DIR/exim4-smtorp/tor-smtp/tor-smtp ]; then
  4064. echo $'Unable to make tor smtp transport'
  4065. exit 52629
  4066. fi
  4067. if [ ! -d /usr/lib/exim4-smtorp ]; then
  4068. mkdir /usr/lib/exim4-smtorp
  4069. fi
  4070. cp $INSTALL_DIR/exim4-smtorp/tor-smtp/tor-smtp /usr/lib/exim4-smtorp/tor-smtp
  4071. if [ ! -f /usr/lib/exim4-smtorp/tor-smtp ]; then
  4072. echo $'Unable to copy tor-smtp'
  4073. exit 83503
  4074. fi
  4075. cp $INSTALL_DIR/exim4-smtorp/xinetd /etc/xinetd.d/tor-smtp
  4076. if [ ! -f /etc/xinetd.d/tor-smtp ]; then
  4077. echo $'Unable to copy to xinetd.d'
  4078. exit 835954
  4079. fi
  4080. systemctl restart xinetd
  4081. # configure for Maildir format
  4082. sed -i 's/MAIL_DIR/#MAIL_DIR/g' /etc/login.defs
  4083. sed -i 's|#MAIL_FILE.*|MAIL_FILE Maildir/|g' /etc/login.defs
  4084. if ! grep -q "export MAIL" /etc/profile; then
  4085. echo 'export MAIL=~/Maildir' >> /etc/profile
  4086. fi
  4087. sed -i 's|pam_mail.so standard|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/login
  4088. sed -i 's|pam_mail.so standard noenv|pam_mail.so dir=~/Maildir standard|g' /etc/pam.d/sshd
  4089. sed -i 's|pam_mail.so nopen|pam_mail.so dir=~/Maildir nopen|g' /etc/pam.d/su
  4090. echo 'dc_eximconfig_configtype="internet"' > /etc/exim4/update-exim4.conf.conf
  4091. if [[ $ONION_ONLY == "no" ]]; then
  4092. # both ICANN and onion domains
  4093. echo "dc_other_hostnames='${DEFAULT_DOMAIN_NAME};${EMAIL_ONION_HOSTNAME}'" >> /etc/exim4/update-exim4.conf.conf
  4094. else
  4095. echo "dc_other_hostnames='${EMAIL_ONION_HOSTNAME}'" >> /etc/exim4/update-exim4.conf.conf
  4096. fi
  4097. echo "dc_local_interfaces=''" >> /etc/exim4/update-exim4.conf.conf
  4098. echo "dc_readhost=''" >> /etc/exim4/update-exim4.conf.conf
  4099. echo "dc_relay_domains=''" >> /etc/exim4/update-exim4.conf.conf
  4100. echo "dc_minimaldns='false'" >> /etc/exim4/update-exim4.conf.conf
  4101. RELAY_NETS='192.168.1.0/24'
  4102. if [ $LOCAL_NETWORK_STATIC_IP_ADDRESS ]; then
  4103. RELAY_NETS=$(echo $LOCAL_NETWORK_STATIC_IP_ADDRESS | awk -F '.' '{print $1 "." $2 "." $3 ".0/24"}')
  4104. fi
  4105. echo "dc_relay_nets='$RELAY_NETS'" >> /etc/exim4/update-exim4.conf.conf
  4106. echo "dc_smarthost=''" >> /etc/exim4/update-exim4.conf.conf
  4107. echo "CFILEMODE='644'" >> /etc/exim4/update-exim4.conf.conf
  4108. echo "dc_use_split_config='false'" >> /etc/exim4/update-exim4.conf.conf
  4109. echo "dc_hide_mailname=''" >> /etc/exim4/update-exim4.conf.conf
  4110. echo "dc_mailname_in_oh='true'" >> /etc/exim4/update-exim4.conf.conf
  4111. echo "dc_localdelivery='maildir_home'" >> /etc/exim4/update-exim4.conf.conf
  4112. update-exim4.conf
  4113. sed -i "s/START=no/START=yes/g" /etc/default/saslauthd
  4114. systemctl start saslauthd
  4115. # make a tls certificate for email
  4116. if [ ! -f /etc/ssl/certs/exim.dhparam ]; then
  4117. ${PROJECT_NAME}-addcert -h exim --dhkey $DH_KEYLENGTH
  4118. check_certificates exim
  4119. fi
  4120. cp /etc/ssl/private/exim.key /etc/exim4
  4121. cp /etc/ssl/certs/exim.crt /etc/exim4
  4122. cp /etc/ssl/certs/exim.dhparam /etc/exim4
  4123. chown root:Debian-exim /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  4124. chmod 640 /etc/exim4/exim.key /etc/exim4/exim.crt /etc/exim4/exim.dhparam
  4125. sed -i '/login_saslauthd_server/,/.endif/ s/# *//' /etc/exim4/exim4.conf.template
  4126. sed -i "/.ifdef MAIN_HARDCODE_PRIMARY_HOSTNAME/i\MAIN_HARDCODE_PRIMARY_HOSTNAME = $DEFAULT_DOMAIN_NAME\nMAIN_TLS_ENABLE = true" /etc/exim4/exim4.conf.template
  4127. sed -i "s|SMTPLISTENEROPTIONS=''|SMTPLISTENEROPTIONS='-oX 465:25:587 -oP /var/run/exim4/exim.pid'|g" /etc/default/exim4
  4128. if ! grep -q "tls_on_connect_ports=465" /etc/exim4/exim4.conf.template; then
  4129. sed -i '/SSL configuration for exim/i\tls_on_connect_ports=465' /etc/exim4/exim4.conf.template
  4130. fi
  4131. adduser $MY_USERNAME sasl
  4132. addgroup Debian-exim sasl
  4133. systemctl restart exim4
  4134. if [ ! -d /etc/skel/Maildir ]; then
  4135. mkdir -m 700 /etc/skel/.mutt
  4136. mkdir -m 700 /etc/skel/Maildir
  4137. mkdir -m 700 /etc/skel/Maildir/new
  4138. mkdir -m 700 /etc/skel/Maildir/cur
  4139. mkdir -m 700 /etc/skel/Maildir/Sent
  4140. mkdir -m 700 /etc/skel/Maildir/Sent/tmp
  4141. mkdir -m 700 /etc/skel/Maildir/Sent/cur
  4142. mkdir -m 700 /etc/skel/Maildir/Sent/new
  4143. mkdir -m 700 /etc/skel/Maildir/.learn-spam
  4144. mkdir -m 700 /etc/skel/Maildir/.learn-spam/cur
  4145. mkdir -m 700 /etc/skel/Maildir/.learn-spam/new
  4146. mkdir -m 700 /etc/skel/Maildir/.learn-spam/tmp
  4147. mkdir -m 700 /etc/skel/Maildir/.learn-ham
  4148. mkdir -m 700 /etc/skel/Maildir/.learn-ham/cur
  4149. mkdir -m 700 /etc/skel/Maildir/.learn-ham/new
  4150. mkdir -m 700 /etc/skel/Maildir/.learn-ham/tmp
  4151. ln -s /etc/skel/Maildir/.learn-spam /etc/skel/Maildir/spam
  4152. ln -s /etc/skel/Maildir/.learn-ham /etc/skel/Maildir/ham
  4153. fi
  4154. if [ ! -d /home/$MY_USERNAME/Maildir ]; then
  4155. mkdir -m 700 /home/$MY_USERNAME/.mutt
  4156. mkdir -m 700 /home/$MY_USERNAME/Maildir
  4157. mkdir -m 700 /home/$MY_USERNAME/Maildir/cur
  4158. mkdir -m 700 /home/$MY_USERNAME/Maildir/tmp
  4159. mkdir -m 700 /home/$MY_USERNAME/Maildir/new
  4160. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent
  4161. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/cur
  4162. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/tmp
  4163. mkdir -m 700 /home/$MY_USERNAME/Maildir/Sent/new
  4164. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam
  4165. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/cur
  4166. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/new
  4167. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-spam/tmp
  4168. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham
  4169. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/cur
  4170. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/new
  4171. mkdir -m 700 /home/$MY_USERNAME/Maildir/.learn-ham/tmp
  4172. ln -s /home/$MY_USERNAME/Maildir/.learn-spam /home/$MY_USERNAME/Maildir/spam
  4173. ln -s /home/$MY_USERNAME/Maildir/.learn-ham /home/$MY_USERNAME/Maildir/ham
  4174. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  4175. fi
  4176. echo 'configure_email' >> $COMPLETION_FILE
  4177. }
  4178. function create_procmail {
  4179. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4180. return
  4181. fi
  4182. if grep -Fxq "create_procmail" $COMPLETION_FILE; then
  4183. return
  4184. fi
  4185. if [ ! -f /home/$MY_USERNAME/.procmailrc ]; then
  4186. echo 'MAILDIR=$HOME/Maildir' > /home/$MY_USERNAME/.procmailrc
  4187. echo 'DEFAULT=$MAILDIR/' >> /home/$MY_USERNAME/.procmailrc
  4188. echo 'LOGFILE=$HOME/log/procmail.log' >> /home/$MY_USERNAME/.procmailrc
  4189. echo 'LOGABSTRACT=all' >> /home/$MY_USERNAME/.procmailrc
  4190. echo '' >> /home/$MY_USERNAME/.procmailrc
  4191. echo $"# Tripwire reports which have no violations don't need to be logged" >> /home/$MY_USERNAME/.procmailrc
  4192. echo ':0 BD:' >> /home/$MY_USERNAME/.procmailrc
  4193. TRIPWIRE_VIOLATIONS_STR=$'Total violations found: 0'
  4194. echo " * .*$TRIPWIRE_VIOLATIONS_STR" >> /home/$MY_USERNAME/.procmailrc
  4195. echo '/dev/null' >> /home/$MY_USERNAME/.procmailrc
  4196. echo '' >> /home/$MY_USERNAME/.procmailrc
  4197. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  4198. fi
  4199. mkdir -p /home/$MY_USERNAME/Maildir/admin/new
  4200. mkdir -p /home/$MY_USERNAME/Maildir/admin/cur
  4201. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir/admin
  4202. if [ ! -f /etc/skel/.procmailrc ]; then
  4203. cp /home/$MY_USERNAME/.procmailrc /etc/skel/.procmailrc
  4204. chown root:root /etc/skel/.procmailrc
  4205. fi
  4206. echo 'create_procmail' >> $COMPLETION_FILE
  4207. }
  4208. function handle_admin_emails {
  4209. # keep emails for root in a separate folder
  4210. if [ -d /home/$MY_USERNAME/Maildir/admin ]; then
  4211. return
  4212. fi
  4213. freedombone-addemail -u $MY_USERNAME -e "root@$DEFAULT_DOMAIN_NAME" -g admin --public no
  4214. }
  4215. function spam_filtering {
  4216. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4217. return
  4218. fi
  4219. if grep -Fxq "spam_filtering" $COMPLETION_FILE; then
  4220. return
  4221. fi
  4222. apt-get -y install exim4-daemon-heavy
  4223. apt-get -y install spamassassin
  4224. if [ ! -f /etc/default/spamassassin ]; then
  4225. echo 'Spamassassin was not installed'
  4226. exit 72570
  4227. fi
  4228. sa-update -v
  4229. sed -i 's/ENABLED=0/ENABLED=1/g' /etc/default/spamassassin
  4230. sed -i 's/# spamd_address = 127.0.0.1 783/spamd_address = 127.0.0.1 783/g' /etc/exim4/exim4.conf.template
  4231. # This configuration is based on https://wiki.debian.org/DebianSpamAssassin
  4232. sed -i 's/local_parts = postmaster/local_parts = postmaster:abuse/g' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  4233. sed -i '/domains = +local_domains : +relay_to_domains/a\ set acl_m0 = rfcnames' /etc/exim4/conf.d/acl/30_exim4-config_check_rcpt
  4234. sed -i 's/accept/accept condition = ${if eq{$acl_m0}{rfcnames} {1}{0}}/g' /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4235. echo 'warn message = X-Spam-Score: $spam_score ($spam_bar)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4236. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4237. echo 'warn message = X-Spam-Flag: YES' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4238. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4239. echo 'warn message = X-Spam-Report: $spam_report' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4240. echo ' spam = nobody' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4241. echo '# reject spam at high scores (> 12)' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4242. echo 'deny message = This message scored $spam_score spam points.' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4243. echo ' spam = nobody:true' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4244. echo ' condition = ${if >{$spam_score_int}{120}{1}{0}}' >> /etc/exim4/conf.d/acl/40_exim4-config_check_data
  4245. # procmail configuration
  4246. echo '# get spamassassin to check emails' >> /home/$MY_USERNAME/.procmailrc
  4247. echo ':0fw: .spamassassin.lock' >> /home/$MY_USERNAME/.procmailrc
  4248. echo ' * < 256000' >> /home/$MY_USERNAME/.procmailrc
  4249. echo '| spamc' >> /home/$MY_USERNAME/.procmailrc
  4250. echo '# strong spam are discarded' >> /home/$MY_USERNAME/.procmailrc
  4251. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4252. echo ' * ^X-Spam-Level: \*\*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  4253. echo '/dev/null' >> /home/$MY_USERNAME/.procmailrc
  4254. echo '# weak spam are kept just in case - clear this out every now and then' >> /home/$MY_USERNAME/.procmailrc
  4255. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4256. echo ' * ^X-Spam-Level: \*\*\*\*\*' >> /home/$MY_USERNAME/.procmailrc
  4257. echo 'maybe-spam/' >> /home/$MY_USERNAME/.procmailrc
  4258. echo '# otherwise, marginal spam goes here for revision' >> /home/$MY_USERNAME/.procmailrc
  4259. echo ':0' >> /home/$MY_USERNAME/.procmailrc
  4260. echo ' * ^X-Spam-Level: \*\*' >> /home/$MY_USERNAME/.procmailrc
  4261. echo 'spam/' >> /home/$MY_USERNAME/.procmailrc
  4262. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  4263. echo '# get spamassassin to check emails' >> /etc/skel/.procmailrc
  4264. echo ':0fw: .spamassassin.lock' >> /etc/skel/.procmailrc
  4265. echo ' * < 256000' >> /etc/skel/.procmailrc
  4266. echo '| spamc' >> /etc/skel/.procmailrc
  4267. echo '# strong spam are discarded' >> /etc/skel/.procmailrc
  4268. echo ':0' >> /etc/skel/.procmailrc
  4269. echo ' * ^X-Spam-Level: \*\*\*\*\*\*' >> /etc/skel/.procmailrc
  4270. echo '/dev/null' >> /etc/skel/.procmailrc
  4271. echo '# weak spam are kept just in case - clear this out every now and then' >> /etc/skel/.procmailrc
  4272. echo ':0' >> /etc/skel/.procmailrc
  4273. echo ' * ^X-Spam-Level: \*\*\*\*\*' >> /etc/skel/.procmailrc
  4274. echo 'maybe-spam/' >> /etc/skel/.procmailrc
  4275. echo '# otherwise, marginal spam goes here for revision' >> /etc/skel/.procmailrc
  4276. echo ':0' >> /etc/skel/.procmailrc
  4277. echo ' * ^X-Spam-Level: \*\*' >> /etc/skel/.procmailrc
  4278. echo 'spam/' >> /etc/skel/.procmailrc
  4279. # filtering scripts
  4280. echo '#!/bin/bash' > /usr/bin/filterspam
  4281. echo 'for d in /home/*/ ; do' >> /usr/bin/filterspam
  4282. echo ' USERNAME=$(echo "$d" | awk -F '"'"'/'"'"' '"'"'{print $3}'"'"')' >> /usr/bin/filterspam
  4283. echo ' if [[ $USERNAME != "git" && $USERNAME != "mirrors" && $USERNAME != "sync" ]]; then' >> /usr/bin/filterspam
  4284. echo ' MAILDIR=/home/$USERNAME/Maildir/.learn-spam' >> /usr/bin/filterspam
  4285. echo ' if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterspam
  4286. echo ' exit' >> /usr/bin/filterspam
  4287. echo ' fi' >> /usr/bin/filterspam
  4288. echo ' for f in `ls $MAILDIR/cur`' >> /usr/bin/filterspam
  4289. echo ' do' >> /usr/bin/filterspam
  4290. echo ' spamc -L spam < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterspam
  4291. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterspam
  4292. echo ' done' >> /usr/bin/filterspam
  4293. echo ' for f in `ls $MAILDIR/new`' >> /usr/bin/filterspam
  4294. echo ' do' >> /usr/bin/filterspam
  4295. echo ' spamc -L spam < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterspam
  4296. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterspam
  4297. echo ' done' >> /usr/bin/filterspam
  4298. echo ' fi' >> /usr/bin/filterspam
  4299. echo 'done' >> /usr/bin/filterspam
  4300. echo 'exit 0' >> /usr/bin/filterspam
  4301. echo '#!/bin/bash' > /usr/bin/filterham
  4302. echo 'for d in /home/*/ ; do' >> /usr/bin/filterham
  4303. echo ' USERNAME=$(echo "$d" | awk -F '"'"'/'"'"' '"'"'{print $3}'"'"')' >> /usr/bin/filterham
  4304. echo ' if [[ $USERNAME != "git" && $USERNAME != "mirrors" && $USERNAME != "sync" ]]; then' >> /usr/bin/filterham
  4305. echo ' MAILDIR=/home/$USERNAME/Maildir/.learn-ham' >> /usr/bin/filterham
  4306. echo ' if [ ! -d "$MAILDIR" ]; then' >> /usr/bin/filterham
  4307. echo ' exit' >> /usr/bin/filterham
  4308. echo ' fi' >> /usr/bin/filterham
  4309. echo ' for f in `ls $MAILDIR/cur`' >> /usr/bin/filterham
  4310. echo ' do' >> /usr/bin/filterham
  4311. echo ' spamc -L ham < "$MAILDIR/cur/$f" > /dev/null' >> /usr/bin/filterham
  4312. echo ' rm "$MAILDIR/cur/$f"' >> /usr/bin/filterham
  4313. echo ' done' >> /usr/bin/filterham
  4314. echo ' for f in `ls $MAILDIR/new`' >> /usr/bin/filterham
  4315. echo ' do' >> /usr/bin/filterham
  4316. echo ' spamc -L ham < "$MAILDIR/new/$f" > /dev/null' >> /usr/bin/filterham
  4317. echo ' rm "$MAILDIR/new/$f"' >> /usr/bin/filterham
  4318. echo ' done' >> /usr/bin/filterham
  4319. echo ' fi' >> /usr/bin/filterham
  4320. echo 'done' >> /usr/bin/filterham
  4321. echo 'exit 0' >> /usr/bin/filterham
  4322. if ! grep -q "filterspam" /etc/crontab; then
  4323. echo "*/3 * * * * root /usr/bin/timeout 120 /usr/bin/filterspam" >> /etc/crontab
  4324. fi
  4325. if ! grep -q "filterham" /etc/crontab; then
  4326. echo "*/3 * * * * root /usr/bin/timeout 120 /usr/bin/filterham" >> /etc/crontab
  4327. fi
  4328. chmod 655 /usr/bin/filterspam /usr/bin/filterham
  4329. sed -i 's/# use_bayes 1/use_bayes 1/g' /etc/mail/spamassassin/local.cf
  4330. sed -i 's/# bayes_auto_learn 1/bayes_auto_learn 1/g' /etc/mail/spamassassin/local.cf
  4331. # user preferences
  4332. if [ ! -d /home/$MY_USERNAME/.spamassassin ]; then
  4333. mkdir /home/$MY_USERNAME/.spamassassin
  4334. echo $'# How many points before a mail is considered spam.' > /home/$MY_USERNAME/.spamassassin/user_prefs
  4335. echo '# required_score 5' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4336. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4337. echo $'# Whitelist and blacklist addresses are now file-glob-style patterns, so' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4338. echo $'# "friend@somewhere.com", "*@isp.com", or "*.domain.net" will all work.' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4339. echo '# whitelist_from someone@somewhere.com' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4340. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4341. echo $'# Add your own customised scores for some tests below. The default scores are' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4342. echo $'# read from the installed spamassassin rules files, but you can override them' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4343. echo $'# here. To see the list of tests and their default scores, go to' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4344. echo '# http://spamassassin.apache.org/tests.html .' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4345. echo '#' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4346. echo '# score SYMBOLIC_TEST_NAME n.nn' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4347. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4348. echo $'# Speakers of Asian languages, like Chinese, Japanese and Korean, will almost' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4349. echo $'# definitely want to uncomment the following lines. They will switch off some' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4350. echo $'# rules that detect 8-bit characters, which commonly trigger on mails using CJK' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4351. echo $'# character sets, or that assume a western-style charset is in use. ' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4352. echo '# ' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4353. echo '# score HTML_COMMENT_8BITS 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4354. echo '# score UPPERCASE_25_50 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4355. echo '# score UPPERCASE_50_75 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4356. echo '# score UPPERCASE_75_100 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4357. echo '# score OBSCURED_EMAIL 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4358. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4359. echo $'# Speakers of any language that uses non-English, accented characters may wish' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4360. echo $'# to uncomment the following lines. They turn off rules that fire on' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4361. echo $'# misformatted messages generated by common mail apps in contravention of the' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4362. echo $'# email RFCs.' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4363. echo '' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4364. echo '# score SUBJ_ILLEGAL_CHARS 0' >> /home/$MY_USERNAME/.spamassassin/user_prefs
  4365. fi
  4366. # this must be accessible by root
  4367. chown -R $MY_USERNAME:root /home/$MY_USERNAME/.spamassassin
  4368. systemctl restart spamassassin
  4369. systemctl restart exim4
  4370. systemctl restart cron
  4371. echo 'spam_filtering' >> $COMPLETION_FILE
  4372. }
  4373. function configure_imap {
  4374. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4375. return
  4376. fi
  4377. if grep -Fxq "configure_imap" $COMPLETION_FILE; then
  4378. return
  4379. fi
  4380. dpkg -P dovecot-imapd
  4381. dpkg -P dovecot-core
  4382. apt-get -y install dovecot-imapd
  4383. if [ ! -d /etc/dovecot ]; then
  4384. echo $"ERROR: Dovecot does not appear to have installed. $CHECK_MESSAGE"
  4385. exit 48
  4386. fi
  4387. if [ ! -f /etc/ssl/certs/dovecot.dhparam ]; then
  4388. ${PROJECT_NAME}-addcert -h dovecot --dhkey $DH_KEYLENGTH
  4389. check_certificates dovecot
  4390. fi
  4391. chown root:dovecot /etc/ssl/certs/dovecot.*
  4392. chown root:dovecot /etc/ssl/private/dovecot.*
  4393. if [ ! -f /etc/dovecot/conf.d/10-ssl.conf ]; then
  4394. echo $'Unable to find /etc/dovecot/conf.d/10-ssl.conf'
  4395. exit 83629
  4396. fi
  4397. sed -i 's|#ssl =.*|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  4398. sed -i 's|ssl = no|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  4399. sed -i 's|ssl = yes|ssl = required|g' /etc/dovecot/conf.d/10-ssl.conf
  4400. sed -i 's|#ssl_cert =.*|ssl_cert = </etc/ssl/certs/dovecot.crt|g' /etc/dovecot/conf.d/10-ssl.conf
  4401. sed -i 's|ssl_cert =.*|ssl_cert = </etc/ssl/certs/dovecot.crt|g' /etc/dovecot/conf.d/10-ssl.conf
  4402. sed -i 's|#ssl_key =.*|ssl_key = </etc/ssl/private/dovecot.key|g' /etc/dovecot/conf.d/10-ssl.conf
  4403. sed -i 's|ssl_key =.*|ssl_key = </etc/ssl/private/dovecot.key|g' /etc/dovecot/conf.d/10-ssl.conf
  4404. sed -i 's|#ssl_dh_parameters_length.*|ssl_dh_parameters_length = 2048|g' /etc/dovecot/conf.d/10-ssl.conf
  4405. sed -i 's/#ssl_prefer_server_ciphers.*/ssl_prefer_server_ciphers = yes/g' /etc/dovecot/conf.d/10-ssl.conf
  4406. sed -i "s|#ssl_protocols =.*|ssl_protocols = '$SSL_PROTOCOLS'|g" /etc/dovecot/conf.d/10-ssl.conf
  4407. sed -i "s|ssl_protocols =.*|ssl_protocols = '$SSL_PROTOCOLS'|g" /etc/dovecot/conf.d/10-ssl.conf
  4408. echo "ssl_cipher_list = '$SSL_CIPHERS'" >> /etc/dovecot/conf.d/10-ssl.conf
  4409. if [ ! -f /etc/dovecot/conf.d/10-master.conf ]; then
  4410. echo $'Unable to find /etc/dovecot/conf.d/10-master.conf'
  4411. exit 49259
  4412. fi
  4413. sed -i 's/#process_limit =.*/process_limit = 100/g' /etc/dovecot/conf.d/10-master.conf
  4414. sed -i 's/#default_client_limit.*/default_client_limit = 100/g' /etc/dovecot/conf.d/10-master.conf
  4415. sed -i 's|#default_process_limit =.*|default_process_limit = 100|g' /etc/dovecot/conf.d/10-master.conf
  4416. if [ ! -f /etc/dovecot/conf.d/10-logging.conf ]; then
  4417. echo $'Unable to find /etc/dovecot/conf.d/10-logging.conf'
  4418. exit 48936
  4419. fi
  4420. sed -i 's/#auth_verbose.*/auth_verbose = yes/g' /etc/dovecot/conf.d/10-logging.conf
  4421. if [ ! -f /etc/dovecot/dovecot.conf ]; then
  4422. echo $'Unable to find /etc/dovecot/dovecot.conf'
  4423. exit 43890
  4424. fi
  4425. sed -i 's/#listen =.*/listen = */g' /etc/dovecot/dovecot.conf
  4426. if [ ! -f /etc/dovecot/conf.d/10-auth.conf ]; then
  4427. echo $'Unable to find /etc/dovecot/conf.d/10-auth.conf'
  4428. exit 843256
  4429. fi
  4430. sed -i 's/#disable_plaintext_auth =.*/disable_plaintext_auth = no/g' /etc/dovecot/conf.d/10-auth.conf
  4431. sed -i 's/auth_mechanisms =.*/auth_mechanisms = plain login/g' /etc/dovecot/conf.d/10-auth.conf
  4432. if [ ! -f /etc/dovecot/conf.d/10-mail.conf ]; then
  4433. echo $'Unable to find /etc/dovecot/conf.d/10-mail.conf'
  4434. exit 42036
  4435. fi
  4436. sed -i 's|mail_location =.*|mail_location = maildir:~/Maildir:LAYOUT=fs|g' /etc/dovecot/conf.d/10-mail.conf
  4437. # This long notify interval makes the system more suited for use with
  4438. # battery powered mobile devices
  4439. sed -i 's|#imap_idle_notify_interval =.*|imap_idle_notify_interval = 29|g' /etc/dovecot/conf.d/20-imap.conf
  4440. if [ -f /var/lib/dovecot/ssl-parameters.dat ]; then
  4441. rm /var/lib/dovecot/ssl-parameters.dat
  4442. fi
  4443. systemctl restart dovecot
  4444. echo 'configure_imap' >> $COMPLETION_FILE
  4445. }
  4446. function configure_imap_client_certs {
  4447. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4448. return
  4449. fi
  4450. if grep -Fxq "configure_imap_client_certs" $COMPLETION_FILE; then
  4451. return
  4452. fi
  4453. # http://strange.systems/certificate-based-auth-with-dovecot-sendmail/
  4454. sed -i 's|#default_process_limit =.*|default_process_limit = 100|g' /etc/dovecot/conf.d/10-master.conf
  4455. sed -i 's/disable_plaintext_auth =.*/disable_plaintext_auth = yes/g' /etc/dovecot/conf.d/10-auth.conf
  4456. sed -i 's|#auth_ssl_require_client_cert =.*|auth_ssl_require_client_cert = yes|g' /etc/dovecot/conf.d/10-auth.conf
  4457. sed -i 's|#auth_ssl_username_from_cert =.*|auth_ssl_username_from_cert = yes|g' /etc/dovecot/conf.d/10-auth.conf
  4458. sed -i "s|#ssl_ca =.*|ssl_ca = /etc/ssl/certs/ca-$DEFAULT_DOMAIN_NAME.crt|g" /etc/dovecot/conf.d/10-ssl.conf
  4459. sed -i 's|#ssl_cert_username_field =.*|ssl_cert_username_field = commonName|g' /etc/dovecot/conf.d/10-ssl.conf
  4460. sed -i 's|#ssl_verify_client_cert =.*|ssl_verify_client_cert = yes|g' /etc/dovecot/conf.d/10-ssl.conf
  4461. if ! grep -q "passdb {" /etc/dovecot/conf.d/10-auth.conf; then
  4462. echo '' >> /etc/dovecot/conf.d/10-auth.conf
  4463. echo 'passdb {' >> /etc/dovecot/conf.d/10-auth.conf
  4464. echo ' driver = passwd-file' >> /etc/dovecot/conf.d/10-auth.conf
  4465. echo ' args = /etc/dovecot/passwd-file' >> /etc/dovecot/conf.d/10-auth.conf
  4466. echo ' deny = no' >> /etc/dovecot/conf.d/10-auth.conf
  4467. echo ' master = no' >> /etc/dovecot/conf.d/10-auth.conf
  4468. echo ' pass = no' >> /etc/dovecot/conf.d/10-auth.conf
  4469. echo '}' >> /etc/dovecot/conf.d/10-auth.conf
  4470. fi
  4471. if [[ $ONION_ONLY == "no" ]]; then
  4472. # make a CA cert
  4473. if [ ! -f /etc/ssl/private/ca-$DEFAULT_DOMAIN_NAME.key ]; then
  4474. if [[ $LETSENCRYPT_ENABLED != "yes" ]]; then
  4475. ${PROJECT_NAME}-addcert -h $DEFAULT_DOMAIN_NAME --ca "" --dhkey $DH_KEYLENGTH
  4476. else
  4477. ${PROJECT_NAME}-addcert -e $DEFAULT_DOMAIN_NAME -s $LETSENCRYPT_SERVER --ca "" --dhkey $DH_KEYLENGTH --email $MY_EMAIL_ADDRESS
  4478. fi
  4479. fi
  4480. fi
  4481. # CA configuration
  4482. echo '[ ca ]' > /etc/ssl/dovecot-ca.cnf
  4483. echo "default_ca = dovecot-ca" >> /etc/ssl/dovecot-ca.cnf
  4484. echo '' >> /etc/ssl/dovecot-ca.cnf
  4485. echo '[ crl_ext ]' >> /etc/ssl/dovecot-ca.cnf
  4486. echo 'authorityKeyIdentifier=keyid:always' >> /etc/ssl/dovecot-ca.cnf
  4487. echo '' >> /etc/ssl/dovecot-ca.cnf
  4488. echo '[ dovecot-ca ]' >> /etc/ssl/dovecot-ca.cnf
  4489. echo 'new_certs_dir = .' >> /etc/ssl/dovecot-ca.cnf
  4490. echo 'unique_subject = no' >> /etc/ssl/dovecot-ca.cnf
  4491. echo "certificate = /etc/ssl/certs/ca-$DEFAULT_DOMAIN_NAME.crt" >> /etc/ssl/dovecot-ca.cnf
  4492. echo 'database = ssldb' >> /etc/ssl/dovecot-ca.cnf
  4493. echo "private_key = /etc/ssl/private/ca-$DEFAULT_DOMAIN_NAME.key" >> /etc/ssl/dovecot-ca.cnf
  4494. echo 'serial = sslserial' >> /etc/ssl/dovecot-ca.cnf
  4495. echo 'default_days = 3650' >> /etc/ssl/dovecot-ca.cnf
  4496. echo 'default_md = sha256' >> /etc/ssl/dovecot-ca.cnf
  4497. echo 'default_bits = 4096' >> /etc/ssl/dovecot-ca.cnf
  4498. echo 'policy = dovecot-ca_policy' >> /etc/ssl/dovecot-ca.cnf
  4499. echo 'x509_extensions = dovecot-ca_extensions' >> /etc/ssl/dovecot-ca.cnf
  4500. echo '' >> /etc/ssl/dovecot-ca.cnf
  4501. echo '[ dovecot-ca_policy ]' >> /etc/ssl/dovecot-ca.cnf
  4502. echo 'commonName = supplied' >> /etc/ssl/dovecot-ca.cnf
  4503. echo 'stateOrProvinceName = supplied' >> /etc/ssl/dovecot-ca.cnf
  4504. echo 'countryName = supplied' >> /etc/ssl/dovecot-ca.cnf
  4505. echo 'emailAddress = optional' >> /etc/ssl/dovecot-ca.cnf
  4506. echo 'organizationName = supplied' >> /etc/ssl/dovecot-ca.cnf
  4507. echo 'organizationalUnitName = optional' >> /etc/ssl/dovecot-ca.cnf
  4508. echo '' >> /etc/ssl/dovecot-ca.cnf
  4509. echo '[ dovecot-ca_extensions ]' >> /etc/ssl/dovecot-ca.cnf
  4510. echo 'basicConstraints = CA:false' >> /etc/ssl/dovecot-ca.cnf
  4511. echo 'subjectKeyIdentifier = hash' >> /etc/ssl/dovecot-ca.cnf
  4512. echo 'authorityKeyIdentifier = keyid:always' >> /etc/ssl/dovecot-ca.cnf
  4513. echo 'keyUsage = digitalSignature,keyEncipherment' >> /etc/ssl/dovecot-ca.cnf
  4514. echo 'extendedKeyUsage = clientAuth' >> /etc/ssl/dovecot-ca.cnf
  4515. if [ -f /etc/ssl/ssldb ]; then
  4516. rm /etc/ssl/ssldb
  4517. fi
  4518. if [ -f /etc/ssl/sslserial ]; then
  4519. rm /etc/ssl/sslserial
  4520. fi
  4521. touch /etc/ssl/ssldb
  4522. echo 0001 > /etc/ssl/sslserial
  4523. #${PROJECT_NAME}-clientcert -u $MY_USERNAME
  4524. systemctl restart dovecot
  4525. echo 'configure_imap_client_certs' >> $COMPLETION_FILE
  4526. }
  4527. function create_gpg_subkey {
  4528. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4529. return
  4530. fi
  4531. if grep -Fxq "create_gpg_subkey" $COMPLETION_FILE; then
  4532. return
  4533. fi
  4534. apt-get -y install gnupg
  4535. GPG_KEY_USAGE=$1
  4536. if [[ $GPG_KEY_USAGE != "sign" && $GPG_KEY_USAGE != "auth" && $GPG_KEY_USAGE != "encrypt" ]]; then
  4537. echo $"Unknown subkey usage: $GPG_KEY_USAGE"
  4538. echo $'Available types: sign|auth|encrypt'
  4539. exit 14783
  4540. fi
  4541. KEYGRIP=$(gpg --fingerprint --fingerprint $MY_EMAIL_ADDRESS | grep fingerprint | tail -1 | cut -d= -f2 | sed -e 's/ //g')
  4542. # Generate a GPG subkey
  4543. # Here a 2048bit length is used to be compatible with yubikey
  4544. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  4545. echo "Key-Grip: $KEYGRIP" > /home/$MY_USERNAME/gpg-genkey.conf
  4546. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  4547. echo 'Subkey-Length: 2048' >> /home/$MY_USERNAME/gpg-genkey.conf
  4548. echo "subkey-Usage: $GPG_KEY_USAGE" > /home/$MY_USERNAME/gpg-genkey.conf
  4549. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  4550. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  4551. echo "Name-Comment: $GPG_KEY_USAGE" >> /home/$MY_USERNAME/gpg-genkey.conf
  4552. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  4553. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  4554. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  4555. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  4556. MY_GPG_SUBKEY_ID=$(su -c "gpg --list-keys $MY_EMAIL_ADDRESS | grep 'pub '" - $MY_USERNAME | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4557. echo 'create_gpg_subkey' >> $COMPLETION_FILE
  4558. }
  4559. function gpg_key_exists {
  4560. key_owner_username=$1
  4561. key_search_text=$2
  4562. if [[ $key_owner_username != "root" ]]; then
  4563. KEY_EXISTS=$(su -c "gpg --list-keys \"${key_search_text}\"" - $key_owner_username)
  4564. else
  4565. KEY_EXISTS=$(gpg --list-keys "${key_search_text}")
  4566. fi
  4567. if [ ! "$KEY_EXISTS" ]; then
  4568. echo "no"
  4569. return
  4570. fi
  4571. if [ "$KEY_EXISTS" == *"error"* ]; then
  4572. echo "no"
  4573. return
  4574. fi
  4575. echo "yes"
  4576. }
  4577. function gpg_pubkey_from_email {
  4578. key_owner_username=$1
  4579. key_email_address=$2
  4580. key_id=
  4581. if [[ $key_owner_username != "root" ]]; then
  4582. key_id=$(su -c "gpg --list-keys $key_email_address | grep 'pub '" - $key_owner_username | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4583. else
  4584. key_id=$(gpg --list-keys $key_email_address | grep 'pub ' | awk -F ' ' '{print $2}' | awk -F '/' '{print $2}')
  4585. fi
  4586. echo $key_id
  4587. }
  4588. function configure_gpg {
  4589. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4590. return
  4591. fi
  4592. if grep -Fxq "configure_gpg" $COMPLETION_FILE; then
  4593. return
  4594. fi
  4595. apt-get -y install gnupg
  4596. gpg_dir=/home/$MY_USERNAME/.gnupg
  4597. # if gpg keys directory was previously imported from usb
  4598. if [[ $GPG_KEYS_IMPORTED == "yes" && -d $gpg_dir ]]; then
  4599. echo $'GPG keys were imported'
  4600. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" $gpg_dir/gpg.conf
  4601. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4602. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  4603. echo $'GPG public key ID could not be obtained'
  4604. fi
  4605. chown -R $MY_USERNAME:$MY_USERNAME $gpg_dir
  4606. chmod 700 $gpg_dir
  4607. chmod 600 $gpg_dir/*
  4608. echo 'configure_gpg' >> $COMPLETION_FILE
  4609. return
  4610. fi
  4611. if [ ! -d $gpg_dir ]; then
  4612. mkdir $gpg_dir
  4613. echo "keyserver $GPG_KEYSERVER" >> $gpg_dir/gpg.conf
  4614. echo 'keyserver-options auto-key-retrieve' >> $gpg_dir/gpg.conf
  4615. fi
  4616. sed -i "s|keyserver hkp://keys.gnupg.net|keyserver $GPG_KEYSERVER|g" $gpg_dir/gpg.conf
  4617. if ! grep -q "# default preferences" $gpg_dir/gpg.conf; then
  4618. echo '' >> $gpg_dir/gpg.conf
  4619. echo '# default preferences' >> $gpg_dir/gpg.conf
  4620. echo 'personal-digest-preferences SHA256' >> $gpg_dir/gpg.conf
  4621. echo 'cert-digest-algo SHA256' >> $gpg_dir/gpg.conf
  4622. echo 'default-preference-list SHA512 SHA384 SHA256 SHA224 AES256 AES192 AES CAST5 ZLIB BZIP2 ZIP Uncompressed' >> $gpg_dir/gpg.conf
  4623. fi
  4624. chown -R $MY_USERNAME:$MY_USERNAME $gpg_dir
  4625. chmod 700 $gpg_dir
  4626. chmod 600 $gpg_dir/*
  4627. if [[ $MY_GPG_PUBLIC_KEY && $MY_GPG_PRIVATE_KEY ]]; then
  4628. echo $'Importing GPG keys from file'
  4629. echo $"Public key: $MY_GPG_PUBLIC_KEY"
  4630. echo $"Private key: $MY_GPG_PRIVATE_KEY"
  4631. # use your existing GPG keys which were exported
  4632. if [ ! -f $MY_GPG_PUBLIC_KEY ]; then
  4633. echo $"GPG public key file $MY_GPG_PUBLIC_KEY was not found"
  4634. exit 2483
  4635. fi
  4636. if [ ! -f $MY_GPG_PRIVATE_KEY ]; then
  4637. echo $"GPG private key file $MY_GPG_PRIVATE_KEY was not found"
  4638. exit 5383
  4639. fi
  4640. su -c "gpg --import $MY_GPG_PUBLIC_KEY" - $MY_USERNAME
  4641. su -c "gpg --allow-secret-key-import --import $MY_GPG_PRIVATE_KEY" - $MY_USERNAME
  4642. KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4643. if [[ $KEY_EXISTS == "no" ]]; then
  4644. echo $"The GPG key for $MY_EMAIL_ADDRESS could not be imported"
  4645. exit 13821
  4646. fi
  4647. # for security ensure that the private key file doesn't linger around
  4648. shred -zu $MY_GPG_PRIVATE_KEY
  4649. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4650. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  4651. echo $'GPG public key ID could not be obtained'
  4652. fi
  4653. else
  4654. # Generate a GPG key
  4655. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  4656. echo 'Key-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4657. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  4658. echo 'Subkey-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4659. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  4660. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  4661. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  4662. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  4663. echo $'Generating a new GPG key'
  4664. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  4665. KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4666. if [[ $KEY_EXISTS == "no" ]]; then
  4667. echo $"A GPG key for $MY_EMAIL_ADDRESS could not be created"
  4668. exit 6362
  4669. fi
  4670. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  4671. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4672. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  4673. echo $'GPG public key ID could not be obtained'
  4674. fi
  4675. MY_GPG_PUBLIC_KEY=/tmp/public_key.gpg
  4676. su -c "gpg --output $MY_GPG_PUBLIC_KEY --armor --export $MY_GPG_PUBLIC_KEY_ID" - $MY_USERNAME
  4677. if grep -q "configure_email" $COMPLETION_FILE; then
  4678. if ! grep -q $"Change your GPG password" /home/$MY_USERNAME/README; then
  4679. echo '' >> /home/$MY_USERNAME/README
  4680. echo '' >> /home/$MY_USERNAME/README
  4681. echo $'Change your GPG password' >> /home/$MY_USERNAME/README
  4682. echo '========================' >> /home/$MY_USERNAME/README
  4683. echo $"It's very important to add a password to your GPG key so that" >> /home/$MY_USERNAME/README
  4684. echo $"if anyone does get access to your email they still won't be able" >> /home/$MY_USERNAME/README
  4685. echo $'to read them without knowning the GPG password.' >> /home/$MY_USERNAME/README
  4686. echo $'You can change the it with:' >> /home/$MY_USERNAME/README
  4687. echo '' >> /home/$MY_USERNAME/README
  4688. echo " gpg --edit-key $MY_GPG_PUBLIC_KEY_ID" >> /home/$MY_USERNAME/README
  4689. echo ' passwd' >> /home/$MY_USERNAME/README
  4690. echo ' save' >> /home/$MY_USERNAME/README
  4691. echo ' quit' >> /home/$MY_USERNAME/README
  4692. fi
  4693. if ! grep -q $"Publish your GPG public key" /home/$MY_USERNAME/README; then
  4694. echo '' >> /home/$MY_USERNAME/README
  4695. echo '' >> /home/$MY_USERNAME/README
  4696. echo $'Publish your GPG public key' >> /home/$MY_USERNAME/README
  4697. echo '===========================' >> /home/$MY_USERNAME/README
  4698. echo $'So that others can send emails to you securely you should' >> /home/$MY_USERNAME/README
  4699. echo $'publish your GPG public key with the command:' >> /home/$MY_USERNAME/README
  4700. echo '' >> /home/$MY_USERNAME/README
  4701. echo " gpg --send-keys $MY_GPG_PUBLIC_KEY_ID" >> /home/$MY_USERNAME/README
  4702. fi
  4703. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  4704. chmod 600 /home/$MY_USERNAME/README
  4705. fi
  4706. fi
  4707. echo 'configure_gpg' >> $COMPLETION_FILE
  4708. }
  4709. function configure_backup_key {
  4710. if grep -Fxq "configure_backup_key" $COMPLETION_FILE; then
  4711. return
  4712. fi
  4713. apt-get -y install gnupg
  4714. BACKUP_KEY_EXISTS=$(gpg_key_exists "root" "$MY_NAME (backup key)")
  4715. if [[ $BACKUP_KEY_EXISTS == "yes" ]]; then
  4716. return
  4717. fi
  4718. # Generate a GPG key for backups
  4719. BACKUP_KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_NAME (backup key)")
  4720. if [[ $BACKUP_KEY_EXISTS == "no" ]]; then
  4721. echo 'Key-Type: 1' > /home/$MY_USERNAME/gpg-genkey.conf
  4722. echo 'Key-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4723. echo 'Subkey-Type: 1' >> /home/$MY_USERNAME/gpg-genkey.conf
  4724. echo 'Subkey-Length: 4096' >> /home/$MY_USERNAME/gpg-genkey.conf
  4725. echo "Name-Real: $MY_NAME" >> /home/$MY_USERNAME/gpg-genkey.conf
  4726. echo "Name-Email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/gpg-genkey.conf
  4727. echo "Name-Comment: backup key" >> /home/$MY_USERNAME/gpg-genkey.conf
  4728. echo 'Expire-Date: 0' >> /home/$MY_USERNAME/gpg-genkey.conf
  4729. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/gpg-genkey.conf
  4730. echo $'Backup key does not exist. Creating it.'
  4731. su -c "gpg --batch --gen-key /home/$MY_USERNAME/gpg-genkey.conf" - $MY_USERNAME
  4732. shred -zu /home/$MY_USERNAME/gpg-genkey.conf
  4733. echo $'Checking that the Backup key was created'
  4734. BACKUP_KEY_EXISTS=$(gpg_key_exists "$MY_USERNAME" "$MY_NAME (backup key)")
  4735. if [[ $BACKUP_KEY_EXISTS == "no" ]]; then
  4736. echo $'Backup key could not be created'
  4737. exit 43382
  4738. fi
  4739. fi
  4740. 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}')
  4741. echo "Backup key: $MY_BACKUP_KEY_ID"
  4742. MY_BACKUP_KEY=/home/$MY_USERNAME/backup_key
  4743. su -c "gpg --output ${MY_BACKUP_KEY}_public.asc --armor --export $MY_BACKUP_KEY_ID" - $MY_USERNAME
  4744. su -c "gpg --output ${MY_BACKUP_KEY}_private.asc --armor --export-secret-key $MY_BACKUP_KEY_ID" - $MY_USERNAME
  4745. if [ ! -f ${MY_BACKUP_KEY}_public.asc ]; then
  4746. echo 'Public backup key could not be exported'
  4747. exit 36829
  4748. fi
  4749. if [ ! -f ${MY_BACKUP_KEY}_private.asc ]; then
  4750. echo 'Private backup key could not be exported'
  4751. exit 29235
  4752. fi
  4753. # import backup key to root user
  4754. gpg --import --import ${MY_BACKUP_KEY}_public.asc
  4755. gpg --allow-secret-key-import --import ${MY_BACKUP_KEY}_private.asc
  4756. shred -zu ${MY_BACKUP_KEY}_public.asc
  4757. shred -zu ${MY_BACKUP_KEY}_private.asc
  4758. echo 'configure_backup_key' >> $COMPLETION_FILE
  4759. }
  4760. function encrypt_incoming_email {
  4761. # encrypts incoming mail using your GPG public key
  4762. # so even if an attacker gains access to the data at rest they still need
  4763. # to know your GPG key password to be able to read anything
  4764. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4765. return
  4766. fi
  4767. # update to the next commit
  4768. set_repo_commit $INSTALL_DIR/gpgit "gpgit commit" "$GPGIT_COMMIT" $GPGIT_REPO
  4769. if grep -Fxq "encrypt_incoming_email" $COMPLETION_FILE; then
  4770. return
  4771. fi
  4772. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  4773. return
  4774. fi
  4775. if [ ! -f /usr/bin/gpgit.pl ]; then
  4776. apt-get -y install git libmail-gnupg-perl
  4777. cd $INSTALL_DIR
  4778. git_clone $GPGIT_REPO $INSTALL_DIR/gpgit
  4779. cd $INSTALL_DIR/gpgit
  4780. git checkout $GPGIT_COMMIT -b $GPGIT_COMMIT
  4781. if ! grep -q "gpgit commit" $COMPLETION_FILE; then
  4782. echo "gpgit commit:$GPGIT_COMMIT" >> $COMPLETION_FILE
  4783. else
  4784. sed -i "s/gpgit commit.*/gpgit commit:$GPGIT_COMMIT/g" $COMPLETION_FILE
  4785. fi
  4786. cp gpgit.pl /usr/bin
  4787. fi
  4788. # add a procmail rule
  4789. if ! grep -q "/usr/bin/gpgit.pl" /home/$MY_USERNAME/.procmailrc; then
  4790. echo '' >> /home/$MY_USERNAME/.procmailrc
  4791. echo ':0 f' >> /home/$MY_USERNAME/.procmailrc
  4792. echo "| /usr/bin/gpgit.pl --encrypt-mode prefer-inline --inline-flatten $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/.procmailrc
  4793. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.procmailrc
  4794. echo '' >> /etc/skel/.procmailrc
  4795. echo ':0 f' >> /etc/skel/.procmailrc
  4796. echo -n '| /usr/bin/gpgit.pl --encrypt-mode prefer-inline --inline-flatten $USER@' >> /etc/skel/.procmailrc
  4797. echo "$DEFAULT_DOMAIN_NAME" >> /etc/skel/.procmailrc
  4798. fi
  4799. echo 'encrypt_incoming_email' >> $COMPLETION_FILE
  4800. }
  4801. function encrypt_outgoing_email {
  4802. # encrypts outgoing mail using your GPG public key
  4803. # so even if an attacker gains access to the data at rest they still need
  4804. # to know your GPG key password to be able to read sent mail
  4805. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4806. return
  4807. fi
  4808. if grep -Fxq "encrypt_outgoing_email" $COMPLETION_FILE; then
  4809. return
  4810. fi
  4811. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  4812. return
  4813. fi
  4814. if [ ! -d /home/$MY_USERNAME/.gnupg ]; then
  4815. return
  4816. fi
  4817. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  4818. return
  4819. fi
  4820. # obtain your public key ID
  4821. if [ ! $MY_GPG_PUBLIC_KEY_ID ]; then
  4822. MY_GPG_PUBLIC_KEY_ID=$(gpg_pubkey_from_email "$MY_USERNAME" "$MY_EMAIL_ADDRESS")
  4823. if [ ! "$MY_GPG_PUBLIC_KEY_ID" ]; then
  4824. return
  4825. fi
  4826. if [ ${#MY_GPG_PUBLIC_KEY_ID} -lt 4 ]; then
  4827. return
  4828. fi
  4829. fi
  4830. if ! grep -q "pgp_encrypt_only_command" /home/$MY_USERNAME/.muttrc; then
  4831. echo '' >> /home/$MY_USERNAME/.muttrc
  4832. echo $'# Encrypt items in the Sent folder' >> /home/$MY_USERNAME/.muttrc
  4833. 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
  4834. else
  4835. 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
  4836. fi
  4837. if ! grep -q "pgp_encrypt_sign_command" /home/$MY_USERNAME/.muttrc; then
  4838. 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
  4839. else
  4840. 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
  4841. fi
  4842. echo 'encrypt_outgoing_email' >> $COMPLETION_FILE
  4843. }
  4844. function encrypt_all_email {
  4845. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4846. return
  4847. fi
  4848. if [[ $GPG_ENCRYPT_STORED_EMAIL != "yes" ]]; then
  4849. return
  4850. fi
  4851. if [ -f /usr/local/bin/${PROJECT_NAME}-encrypt-mail ]; then
  4852. cp /usr/local/bin/${PROJECT_NAME}-encrypt-mail /usr/bin/encmaildir
  4853. else
  4854. cp /usr/bin/${PROJECT_NAME}-encrypt-mail /usr/bin/encmaildir
  4855. fi
  4856. chmod +x /usr/bin/encmaildir
  4857. if grep -Fxq "encrypt_all_email" $COMPLETION_FILE; then
  4858. return
  4859. fi
  4860. if [ ! /home/$MY_USERNAME/README ]; then
  4861. touch /home/$MY_USERNAME/README
  4862. fi
  4863. if ! grep -q $"If you have imported legacy email which is not encrypted" /home/$MY_USERNAME/README; then
  4864. echo '' >> /home/$MY_USERNAME/README
  4865. echo '' >> /home/$MY_USERNAME/README
  4866. echo $'Encrypting legacy email' >> /home/$MY_USERNAME/README
  4867. echo '=======================' >> /home/$MY_USERNAME/README
  4868. echo $'If you have imported legacy email which is not encrypted' >> /home/$MY_USERNAME/README
  4869. echo $'then it can be encrypted with the command:' >> /home/$MY_USERNAME/README
  4870. echo '' >> /home/$MY_USERNAME/README
  4871. echo ' encmaildir' >> /home/$MY_USERNAME/README
  4872. echo '' >> /home/$MY_USERNAME/README
  4873. echo $'But be warned that depending upon how much email you have' >> /home/$MY_USERNAME/README
  4874. echo $'this could take a seriously LONG time on the Beaglebone' >> /home/$MY_USERNAME/README
  4875. echo $'and may be better done on a faster machine.' >> /home/$MY_USERNAME/README
  4876. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  4877. chmod 600 /home/$MY_USERNAME/README
  4878. fi
  4879. echo 'encrypt_all_email' >> $COMPLETION_FILE
  4880. }
  4881. function email_client {
  4882. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  4883. return
  4884. fi
  4885. if grep -Fxq "email_client" $COMPLETION_FILE; then
  4886. return
  4887. fi
  4888. apt-get -y install mutt-patched lynx abook
  4889. if [ ! -f /etc/Muttrc ]; then
  4890. echo $"ERROR: Mutt does not appear to have installed. $CHECK_MESSAGE"
  4891. exit 49
  4892. fi
  4893. if [ ! -d /home/$MY_USERNAME/.mutt ]; then
  4894. mkdir /home/$MY_USERNAME/.mutt
  4895. fi
  4896. echo "text/html; lynx -dump -width=78 -nolist %s | sed ‘s/^ //’; copiousoutput; needsterminal; nametemplate=%s.html" > /home/$MY_USERNAME/.mutt/mailcap
  4897. cp /home/$MY_USERNAME/.mutt/mailcap /etc/skel/.mutt
  4898. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt
  4899. chown -R root:root /etc/skel/.mutt
  4900. echo 'set mbox_type=Maildir' >> /etc/Muttrc
  4901. echo 'set folder="~/Maildir"' >> /etc/Muttrc
  4902. echo 'set mask="!^\\.[^.]"' >> /etc/Muttrc
  4903. echo 'set mbox="~/Maildir"' >> /etc/Muttrc
  4904. echo 'set record="+Sent"' >> /etc/Muttrc
  4905. echo 'set postponed="+Drafts"' >> /etc/Muttrc
  4906. echo 'set trash="+Trash"' >> /etc/Muttrc
  4907. echo 'set spoolfile="~/Maildir"' >> /etc/Muttrc
  4908. echo 'auto_view text/x-vcard text/html text/enriched' >> /etc/Muttrc
  4909. echo 'set editor="emacs -q --load ~/.emacs-mutt"' >> /etc/Muttrc
  4910. echo 'set header_cache="+.cache"' >> /etc/Muttrc
  4911. echo '' >> /etc/Muttrc
  4912. echo 'macro index S "<tag-prefix><decode-save>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  4913. echo 'macro pager S "<decode-save>=.learn-spam<enter>" "move to learn-spam"' >> /etc/Muttrc
  4914. echo 'macro index H "<tag-prefix><decode-copy>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  4915. echo 'macro pager H "<decode-copy>=.learn-ham<enter>" "copy to learn-ham"' >> /etc/Muttrc
  4916. echo '' >> /etc/Muttrc
  4917. echo '# set up the sidebar' >> /etc/Muttrc
  4918. echo 'set sidebar_width=22' >> /etc/Muttrc
  4919. echo 'set sidebar_visible=yes' >> /etc/Muttrc
  4920. echo "set sidebar_delim='|'" >> /etc/Muttrc
  4921. echo 'set sidebar_sort=yes' >> /etc/Muttrc
  4922. echo '' >> /etc/Muttrc
  4923. echo 'set rfc2047_parameters' >> /etc/Muttrc
  4924. echo '' >> /etc/Muttrc
  4925. echo '# Show inbox and sent items' >> /etc/Muttrc
  4926. echo 'mailboxes = =Sent =maybe-spam =spam' >> /etc/Muttrc
  4927. echo '' >> /etc/Muttrc
  4928. echo '# Alter these colours as needed for maximum bling' >> /etc/Muttrc
  4929. echo 'color sidebar_new yellow default' >> /etc/Muttrc
  4930. echo 'color normal white default' >> /etc/Muttrc
  4931. echo 'color hdrdefault brightcyan default' >> /etc/Muttrc
  4932. echo 'color signature green default' >> /etc/Muttrc
  4933. echo 'color attachment brightyellow default' >> /etc/Muttrc
  4934. echo 'color quoted green default' >> /etc/Muttrc
  4935. echo 'color quoted1 white default' >> /etc/Muttrc
  4936. echo 'color tilde blue default' >> /etc/Muttrc
  4937. echo '' >> /etc/Muttrc
  4938. echo '# ctrl-n, ctrl-p to select next, prev folder' >> /etc/Muttrc
  4939. echo '# ctrl-o to open selected folder' >> /etc/Muttrc
  4940. echo 'bind index \Cp sidebar-prev' >> /etc/Muttrc
  4941. echo 'bind index \Cn sidebar-next' >> /etc/Muttrc
  4942. echo 'bind index \Co sidebar-open' >> /etc/Muttrc
  4943. echo 'bind pager \Cp sidebar-prev' >> /etc/Muttrc
  4944. echo 'bind pager \Cn sidebar-next' >> /etc/Muttrc
  4945. echo 'bind pager \Co sidebar-open' >> /etc/Muttrc
  4946. echo '' >> /etc/Muttrc
  4947. echo '# ctrl-b toggles sidebar visibility' >> /etc/Muttrc
  4948. echo "macro index,pager \Cb '<enter-command>toggle sidebar_visible<enter><redraw-screen>' 'toggle sidebar'" >> /etc/Muttrc
  4949. echo '' >> /etc/Muttrc
  4950. echo '# esc-m Mark new messages as read' >> /etc/Muttrc
  4951. echo 'macro index <esc>m "T~N<enter>;WNT~O<enter>;WO\CT~T<enter>" "mark all messages read"' >> /etc/Muttrc
  4952. echo '' >> /etc/Muttrc
  4953. echo '# Collapsing threads' >> /etc/Muttrc
  4954. echo 'macro index [ "<collapse-thread>" "collapse/uncollapse thread"' >> /etc/Muttrc
  4955. echo 'macro index ] "<collapse-all>" "collapse/uncollapse all threads"' >> /etc/Muttrc
  4956. echo '' >> /etc/Muttrc
  4957. echo '# threads containing new messages' >> /etc/Muttrc
  4958. echo 'uncolor index "~(~N)"' >> /etc/Muttrc
  4959. echo 'color index brightblue default "~(~N)"' >> /etc/Muttrc
  4960. echo '' >> /etc/Muttrc
  4961. echo '# new messages themselves' >> /etc/Muttrc
  4962. echo 'uncolor index "~N"' >> /etc/Muttrc
  4963. echo 'color index brightyellow default "~N"' >> /etc/Muttrc
  4964. echo '' >> /etc/Muttrc
  4965. echo '# GPG/PGP integration' >> /etc/Muttrc
  4966. echo '# this set the number of seconds to keep in memory the passphrase used to encrypt/sign' >> /etc/Muttrc
  4967. echo 'set pgp_timeout=1800' >> /etc/Muttrc
  4968. echo '' >> /etc/Muttrc
  4969. echo '# automatically sign and encrypt with PGP/MIME' >> /etc/Muttrc
  4970. echo 'set pgp_autosign # autosign all outgoing mails' >> /etc/Muttrc
  4971. echo 'set pgp_autoencrypt # Try to encrypt automatically' >> /etc/Muttrc
  4972. echo 'set pgp_replyencrypt # autocrypt replies to crypted' >> /etc/Muttrc
  4973. echo 'set pgp_replysign # autosign replies to signed' >> /etc/Muttrc
  4974. echo 'set pgp_auto_decode=yes # decode attachments' >> /etc/Muttrc
  4975. echo 'set fcc_clear=no # Keep encrypted copy of sent encrypted mail' >> /etc/Muttrc
  4976. echo 'unset smime_is_default' >> /etc/Muttrc
  4977. echo '' >> /etc/Muttrc
  4978. echo 'set alias_file=~/.mutt-alias' >> /etc/Muttrc
  4979. echo 'source ~/.mutt-alias' >> /etc/Muttrc
  4980. echo 'set query_command= "abook --mutt-query \"%s\""' >> /etc/Muttrc
  4981. echo 'macro index,pager A "<pipe-message>abook --add-email-quiet<return>" "add the sender address to abook"' >> /etc/Muttrc
  4982. echo '' >> /etc/Muttrc
  4983. echo '# Optional relay of SMTP via ISP' >> /etc/Muttrc
  4984. echo '#set smtp_url="smtps://username:password@isp_mail_domain:465/"' >> /etc/Muttrc
  4985. # create an Emacs configuration specifically for use with Mutt, which
  4986. # has word wrap and spell checking on by default
  4987. echo "(add-hook 'before-save-hook 'delete-trailing-whitespace)" > /home/$MY_USERNAME/.emacs-mutt
  4988. echo '(setq org-support-shift-select t)' >> /home/$MY_USERNAME/.emacs-mutt
  4989. echo '(setq standard-indent 4)' >> /home/$MY_USERNAME/.emacs-mutt
  4990. echo '(setq-default tab-width 4)' >> /home/$MY_USERNAME/.emacs-mutt
  4991. echo '(setq c-basic-offset 4)' >> /home/$MY_USERNAME/.emacs-mutt
  4992. echo '(mouse-wheel-mode t)' >> /home/$MY_USERNAME/.emacs-mutt
  4993. echo '(setq make-backup-files t)' >> /home/$MY_USERNAME/.emacs-mutt
  4994. echo '(setq version-control t)' >> /home/$MY_USERNAME/.emacs-mutt
  4995. echo '(setq backup-directory-alist (quote ((".*" . "~/.emacs_backups/"))))' >> /home/$MY_USERNAME/.emacs-mutt
  4996. echo "(setq default-major-mode 'text-mode)" >> /home/$MY_USERNAME/.emacs-mutt
  4997. echo "(dolist (hook '(text-mode-hook))" >> /home/$MY_USERNAME/.emacs-mutt
  4998. echo ' (add-hook hook (lambda () (flyspell-mode 1))))' >> /home/$MY_USERNAME/.emacs-mutt
  4999. echo '(setq-default fill-column 72)' >> /home/$MY_USERNAME/.emacs-mutt
  5000. echo '(setq auto-fill-mode 0)' >> /home/$MY_USERNAME/.emacs-mutt
  5001. echo "(add-hook 'text-mode-hook 'turn-on-auto-fill)" >> /home/$MY_USERNAME/.emacs-mutt
  5002. echo "(setq-default auto-fill-function 'do-auto-fill)" >> /home/$MY_USERNAME/.emacs-mutt
  5003. # add the emacs mutt configuration to the user profile skeleton
  5004. if [ ! -f /etc/skel/.emacs-mutt ]; then
  5005. cp /home/$MY_USERNAME/.emacs-mutt /etc/skel/.emacs-mutt
  5006. chown root:root /etc/skel/.emacs-mutt
  5007. fi
  5008. cp -f /etc/Muttrc /home/$MY_USERNAME/.muttrc
  5009. cp -f /etc/Muttrc /etc/skel/.muttrc
  5010. touch /home/$MY_USERNAME/.mutt-alias
  5011. cp /home/$MY_USERNAME/.mutt-alias /etc/skel/.mutt-alias
  5012. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.emacs-mutt
  5013. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.muttrc
  5014. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.mutt-alias
  5015. # default user on generic images
  5016. if [ -d /home/${GENERIC_IMAGE_USERNAME} ]; then
  5017. cp -f /etc/Muttrc /home/${GENERIC_IMAGE_USERNAME}/.muttrc
  5018. chown ${GENERIC_IMAGE_USERNAME}:${GENERIC_IMAGE_USERNAME} /home/${GENERIC_IMAGE_USERNAME}/.muttrc
  5019. touch /home/${GENERIC_IMAGE_USERNAME}/.mutt-alias
  5020. chown ${GENERIC_IMAGE_USERNAME}:${GENERIC_IMAGE_USERNAME} /home/${GENERIC_IMAGE_USERNAME}/.mutt-alias
  5021. cp /etc/skel/.emacs-mutt /home/${GENERIC_IMAGE_USERNAME}/.emacs-mutt
  5022. chown ${GENERIC_IMAGE_USERNAME}:${GENERIC_IMAGE_USERNAME} /home/${GENERIC_IMAGE_USERNAME}/.emacs-mutt
  5023. fi
  5024. echo 'email_client' >> $COMPLETION_FILE
  5025. }
  5026. function email_archiving {
  5027. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5028. return
  5029. fi
  5030. # ensure that the mail archive script is up to date
  5031. if [ -f /usr/local/bin/${PROJECT_NAME}-archive-mail ]; then
  5032. cp /usr/local/bin/${PROJECT_NAME}-archive-mail /etc/cron.daily/archivemail
  5033. else
  5034. if [ -f /usr/bin/${PROJECT_NAME}-archive-mail ]; then
  5035. cp /usr/bin/${PROJECT_NAME}-archive-mail /etc/cron.daily/archivemail
  5036. else
  5037. echo "/usr/bin/${PROJECT_NAME}-archive-mail was not found. ${PROJECT_NAME} might not have fully installed."
  5038. exit 62379
  5039. fi
  5040. fi
  5041. chmod +x /etc/cron.daily/archivemail
  5042. # update to the next commit
  5043. set_repo_commit $INSTALL_DIR/cleanup-maildir "cleanup-maildir commit" "$CLEANUP_MAILDIR_COMMIT" $CLEANUP_MAILDIR_REPO
  5044. if grep -Fxq "email_archiving" $COMPLETION_FILE; then
  5045. return
  5046. fi
  5047. if [ ! -d $INSTALL_DIR ]; then
  5048. mkdir $INSTALL_DIR
  5049. fi
  5050. cd $INSTALL_DIR
  5051. git_clone $CLEANUP_MAILDIR_REPO $INSTALL_DIR/cleanup-maildir
  5052. cd $INSTALL_DIR/cleanup-maildir
  5053. git checkout $CLEANUP_MAILDIR_COMMIT -b $CLEANUP_MAILDIR_COMMIT
  5054. if ! grep -q "cleanup-maildir commit" $COMPLETION_FILE; then
  5055. echo "cleanup-maildir commit:$CLEANUP_MAILDIR_COMMIT" >> $COMPLETION_FILE
  5056. else
  5057. sed -i "s/cleanup-maildir commit.*/cleanup-maildir commit:$CLEANUP_MAILDIR_COMMIT/g" $COMPLETION_FILE
  5058. fi
  5059. cp $INSTALL_DIR/cleanup-maildir/cleanup-maildir /usr/bin
  5060. echo 'email_archiving' >> $COMPLETION_FILE
  5061. }
  5062. # Ensure that the from field is correct when sending email from Mutt
  5063. function email_from_address {
  5064. if grep -Fxq "email_from_address" $COMPLETION_FILE; then
  5065. return
  5066. fi
  5067. if [ ! -f /home/$MY_USERNAME/.muttrc ]; then
  5068. return
  5069. fi
  5070. if grep -q "set from=" /home/$MY_USERNAME/.muttrc; then
  5071. sed -i "s|set from=.*|set from='$MY_NAME <$MY_EMAIL_ADDRESS>'|g" /home/$MY_USERNAME/.muttrc
  5072. else
  5073. echo "set from='$MY_NAME <$MY_EMAIL_ADDRESS>'" >> /home/$MY_USERNAME/.muttrc
  5074. fi
  5075. echo 'email_from_address' >> $COMPLETION_FILE
  5076. }
  5077. function create_public_mailing_list {
  5078. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5079. return
  5080. fi
  5081. if grep -Fxq "create_public_mailing_list" $COMPLETION_FILE; then
  5082. return
  5083. fi
  5084. if [ ! $PUBLIC_MAILING_LIST ]; then
  5085. return
  5086. fi
  5087. # does the mailing list have a separate domain name?
  5088. if [ ! $PUBLIC_MAILING_LIST_DOMAIN_NAME ]; then
  5089. PUBLIC_MAILING_LIST_DOMAIN_NAME=$DEFAULT_DOMAIN_NAME
  5090. fi
  5091. PUBLIC_MAILING_LIST_USER="mlmmj"
  5092. apt-get -y install mlmmj
  5093. adduser --system $PUBLIC_MAILING_LIST_USER
  5094. addgroup $PUBLIC_MAILING_LIST_USER
  5095. adduser $PUBLIC_MAILING_LIST_USER $PUBLIC_MAILING_LIST_USER
  5096. echo ''
  5097. echo $"Creating the $PUBLIC_MAILING_LIST mailing list"
  5098. echo ''
  5099. # create the list
  5100. mlmmj-make-ml -a -L "$PUBLIC_MAILING_LIST" -c $PUBLIC_MAILING_LIST_USER
  5101. echo 'SYSTEM_ALIASES_PIPE_TRANSPORT = address_pipe' > /etc/exim4/conf.d/main/000_localmacros
  5102. echo "SYSTEM_ALIASES_USER = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  5103. echo "SYSTEM_ALIASES_GROUP = $PUBLIC_MAILING_LIST_USER" >> /etc/exim4/conf.d/main/000_localmacros
  5104. # router
  5105. echo 'mlmmj_router:' > /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5106. echo ' debug_print = "R: mlmmj_router for $local_part@$domain"' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5107. echo ' driver = accept' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5108. echo ' domains = +mlmmj_domains' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5109. echo ' #require_files = MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5110. 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
  5111. echo ' # Exim will then spawn a new process running under the UID of "mlmmj".' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5112. echo ' require_files = mlmmj:MLMMJ_HOME/${lc::$local_part}' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5113. echo ' local_part_suffix = +*' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5114. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5115. echo ' headers_remove = Delivered-To' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5116. echo ' headers_add = Delivered-To: $local_part$local_part_suffix@$domain' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5117. echo ' transport = mlmmj_transport' >> /etc/exim4/conf.d/router/750_exim4-config_mlmmj
  5118. # transport
  5119. echo 'mlmmj_transport:' > /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5120. echo ' debug_print = "T: mlmmj_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5121. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5122. echo ' return_path_add' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5123. echo ' user = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5124. echo ' group = mlmmj' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5125. echo ' home_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5126. echo ' current_directory = MLMMJ_HOME' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5127. echo ' command = /usr/bin/mlmmj-receive -F -L MLMMJ_HOME/${lc:$local_part}' >> /etc/exim4/conf.d/transport/40_exim4-config_mlmmj
  5128. if ! grep -q "MLMMJ_HOME=/var/spool/mlmmj" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5129. sed -i '/MAIN CONFIGURATION SETTINGS/a\MLMMJ_HOME=/var/spool/mlmmj' /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5130. fi
  5131. if ! grep -q "domainlist mlmmj_domains =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5132. sed -i "/MLMMJ_HOME/a\domainlist mlmmj_domains = $PUBLIC_MAILING_LIST_DOMAIN_NAME" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs
  5133. fi
  5134. if ! grep -q "delay_warning_condition =" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5135. 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
  5136. fi
  5137. if ! grep -q ": +mlmmj_domains" /etc/exim4/conf.d/main/01_exim4-config_listmacrosdefs; then
  5138. 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
  5139. fi
  5140. if ! grep -q "! +mlmmj_domains" /etc/exim4/conf.d/router/200_exim4-config_primary; then
  5141. sed -i 's/domains = ! +local_domains/domains = ! +mlmmj_domains : ! +local_domains/g' /etc/exim4/conf.d/router/200_exim4-config_primary
  5142. fi
  5143. newaliases
  5144. update-exim4.conf.template -r
  5145. update-exim4.conf
  5146. systemctl restart exim4
  5147. if ! grep -q $"$PUBLIC_MAILING_LIST mailing list" /home/$MY_USERNAME/README; then
  5148. echo '' >> /home/$MY_USERNAME/README
  5149. echo '' >> /home/$MY_USERNAME/README
  5150. echo $"$PUBLIC_MAILING_LIST mailing list" >> /home/$MY_USERNAME/README
  5151. echo '=================================' >> /home/$MY_USERNAME/README
  5152. echo $"To subscribe to the $PUBLIC_MAILING_LIST mailing list send a" >> /home/$MY_USERNAME/README
  5153. echo $"cleartext email to $PUBLIC_MAILING_LIST+subscribe@$DEFAULT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  5154. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5155. chmod 600 /home/$MY_USERNAME/README
  5156. fi
  5157. ${PROJECT_NAME}-addlist -u $MY_USERNAME -l "$PUBLIC_MAILING_LIST" -s "$PUBLIC_MAILING_LIST"
  5158. echo 'create_public_mailing_list' >> $COMPLETION_FILE
  5159. }
  5160. function create_private_mailing_list {
  5161. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5162. return
  5163. fi
  5164. # This installation doesn't work, results in ruby errors
  5165. # There is currently no schleuder package for Debian jessie
  5166. if grep -Fxq "create_private_mailing_list" $COMPLETION_FILE; then
  5167. return
  5168. fi
  5169. if [ ! $PRIVATE_MAILING_LIST ]; then
  5170. return
  5171. fi
  5172. if [[ $PRIVATE_MAILING_LIST == $MY_USERNAME ]]; then
  5173. echo $'The name of the private mailing list should not be the same as your username'
  5174. exit 10
  5175. fi
  5176. if [ ! $MY_GPG_PUBLIC_KEY ]; then
  5177. echo $'To create a private mailing list you need to specify a file'
  5178. echo $'containing your exported GPG key within MY_GPG_PUBLIC_KEY at'
  5179. echo $'the top of the script'
  5180. exit 11
  5181. fi
  5182. apt-get -y install ruby ruby-dev ruby-gpgme libgpgme11-dev libmagic-dev
  5183. gem install schleuder
  5184. schleuder-fix-gem-dependencies
  5185. schleuder-init-setup --gem
  5186. # NOTE: this is version number sensitive and so might need changing
  5187. ln -s /var/lib/gems/2.1.0/gems/schleuder-2.2.4 /var/lib/schleuder
  5188. sed -i 's/#smtp_port: 25/smtp_port: 465/g' /etc/schleuder/schleuder.conf
  5189. sed -i 's/#superadminaddr: root@localhost/superadminaddr: root@localhost' /etc/schleuder/schleuder.conf
  5190. 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
  5191. ${PROJECT_NAME}-addemail -u $MY_USERNAME -e $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME -l $PRIVATE_MAILING_LIST
  5192. echo 'schleuder:' > /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5193. echo ' debug_print = "R: schleuder for $local_part@$domain"' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5194. echo ' driver = accept' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5195. echo ' local_part_suffix_optional' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5196. echo ' local_part_suffix = +* : -bounce : -sendkey' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5197. echo ' domains = +local_domains' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5198. echo ' user = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5199. echo ' group = schleuder' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5200. echo ' require_files = schleuder:+/var/lib/schleuder/$domain/${local_part}' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5201. echo ' transport = schleuder_transport' >> /etc/exim4/conf.d/router/550_exim4-config_schleuder
  5202. echo 'schleuder_transport:' > /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5203. echo ' debug_print = "T: schleuder_transport for $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5204. echo ' driver = pipe' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5205. echo ' home_directory = "/var/lib/schleuder/$domain/$local_part"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5206. echo ' command = "/usr/bin/schleuder $local_part@$domain"' >> /etc/exim4/conf.d/transport/30_exim4-config_schleuder
  5207. chown -R schleuder:schleuder /var/lib/schleuder
  5208. update-exim4.conf.template -r
  5209. update-exim4.conf
  5210. systemctl restart exim4
  5211. useradd -d /var/schleuderlists -s /bin/false schleuder
  5212. adduser Debian-exim schleuder
  5213. usermod -a -G mail schleuder
  5214. #exim -d -bt $PRIVATE_MAILING_LIST@$DEFAULT_DOMAIN_NAME
  5215. echo 'create_private_mailing_list' >> $COMPLETION_FILE
  5216. }
  5217. function split_gpg_key_into_fragments {
  5218. # split the gpg key into fragments if social key management is enabled
  5219. if [[ $ENABLE_SOCIAL_KEY_MANAGEMENT == "yes" ]]; then
  5220. echo 'Splitting GPG key. You may need to enter your passphrase.'
  5221. ${PROJECT_NAME}-splitkey -u $MY_USERNAME -e $MY_EMAIL_ADDRESS --fullname "$MY_NAME"
  5222. if [ ! -d /home/$MY_USERNAME/.gnupg_fragments ]; then
  5223. echo 'Yhe GPG key could not be split'
  5224. exit 86548
  5225. fi
  5226. fi
  5227. }
  5228. function import_email {
  5229. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_NONMAILBOX" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  5230. return
  5231. fi
  5232. EMAIL_COMPLETE_MSG=$"
  5233. *** ${PROJECT_NAME} mailbox installation is complete ***
  5234. Now on your internet router forward ports
  5235. 25, 587, 465, 993 and 2222 to the ${PROJECT_NAME}
  5236. "
  5237. if grep -Fxq "import_email" $COMPLETION_FILE; then
  5238. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  5239. backup_to_friends_servers
  5240. intrusion_detection
  5241. split_gpg_key_into_fragments
  5242. clear
  5243. echo ''
  5244. echo "$EMAIL_COMPLETE_MSG"
  5245. if [ -d $USB_MOUNT ]; then
  5246. umount $USB_MOUNT
  5247. rm -rf $USB_MOUNT
  5248. echo $' You can now remove the USB drive'
  5249. fi
  5250. exit 0
  5251. fi
  5252. return
  5253. fi
  5254. if [ $IMPORT_MAILDIR ]; then
  5255. if [ -d $IMPORT_MAILDIR ]; then
  5256. echo $'Transfering email files'
  5257. cp -r $IMPORT_MAILDIR /home/$MY_USERNAME
  5258. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/Maildir
  5259. else
  5260. echo $"Email import directory $IMPORT_MAILDIR not found"
  5261. exit 9
  5262. fi
  5263. fi
  5264. echo 'import_email' >> $COMPLETION_FILE
  5265. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  5266. backup_to_friends_servers
  5267. intrusion_detection
  5268. split_gpg_key_into_fragments
  5269. # unmount any attached usb drive
  5270. clear
  5271. echo ''
  5272. echo "$EMAIL_COMPLETE_MSG"
  5273. echo ''
  5274. if [ -d $USB_MOUNT ]; then
  5275. umount $USB_MOUNT
  5276. rm -rf $USB_MOUNT
  5277. echo $' You can now remove the USB drive'
  5278. fi
  5279. exit 0
  5280. fi
  5281. }
  5282. function install_web_server {
  5283. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" ]]; then
  5284. return
  5285. fi
  5286. # update to the next commit
  5287. set_repo_commit $INSTALL_DIR/nginx_ensite "Nginx-ensite commit" "$NGINX_ENSITE_COMMIT" $NGINX_ENSITE_REPO
  5288. if grep -Fxq "install_web_server" $COMPLETION_FILE; then
  5289. return
  5290. fi
  5291. # remove apache
  5292. apt-get -y remove --purge apache2
  5293. if [ -d /etc/apache2 ]; then
  5294. rm -rf /etc/apache2
  5295. fi
  5296. # install nginx
  5297. apt-get -y install nginx php5-fpm git
  5298. # limit the number of php processes
  5299. sed -i 's/; process.max =.*/process.max = 32/g' /etc/php5/fpm/php-fpm.conf
  5300. sed -i 's/;process_control_timeout =.*/process_control_timeout = 300/g' /etc/php5/fpm/php-fpm.conf
  5301. if ! grep -q "pm.max_children" /etc/php5/fpm/php-fpm.conf; then
  5302. echo 'pm.max_children = 10' >> /etc/php5/fpm/php-fpm.conf
  5303. echo 'pm.start_servers = 2' >> /etc/php5/fpm/php-fpm.conf
  5304. echo 'pm.min_spare_servers = 2' >> /etc/php5/fpm/php-fpm.conf
  5305. echo 'pm.max_spare_servers = 5' >> /etc/php5/fpm/php-fpm.conf
  5306. echo 'pm.max_requests = 50' >> /etc/php5/fpm/php-fpm.conf
  5307. fi
  5308. if [ ! -d /etc/nginx ]; then
  5309. echo $"ERROR: nginx does not appear to have installed. $CHECK_MESSAGE"
  5310. exit 51
  5311. fi
  5312. # Nginx settings
  5313. echo 'user www-data;' > /etc/nginx/nginx.conf
  5314. #echo "worker_processes; $CPU_CORES" >> /etc/nginx/nginx.conf
  5315. echo 'pid /run/nginx.pid;' >> /etc/nginx/nginx.conf
  5316. echo '' >> /etc/nginx/nginx.conf
  5317. echo 'events {' >> /etc/nginx/nginx.conf
  5318. echo ' worker_connections 50;' >> /etc/nginx/nginx.conf
  5319. echo ' # multi_accept on;' >> /etc/nginx/nginx.conf
  5320. echo '}' >> /etc/nginx/nginx.conf
  5321. echo '' >> /etc/nginx/nginx.conf
  5322. echo 'http {' >> /etc/nginx/nginx.conf
  5323. echo ' # limit the number of connections per single IP' >> /etc/nginx/nginx.conf
  5324. echo ' limit_conn_zone $binary_remote_addr zone=conn_limit_per_ip:10m;' >> /etc/nginx/nginx.conf
  5325. echo '' >> /etc/nginx/nginx.conf
  5326. echo ' # limit the number of requests for a given session' >> /etc/nginx/nginx.conf
  5327. echo ' limit_req_zone $binary_remote_addr zone=req_limit_per_ip:10m rate=140r/s;' >> /etc/nginx/nginx.conf
  5328. echo '' >> /etc/nginx/nginx.conf
  5329. 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
  5330. echo ' client_body_buffer_size 128k;' >> /etc/nginx/nginx.conf
  5331. echo '' >> /etc/nginx/nginx.conf
  5332. echo ' # headerbuffer size for the request header from client, its set for testing purpose' >> /etc/nginx/nginx.conf
  5333. echo ' client_header_buffer_size 3m;' >> /etc/nginx/nginx.conf
  5334. echo '' >> /etc/nginx/nginx.conf
  5335. echo ' # maximum number and size of buffers for large headers to read from client request' >> /etc/nginx/nginx.conf
  5336. echo ' large_client_header_buffers 4 256k;' >> /etc/nginx/nginx.conf
  5337. echo '' >> /etc/nginx/nginx.conf
  5338. echo ' # read timeout for the request body from client, its set for testing purpose' >> /etc/nginx/nginx.conf
  5339. echo ' client_body_timeout 3m;' >> /etc/nginx/nginx.conf
  5340. echo '' >> /etc/nginx/nginx.conf
  5341. echo ' # how long to wait for the client to send a request header, its set for testing purpose' >> /etc/nginx/nginx.conf
  5342. echo ' client_header_timeout 3m;' >> /etc/nginx/nginx.conf
  5343. echo '' >> /etc/nginx/nginx.conf
  5344. echo ' ##' >> /etc/nginx/nginx.conf
  5345. echo ' # Basic Settings' >> /etc/nginx/nginx.conf
  5346. echo ' ##' >> /etc/nginx/nginx.conf
  5347. echo '' >> /etc/nginx/nginx.conf
  5348. echo ' sendfile on;' >> /etc/nginx/nginx.conf
  5349. echo ' tcp_nopush on;' >> /etc/nginx/nginx.conf
  5350. echo ' tcp_nodelay on;' >> /etc/nginx/nginx.conf
  5351. echo ' keepalive_timeout 65;' >> /etc/nginx/nginx.conf
  5352. echo ' types_hash_max_size 2048;' >> /etc/nginx/nginx.conf
  5353. echo ' server_tokens off;' >> /etc/nginx/nginx.conf
  5354. echo '' >> /etc/nginx/nginx.conf
  5355. echo ' # server_names_hash_bucket_size 64;' >> /etc/nginx/nginx.conf
  5356. echo ' # server_name_in_redirect off;' >> /etc/nginx/nginx.conf
  5357. echo '' >> /etc/nginx/nginx.conf
  5358. echo ' include /etc/nginx/mime.types;' >> /etc/nginx/nginx.conf
  5359. echo ' default_type application/octet-stream;' >> /etc/nginx/nginx.conf
  5360. echo '' >> /etc/nginx/nginx.conf
  5361. echo ' ##' >> /etc/nginx/nginx.conf
  5362. echo ' # Logging Settings' >> /etc/nginx/nginx.conf
  5363. echo ' ##' >> /etc/nginx/nginx.conf
  5364. echo '' >> /etc/nginx/nginx.conf
  5365. echo ' access_log /var/log/nginx/access.log;' >> /etc/nginx/nginx.conf
  5366. echo ' error_log /var/log/nginx/error.log;' >> /etc/nginx/nginx.conf
  5367. echo '' >> /etc/nginx/nginx.conf
  5368. echo ' ###' >> /etc/nginx/nginx.conf
  5369. echo ' # Gzip Settings' >> /etc/nginx/nginx.conf
  5370. echo ' ##' >> /etc/nginx/nginx.conf
  5371. echo ' gzip on;' >> /etc/nginx/nginx.conf
  5372. echo ' gzip_disable "msie6";' >> /etc/nginx/nginx.conf
  5373. echo '' >> /etc/nginx/nginx.conf
  5374. echo ' # gzip_vary on;' >> /etc/nginx/nginx.conf
  5375. echo ' # gzip_proxied any;' >> /etc/nginx/nginx.conf
  5376. echo ' # gzip_comp_level 6;' >> /etc/nginx/nginx.conf
  5377. echo ' # gzip_buffers 16 8k;' >> /etc/nginx/nginx.conf
  5378. echo ' # gzip_http_version 1.1;' >> /etc/nginx/nginx.conf
  5379. echo ' # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;' >> /etc/nginx/nginx.conf
  5380. echo '' >> /etc/nginx/nginx.conf
  5381. echo ' ##' >> /etc/nginx/nginx.conf
  5382. echo ' # Virtual Host Configs' >> /etc/nginx/nginx.conf
  5383. echo ' ##' >> /etc/nginx/nginx.conf
  5384. echo '' >> /etc/nginx/nginx.conf
  5385. echo ' include /etc/nginx/conf.d/*.conf;' >> /etc/nginx/nginx.conf
  5386. echo ' include /etc/nginx/sites-enabled/*;' >> /etc/nginx/nginx.conf
  5387. echo '}' >> /etc/nginx/nginx.conf
  5388. # install a script to easily enable and disable nginx virtual hosts
  5389. if [ ! -d $INSTALL_DIR ]; then
  5390. mkdir $INSTALL_DIR
  5391. fi
  5392. cd $INSTALL_DIR
  5393. git_clone $NGINX_ENSITE_REPO $INSTALL_DIR/nginx_ensite
  5394. cd $INSTALL_DIR/nginx_ensite
  5395. git checkout $NGINX_ENSITE_COMMIT -b $NGINX_ENSITE_COMMIT
  5396. if ! grep -q "Nginx-ensite commit" $COMPLETION_FILE; then
  5397. echo "Nginx-ensite commit:$NGINX_ENSITE_COMMIT" >> $COMPLETION_FILE
  5398. else
  5399. sed -i "s/Nginx-ensite commit.*/Nginx-ensite commit:$NGINX_ENSITE_COMMIT/g" $COMPLETION_FILE
  5400. fi
  5401. make install
  5402. nginx_dissite default
  5403. echo 'install_web_server' >> $COMPLETION_FILE
  5404. }
  5405. function install_web_server_access_control {
  5406. if [ ! -f /etc/pam.d/nginx ]; then
  5407. echo '#%PAM-1.0' > /etc/pam.d/nginx
  5408. echo '@include common-auth' >> /etc/pam.d/nginx
  5409. echo '@include common-account' >> /etc/pam.d/nginx
  5410. echo '@include common-session' >> /etc/pam.d/nginx
  5411. fi
  5412. }
  5413. function configure_php {
  5414. sed -i "s/memory_limit = 128M/memory_limit = ${MAX_PHP_MEMORY}M/g" /etc/php5/fpm/php.ini
  5415. sed -i 's/;cgi.fix_pathinfo=1/cgi.fix_pathinfo=0/g' /etc/php5/fpm/php.ini
  5416. sed -i "s/memory_limit = -1/memory_limit = ${MAX_PHP_MEMORY}M/g" /etc/php5/cli/php.ini
  5417. sed -i "s/upload_max_filesize = 2M/upload_max_filesize = 50M/g" /etc/php5/fpm/php.ini
  5418. sed -i "s/post_max_size = 8M/post_max_size = 50M/g" /etc/php5/fpm/php.ini
  5419. }
  5420. function install_mariadb {
  5421. if grep -Fxq "install_mariadb" $COMPLETION_FILE; then
  5422. return
  5423. fi
  5424. apt-get -y install python-software-properties debconf-utils
  5425. apt-get -y install software-properties-common
  5426. apt-get -y update
  5427. get_mariadb_password
  5428. if [ ! $MARIADB_PASSWORD ]; then
  5429. if [ -f $IMAGE_PASSWORD_FILE ]; then
  5430. MARIADB_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  5431. else
  5432. MARIADB_PASSWORD="$(openssl rand -base64 32 | cut -c1-30)"
  5433. fi
  5434. echo "$MARIADB_PASSWORD" > $DATABASE_PASSWORD_FILE
  5435. chmod 600 $DATABASE_PASSWORD_FILE
  5436. echo '' >> /home/$MY_USERNAME/README
  5437. echo '' >> /home/$MY_USERNAME/README
  5438. echo 'MariaDB / MySql' >> /home/$MY_USERNAME/README
  5439. echo '===============' >> /home/$MY_USERNAME/README
  5440. echo $"Your MariaDB password is: $MARIADB_PASSWORD" >> /home/$MY_USERNAME/README
  5441. echo '' >> /home/$MY_USERNAME/README
  5442. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5443. chmod 600 /home/$MY_USERNAME/README
  5444. fi
  5445. debconf-set-selections <<< "mariadb-server mariadb-server/root_password password $MARIADB_PASSWORD"
  5446. debconf-set-selections <<< "mariadb-server mariadb-server/root_password_again password $MARIADB_PASSWORD"
  5447. apt-get -y install mariadb-server
  5448. apt-get -y remove --purge apache*
  5449. if [ -d /etc/apache2 ]; then
  5450. rm -rf /etc/apache2
  5451. echo $'Removed Apache installation after MariaDB install'
  5452. fi
  5453. if [ ! -d /etc/mysql ]; then
  5454. echo $"ERROR: mariadb-server does not appear to have installed. $CHECK_MESSAGE"
  5455. exit 54
  5456. fi
  5457. mysqladmin -u root password "$MARIADB_PASSWORD"
  5458. echo 'install_mariadb' >> $COMPLETION_FILE
  5459. }
  5460. function backup_databases_script_header {
  5461. if [ ! -f /usr/bin/backupdatabases ]; then
  5462. # daily
  5463. echo '#!/bin/sh' > /usr/bin/backupdatabases
  5464. echo '' >> /usr/bin/backupdatabases
  5465. echo "EMAIL='$MY_EMAIL_ADDRESS'" >> /usr/bin/backupdatabases
  5466. echo '' >> /usr/bin/backupdatabases
  5467. echo -n 'MYSQL_PASSWORD=$(cat ' >> /usr/bin/backupdatabases
  5468. echo "$DATABASE_PASSWORD_FILE)" >> /usr/bin/backupdatabases
  5469. echo 'umask 0077' >> /usr/bin/backupdatabases
  5470. echo '' >> /usr/bin/backupdatabases
  5471. echo '# exit if we are backing up to friends servers' >> /usr/bin/backupdatabases
  5472. echo "if [ -f $FRIENDS_SERVERS_LIST ]; then" >> /usr/bin/backupdatabases
  5473. echo ' exit 1' >> /usr/bin/backupdatabases
  5474. echo 'fi' >> /usr/bin/backupdatabases
  5475. chmod 600 /usr/bin/backupdatabases
  5476. chmod +x /usr/bin/backupdatabases
  5477. echo '#!/bin/sh' > /etc/cron.daily/backupdatabasesdaily
  5478. echo '/usr/bin/backupdatabases' >> /etc/cron.daily/backupdatabasesdaily
  5479. chmod 600 /etc/cron.daily/backupdatabasesdaily
  5480. chmod +x /etc/cron.daily/backupdatabasesdaily
  5481. # weekly
  5482. echo '#!/bin/sh' > /etc/cron.weekly/backupdatabasesweekly
  5483. echo '' >> /etc/cron.weekly/backupdatabasesweekly
  5484. echo 'umask 0077' >> /etc/cron.weekly/backupdatabasesweekly
  5485. chmod 600 /etc/cron.weekly/backupdatabasesweekly
  5486. chmod +x /etc/cron.weekly/backupdatabasesweekly
  5487. # monthly
  5488. echo '#!/bin/sh' > /etc/cron.monthly/backupdatabasesmonthly
  5489. echo '' >> /etc/cron.monthly/backupdatabasesmonthly
  5490. echo 'umask 0077' >> /etc/cron.monthly/backupdatabasesmonthly
  5491. chmod 600 /etc/cron.monthly/backupdatabasesmonthly
  5492. chmod +x /etc/cron.monthly/backupdatabasesmonthly
  5493. fi
  5494. }
  5495. function repair_databases_script {
  5496. if [ -f /etc/cron.hourly/repair ]; then
  5497. sed -i "s|/usr/bin/repairdatabase|${PROJECT_NAME}-repair-database|g" /etc/cron.hourly/repair
  5498. fi
  5499. if grep -Fxq "repair_databases_script" $COMPLETION_FILE; then
  5500. return
  5501. fi
  5502. if [ ! -f $DATABASE_PASSWORD_FILE ]; then
  5503. return
  5504. fi
  5505. echo '#!/bin/bash' > /etc/cron.hourly/repair
  5506. echo '' >> /etc/cron.hourly/repair
  5507. chmod 600 /etc/cron.hourly/repair
  5508. chmod +x /etc/cron.hourly/repair
  5509. echo 'repair_databases_script' >> $COMPLETION_FILE
  5510. }
  5511. function add_ddns_domain {
  5512. if [ ! $1 ]; then
  5513. echo $'ddns domain not specified'
  5514. exit 5638
  5515. fi
  5516. CURRENT_DDNS_DOMAIN="$1"
  5517. if [[ $ONION_ONLY != "no" ]]; then
  5518. return
  5519. fi
  5520. if [ ! -f /etc/inadyn.conf ]; then
  5521. echo $'Unable to find inadyn configuration file /etc/inadyn.conf'
  5522. exit 5745
  5523. fi
  5524. if ! grep -q "$DDNS_PROVIDER" /etc/inadyn.conf; then
  5525. echo '' >> /etc/inadyn.conf
  5526. echo "system $DDNS_PROVIDER" >> /etc/inadyn.conf
  5527. echo ' ssl' >> /etc/inadyn.conf
  5528. echo " checkip-url $GET_IP_ADDRESS_URL /" >> /etc/inadyn.conf
  5529. if [ $DDNS_USERNAME ]; then
  5530. echo " username $DDNS_USERNAME" >> /etc/inadyn.conf
  5531. fi
  5532. if [ $DDNS_PASSWORD ]; then
  5533. echo " password $DDNS_PASSWORD" >> /etc/inadyn.conf
  5534. fi
  5535. fi
  5536. if ! grep -q "$CURRENT_DDNS_DOMAIN" /etc/inadyn.conf; then
  5537. echo " alias $CURRENT_DDNS_DOMAIN" >> /etc/inadyn.conf
  5538. fi
  5539. chmod 600 /etc/inadyn.conf
  5540. systemctl restart inadyn
  5541. systemctl daemon-reload
  5542. }
  5543. function install_syncthing {
  5544. 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
  5545. return
  5546. fi
  5547. if grep -Fxq "install_syncthing" $COMPLETION_FILE; then
  5548. return
  5549. fi
  5550. apt-get -y install curl
  5551. curl -s https://syncthing.net/release-key.txt | apt-key add -
  5552. echo "deb http://apt.syncthing.net/ syncthing release" | tee /etc/apt/sources.list.d/syncthing.list
  5553. apt-get update
  5554. apt-get -y install syncthing
  5555. # This probably does need to run as root so that it can access the Sync directories
  5556. # in each user's home directory
  5557. echo '[Unit]' > /etc/systemd/system/syncthing.service
  5558. echo 'Description=Syncthing - Open Source Continuous File Synchronization' >> /etc/systemd/system/syncthing.service
  5559. echo 'Documentation=man:syncthing(1)' >> /etc/systemd/system/syncthing.service
  5560. echo 'After=network.target' >> /etc/systemd/system/syncthing.service
  5561. echo 'Wants=syncthing-inotify@.service' >> /etc/systemd/system/syncthing.service
  5562. echo '' >> /etc/systemd/system/syncthing.service
  5563. echo '[Service]' >> /etc/systemd/system/syncthing.service
  5564. echo 'User=root' >> /etc/systemd/system/syncthing.service
  5565. echo 'ExecStart=/usr/bin/syncthing -no-browser -no-restart -logflags=0' >> /etc/systemd/system/syncthing.service
  5566. echo 'Restart=on-failure' >> /etc/systemd/system/syncthing.service
  5567. echo 'SuccessExitStatus=3 4' >> /etc/systemd/system/syncthing.service
  5568. echo 'RestartForceExitStatus=3 4' >> /etc/systemd/system/syncthing.service
  5569. echo '' >> /etc/systemd/system/syncthing.service
  5570. echo '[Install]' >> /etc/systemd/system/syncthing.service
  5571. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/syncthing.service
  5572. systemctl enable syncthing
  5573. systemctl daemon-reload
  5574. systemctl start syncthing
  5575. if ! grep -q "syncthing" /etc/crontab; then
  5576. echo "*/1 * * * * root /usr/local/bin/freedombone-syncthing > /dev/null" >> /etc/crontab
  5577. systemctl restart cron
  5578. fi
  5579. echo 'install_syncthing' >> $COMPLETION_FILE
  5580. }
  5581. function upgrade_golang {
  5582. 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
  5583. return
  5584. fi
  5585. # NOTE: this is annoyingly hacky and going in the opposite
  5586. # direction of a pure blend, but it's necessary if you want
  5587. # to run the latest version of gogs
  5588. # update to the next commit
  5589. set_repo_commit $INSTALL_DIR/gvm "gvm commit" "$GVM_COMMIT" $GVM_REPO
  5590. if grep -Fxq "upgrade_golang" $COMPLETION_FILE; then
  5591. return
  5592. fi
  5593. apt-get -y install curl git mercurial make binutils bison gcc build-essential
  5594. if [ ! -d $INSTALL_DIR ]; then
  5595. mkdir $INSTALL_DIR
  5596. fi
  5597. cd $INSTALL_DIR
  5598. git_clone $GVM_REPO gvm
  5599. cd $INSTALL_DIR/gvm
  5600. git checkout $GVM_COMMIT -b $GVM_COMMIT
  5601. if [ ! -f binscripts/gvm-installer ]; then
  5602. echo $'gvm installer not found'
  5603. fi
  5604. chmod +x binscripts/gvm-installer
  5605. # TODO: this script is all over the place
  5606. # and contains hardcoded github. See if you can do better
  5607. ./binscripts/gvm-installer
  5608. [[ -s "$HOME/.gvm/scripts/gvm" ]] && source "$HOME/.gvm/scripts/gvm"
  5609. gvm install go1.4
  5610. gvm use go1.4
  5611. export GOROOT_BOOTSTRAP=$GOROOT
  5612. gvm install go1.5
  5613. if [ ! "$?" = "0" ]; then
  5614. echo $'Unable to upgrade golang'
  5615. exit 529252
  5616. fi
  5617. gvm use go1.5 --default
  5618. if ! grep -q "gvm commit" $COMPLETION_FILE; then
  5619. echo "gvm commit:$GVM_COMMIT" >> $COMPLETION_FILE
  5620. else
  5621. sed -i "s/gvm commit.*/gvm commit:$GVM_COMMIT/g" $COMPLETION_FILE
  5622. fi
  5623. echo 'upgrade_golang' >> $COMPLETION_FILE
  5624. }
  5625. function install_gogs {
  5626. 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
  5627. return
  5628. fi
  5629. if [ ! $GIT_DOMAIN_NAME ]; then
  5630. return
  5631. fi
  5632. export GOPATH=/home/git/go
  5633. systemctl set-environment GOPATH=/home/git/go
  5634. # update to the next commit
  5635. set_repo_commit $GOPATH/src/github.com/gogits/gogs "Gogs commit" "$GOGS_COMMIT" $GIT_DOMAIN_REPO
  5636. if grep -Fxq "install_gogs" $COMPLETION_FILE; then
  5637. return
  5638. fi
  5639. # http://gogs.io/docs/installation/install_from_source.md
  5640. # add a gogs user account
  5641. adduser --disabled-login --gecos 'Gogs' git
  5642. # install Go
  5643. apt-get -y install golang libpam0g-dev
  5644. if ! grep -q "export GOPATH=/home/git/go" ~/.bashrc; then
  5645. echo 'export GOPATH=/home/git/go' >> ~/.bashrc
  5646. echo 'systemctl set-environment GOPATH=/home/git/go' >> ~/.bashrc
  5647. fi
  5648. if [ ! -d $GOPATH ]; then
  5649. mkdir -p $GOPATH
  5650. fi
  5651. GO_PACKAGE_MANAGER_REPO2=$(echo "$GO_PACKAGE_MANAGER_REPO" | sed 's|https://||g')
  5652. go get -u $GO_PACKAGE_MANAGER_REPO2
  5653. if [ ! "$?" = "0" ]; then
  5654. echo $'install_gogs: go get failed'
  5655. exit 479832
  5656. fi
  5657. # clone the repo
  5658. if [ ! -d $GOPATH/src/github.com/gogits ]; then
  5659. mkdir -p $GOPATH/src/github.com/gogits
  5660. fi
  5661. git_clone $GIT_DOMAIN_REPO $GOPATH/src/github.com/gogits/gogs
  5662. if [ ! -d $GOPATH/src/github.com/gogits/gogs ]; then
  5663. echo $"Unable to clone repo $GOPATH/src/github.com/gogits/gogs"
  5664. exit 85482
  5665. fi
  5666. cd $GOPATH/src/github.com/gogits/gogs
  5667. # install
  5668. go get -u ./...
  5669. git checkout $GOGS_COMMIT -b $GOGS_COMMIT
  5670. if ! grep -q "Gogs commit" $COMPLETION_FILE; then
  5671. echo "Gogs commit:$GOGS_COMMIT" >> $COMPLETION_FILE
  5672. else
  5673. sed -i "s/Gogs commit.*/Gogs commit:$GOGS_COMMIT/g" $COMPLETION_FILE
  5674. fi
  5675. go build
  5676. if [ ! "$?" = "0" ]; then
  5677. echo $'install_gogs: go build failed'
  5678. exit 546750
  5679. fi
  5680. install_mariadb
  5681. get_mariadb_password
  5682. get_mariadb_git_admin_password
  5683. if [ ! $GIT_ADMIN_PASSWORD ]; then
  5684. if [ -f $IMAGE_PASSWORD_FILE ]; then
  5685. GIT_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  5686. else
  5687. GIT_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-30)"
  5688. fi
  5689. fi
  5690. if ! grep -q $"Gogs admin user password" /home/$MY_USERNAME/README; then
  5691. echo '' >> /home/$MY_USERNAME/README
  5692. echo '' >> /home/$MY_USERNAME/README
  5693. echo 'Gogs' >> /home/$MY_USERNAME/README
  5694. echo '====' >> /home/$MY_USERNAME/README
  5695. echo $'Database type: MySql' >> /home/$MY_USERNAME/README
  5696. echo $'Database host: 127.0.0.1:3306' >> /home/$MY_USERNAME/README
  5697. echo $'Database user: root' >> /home/$MY_USERNAME/README
  5698. echo $"Database password: $MARIADB_PASSWORD" >> /home/$MY_USERNAME/README
  5699. echo $'Database name: gogs' >> /home/$MY_USERNAME/README
  5700. echo $'Gogs admin user: gogsadmin' >> /home/$MY_USERNAME/README
  5701. echo $"Gogs admin user password: $GIT_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  5702. echo $"Gogs admin user email: $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/README
  5703. echo '' >> /home/$MY_USERNAME/README
  5704. echo $'Install Steps For First-time Run:' >> /home/$MY_USERNAME/README
  5705. echo $'Leave email service settings empty' >> /home/$MY_USERNAME/README
  5706. echo $'Check "Enable Register Confirmation"' >> /home/$MY_USERNAME/README
  5707. echo $'Check "Enable Mail Notification"' >> /home/$MY_USERNAME/README
  5708. echo '' >> /home/$MY_USERNAME/README
  5709. echo $'After the initial install edit /home/git/go/src/github.com/gogits/gogs/custom/conf/app.ini' >> /home/$MY_USERNAME/README
  5710. echo $'and within the [server] section set:' >> /home/$MY_USERNAME/README
  5711. echo " DOMAIN = $GIT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  5712. echo " ROOT_URL = http://$GIT_DOMAIN_NAME/" >> /home/$MY_USERNAME/README
  5713. echo " SSH_PORT = $SSH_PORT" >> /home/$MY_USERNAME/README
  5714. echo $'If you want to disable new account registrations then append the following:' >> /home/$MY_USERNAME/README
  5715. echo ' [service]' >> /home/$MY_USERNAME/README
  5716. echo ' DISABLE_REGISTRATION = true' >> /home/$MY_USERNAME/README
  5717. echo $'Then restart with:' >> /home/$MY_USERNAME/README
  5718. echo ' systemctl restart gogs' >> /home/$MY_USERNAME/README
  5719. echo '' >> /home/$MY_USERNAME/README
  5720. echo $"Note that there's a usability/security trade-off made here." >> /home/$MY_USERNAME/README
  5721. echo $"In order to allow git clone via http we don't redirect everything" >> /home/$MY_USERNAME/README
  5722. echo $'over https. Instead only critical things such as user login,' >> /home/$MY_USERNAME/README
  5723. echo $'settings and admin are encrypted.' >> /home/$MY_USERNAME/README
  5724. echo $'There are also potential security issues with cloning/pulling/pushing' >> /home/$MY_USERNAME/README
  5725. echo $'code over http, since a determined adversary could inject malware' >> /home/$MY_USERNAME/README
  5726. echo $'into the stream as it passes, so beware.' >> /home/$MY_USERNAME/README
  5727. echo $'If you have a bought domain and a non-self signed cert then you' >> /home/$MY_USERNAME/README
  5728. echo $"should change /etc/nginx/sites-available/$GIT_DOMAIN_NAME to redirect everything over https." >> /home/$MY_USERNAME/README
  5729. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5730. chmod 600 /home/$MY_USERNAME/README
  5731. fi
  5732. create_database gogs "$GOGS_ADMIN_PASSWORD"
  5733. chmod 600 /home/git/go/src/github.com/gogits/gogs/custom/conf/app.ini
  5734. chown -R git:git /home/git
  5735. cp $GOPATH/src/github.com/gogits/gogs/scripts/systemd/gogs.service /etc/systemd/system
  5736. sed -i 's|#After=mysqld.service|After=mysqld.service|g' /etc/systemd/system/gogs.service
  5737. sed -i "s|WorkingDirectory=.*|WorkingDirectory=$GOPATH/src/github.com/gogits/gogs|g" /etc/systemd/system/gogs.service
  5738. sed -i "s|ExecStart=.*|ExecStart=$GOPATH/src/github.com/gogits/gogs/gogs web|g" /etc/systemd/system/gogs.service
  5739. sed -i "s|Environment.*|Environment=\"USER=git\" \"HOME=/home/git\" \"GOPATH=/home/git/go\"|g" /etc/systemd/system/gogs.service
  5740. systemctl enable gogs
  5741. systemctl daemon-reload
  5742. systemctl restart gogs
  5743. if [ ! -d /var/www/$GIT_DOMAIN_NAME ]; then
  5744. mkdir /var/www/$GIT_DOMAIN_NAME
  5745. fi
  5746. if [ -d /var/www/$GIT_DOMAIN_NAME/htdocs ]; then
  5747. rm -rf /var/www/$GIT_DOMAIN_NAME/htdocs
  5748. fi
  5749. if [[ $ONION_ONLY == "no" ]]; then
  5750. echo 'server {' > /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5751. echo ' listen 80;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5752. echo " server_name $GIT_DOMAIN_NAME;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5753. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5754. echo " error_log /var/log/nginx/${GIT_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5755. nginx_disable_sniffing $GIT_DOMAIN_NAME
  5756. nginx_limits $GIT_DOMAIN_NAME
  5757. echo ' location / {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5758. echo ' proxy_pass http://localhost:3000;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5759. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5760. echo ' location ^~ /user/ {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5761. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5762. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5763. echo ' location ^~ /admin/ {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5764. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5765. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5766. echo '}' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5767. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5768. echo 'server {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5769. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5770. echo " root /var/www/$GIT_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5771. echo " server_name $GIT_DOMAIN_NAME;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5772. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5773. echo " error_log /var/log/nginx/${GIT_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5774. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5775. nginx_limits $GIT_DOMAIN_NAME '10G'
  5776. nginx_ssl $GIT_DOMAIN_NAME
  5777. nginx_disable_sniffing $GIT_DOMAIN_NAME
  5778. echo ' add_header Strict-Transport-Security max-age=0;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5779. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5780. echo ' location / {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5781. echo ' proxy_pass http://localhost:3000;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5782. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5783. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5784. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5785. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5786. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5787. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5788. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5789. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5790. echo ' allow all;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5791. echo ' log_not_found off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5792. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5793. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5794. echo '}' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5795. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5796. else
  5797. echo -n '' > /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5798. fi
  5799. echo 'server {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5800. echo " listen 127.0.0.1:${GIT_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5801. echo " root /var/www/$GIT_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5802. echo " server_name $GIT_DOMAIN_NAME;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5803. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5804. echo " error_log /var/log/nginx/${GIT_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5805. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5806. nginx_limits $GIT_DOMAIN_NAME '10G'
  5807. nginx_disable_sniffing $GIT_DOMAIN_NAME
  5808. echo ' add_header Strict-Transport-Security max-age=0;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5809. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5810. echo ' location / {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5811. echo ' proxy_pass http://localhost:3000;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5812. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5813. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5814. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5815. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5816. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5817. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5818. echo '' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5819. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5820. echo ' allow all;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5821. echo ' log_not_found off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5822. echo ' access_log off;' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5823. echo ' }' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5824. echo '}' >> /etc/nginx/sites-available/$GIT_DOMAIN_NAME
  5825. configure_php
  5826. create_site_certificate $GIT_DOMAIN_NAME
  5827. nginx_ensite $GIT_DOMAIN_NAME
  5828. if [ ! -d /var/lib/tor ]; then
  5829. echo $'No Tor installation found. Gogs onion site cannot be configured.'
  5830. exit 877367
  5831. fi
  5832. if ! grep -q "hidden_service_gogs" /etc/tor/torrc; then
  5833. echo 'HiddenServiceDir /var/lib/tor/hidden_service_gogs/' >> /etc/tor/torrc
  5834. echo "HiddenServicePort 80 127.0.0.1:${GIT_ONION_PORT}" >> /etc/tor/torrc
  5835. echo "HiddenServicePort 9418 127.0.0.1:9418" >> /etc/tor/torrc
  5836. echo $'Added onion site for Gogs'
  5837. fi
  5838. systemctl restart tor
  5839. wait_for_onion_service 'gogs'
  5840. GIT_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_gogs/hostname)
  5841. systemctl restart php5-fpm
  5842. systemctl restart nginx
  5843. if ! grep -q "Gogs onion domain" /home/$MY_USERNAME/README; then
  5844. echo "Gogs onion domain: ${GIT_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  5845. echo '' >> /home/$MY_USERNAME/README
  5846. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5847. chmod 600 /home/$MY_USERNAME/README
  5848. fi
  5849. if ! grep -q "Gogs onion domain" $COMPLETION_FILE; then
  5850. echo "Gogs onion domain:${GIT_ONION_HOSTNAME}" >> $COMPLETION_FILE
  5851. fi
  5852. add_ddns_domain $GIT_DOMAIN_NAME
  5853. echo "Gogs domain:$GIT_DOMAIN_NAME" >> $COMPLETION_FILE
  5854. echo 'install_gogs' >> $COMPLETION_FILE
  5855. }
  5856. function tox_avahi {
  5857. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  5858. return
  5859. fi
  5860. if grep -Fxq "tox_avahi" $COMPLETION_FILE; then
  5861. return
  5862. fi
  5863. if [ ! -d /etc/avahi ]; then
  5864. echo $'tox_avahi: avahi is not installed'
  5865. exit 87359
  5866. fi
  5867. # install a command to obtain the Tox ID
  5868. cd $INSTALL_DIR
  5869. git_clone $TOXID_REPO $INSTALL_DIR/toxid
  5870. if [ ! -d $INSTALL_DIR/toxid ]; then
  5871. exit 63921
  5872. fi
  5873. cd $INSTALL_DIR/toxid
  5874. make
  5875. if [ ! "$?" = "0" ]; then
  5876. exit 58432
  5877. fi
  5878. make install
  5879. toxavahi
  5880. # publish regularly
  5881. if ! grep -q "toxavahi" /etc/crontab; then
  5882. echo "* * * * * root toxavahi > /dev/null" >> /etc/crontab
  5883. fi
  5884. systemctl restart avahi-daemon
  5885. echo 'tox_avahi' >> $COMPLETION_FILE
  5886. }
  5887. function install_tox_node {
  5888. 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
  5889. return
  5890. fi
  5891. # update to the next commit
  5892. set_repo_commit $INSTALL_DIR/toxcore "toxcore commit" "$TOX_COMMIT" $TOX_REPO
  5893. if grep -Fxq "install_tox_node" $COMPLETION_FILE; then
  5894. return
  5895. fi
  5896. ${PROJECT_NAME}-mesh-install -f tox_node
  5897. if [ ! "$?" = "0" ]; then
  5898. echo $'Failed to install tox node'
  5899. exit 26778
  5900. fi
  5901. TOX_ONION_HOSTNAME=$(add_onion_service tox ${TOX_PORT} ${TOX_PORT})
  5902. if ! grep -q "tox onion domain" $COMPLETION_FILE; then
  5903. echo "tox onion domain:${TOX_ONION_HOSTNAME}" >> $COMPLETION_FILE
  5904. else
  5905. sed -i "s|tox onion domain.*|tox onion domain:${TOX_ONION_HOSTNAME}|g" $COMPLETION_FILE
  5906. fi
  5907. systemctl restart tox-bootstrapd.service
  5908. TOX_PUBLIC_KEY=$(cat /var/log/syslog | grep tox | grep "Public Key" | awk -F ' ' '{print $8}' | tail -1)
  5909. if [ ${#TOX_PUBLIC_KEY} -lt 30 ]; then
  5910. echo $'Could not obtain the tox node public key'
  5911. exit 6529
  5912. fi
  5913. # save the public key for later reference
  5914. echo "$TOX_PUBLIC_KEY" > $TOX_BOOTSTRAP_ID_FILE
  5915. configure_firewall_for_tox
  5916. if ! grep -q $"Your Tox node public key is" /home/$MY_USERNAME/README; then
  5917. echo '' >> /home/$MY_USERNAME/README
  5918. echo '' >> /home/$MY_USERNAME/README
  5919. echo 'Tox' >> /home/$MY_USERNAME/README
  5920. echo '===' >> /home/$MY_USERNAME/README
  5921. echo $"tox onion domain: ${TOX_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  5922. echo $"Your Tox node public key is: $TOX_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  5923. echo $'In the Toxic client you can connect to it with:' >> /home/$MY_USERNAME/README
  5924. echo " /connect $DEFAULT_DOMAIN_NAME.local $TOX_PORT $TOX_PUBLIC_KEY" >> /home/$MY_USERNAME/README
  5925. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  5926. chmod 600 /home/$MY_USERNAME/README
  5927. fi
  5928. echo 'install_tox_node' >> $COMPLETION_FILE
  5929. }
  5930. function install_tox_client {
  5931. 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
  5932. return
  5933. fi
  5934. # update to the next commit
  5935. set_repo_commit $INSTALL_DIR/toxic "Toxic commit" "$TOXIC_COMMIT" $TOXIC_REPO
  5936. if grep -Fxq "install_tox_client" $COMPLETION_FILE; then
  5937. return
  5938. fi
  5939. ${PROJECT_NAME}-mesh-install -f tox_client
  5940. if [ ! "$?" = "0" ]; then
  5941. echo $'Could not install Tox client'
  5942. exit 67248
  5943. fi
  5944. # initial setup of username
  5945. su -c "echo 'n
  5946. /nick $MY_USERNAME
  5947. /exit
  5948. ' | $TOXIC_FILE -d" - $MY_USERNAME
  5949. echo 'install_tox_client' >> $COMPLETION_FILE
  5950. }
  5951. function install_xmpp {
  5952. 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
  5953. return
  5954. fi
  5955. if grep -Fxq "install_xmpp" $COMPLETION_FILE; then
  5956. return
  5957. fi
  5958. apt-get -y install lua-sec lua-bitop
  5959. apt-get -y install prosody prosody-modules mercurial
  5960. if [ ! -d /etc/prosody ]; then
  5961. echo $"ERROR: prosody does not appear to have installed. $CHECK_MESSAGE"
  5962. exit 52
  5963. fi
  5964. # obtain the prosody modules
  5965. cd $INSTALL_DIR
  5966. hg clone https://hg.prosody.im/prosody-modules/ prosody-modules
  5967. if [ ! -d $INSTALL_DIR/prosody-modules/mod_onions ]; then
  5968. echo $'mod_onions prosody module could not be found'
  5969. exit 73254
  5970. fi
  5971. # install the onions module
  5972. cp $INSTALL_DIR/prosody-modules/mod_onions/mod_onions.lua /usr/lib/prosody/modules/mod_onions.lua
  5973. if [ ! -f /usr/lib/prosody/modules/mod_onions.lua ]; then
  5974. echo $'mod_onions.lua could not be copied to the prosody modules directory'
  5975. exit 63952
  5976. fi
  5977. # create a certificate
  5978. if [ ! -f /etc/ssl/certs/xmpp.dhparam ]; then
  5979. ${PROJECT_NAME}-addcert -h xmpp --dhkey $DH_KEYLENGTH
  5980. check_certificates xmpp
  5981. fi
  5982. chown prosody:prosody /etc/ssl/private/xmpp.key
  5983. chown prosody:prosody /etc/ssl/certs/xmpp.*
  5984. cp -a /etc/prosody/conf.avail/example.com.cfg.lua /etc/prosody/conf.avail/xmpp.cfg.lua
  5985. sed -i 's|/etc/prosody/certs/example.com.key|/etc/ssl/private/xmpp.key|g' /etc/prosody/conf.avail/xmpp.cfg.lua
  5986. sed -i 's|/etc/prosody/certs/example.com.crt|/etc/ssl/certs/xmpp.crt|g' /etc/prosody/conf.avail/xmpp.cfg.lua
  5987. if ! grep -q "xmpp.dhparam" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  5988. sed -i '/certificate =/a\ dhparam = "/etc/ssl/certs/xmpp.dhparam";' /etc/prosody/conf.avail/xmpp.cfg.lua
  5989. fi
  5990. if ! grep -q 'options = {"no_sslv2", "no_sslv3" }' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  5991. sed -i '/certificate =/a\ options = {"no_sslv2", "no_sslv3" };' /etc/prosody/conf.avail/xmpp.cfg.lua
  5992. fi
  5993. if ! grep -q 'ciphers =' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  5994. sed -i "/certificate =/a\ ciphers = $XMPP_CIPHERS;" /etc/prosody/conf.avail/xmpp.cfg.lua
  5995. fi
  5996. if ! grep -q 'depth = "1";' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  5997. sed -i '/certificate =/a\ depth = "1";' /etc/prosody/conf.avail/xmpp.cfg.lua
  5998. fi
  5999. if ! grep -q 'curve =' /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6000. sed -i "/certificate =/a\ curve = $XMPP_ECC_CURVE;" /etc/prosody/conf.avail/xmpp.cfg.lua
  6001. fi
  6002. sed -i "s/example.com/$DEFAULT_DOMAIN_NAME/g" /etc/prosody/conf.avail/xmpp.cfg.lua
  6003. sed -i 's/enabled = false -- Remove this line to enable this host//g' /etc/prosody/conf.avail/xmpp.cfg.lua
  6004. if ! grep -q "modules_enabled" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6005. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6006. echo 'modules_enabled = {' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6007. echo ' "bosh"; -- Enable mod_bosh' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6008. echo ' "tls"; -- Enable mod_tls' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6009. echo ' "saslauth"; -- Enable mod_saslauth' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6010. echo ' "onions"; -- Enable chat via onion service' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6011. echo '}' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6012. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6013. echo 'c2s_require_encryption = true' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6014. echo 's2s_require_encryption = true' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6015. echo 'allow_unencrypted_plain_auth = false' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6016. fi
  6017. ln -sf /etc/prosody/conf.avail/xmpp.cfg.lua /etc/prosody/conf.d/xmpp.cfg.lua
  6018. sed -i 's|/etc/prosody/certs/localhost.key|/etc/ssl/private/xmpp.key|g' /etc/prosody/prosody.cfg.lua
  6019. sed -i 's|/etc/prosody/certs/localhost.crt|/etc/ssl/certs/xmpp.crt|g' /etc/prosody/prosody.cfg.lua
  6020. if ! grep -q "xmpp.dhparam" /etc/prosody/prosody.cfg.lua; then
  6021. sed -i '/certificate =/a\ dhparam = "/etc/ssl/certs/xmpp.dhparam";' /etc/prosody/prosody.cfg.lua
  6022. fi
  6023. if ! grep -q 'options = {"no_sslv2", "no_sslv3" }' /etc/prosody/prosody.cfg.lua; then
  6024. sed -i '/certificate =/a\ options = {"no_sslv2", "no_sslv3" };' /etc/prosody/prosody.cfg.lua
  6025. fi
  6026. if ! grep -q 'ciphers =' /etc/prosody/prosody.cfg.lua; then
  6027. sed -i "/certificate =/a\ ciphers = $XMPP_CIPHERS;" /etc/prosody/prosody.cfg.lua
  6028. fi
  6029. if ! grep -q 'depth = "1";' /etc/prosody/prosody.cfg.lua; then
  6030. sed -i '/certificate =/a\ depth = "1";' /etc/prosody/prosody.cfg.lua
  6031. fi
  6032. if ! grep -q 'curve =' /etc/prosody/prosody.cfg.lua; then
  6033. sed -i "/certificate =/a\ curve = $XMPP_ECC_CURVE;" /etc/prosody/prosody.cfg.lua
  6034. fi
  6035. sed -i 's/c2s_require_encryption = false/c2s_require_encryption = true/g' /etc/prosody/prosody.cfg.lua
  6036. if ! grep -q "s2s_require_encryption" /etc/prosody/prosody.cfg.lua; then
  6037. sed -i '/c2s_require_encryption/a\s2s_require_encryption = true' /etc/prosody/prosody.cfg.lua
  6038. fi
  6039. if ! grep -q "allow_unencrypted_plain_auth" /etc/prosody/prosody.cfg.lua; then
  6040. echo 'allow_unencrypted_plain_auth = false' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6041. fi
  6042. sed -i 's/--"bosh";/"bosh";/g' /etc/prosody/prosody.cfg.lua
  6043. sed -i 's/authentication = "internal_plain"/authentication = "internal_hashed"/g' /etc/prosody/prosody.cfg.lua
  6044. sed -i 's/enabled = false -- Remove this line to enable this host//g' /etc/prosody/prosody.cfg.lua
  6045. sed -i 's|key = "/etc/prosody/certs/example.com.key"|key = "/etc/ssl/private/xmpp.key"|g' /etc/prosody/prosody.cfg.lua
  6046. sed -i 's|certificate = "/etc/prosody/certs/example.com.crt"|certificate = "/etc/ssl/certs/xmpp.crt"|g' /etc/prosody/prosody.cfg.lua
  6047. sed -i "s/example.com/$DEFAULT_DOMAIN_NAME/g" /etc/prosody/prosody.cfg.lua
  6048. systemctl restart prosody
  6049. touch /home/$MY_USERNAME/README
  6050. if [ ! -d /var/lib/tor ]; then
  6051. echo $'No Tor installation found. XMPP onion site cannot be configured.'
  6052. exit 877367
  6053. fi
  6054. if ! grep -q "hidden_service_xmpp" /etc/tor/torrc; then
  6055. echo 'HiddenServiceDir /var/lib/tor/hidden_service_xmpp/' >> /etc/tor/torrc
  6056. echo "HiddenServicePort 5222 127.0.0.1:5222" >> /etc/tor/torrc
  6057. echo "HiddenServicePort 5269 127.0.0.1:5269" >> /etc/tor/torrc
  6058. echo $'Added onion site for XMPP chat'
  6059. fi
  6060. systemctl restart tor
  6061. wait_for_onion_service 'xmpp'
  6062. if [ ! -f /var/lib/tor/hidden_service_xmpp/hostname ]; then
  6063. echo $'XMPP onion site hostname not found'
  6064. exit 65349
  6065. fi
  6066. XMPP_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_xmpp/hostname)
  6067. if ! grep -q "${XMPP_ONION_HOSTNAME}" /etc/prosody/conf.avail/xmpp.cfg.lua; then
  6068. echo '' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6069. echo "VirtualHost \"${XMPP_ONION_HOSTNAME}\"" >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6070. echo ' modules_enabled = { "onions" };' >> /etc/prosody/conf.avail/xmpp.cfg.lua
  6071. fi
  6072. if ! grep -q "XMPP onion domain" $COMPLETION_FILE; then
  6073. echo "XMPP onion domain:${XMPP_ONION_HOSTNAME}" >> $COMPLETION_FILE
  6074. else
  6075. sed -i "s|XMPP onion domain.*|XMPP onion domain:${XMPP_ONION_HOSTNAME}|g" $COMPLETION_FILE
  6076. fi
  6077. if ! grep -q "Your XMPP password is" /home/$MY_USERNAME/README; then
  6078. if [ ${#XMPP_PASSWORD} -lt 8 ]; then
  6079. if [ -f $IMAGE_PASSWORD_FILE ]; then
  6080. XMPP_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  6081. else
  6082. XMPP_PASSWORD="$(openssl rand -base64 10 | cut -c1-8)"
  6083. fi
  6084. fi
  6085. prosodyctl register $MY_USERNAME $DEFAULT_DOMAIN_NAME $XMPP_PASSWORD
  6086. echo '' >> /home/$MY_USERNAME/README
  6087. echo '' >> /home/$MY_USERNAME/README
  6088. echo $'XMPP' >> /home/$MY_USERNAME/README
  6089. echo '====' >> /home/$MY_USERNAME/README
  6090. echo $"XMPP onion domain: ${XMPP_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  6091. echo $"Your XMPP password is: $XMPP_PASSWORD" >> /home/$MY_USERNAME/README
  6092. echo $'You can change it with: ' >> /home/$MY_USERNAME/README
  6093. echo '' >> /home/$MY_USERNAME/README
  6094. echo " prosodyctl passwd $MY_EMAIL_ADDRESS" >> /home/$MY_USERNAME/README
  6095. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6096. chmod 600 /home/$MY_USERNAME/README
  6097. fi
  6098. echo 'install_xmpp' >> $COMPLETION_FILE
  6099. }
  6100. function install_xmpp_client {
  6101. 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
  6102. return
  6103. fi
  6104. if grep -Fxq "install_xmpp_client" $COMPLETION_FILE; then
  6105. return
  6106. fi
  6107. apt-get -y install profanity
  6108. XMPP_CLIENT_DIR=/home/$MY_USERNAME/.local/share/profanity
  6109. XMPP_CLIENT_ACCOUNTS=$XMPP_CLIENT_DIR/accounts
  6110. if [ ! -d $XMPP_CLIENT_DIR ]; then
  6111. mkdir -p $XMPP_CLIENT_DIR
  6112. fi
  6113. if [[ $ONION_ONLY == 'no' ]]; then
  6114. echo "[${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}]" > $XMPP_CLIENT_ACCOUNTS
  6115. echo 'enabled=true' >> $XMPP_CLIENT_ACCOUNTS
  6116. echo "jid=${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}" >> $XMPP_CLIENT_ACCOUNTS
  6117. echo 'resource=profanity' >> $XMPP_CLIENT_ACCOUNTS
  6118. echo "muc.service=conference.${DEFAULT_DOMAIN_NAME}" >> $XMPP_CLIENT_ACCOUNTS
  6119. echo "muc.nick=${MY_USERNAME}" >> $XMPP_CLIENT_ACCOUNTS
  6120. echo 'presence.last=online' >> $XMPP_CLIENT_ACCOUNTS
  6121. echo 'presence.login=online' >> $XMPP_CLIENT_ACCOUNTS
  6122. echo 'priority.online=0' >> $XMPP_CLIENT_ACCOUNTS
  6123. echo 'priority.chat=0' >> $XMPP_CLIENT_ACCOUNTS
  6124. echo 'priority.away=0' >> $XMPP_CLIENT_ACCOUNTS
  6125. echo 'priority.xa=0' >> $XMPP_CLIENT_ACCOUNTS
  6126. echo 'priority.dnd=0' >> $XMPP_CLIENT_ACCOUNTS
  6127. if [ ${#XMPP_PASSWORD} -gt 2 ]; then
  6128. echo "password=$XMPP_PASSWORD" >> $XMPP_CLIENT_ACCOUNTS
  6129. fi
  6130. fi
  6131. if [ -f /var/lib/tor/hidden_service_xmpp/hostname ]; then
  6132. XMPP_ONION_HOSTNAME=$(cat /var/lib/tor/hidden_service_xmpp/hostname)
  6133. echo "[${MY_USERNAME}@${XMPP_ONION_HOSTNAME}]" >> $XMPP_CLIENT_ACCOUNTS
  6134. if [[ $ONION_ONLY == 'no' ]]; then
  6135. echo 'enabled=false' >> $XMPP_CLIENT_ACCOUNTS
  6136. else
  6137. echo 'enabled=true' >> $XMPP_CLIENT_ACCOUNTS
  6138. fi
  6139. echo "jid=${MY_USERNAME}@${XMPP_ONION_HOSTNAME}" >> $XMPP_CLIENT_ACCOUNTS
  6140. echo 'resource=profanity' >> $XMPP_CLIENT_ACCOUNTS
  6141. echo "muc.service=conference.${XMPP_ONION_HOSTNAME}" >> $XMPP_CLIENT_ACCOUNTS
  6142. echo "muc.nick=${MY_USERNAME}" >> $XMPP_CLIENT_ACCOUNTS
  6143. echo 'presence.last=online' >> $XMPP_CLIENT_ACCOUNTS
  6144. echo 'presence.login=online' >> $XMPP_CLIENT_ACCOUNTS
  6145. echo 'priority.online=0' >> $XMPP_CLIENT_ACCOUNTS
  6146. echo 'priority.chat=0' >> $XMPP_CLIENT_ACCOUNTS
  6147. echo 'priority.away=0' >> $XMPP_CLIENT_ACCOUNTS
  6148. echo 'priority.xa=0' >> $XMPP_CLIENT_ACCOUNTS
  6149. echo 'priority.dnd=0' >> $XMPP_CLIENT_ACCOUNTS
  6150. if [ ${#XMPP_PASSWORD} -gt 2 ]; then
  6151. echo "password=$XMPP_PASSWORD" >> $XMPP_CLIENT_ACCOUNTS
  6152. fi
  6153. fi
  6154. if [ ! -d /home/$MY_USERNAME/.config/profanity ]; then
  6155. mkdir /home/$MY_USERNAME/.config/profanity
  6156. fi
  6157. echo '[connection]' > /home/$MY_USERNAME/.config/profanity/profrc
  6158. echo "account=${MY_USERNAME}@${DEFAULT_DOMAIN_NAME}" >> /home/$MY_USERNAME/.config/profanity/profrc
  6159. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.local
  6160. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.config
  6161. echo 'install_xmpp_client' >> $COMPLETION_FILE
  6162. }
  6163. function install_watchdog_script {
  6164. if grep -Fxq "install_watchdog_script" $COMPLETION_FILE; then
  6165. return
  6166. fi
  6167. echo '#!/bin/bash' > /usr/bin/$WATCHDOG_SCRIPT_NAME
  6168. echo 'LOGFILE=/var/log/keepon.log' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6169. echo 'CURRENT_DATE=$(date)' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6170. # application specific stuff is added later
  6171. chmod +x /usr/bin/$WATCHDOG_SCRIPT_NAME
  6172. if ! grep -q "/usr/bin/$WATCHDOG_SCRIPT_NAME" /etc/crontab; then
  6173. echo "* * * * * root /usr/bin/$WATCHDOG_SCRIPT_NAME" >> /etc/crontab
  6174. fi
  6175. echo 'install_watchdog_script' >> $COMPLETION_FILE
  6176. }
  6177. function install_irc_client {
  6178. 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
  6179. return
  6180. fi
  6181. if grep -Fxq "install_irc_client" $COMPLETION_FILE; then
  6182. return
  6183. fi
  6184. apt-get -y install irssi
  6185. if [ ! -d /home/$MY_USERNAME/.irssi ]; then
  6186. mkdir /home/$MY_USERNAME/.irssi
  6187. fi
  6188. echo 'servers = (' > /home/$MY_USERNAME/.irssi/config
  6189. echo ' {' >> /home/$MY_USERNAME/.irssi/config
  6190. echo ' address = "chat.freenode.net";' >> /home/$MY_USERNAME/.irssi/config
  6191. echo ' chatnet = "Freenode";' >> /home/$MY_USERNAME/.irssi/config
  6192. echo ' port = "6667";' >> /home/$MY_USERNAME/.irssi/config
  6193. echo ' autoconnect = "no";' >> /home/$MY_USERNAME/.irssi/config
  6194. echo ' },' >> /home/$MY_USERNAME/.irssi/config
  6195. echo ' {' >> /home/$MY_USERNAME/.irssi/config
  6196. echo ' address = "irc.oftc.net";' >> /home/$MY_USERNAME/.irssi/config
  6197. echo ' chatnet = "OFTC";' >> /home/$MY_USERNAME/.irssi/config
  6198. echo ' port = "6667";' >> /home/$MY_USERNAME/.irssi/config
  6199. echo ' autoconnect = "yes";' >> /home/$MY_USERNAME/.irssi/config
  6200. echo ' },' >> /home/$MY_USERNAME/.irssi/config
  6201. echo ' {' >> /home/$MY_USERNAME/.irssi/config
  6202. if [[ $ONION_ONLY == 'no' ]]; then
  6203. echo " address = \"${DEFAULT_DOMAIN_NAME}\";" >> /home/$MY_USERNAME/.irssi/config
  6204. echo " port = \"${IRC_PORT}\";" >> /home/$MY_USERNAME/.irssi/config
  6205. echo ' use_ssl = "yes";' >> /home/$MY_USERNAME/.irssi/config
  6206. else
  6207. IRC_ONION_HOSTNAME=$(cat $COMPLETION_FILE | grep "IRC onion domain" | awk -F ':' '{print $2}')
  6208. echo " address = \"${IRC_ONION_HOSTNAME}\";" >> /home/$MY_USERNAME/.irssi/config
  6209. echo " port = \"${IRC_ONION_PORT}\";" >> /home/$MY_USERNAME/.irssi/config
  6210. echo ' use_ssl = "no";' >> /home/$MY_USERNAME/.irssi/config
  6211. sed -i "s/;Ports =.*/Ports = $IRC_PORT, $IRC_ONION_PORT/1" /etc/ngircd/ngircd.conf
  6212. systemctl restart ngircd
  6213. fi
  6214. echo ' chatnet = "Freedombone";' >> /home/$MY_USERNAME/.irssi/config
  6215. echo ' ssl_verify = "no";' >> /home/$MY_USERNAME/.irssi/config
  6216. echo ' autoconnect = "yes";' >> /home/$MY_USERNAME/.irssi/config
  6217. if [ $IRC_PASSWORD ]; then
  6218. echo " password = \"${IRC_PASSWORD}\";" >> /home/$MY_USERNAME/.irssi/config
  6219. fi
  6220. echo ' }' >> /home/$MY_USERNAME/.irssi/config
  6221. echo ');' >> /home/$MY_USERNAME/.irssi/config
  6222. echo '' >> /home/$MY_USERNAME/.irssi/config
  6223. echo 'chatnets = {' >> /home/$MY_USERNAME/.irssi/config
  6224. echo ' Freedombone = {' >> /home/$MY_USERNAME/.irssi/config
  6225. echo ' type = "IRC";' >> /home/$MY_USERNAME/.irssi/config
  6226. echo ' max_kicks = "1";' >> /home/$MY_USERNAME/.irssi/config
  6227. echo ' max_msgs = "4";' >> /home/$MY_USERNAME/.irssi/config
  6228. echo ' max_whois = "1";' >> /home/$MY_USERNAME/.irssi/config
  6229. echo ' };' >> /home/$MY_USERNAME/.irssi/config
  6230. echo ' Freenode = {' >> /home/$MY_USERNAME/.irssi/config
  6231. echo ' type = "IRC";' >> /home/$MY_USERNAME/.irssi/config
  6232. echo ' max_kicks = "1";' >> /home/$MY_USERNAME/.irssi/config
  6233. echo ' max_msgs = "4";' >> /home/$MY_USERNAME/.irssi/config
  6234. echo ' max_whois = "1";' >> /home/$MY_USERNAME/.irssi/config
  6235. echo ' };' >> /home/$MY_USERNAME/.irssi/config
  6236. echo ' OFTC = {' >> /home/$MY_USERNAME/.irssi/config
  6237. echo ' type = "IRC";' >> /home/$MY_USERNAME/.irssi/config
  6238. echo ' max_kicks = "1";' >> /home/$MY_USERNAME/.irssi/config
  6239. echo ' max_msgs = "1";' >> /home/$MY_USERNAME/.irssi/config
  6240. echo ' max_whois = "1";' >> /home/$MY_USERNAME/.irssi/config
  6241. echo ' };' >> /home/$MY_USERNAME/.irssi/config
  6242. echo '};' >> /home/$MY_USERNAME/.irssi/config
  6243. echo '' >> /home/$MY_USERNAME/.irssi/config
  6244. echo 'channels = (' >> /home/$MY_USERNAME/.irssi/config
  6245. echo ' { name = "#freedombone"; chatnet = "Freedombone"; autojoin = "Yes"; },' >> /home/$MY_USERNAME/.irssi/config
  6246. echo ');' >> /home/$MY_USERNAME/.irssi/config
  6247. echo '' >> /home/$MY_USERNAME/.irssi/config
  6248. echo 'settings = {' >> /home/$MY_USERNAME/.irssi/config
  6249. echo " core = { real_name = \"$MY_NAME\"; user_name = \"$MY_USERNAME\"; nick = \"$MY_USERNAME\"; };" >> /home/$MY_USERNAME/.irssi/config
  6250. echo ' "fe-text" = { actlist_sort = "refnum"; };' >> /home/$MY_USERNAME/.irssi/config
  6251. echo '};' >> /home/$MY_USERNAME/.irssi/config
  6252. echo 'ignores = ( { level = "CTCPS"; } );' >> /home/$MY_USERNAME/.irssi/config
  6253. chown -R $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.irssi
  6254. echo 'install_irc_client' >> $COMPLETION_FILE
  6255. }
  6256. function install_irc_server {
  6257. 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
  6258. return
  6259. fi
  6260. if grep -Fxq "install_irc_server" $COMPLETION_FILE; then
  6261. return
  6262. fi
  6263. apt-get -y install ngircd
  6264. if [ ! -d /etc/ngircd ]; then
  6265. echo $"ERROR: ngircd does not appear to have installed. $CHECK_MESSAGE"
  6266. exit 53
  6267. fi
  6268. if [ ! -f /etc/ssl/certs/ngircd.dhparam ]; then
  6269. ${PROJECT_NAME}-addcert -h ngircd --dhkey $DH_KEYLENGTH
  6270. check_certificates ngircd
  6271. fi
  6272. DEFAULTDOMAIN=$DEFAULT_DOMAIN_NAME
  6273. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  6274. DEFAULTDOMAIN="${DEFAULT_DOMAIN_NAME}.local"
  6275. fi
  6276. # create a login password if needed
  6277. if [ ! $IRC_PASSWORD ]; then
  6278. IRC_PASSWORD="$(openssl rand -base64 32 | cut -c1-10)"
  6279. fi
  6280. echo '**************************************************' > /etc/ngircd/motd
  6281. echo $'* F R E E D O M B O N E I R C *' >> /etc/ngircd/motd
  6282. echo '* *' >> /etc/ngircd/motd
  6283. echo $'* Freedom in the Cloud *' >> /etc/ngircd/motd
  6284. echo '**************************************************' >> /etc/ngircd/motd
  6285. sed -i 's|MotdFile = /etc/ngircd/ngircd.motd|MotdFile = /etc/ngircd/motd|g' /etc/ngircd/ngircd.conf
  6286. sed -i "s/irc@irc.example.com/$MY_EMAIL_ADDRESS/g" /etc/ngircd/ngircd.conf
  6287. sed -i "s/irc.example.net/$DEFAULTDOMAIN/g" /etc/ngircd/ngircd.conf
  6288. sed -i "s|Yet another IRC Server running on Debian GNU/Linux|IRC Server of $DEFAULTDOMAIN|g" /etc/ngircd/ngircd.conf
  6289. sed -i 's/;Password = wealllikedebian/Password =/g' /etc/ngircd/ngircd.conf
  6290. sed -i 's|;CertFile = /etc/ssl/certs/server.crt|CertFile = /etc/ssl/certs/ngircd.crt|g' /etc/ngircd/ngircd.conf
  6291. sed -i 's|;DHFile = /etc/ngircd/dhparams.pem|DHFile = /etc/ssl/certs/ngircd.dhparam|g' /etc/ngircd/ngircd.conf
  6292. sed -i 's|;KeyFile = /etc/ssl/private/server.key|KeyFile = /etc/ssl/private/ngircd.key|g' /etc/ngircd/ngircd.conf
  6293. sed -i "s/;Ports =.*/Ports = $IRC_PORT/2" /etc/ngircd/ngircd.conf
  6294. if [[ $ONION_ONLY != 'yes' ]]; then
  6295. sed -i "s/;Ports =.*/;Ports = $IRC_PORT, $IRC_ONION_PORT/1" /etc/ngircd/ngircd.conf
  6296. else
  6297. sed -i "s/;Ports =.*/Ports = $IRC_PORT, $IRC_ONION_PORT/1" /etc/ngircd/ngircd.conf
  6298. fi
  6299. sed -i "s/;Name = #ngircd/Name = #${PROJECT_NAME}/g" /etc/ngircd/ngircd.conf
  6300. sed -i "s/;Topic = Our ngircd testing channel/Topic = ${PROJECT_NAME} chat channel/g" /etc/ngircd/ngircd.conf
  6301. sed -i 's/;MaxUsers = 23/MaxUsers = 23/g' /etc/ngircd/ngircd.conf
  6302. sed -i "s|;KeyFile = /etc/ngircd/#chan.key|KeyFile = /etc/ngircd/#${PROJECT_NAME}.key|g" /etc/ngircd/ngircd.conf
  6303. sed -i "s/;CloakHost = cloaked.host/CloakHost = ${PROJECT_NAME}/g" /etc/ngircd/ngircd.conf
  6304. IRC_SALT="$(openssl rand -base64 32 | cut -c1-30)"
  6305. if [ -f $IMAGE_PASSWORD_FILE ]; then
  6306. IRC_OPERATOR_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  6307. else
  6308. IRC_OPERATOR_PASSWORD="$(openssl rand -base64 10 | cut -c1-8)"
  6309. fi
  6310. sed -i "s|;CloakHostSalt = abcdefghijklmnopqrstuvwxyz|CloakHostSalt = $IRC_SALT|g" /etc/ngircd/ngircd.conf
  6311. sed -i 's/;ConnectIPv4 = yes/ConnectIPv4 = yes/g' /etc/ngircd/ngircd.conf
  6312. sed -i 's/;MorePrivacy = no/MorePrivacy = yes/g' /etc/ngircd/ngircd.conf
  6313. sed -i 's/;RequireAuthPing = no/RequireAuthPing = no/g' /etc/ngircd/ngircd.conf
  6314. sed -i "s/;Name = TheOper/Name = $MY_USERNAME/g" /etc/ngircd/ngircd.conf
  6315. sed -i "s/;Password = ThePwd/Password = $IRC_OPERATOR_PASSWORD/g" /etc/ngircd/ngircd.conf
  6316. 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
  6317. if [ $IRC_PASSWORD ]; then
  6318. sed -i "0,/RE/s/Password =.*/Password =$IRC_PASSWORD/" /etc/ngircd/ngircd.conf
  6319. fi
  6320. # If we are on a mesh then DNS is not available
  6321. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  6322. sed -i "s/;DNS =.*/DNS = no/g" /etc/ngircd/ngircd.conf
  6323. fi
  6324. # upgrade a cypher
  6325. sed -i 's|SECURE128|SECURE256|g' /etc/ngircd/ngircd.conf
  6326. mkdir /var/run/ircd
  6327. chown -R irc:irc /var/run/ircd
  6328. mkdir /var/run/ngircd
  6329. touch /var/run/ngircd/ngircd.pid
  6330. chown -R irc:irc /var/run/ngircd
  6331. IRC_ONION_HOSTNAME=$(add_onion_service irc ${IRC_PORT} ${IRC_ONION_PORT})
  6332. if ! grep -q $"IRC onion domain" $COMPLETION_FILE; then
  6333. echo "IRC onion domain:$IRC_ONION_HOSTNAME" >> $COMPLETION_FILE
  6334. fi
  6335. systemctl stop ngircd
  6336. if [ ! -f /lib/systemd/system/ngircd.service ]; then
  6337. echo $'No systemd daemon found for ngircd'
  6338. exit 82528
  6339. fi
  6340. if [[ $ONION_ONLY == 'no' ]]; then
  6341. sed -i 's|ExecStart.*|ExecStart=/usr/sbin/ngircd|g' /lib/systemd/system/ngircd.service
  6342. else
  6343. sed -i 's|ExecStart.*|ExecStart=/usr/bin/torify /usr/sbin/ngircd|g' /lib/systemd/system/ngircd.service
  6344. fi
  6345. systemctl daemon-reload
  6346. systemctl start ngircd
  6347. # keep the daemon running
  6348. echo '' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6349. echo '# keep irc daemon running' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6350. echo 'IRC_RUNNING=$(pgrep ngircd > /dev/null && echo Running)' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6351. echo 'if [ ! $IRC_RUNNING ]; then' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6352. echo ' systemctl start ngircd' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6353. echo ' echo -n $CURRENT_DATE >> $LOGFILE' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6354. echo ' echo " IRC daemon restarted" >> $LOGFILE' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6355. echo 'fi' >> /usr/bin/$WATCHDOG_SCRIPT_NAME
  6356. if ! grep -q $"IRC Server" /home/$MY_USERNAME/README; then
  6357. echo '' >> /home/$MY_USERNAME/README
  6358. echo '' >> /home/$MY_USERNAME/README
  6359. echo $'IRC Server' >> /home/$MY_USERNAME/README
  6360. echo '==========' >> /home/$MY_USERNAME/README
  6361. echo $'To connect to your IRC server in irssi:' >> /home/$MY_USERNAME/README
  6362. echo '' >> /home/$MY_USERNAME/README
  6363. if [[ $ONION_ONLY != 'yes' ]]; then
  6364. echo " irssi" >> /home/$MY_USERNAME/README
  6365. echo " /server add -auto -ssl $DEFAULTDOMAIN $IRC_PORT" >> /home/$MY_USERNAME/README
  6366. echo " /connect $DEFAULT_DOMAIN_NAME" >> /home/$MY_USERNAME/README
  6367. else
  6368. echo " usetorwith irssi" >> /home/$MY_USERNAME/README
  6369. echo " /server add -auto $IRC_ONION_HOSTNAME $IRC_PORT" >> /home/$MY_USERNAME/README
  6370. echo " /connect $IRC_ONION_HOSTNAME" >> /home/$MY_USERNAME/README
  6371. fi
  6372. echo " /join #${PROJECT_NAME}" >> /home/$MY_USERNAME/README
  6373. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6374. chmod 600 /home/$MY_USERNAME/README
  6375. fi
  6376. echo 'install_irc_server' >> $COMPLETION_FILE
  6377. }
  6378. function get_wiki_admin_password {
  6379. if [ -f /home/$MY_USERNAME/README ]; then
  6380. if grep -q "Wiki password" /home/$MY_USERNAME/README; then
  6381. WIKI_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Wiki password:" | awk -F ':' '{print $2}' | sed 's/^ *//')
  6382. fi
  6383. fi
  6384. }
  6385. function install_wiki {
  6386. 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
  6387. return
  6388. fi
  6389. if grep -Fxq "install_wiki" $COMPLETION_FILE; then
  6390. return
  6391. fi
  6392. if [ ! $WIKI_DOMAIN_NAME ]; then
  6393. return
  6394. fi
  6395. apt-get -y install dokuwiki
  6396. apt-get -y remove --purge apache*
  6397. if [ -d /etc/apache2 ]; then
  6398. rm -rf /etc/apache2
  6399. echo $'Removed Apache installation after Dokuwiki install'
  6400. fi
  6401. if [ ! -d /var/www/$WIKI_DOMAIN_NAME ]; then
  6402. mkdir /var/www/$WIKI_DOMAIN_NAME
  6403. fi
  6404. if [ -d /var/www/$WIKI_DOMAIN_NAME/htdocs ]; then
  6405. rm -rf /var/www/$WIKI_DOMAIN_NAME/htdocs
  6406. fi
  6407. ln -s /usr/share/dokuwiki /var/www/$WIKI_DOMAIN_NAME/htdocs
  6408. mkdir /var/lib/dokuwiki/custom
  6409. cp /etc/dokuwiki/local.php.dist /var/lib/dokuwiki/custom/local.php
  6410. ln -s /var/lib/dokuwiki/custom/local.php /etc/dokuwiki/local.php
  6411. chown www-data /var/lib/dokuwiki/custom
  6412. chown www-data /var/lib/dokuwiki/custom/local.php
  6413. chown -R www-data /etc/dokuwiki
  6414. chown -R www-data /usr/share/dokuwiki/lib/
  6415. chmod 600 /var/lib/dokuwiki/custom/local.php
  6416. chmod -R 755 /usr/share/dokuwiki/lib
  6417. sed -i 's|//$conf|$conf|g' /var/lib/dokuwiki/custom/local.php
  6418. sed -i "s|joe|$MY_USERNAME|g" /var/lib/dokuwiki/custom/local.php
  6419. sed -i "s|Debian DokuWiki|$WIKI_TITLE|g" /etc/dokuwiki/local.php
  6420. # set the admin user
  6421. sed -i "s/@admin/$MY_USERNAME/g" /etc/dokuwiki/local.php
  6422. # disallow registration of new users
  6423. if ! grep -q "disableactions" /etc/dokuwiki/local.php; then
  6424. echo "\$conf['disableactions'] = 'register';" >> /etc/dokuwiki/local.php
  6425. fi
  6426. if ! grep -q "disableactions" /var/lib/dokuwiki/custom/local.php; then
  6427. echo "\$conf['disableactions'] = 'register';" >> /var/lib/dokuwiki/custom/local.php
  6428. fi
  6429. if ! grep -q "authtype" /var/lib/dokuwiki/custom/local.php; then
  6430. echo "\$conf['authtype'] = 'authplain';" >> /var/lib/dokuwiki/custom/local.php
  6431. fi
  6432. if ! grep -q "authtype" /etc/dokuwiki/local.php; then
  6433. echo "\$conf['authtype'] = 'authplain';" >> /etc/dokuwiki/local.php
  6434. fi
  6435. get_wiki_admin_password
  6436. if [ ! $WIKI_ADMIN_PASSWORD ]; then
  6437. if [ -f $IMAGE_PASSWORD_FILE ]; then
  6438. WIKI_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  6439. else
  6440. WIKI_ADMIN_PASSWORD="$(openssl rand -base64 18 | cut -c1-16)"
  6441. fi
  6442. fi
  6443. HASHED_WIKI_PASSWORD=$(echo -n "$WIKI_ADMIN_PASSWORD" | md5sum | awk -F ' ' '{print $1}')
  6444. echo -n "$MY_USERNAME:$HASHED_WIKI_PASSWORD:$MY_NAME:$MY_EMAIL:admin,user,upload" > /var/lib/dokuwiki/acl/users.auth.php
  6445. chmod 640 /var/lib/dokuwiki/acl/users.auth.php
  6446. if ! grep -q "video/ogg" /etc/dokuwiki/mime.conf; then
  6447. echo 'ogv video/ogg' >> /etc/dokuwiki/mime.conf
  6448. fi
  6449. if ! grep -q "video/mp4" /etc/dokuwiki/mime.conf; then
  6450. echo 'mp4 video/mp4' >> /etc/dokuwiki/mime.conf
  6451. fi
  6452. if ! grep -q "video/webm" /etc/dokuwiki/mime.conf; then
  6453. echo 'webm video/webm' >> /etc/dokuwiki/mime.conf
  6454. fi
  6455. WIKI_ONION_HOSTNAME=$(add_onion_service wiki 80 ${WIKI_ONION_PORT})
  6456. if [[ $ONION_ONLY == "no" ]]; then
  6457. echo 'server {' > /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6458. echo ' listen 80;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6459. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6460. echo " server_name $WIKI_DOMAIN_NAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6461. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6462. echo " error_log /var/log/nginx/${WIKI_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6463. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6464. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6465. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6466. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6467. nginx_disable_sniffing $WIKI_DOMAIN_NAME
  6468. nginx_limits $WIKI_DOMAIN_NAME
  6469. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6470. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6471. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6472. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6473. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6474. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6475. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6476. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6477. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6478. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6479. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6480. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6481. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6482. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6483. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6484. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6485. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6486. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6487. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6488. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6489. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6490. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6491. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6492. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6493. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6494. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6495. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6496. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6497. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6498. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6499. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6500. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6501. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6502. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6503. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6504. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6505. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6506. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6507. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6508. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6509. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6510. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6511. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6512. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6513. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6514. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6515. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6516. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6517. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6518. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6519. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6520. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6521. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6522. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6523. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6524. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6525. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6526. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6527. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6528. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6529. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6530. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6531. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6532. echo 'server {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6533. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6534. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6535. echo " server_name $WIKI_DOMAIN_NAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6536. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6537. echo " error_log /var/log/nginx/${WIKI_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6538. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6539. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6540. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6541. nginx_limits $WIKI_DOMAIN_NAME
  6542. nginx_ssl $WIKI_DOMAIN_NAME
  6543. nginx_disable_sniffing $WIKI_DOMAIN_NAME
  6544. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6545. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6546. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6547. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6548. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6549. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6550. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6551. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6552. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6553. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6554. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6555. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6556. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6557. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6558. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6559. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6560. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6561. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6562. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6563. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6564. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6565. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6566. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6567. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6568. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6569. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6570. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6571. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6572. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6573. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6574. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6575. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6576. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6577. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6578. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6579. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6580. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6581. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6582. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6583. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6584. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6585. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6586. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6587. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6588. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6589. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6590. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6591. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6592. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6593. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6594. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6595. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6596. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6597. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6598. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6599. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6600. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6601. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6602. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6603. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6604. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6605. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6606. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6607. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6608. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6609. else
  6610. echo -n '' > /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6611. fi
  6612. echo 'server {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6613. echo " listen 127.0.0.1:${WIKI_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6614. echo " root /var/www/$WIKI_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6615. echo " server_name $WIKI_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6616. echo ' access_log off;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6617. echo " error_log /var/log/nginx/${WIKI_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6618. echo ' index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6619. echo ' charset utf-8;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6620. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6621. nginx_limits $WIKI_DOMAIN_NAME
  6622. nginx_disable_sniffing $WIKI_DOMAIN_NAME
  6623. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6624. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6625. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6626. echo ' location / {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6627. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6628. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6629. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6630. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6631. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6632. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6633. echo ' allow all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6634. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6635. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6636. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6637. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6638. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6639. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6640. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6641. echo ' expires 30d;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6642. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6643. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6644. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6645. echo ' # block these file types' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6646. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6647. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6648. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6649. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6650. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6651. echo ' # or a unix socket' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6652. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6653. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6654. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6655. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6656. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6657. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6658. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6659. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6660. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6661. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6662. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6663. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6664. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6665. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6666. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6667. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6668. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6669. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6670. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6671. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6672. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6673. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6674. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6675. echo '' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6676. echo ' #deny access to store' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6677. echo ' location ~ /store {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6678. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6679. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6680. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6681. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6682. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6683. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6684. echo ' deny all;' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6685. echo ' }' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6686. echo '}' >> /etc/nginx/sites-available/$WIKI_DOMAIN_NAME
  6687. create_site_certificate $WIKI_DOMAIN_NAME
  6688. configure_php
  6689. nginx_ensite $WIKI_DOMAIN_NAME
  6690. systemctl restart php5-fpm
  6691. systemctl restart nginx
  6692. echo "Wiki onion domain:${WIKI_ONION_HOSTNAME}" >> $COMPLETION_FILE
  6693. add_ddns_domain $WIKI_DOMAIN_NAME
  6694. # add some post-install instructions
  6695. if ! grep -q $"Wiki password" /home/$MY_USERNAME/README; then
  6696. echo '' >> /home/$MY_USERNAME/README
  6697. echo '' >> /home/$MY_USERNAME/README
  6698. echo $'Wiki' >> /home/$MY_USERNAME/README
  6699. echo '====' >> /home/$MY_USERNAME/README
  6700. echo $"Wiki onion domain: ${WIKI_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  6701. echo $"Wiki username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  6702. echo $"Wiki password: $WIKI_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  6703. echo '' >> /home/$MY_USERNAME/README
  6704. echo $'Once you have set up the wiki then remove the install file:' >> /home/$MY_USERNAME/README
  6705. echo '' >> /home/$MY_USERNAME/README
  6706. echo " rm /var/www/$WIKI_DOMAIN_NAME/htdocs/install.php" >> /home/$MY_USERNAME/README
  6707. echo '' >> /home/$MY_USERNAME/README
  6708. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  6709. chmod 600 /home/$MY_USERNAME/README
  6710. fi
  6711. echo "Wiki domain:$WIKI_DOMAIN_NAME" >> $COMPLETION_FILE
  6712. echo 'install_wiki' >> $COMPLETION_FILE
  6713. }
  6714. function get_blog_admin_password {
  6715. if [ -f /home/$MY_USERNAME/README ]; then
  6716. if grep -q "Your blog password is" /home/$MY_USERNAME/README; then
  6717. FULLBLOG_ADMIN_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "Your blog password is" | awk -F ':' '{print $2}' | sed 's/^ *//')
  6718. fi
  6719. fi
  6720. }
  6721. function install_blog {
  6722. 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
  6723. return
  6724. fi
  6725. if [ ! $FULLBLOG_DOMAIN_NAME ]; then
  6726. echo $'The blog domain name was not specified'
  6727. exit 5062
  6728. fi
  6729. # update to the next commit
  6730. set_repo_commit /var/www/$FULLBLOG_DOMAIN_NAME/htdocs "Blog commit" "$FULLBLOG_COMMIT" $FULLBLOG_REPO
  6731. if grep -Fxq "install_blog" $COMPLETION_FILE; then
  6732. return
  6733. fi
  6734. # for the avatar changing command
  6735. apt-get -y install imagemagick
  6736. if [ ! -d /var/www/$FULLBLOG_DOMAIN_NAME ]; then
  6737. mkdir /var/www/$FULLBLOG_DOMAIN_NAME
  6738. fi
  6739. cd /var/www/$FULLBLOG_DOMAIN_NAME
  6740. git_clone $FULLBLOG_REPO htdocs
  6741. cd htdocs
  6742. git checkout $FULLBLOG_COMMIT -b $FULLBLOG_COMMIT
  6743. if ! grep -q "Blog commit" $COMPLETION_FILE; then
  6744. echo "Blog commit:$FULLBLOG_COMMIT" >> $COMPLETION_FILE
  6745. else
  6746. sed -i "s/Blog commit.*/Blog commit:$FULLBLOG_COMMIT/g" $COMPLETION_FILE
  6747. fi
  6748. cd /var/www/$FULLBLOG_DOMAIN_NAME
  6749. chown -R www-data:www-data /var/www/$FULLBLOG_DOMAIN_NAME/htdocs
  6750. if [[ $ONION_ONLY == "no" ]]; then
  6751. echo 'server {' > /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6752. echo ' listen 80;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6753. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6754. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6755. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6756. echo " error_log /var/log/nginx/${FULLBLOG_DOMAIN_NAME}_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6757. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6758. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6759. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6760. nginx_limits $FULLBLOG_DOMAIN_NAME
  6761. nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
  6762. echo ' # Always redirect the login page to https' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6763. echo ' location /login {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6764. echo ' rewrite ^ https://$server_name$request_uri?;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6765. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6766. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6767. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6768. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6769. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6770. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6771. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6772. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6773. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6774. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6775. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6776. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6777. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6778. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6779. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6780. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6781. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6782. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6783. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6784. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6785. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6786. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6787. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6788. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6789. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6790. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6791. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6792. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6793. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6794. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6795. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6796. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6797. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6798. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6799. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6800. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6801. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6802. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6803. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6804. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6805. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6806. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6807. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6808. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6809. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6810. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6811. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6812. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6813. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6814. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6815. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6816. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6817. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6818. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6819. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6820. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6821. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6822. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6823. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6824. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6825. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6826. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6827. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6828. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6829. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6830. echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6831. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6832. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6833. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6834. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6835. echo " error_log /var/log/nginx/${FULLBLOG_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6836. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6837. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6838. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6839. nginx_limits $FULLBLOG_DOMAIN_NAME
  6840. nginx_ssl $FULLBLOG_DOMAIN_NAME
  6841. nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
  6842. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6843. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6844. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6845. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6846. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6847. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6848. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6849. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6850. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6851. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6852. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6853. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6854. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6855. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6856. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6857. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6858. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6859. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6860. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6861. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6862. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6863. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6864. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6865. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6866. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6867. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6868. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6869. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6870. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6871. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6872. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6873. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6874. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6875. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6876. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6877. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6878. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6879. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6880. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6881. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6882. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6883. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6884. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6885. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6886. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6887. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6888. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6889. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6890. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6891. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6892. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6893. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6894. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6895. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6896. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6897. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6898. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6899. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6900. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6901. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6902. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6903. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6904. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6905. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6906. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6907. else
  6908. echo -n '' > /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6909. fi
  6910. echo 'server {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6911. echo " listen 127.0.0.1:${FULLBLOG_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6912. echo " root /var/www/$FULLBLOG_DOMAIN_NAME/htdocs;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6913. echo " server_name $FULLBLOG_DOMAIN_NAME;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6914. echo ' access_log off;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6915. echo " error_log /var/log/nginx/${FULLBLOG_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6916. echo ' index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6917. echo ' charset utf-8;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6918. echo ' proxy_read_timeout 86400s;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6919. nginx_limits $FULLBLOG_DOMAIN_NAME
  6920. nginx_disable_sniffing $FULLBLOG_DOMAIN_NAME
  6921. echo ' add_header Strict-Transport-Security "max-age=0;";' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6922. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6923. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6924. echo ' location / {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6925. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6926. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6927. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6928. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6929. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6930. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6931. echo ' allow all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6932. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6933. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6934. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6935. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6936. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6937. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6938. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6939. echo ' expires 30d;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6940. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6941. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6942. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6943. echo ' # block these file types' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6944. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6945. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6946. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6947. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6948. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6949. echo ' # or a unix socket' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6950. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6951. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6952. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6953. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6954. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6955. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6956. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6957. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6958. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6959. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6960. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6961. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6962. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6963. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6964. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6965. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6966. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6967. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6968. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6969. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6970. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6971. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6972. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6973. echo '' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6974. echo ' #deny access to store' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6975. echo ' location ~ /store {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6976. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6977. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6978. echo ' location ~ /(data|conf|bin|inc)/ {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6979. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6980. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6981. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6982. echo ' deny all;' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6983. echo ' }' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6984. echo '}' >> /etc/nginx/sites-available/$FULLBLOG_DOMAIN_NAME
  6985. create_site_certificate $FULLBLOG_DOMAIN_NAME
  6986. configure_php
  6987. # blog settings
  6988. cp /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini.example /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6989. sed -i "s|site.url.*|site.url = '/'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6990. sed -i "s|blog.title.*|blog.title = '$MY_BLOG_TITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6991. sed -i "s|blog.tagline.*|blog.tagline = '$MY_BLOG_SUBTITLE'|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6992. sed -i 's|timezone.*|timezone = "Europe/London"|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6993. sed -i "s|Your name|$MY_NAME|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6994. # set social networks
  6995. if grep -q "social.hubzilla" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini; then
  6996. sed -i "s|;social.hubzilla|social.hubzilla|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6997. sed -i "s|social.hubzilla.*|social.hubzilla = \"$HUBZILLA_DOMAIN_NAME\"|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  6998. fi
  6999. if grep -q "social.gnusocial" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini; then
  7000. sed -i "s|;social.gnusocial|social.gnusocial|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7001. sed -i "s|social.gnusocial.*|social.gnusocial = \"$MICROBLOG_DOMAIN_NAME\"|g" /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7002. fi
  7003. # clear proprietary social network strings
  7004. sed -i 's|social.facebook.*|social.facebook = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7005. sed -i 's|social.twitter.*|social.twitter = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7006. sed -i 's|social.google.*|social.google = ""|g' /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/config.ini
  7007. # create a user password
  7008. get_blog_admin_password
  7009. if [ ! $FULLBLOG_ADMIN_PASSWORD ]; then
  7010. if [ -f $IMAGE_PASSWORD_FILE ]; then
  7011. FULLBLOG_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  7012. else
  7013. FULLBLOG_ADMIN_PASSWORD="$(openssl rand -base64 18 | cut -c1-16)"
  7014. fi
  7015. echo '' >> /home/$MY_USERNAME/README
  7016. echo '' >> /home/$MY_USERNAME/README
  7017. echo $'HTMLy Blog' >> /home/$MY_USERNAME/README
  7018. echo '==========' >> /home/$MY_USERNAME/README
  7019. echo $"Your blog username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  7020. echo $"Your blog password is: $FULLBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7021. if [[ $ONION_ONLY == 'no' ]]; then
  7022. echo $"Log into your blog at https://$FULLBLOG_DOMAIN_NAME/login" >> /home/$MY_USERNAME/README
  7023. fi
  7024. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7025. chmod 600 /home/$MY_USERNAME/README
  7026. fi
  7027. # create a user
  7028. echo ';Password' > /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7029. echo "password = '$FULLBLOG_ADMIN_PASSWORD'" >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7030. echo 'encryption = clear' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7031. echo ';Role' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7032. echo 'role = admin' >> /var/www/$FULLBLOG_DOMAIN_NAME/htdocs/config/users/$MY_USERNAME.ini
  7033. nginx_ensite $FULLBLOG_DOMAIN_NAME
  7034. FULLBLOG_ONION_HOSTNAME=$(add_onion_service blog 80 ${FULLBLOG_ONION_PORT})
  7035. systemctl restart php5-fpm
  7036. systemctl restart nginx
  7037. if ! grep -q "Blog onion domain" /home/$MY_USERNAME/README; then
  7038. echo $"Blog onion domain: ${FULLBLOG_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  7039. echo $"Log into your blog at https://${FULLBLOG_ONION_HOSTNAME}/login" >> /home/$MY_USERNAME/README
  7040. echo '' >> /home/$MY_USERNAME/README
  7041. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7042. chmod 600 /home/$MY_USERNAME/README
  7043. fi
  7044. echo "Blog onion domain:${FULLBLOG_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7045. add_ddns_domain $FULLBLOG_DOMAIN_NAME
  7046. echo 'install_blog' >> $COMPLETION_FILE
  7047. }
  7048. function install_rss_reader {
  7049. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7050. return
  7051. fi
  7052. # update to the next commit
  7053. set_repo_commit $RSS_READER_PATH "RSS reader commit" "$RSS_READER_COMMIT" $RSS_READER_REPO
  7054. if grep -Fxq "install_rss_reader" $COMPLETION_FILE; then
  7055. return
  7056. fi
  7057. apt-get -y install php-gettext php5-curl php5-gd php5-mysql git curl php-xml-parser
  7058. if [ ! -d /etc/share ]; then
  7059. mkdir /etc/share
  7060. fi
  7061. cd /etc/share
  7062. git_clone $RSS_READER_REPO tt-rss
  7063. if [ ! -d $RSS_READER_PATH ]; then
  7064. echo $'Could not clone RSS reader repo'
  7065. exit 52925
  7066. fi
  7067. cd $RSS_READER_PATH
  7068. git checkout $RSS_READER_COMMIT -b $RSS_READER_COMMIT
  7069. if ! grep -q "RSS reader commit" $COMPLETION_FILE; then
  7070. echo "RSS reader commit:$RSS_READER_COMMIT" >> $COMPLETION_FILE
  7071. fi
  7072. install_mariadb
  7073. get_mariadb_password
  7074. repair_databases_script
  7075. get_mariadb_rss_reader_admin_password
  7076. if [ ! $RSS_READER_ADMIN_PASSWORD ]; then
  7077. if [ -f $IMAGE_PASSWORD_FILE ]; then
  7078. RSS_READER_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  7079. else
  7080. RSS_READER_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-30)"
  7081. fi
  7082. fi
  7083. create_database ttrss "$RSS_READER_ADMIN_PASSWORD" $MY_USERNAME
  7084. RSS_READER_ONION_HOSTNAME=$(add_onion_service ttrss 80 ${RSS_READER_ONION_PORT})
  7085. RSS_MOBILE_READER_ONION_HOSTNAME=$(add_onion_service ttrss 80 ${RSS_MOBILE_READER_ONION_PORT})
  7086. echo 'server {' > /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7087. echo " listen 127.0.0.1:$RSS_MOBILE_READER_ONION_PORT;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7088. echo " server_name $RSS_MOBILE_READER_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7089. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7090. echo ' access_log off;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7091. echo ' error_log off;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7092. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7093. echo ' root /etc/share/ttrss-mobile;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7094. echo ' index index.html index.php;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7095. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7096. echo ' location ~ \.php {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7097. echo ' include snippets/fastcgi-php.conf;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7098. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7099. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7100. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7101. echo ' location / {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7102. echo ' try_files $uri $uri/ @ttrss;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7103. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7104. echo ' location /tt-rss {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7105. echo ' try_files $uri $uri/ @ttrss_base;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7106. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7107. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7108. echo ' location @ttrss {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7109. echo ' rewrite ^(.*)$ /index.html?p=$1 last;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7110. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7111. echo ' location @ttrss_base {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7112. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7113. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7114. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7115. echo ' location ~ /\.(git) {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7116. echo ' deny all;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7117. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7118. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7119. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7120. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7121. echo ' client_max_body_size 15m;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7122. echo '}' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7123. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7124. echo 'server {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7125. echo " listen 127.0.0.1:$RSS_READER_ONION_PORT default_server;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7126. echo " server_name $RSS_READER_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7127. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7128. echo ' access_log off;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7129. echo ' error_log off;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7130. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7131. echo ' root /etc/share/tt-rss;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7132. echo ' index index.php;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7133. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7134. echo ' location ~ \.php {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7135. echo ' include snippets/fastcgi-php.conf;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7136. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7137. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7138. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7139. echo ' set $mobile_rewrite do_not_perform;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7140. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7141. echo ' ## chi http_user_agent for mobile / smart phones ##' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7142. 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
  7143. echo ' set $mobile_rewrite perform;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7144. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7145. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7146. 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
  7147. echo ' set $mobile_rewrite perform;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7148. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7149. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7150. echo ' if ($mobile_rewrite = perform) {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7151. echo " rewrite ^/(.*) http://$RSS_MOBILE_READER_ONION_HOSTNAME permanent;" >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7152. echo ' break;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7153. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7154. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7155. echo ' location ~ \.php {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7156. echo ' include snippets/fastcgi-php.conf;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7157. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7158. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7159. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7160. echo ' location / {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7161. echo ' try_files $uri $uri/ @ttrss;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7162. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7163. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7164. echo ' location @ttrss {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7165. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7166. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7167. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7168. echo ' location ~ /\.(git) {' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7169. echo ' deny all;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7170. echo ' }' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7171. echo '' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7172. echo ' add_header X-Frame-Options DENY;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7173. echo ' add_header X-Content-Type-Options nosniff;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7174. echo ' client_max_body_size 15m;' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7175. echo '}' >> /etc/nginx/sites-available/$RSS_READER_DOMAIN_NAME
  7176. if [ ! -f $RSS_READER_PATH/config.php ]; then
  7177. # generate a config file
  7178. RSS_FEED_CRYPT_KEY="$(openssl rand -base64 26 | cut -c1-24)"
  7179. echo '<?php' > $RSS_READER_PATH/config.php
  7180. echo " define ('_CURL_HTTP_PROXY', '127.0.0.1:9050');" >> $RSS_READER_PATH/config.php
  7181. echo " define('DB_TYPE', 'mysql');" >> $RSS_READER_PATH/config.php
  7182. echo " define('DB_HOST', 'localhost');" >> $RSS_READER_PATH/config.php
  7183. echo " define('DB_USER', 'root');" >> $RSS_READER_PATH/config.php
  7184. echo " define('DB_NAME', 'ttrss');" >> $RSS_READER_PATH/config.php
  7185. echo " define('DB_PASS', '${MARIADB_PASSWORD}');" >> $RSS_READER_PATH/config.php
  7186. echo " define('DB_PORT', '3306');" >> $RSS_READER_PATH/config.php
  7187. echo " define('MYSQL_CHARSET', 'UTF8');" >> $RSS_READER_PATH/config.php
  7188. echo " define('SELF_URL_PATH', 'http://${RSS_READER_ONION_HOSTNAME}/');" >> $RSS_READER_PATH/config.php
  7189. echo " define('FEED_CRYPT_KEY', '${RSS_FEED_CRYPT_KEY}');" >> $RSS_READER_PATH/config.php
  7190. echo " define('SINGLE_USER_MODE', false);" >> $RSS_READER_PATH/config.php
  7191. echo " define('SIMPLE_UPDATE_MODE', false);" >> $RSS_READER_PATH/config.php
  7192. echo " define('PHP_EXECUTABLE', '/usr/bin/php');" >> $RSS_READER_PATH/config.php
  7193. echo " define('LOCK_DIRECTORY', 'lock');" >> $RSS_READER_PATH/config.php
  7194. echo " define('CACHE_DIR', 'cache');" >> $RSS_READER_PATH/config.php
  7195. echo " define('ICONS_DIR', \"feed-icons\");" >> $RSS_READER_PATH/config.php
  7196. echo " define('ICONS_URL', \"feed-icons\");" >> $RSS_READER_PATH/config.php
  7197. echo " define('AUTH_AUTO_CREATE', true);" >> $RSS_READER_PATH/config.php
  7198. echo " define('AUTH_AUTO_LOGIN', true);" >> $RSS_READER_PATH/config.php
  7199. echo " define('FORCE_ARTICLE_PURGE', 0);" >> $RSS_READER_PATH/config.php
  7200. echo " define('PUBSUBHUBBUB_HUB', '');" >> $RSS_READER_PATH/config.php
  7201. echo " define('PUBSUBHUBBUB_ENABLED', false);" >> $RSS_READER_PATH/config.php
  7202. echo " define('SPHINX_SERVER', 'localhost:9312');" >> $RSS_READER_PATH/config.php
  7203. echo " define('SPHINX_INDEX', 'ttrss, delta');" >> $RSS_READER_PATH/config.php
  7204. echo " define('ENABLE_REGISTRATION', false);" >> $RSS_READER_PATH/config.php
  7205. echo " define('REG_NOTIFY_ADDRESS', '${MY_EMAIL_ADDRESS}');" >> $RSS_READER_PATH/config.php
  7206. echo " define('REG_MAX_USERS', 10);" >> $RSS_READER_PATH/config.php
  7207. echo " define('SESSION_COOKIE_LIFETIME', 86400);" >> $RSS_READER_PATH/config.php
  7208. echo " define('SMTP_FROM_NAME', 'Tiny Tiny RSS');" >> $RSS_READER_PATH/config.php
  7209. echo " define('SMTP_FROM_ADDRESS', 'noreply@${RSS_READER_ONION_HOSTNAME}');" >> $RSS_READER_PATH/config.php
  7210. echo " define('DIGEST_SUBJECT', '[tt-rss] New headlines for last 24 hours');" >> $RSS_READER_PATH/config.php
  7211. echo " define('SMTP_SERVER', '');" >> $RSS_READER_PATH/config.php
  7212. echo " define('SMTP_LOGIN', '');" >> $RSS_READER_PATH/config.php
  7213. echo " define('SMTP_PASSWORD', '');" >> $RSS_READER_PATH/config.php
  7214. echo " define('SMTP_SECURE', '');" >> $RSS_READER_PATH/config.php
  7215. echo " define('CHECK_FOR_UPDATES', false);" >> $RSS_READER_PATH/config.php
  7216. echo " define('ENABLE_GZIP_OUTPUT', false);" >> $RSS_READER_PATH/config.php
  7217. echo " define('PLUGINS', 'auth_internal, note, gnusocial');" >> $RSS_READER_PATH/config.php
  7218. echo " define('LOG_DESTINATION', 'sql');" >> $RSS_READER_PATH/config.php
  7219. echo " define('CONFIG_VERSION', 26);" >> $RSS_READER_PATH/config.php
  7220. fi
  7221. # initialize the database
  7222. if [ ! -f $RSS_READER_PATH/schema/ttrss_schema_mysql.sql ]; then
  7223. echo $'No database schema found for rss reader'
  7224. exit 52926
  7225. fi
  7226. mysql -u root --password="$MARIADB_PASSWORD" -D ttrss < $RSS_READER_PATH/schema/ttrss_schema_mysql.sql
  7227. # change the password from the default
  7228. RSS_READER_ADMIN_PASSWORD_HASH=$(echo -n "${RSS_READER_ADMIN_PASSWORD}" | sha1sum | awk -F ' ' '{print $1}')
  7229. mysql -u root --password="$MARIADB_PASSWORD" -e "update ttrss_users set pwd_hash = 'SHA1:${RSS_READER_ADMIN_PASSWORD_HASH}', salt= '' WHERE login = 'admin';" ttrss
  7230. rss_reader_modifications
  7231. configure_php
  7232. nginx_ensite $RSS_READER_DOMAIN_NAME
  7233. systemctl restart php5-fpm
  7234. systemctl restart nginx
  7235. if ! grep -q "RSS reader onion domain" $COMPLETION_FILE; then
  7236. echo "RSS reader onion domain:${RSS_READER_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7237. fi
  7238. if ! grep -q "RSS reader domain" $COMPLETION_FILE; then
  7239. echo "RSS reader domain:${RSS_READER_DOMAIN_NAME}" >> $COMPLETION_FILE
  7240. fi
  7241. # daemon to update feeds
  7242. echo '[Unit]' > /etc/systemd/system/ttrss.service
  7243. echo 'Description=ttrss_backend' >> /etc/systemd/system/ttrss.service
  7244. echo 'After=network.target mysql.service' >> /etc/systemd/system/ttrss.service
  7245. echo 'After=tor.service' >> /etc/systemd/system/ttrss.service
  7246. echo '' >> /etc/systemd/system/ttrss.service
  7247. echo '[Service]' >> /etc/systemd/system/ttrss.service
  7248. echo 'User=www-data' >> /etc/systemd/system/ttrss.service
  7249. echo "ExecStart=/usr/bin/php $RSS_READER_PATH/update.php --daemon" >> /etc/systemd/system/ttrss.service
  7250. echo '' >> /etc/systemd/system/ttrss.service
  7251. echo '[Install]' >> /etc/systemd/system/ttrss.service
  7252. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/ttrss.service
  7253. systemctl enable ttrss
  7254. systemctl daemon-reload
  7255. systemctl start ttrss
  7256. # some post-install instructions for the user
  7257. if ! grep -q $"RSS Reader" /home/$MY_USERNAME/README; then
  7258. echo '' >> /home/$MY_USERNAME/README
  7259. echo '' >> /home/$MY_USERNAME/README
  7260. echo $'RSS Reader' >> /home/$MY_USERNAME/README
  7261. echo '==========' >> /home/$MY_USERNAME/README
  7262. echo $"RSS reader domain: ${RSS_READER_DOMAIN_NAME}" >> /home/$MY_USERNAME/README
  7263. echo $"RSS reader onion domain: ${RSS_READER_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  7264. echo $"RSS reader admin username: admin" >> /home/$MY_USERNAME/README
  7265. echo $"RSS reader admin password: ${RSS_READER_ADMIN_PASSWORD}" >> /home/$MY_USERNAME/README
  7266. echo '' >> /home/$MY_USERNAME/README
  7267. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7268. chmod 600 /home/$MY_USERNAME/README
  7269. fi
  7270. echo 'install_rss_reader' >> $COMPLETION_FILE
  7271. }
  7272. function install_rss_reader_gnusocial {
  7273. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7274. return
  7275. fi
  7276. if [ ! $MICROBLOG_DOMAIN_NAME ]; then
  7277. return
  7278. fi
  7279. if [ ! $RSS_READER_PATH ]; then
  7280. RSS_READER_PATH=/etc/share/tt-rss
  7281. fi
  7282. RSS_READER_GNUSOCIAL_PATH=${RSS_READER_PATH}/plugins/gnusocial
  7283. # update to the next commit
  7284. set_repo_commit $RSS_READER_GNUSOCIAL_PATH "RSS reader gnusocial commit" "$RSS_READER_GNUSOCIAL_COMMIT" $RSS_READER_GNUSOCIAL_REPO
  7285. chown -R www-data:www-data $RSS_READER_GNUSOCIAL_PATH
  7286. if grep -Fxq "install_rss_reader_gnusocial" $COMPLETION_FILE; then
  7287. return
  7288. fi
  7289. if [ ! -d $INSTALL_DIR ]; then
  7290. mkdir -p $INSTALL_DIR
  7291. fi
  7292. cd $INSTALL_DIR
  7293. git_clone $RSS_READER_GNUSOCIAL_REPO ttrss-gnusocial
  7294. if [ ! -d $INSTALL_DIR/ttrss-gnusocial ]; then
  7295. echo $'Could not clone repo for RSS reader GNU Social plugin'
  7296. exit 52838
  7297. fi
  7298. cp -r $INSTALL_DIR/ttrss-gnusocial $RSS_READER_GNUSOCIAL_PATH
  7299. cd $RSS_READER_GNUSOCIAL_PATH
  7300. git checkout $RSS_READER_GNUSOCIAL_COMMIT -b $RSS_READER_GNUSOCIAL_COMMIT
  7301. if ! grep -q "RSS reader gnusocial commit" $COMPLETION_FILE; then
  7302. echo "RSS reader gnusocial commit:$RSS_READER_GNUSOCIAL_COMMIT" >> $COMPLETION_FILE
  7303. fi
  7304. chown -R www-data:www-data $RSS_READER_GNUSOCIAL_PATH
  7305. echo 'install_rss_reader_gnusocial' >> $COMPLETION_FILE
  7306. }
  7307. function install_rss_mobile_reader {
  7308. if [[ $SYSTEM_TYPE == "$VARIANT_MAILBOX" || $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MEDIA" || $SYSTEM_TYPE == "$VARIANT_DEVELOPER" || $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7309. return
  7310. fi
  7311. if [ ! $RSS_READER_PATH ]; then
  7312. RSS_READER_PATH=/etc/share/tt-rss
  7313. fi
  7314. if [ ! -d $RSS_READER_PATH ]; then
  7315. echo $'tt-rss is not installed, so the mobile version cannot be installed'
  7316. exit 63452
  7317. fi
  7318. RSS_MOBILE_READER_PATH=/etc/share/ttrss-mobile
  7319. # remove any previous install
  7320. if [ -d $RSS_READER_PATH/g2ttree-mobile ]; then
  7321. if grep -Fxq "install_rss_mobile_reader" $COMPLETION_FILE; then
  7322. sed -i '/install_rss_mobile_reader/d' $COMPLETION_FILE
  7323. sed -i '/RSS mobile reader commit/d' $COMPLETION_FILE
  7324. rm -rf $RSS_READER_PATH/g2ttree-mobile
  7325. fi
  7326. fi
  7327. # update to the next commit
  7328. set_repo_commit $RSS_MOBILE_READER_PATH "RSS mobile reader commit" "$RSS_MOBILE_READER_COMMIT" $RSS_MOBILE_READER_REPO
  7329. if grep -Fxq "install_rss_mobile_reader" $COMPLETION_FILE; then
  7330. return
  7331. fi
  7332. cd /etc/share
  7333. git_clone $RSS_MOBILE_READER_REPO ttrss-mobile
  7334. if [ ! -d $RSS_MOBILE_READER_PATH ]; then
  7335. echo $'Could not clone RSS mobile reader repo'
  7336. exit 24816
  7337. fi
  7338. cd $RSS_MOBILE_READER_PATH
  7339. git checkout $RSS_MOBILE_READER_COMMIT -b $RSS_MOBILE_READER_COMMIT
  7340. if ! grep -q "RSS mobile reader commit" $COMPLETION_FILE; then
  7341. echo "RSS mobile reader commit:$RSS_MOBILE_READER_COMMIT" >> $COMPLETION_FILE
  7342. fi
  7343. echo 'define({' > $RSS_MOBILE_READER_PATH/scripts/conf.js
  7344. echo ' apiPath: "/tt-rss/"' >> $RSS_MOBILE_READER_PATH/scripts/conf.js
  7345. echo '});' >> $RSS_MOBILE_READER_PATH/scripts/conf.js
  7346. # link to the main site
  7347. ln -s $RSS_READER_PATH $RSS_MOBILE_READER_PATH/tt-rss
  7348. chown -R www-data:www-data $RSS_MOBILE_READER_PATH
  7349. chown -R www-data:www-data $RSS_READER_PATH
  7350. chmod a+x $RSS_MOBILE_READER_PATH
  7351. echo 'install_rss_mobile_reader' >> $COMPLETION_FILE
  7352. }
  7353. function install_gnu_social {
  7354. 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
  7355. return
  7356. fi
  7357. if [ ! $MICROBLOG_DOMAIN_NAME ]; then
  7358. echo $'No domain name was given for the microblog'
  7359. exit 7359
  7360. fi
  7361. # update to the next commit
  7362. set_repo_commit /var/www/$MICROBLOG_DOMAIN_NAME/htdocs "GNU Social commit" "$MICROBLOG_COMMIT" $MICROBLOG_REPO
  7363. if grep -Fxq "install_gnu_social" $COMPLETION_FILE; then
  7364. return
  7365. fi
  7366. install_mariadb
  7367. get_mariadb_password
  7368. repair_databases_script
  7369. apt-get -y install php-gettext php5-curl php5-gd php5-mysql git curl php-xml-parser
  7370. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME ]; then
  7371. mkdir /var/www/$MICROBLOG_DOMAIN_NAME
  7372. fi
  7373. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs ]; then
  7374. git_clone $MICROBLOG_REPO /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7375. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs ]; then
  7376. echo $'Unable to clone gnusocial repo'
  7377. exit 87525
  7378. fi
  7379. fi
  7380. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7381. git checkout $MICROBLOG_COMMIT -b $MICROBLOG_COMMIT
  7382. if ! grep -q "GNU Social commit" $COMPLETION_FILE; then
  7383. echo "GNU Social commit:$MICROBLOG_COMMIT" >> $COMPLETION_FILE
  7384. else
  7385. sed -i "s/GNU Social commit.*/GNU Social commit:$MICROBLOG_COMMIT/g" $COMPLETION_FILE
  7386. fi
  7387. chmod a+w /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7388. chown www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7389. chmod +x /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php
  7390. get_mariadb_gnusocial_admin_password
  7391. if [ ! $MICROBLOG_ADMIN_PASSWORD ]; then
  7392. if [ -f $IMAGE_PASSWORD_FILE ]; then
  7393. MICROBLOG_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  7394. else
  7395. MICROBLOG_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-30)"
  7396. fi
  7397. fi
  7398. create_database gnusocial "$MICROBLOG_ADMIN_PASSWORD" $MY_USERNAME
  7399. if [ ! -f "/etc/aliases" ]; then
  7400. touch /etc/aliases
  7401. fi
  7402. if ! grep -q "www-data: root" /etc/aliases; then
  7403. echo 'www-data: root' >> /etc/aliases
  7404. fi
  7405. if ! grep -q "/var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php" /etc/aliases; then
  7406. echo "*: /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/scripts/maildaemon.php" >> /etc/aliases
  7407. fi
  7408. newaliases
  7409. add_ddns_domain $MICROBLOG_DOMAIN_NAME
  7410. microblog_nginx_site=/etc/nginx/sites-available/$MICROBLOG_DOMAIN_NAME
  7411. if [[ $ONION_ONLY == "no" ]]; then
  7412. nginx_http_redirect $MICROBLOG_DOMAIN_NAME
  7413. echo 'server {' >> $microblog_nginx_site
  7414. echo ' listen 443 ssl;' >> $microblog_nginx_site
  7415. echo " server_name $MICROBLOG_DOMAIN_NAME;" >> $microblog_nginx_site
  7416. echo '' >> $microblog_nginx_site
  7417. echo ' # Security' >> $microblog_nginx_site
  7418. nginx_ssl $MICROBLOG_DOMAIN_NAME
  7419. nginx_disable_sniffing $MICROBLOG_DOMAIN_NAME
  7420. nginx_limits $MICROBLOG_DOMAIN_NAME '15m'
  7421. echo ' add_header Strict-Transport-Security max-age=15768000;' >> $microblog_nginx_site
  7422. echo '' >> $microblog_nginx_site
  7423. echo ' # Logs' >> $microblog_nginx_site
  7424. echo ' access_log off;' >> $microblog_nginx_site
  7425. echo ' error_log off;' >> $microblog_nginx_site
  7426. echo '' >> $microblog_nginx_site
  7427. echo ' # Root' >> $microblog_nginx_site
  7428. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> $microblog_nginx_site
  7429. echo '' >> $microblog_nginx_site
  7430. echo ' # Index' >> $microblog_nginx_site
  7431. echo ' index index.php;' >> $microblog_nginx_site
  7432. echo '' >> $microblog_nginx_site
  7433. echo ' # PHP' >> $microblog_nginx_site
  7434. echo ' location ~ \.php {' >> $microblog_nginx_site
  7435. echo ' include snippets/fastcgi-php.conf;' >> $microblog_nginx_site
  7436. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> $microblog_nginx_site
  7437. echo ' }' >> $microblog_nginx_site
  7438. echo '' >> $microblog_nginx_site
  7439. echo ' # Location' >> $microblog_nginx_site
  7440. echo ' location / {' >> $microblog_nginx_site
  7441. echo ' try_files $uri $uri/ @gnusocial;' >> $microblog_nginx_site
  7442. echo ' }' >> $microblog_nginx_site
  7443. echo '' >> $microblog_nginx_site
  7444. echo ' # Fancy URLs' >> $microblog_nginx_site
  7445. echo ' location @gnusocial {' >> $microblog_nginx_site
  7446. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> $microblog_nginx_site
  7447. echo ' }' >> $microblog_nginx_site
  7448. echo '' >> $microblog_nginx_site
  7449. echo ' # Restrict access that is unnecessary anyway' >> $microblog_nginx_site
  7450. echo ' location ~ /\.(ht|git) {' >> $microblog_nginx_site
  7451. echo ' deny all;' >> $microblog_nginx_site
  7452. echo ' }' >> $microblog_nginx_site
  7453. echo '}' >> $microblog_nginx_site
  7454. else
  7455. echo -n '' > $microblog_nginx_site
  7456. fi
  7457. echo 'server {' >> $microblog_nginx_site
  7458. echo " listen 127.0.0.1:$MICROBLOG_ONION_PORT default_server;" >> $microblog_nginx_site
  7459. echo " server_name $MICROBLOG_DOMAIN_NAME;" >> $microblog_nginx_site
  7460. echo '' >> $microblog_nginx_site
  7461. echo ' # Logs' >> $microblog_nginx_site
  7462. echo ' access_log off;' >> $microblog_nginx_site
  7463. echo ' error_log off;' >> $microblog_nginx_site
  7464. echo '' >> $microblog_nginx_site
  7465. echo ' # Root' >> $microblog_nginx_site
  7466. echo " root /var/www/$MICROBLOG_DOMAIN_NAME/htdocs;" >> $microblog_nginx_site
  7467. echo '' >> $microblog_nginx_site
  7468. echo ' # Index' >> $microblog_nginx_site
  7469. echo ' index index.php;' >> $microblog_nginx_site
  7470. echo '' >> $microblog_nginx_site
  7471. echo ' # PHP' >> $microblog_nginx_site
  7472. echo ' location ~ \.php {' >> $microblog_nginx_site
  7473. echo ' include snippets/fastcgi-php.conf;' >> $microblog_nginx_site
  7474. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> $microblog_nginx_site
  7475. echo ' }' >> $microblog_nginx_site
  7476. echo '' >> $microblog_nginx_site
  7477. echo ' # Location' >> $microblog_nginx_site
  7478. echo ' location / {' >> $microblog_nginx_site
  7479. echo ' try_files $uri $uri/ @gnusocial;' >> $microblog_nginx_site
  7480. echo ' }' >> $microblog_nginx_site
  7481. echo '' >> $microblog_nginx_site
  7482. echo ' # Fancy URLs' >> $microblog_nginx_site
  7483. echo ' location @gnusocial {' >> $microblog_nginx_site
  7484. echo ' rewrite ^(.*)$ /index.php?p=$1 last;' >> $microblog_nginx_site
  7485. echo ' }' >> $microblog_nginx_site
  7486. echo '' >> $microblog_nginx_site
  7487. echo ' # Restrict access that is unnecessary anyway' >> $microblog_nginx_site
  7488. echo ' location ~ /\.(ht|git) {' >> $microblog_nginx_site
  7489. echo ' deny all;' >> $microblog_nginx_site
  7490. echo ' }' >> $microblog_nginx_site
  7491. echo '' >> $microblog_nginx_site
  7492. nginx_disable_sniffing $MICROBLOG_DOMAIN_NAME
  7493. nginx_limits $MICROBLOG_DOMAIN_NAME '15m'
  7494. echo '}' >> $microblog_nginx_site
  7495. configure_php
  7496. create_site_certificate $MICROBLOG_DOMAIN_NAME 'yes'
  7497. # Ensure that the database gets backed up locally, if remote
  7498. # backups are not being used
  7499. backup_databases_script_header
  7500. backup_database_local gnusocial
  7501. nginx_ensite $MICROBLOG_DOMAIN_NAME
  7502. # NOTE: For the typical case always enable SSL and only
  7503. # disable it if in onion only mode. This is due to complexities
  7504. # with the way URLs are generated by GNU Social
  7505. gnu_social_ssl='always'
  7506. if [[ $ONION_ONLY != 'no' ]]; then
  7507. gnu_social_ssl='never'
  7508. fi
  7509. MICROBLOG_ONION_HOSTNAME=$(add_onion_service microblog 80 ${MICROBLOG_ONION_PORT})
  7510. MICROBLOG_SERVER=${MICROBLOG_DOMAIN_NAME}
  7511. if [[ $ONION_ONLY != 'no' ]]; then
  7512. MICROBLOG_SERVER=${MICROBLOG_ONION_HOSTNAME}
  7513. fi
  7514. # Create the configuration
  7515. gnu_social_installer=/var/www/${MICROBLOG_DOMAIN_NAME}/htdocs/scripts/install_cli.php
  7516. if [ ! -f $gnu_social_installer ]; then
  7517. echo $'No GNU Social commandline installer found'
  7518. exit 53026
  7519. fi
  7520. ${gnu_social_installer} --server "${MICROBLOG_SERVER}" \
  7521. --host="localhost" --database="gnusocial" \
  7522. --dbtype=mysql --username="root" -v \
  7523. --password="$MARIADB_PASSWORD" \
  7524. --sitename=$"GNU Social" --fancy='yes' \
  7525. --admin-nick="$MY_USERNAME" \
  7526. --admin-pass="$MICROBLOG_ADMIN_PASSWORD" \
  7527. --site-profile="community" \
  7528. --ssl=${gnu_social_ssl}
  7529. # There can be a lot of warnings here so the return value check is disabled
  7530. #if [ ! "$?" = "0" ]; then
  7531. # # failed to install
  7532. # echo $'Could not install GNU Social'
  7533. # exit 72357
  7534. #fi
  7535. # check microblog has a config file
  7536. microblog_config_file=/var/www/$MICROBLOG_DOMAIN_NAME/htdocs/config.php
  7537. if [ ! -f $microblog_config_file ]; then
  7538. echo $'Microblog config.php not found'
  7539. exit 87586
  7540. fi
  7541. # Some useful settings
  7542. if ! grep -q "Recommended GNU social settings" $microblog_config_file; then
  7543. echo "" >> $microblog_config_file
  7544. echo "// Recommended GNU social settings" >> $microblog_config_file
  7545. echo "\$config['thumbnail']['maxsize'] = 3000;" >> $microblog_config_file
  7546. echo "\$config['profile']['delete'] = true;" >> $microblog_config_file
  7547. echo "\$config['profile']['changenick'] = true;" >> $microblog_config_file
  7548. echo "\$config['public']['localonly'] = false;" >> $microblog_config_file
  7549. echo "addPlugin('StoreRemoteMedia');" >> $microblog_config_file
  7550. echo "\$config['queue']['enabled'] = true;" >> $microblog_config_file
  7551. echo "\$config['queue']['daemon'] = true;" >> $microblog_config_file
  7552. fi
  7553. # This improves performance
  7554. sed -i "s|//\$config\['db'\]\['schemacheck'\].*|\$config\['db'\]\['schemacheck'\] = 'script';|g" $microblog_config_file
  7555. systemctl restart php5-fpm
  7556. systemctl restart nginx
  7557. freedombone-addemail -u $MY_USERNAME -e "noreply@$MICROBLOG_DOMAIN_NAME" -g gnusocial --public no
  7558. # some post-install instructions for the user
  7559. if ! grep -q $"Microblog administrator" /home/$MY_USERNAME/README; then
  7560. echo '' >> /home/$MY_USERNAME/README
  7561. echo '' >> /home/$MY_USERNAME/README
  7562. echo $'Microblog' >> /home/$MY_USERNAME/README
  7563. echo '=========' >> /home/$MY_USERNAME/README
  7564. echo $"Microblog administrator nickname: $MY_USERNAME" >> /home/$MY_USERNAME/README
  7565. echo $"Microblog administrator password: $MICROBLOG_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7566. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7567. chmod 600 /home/$MY_USERNAME/README
  7568. fi
  7569. if ! grep -q "Microblog onion domain" /home/$MY_USERNAME/README; then
  7570. echo $"Microblog onion domain: ${MICROBLOG_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  7571. echo '' >> /home/$MY_USERNAME/README
  7572. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7573. chmod 600 /home/$MY_USERNAME/README
  7574. fi
  7575. echo "GNU Social onion domain:${MICROBLOG_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7576. echo "GNU Social domain:$MICROBLOG_DOMAIN_NAME" >> $COMPLETION_FILE
  7577. echo 'install_gnu_social' >> $COMPLETION_FILE
  7578. }
  7579. function expire_gnu_social_posts {
  7580. # To prevent the database size from growing endlessly this script expires posts
  7581. # after a number of months
  7582. 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
  7583. return
  7584. fi
  7585. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs ]; then
  7586. return
  7587. fi
  7588. gnusocial_expire_script=/usr/bin/gnusocial-expire
  7589. echo '<?php' > $gnusocial_expire_script
  7590. echo '' >> $gnusocial_expire_script
  7591. echo '// GNU Social post expiry script, based on StatExpire by Tony Baldwin' >> $gnusocial_expire_script
  7592. echo '// https://github.com/tonybaldwin/statexpire' >> $gnusocial_expire_script
  7593. echo '' >> $gnusocial_expire_script
  7594. echo '$oldate=date(("Y-m-d"), strtotime("-3 months"));' >> $gnusocial_expire_script
  7595. echo '$username="root";' >> $gnusocial_expire_script
  7596. echo "\$password=trim(file_get_contents(\"$DATABASE_PASSWORD_FILE\"));" >> $gnusocial_expire_script
  7597. echo '$database="gnusocial";' >> $gnusocial_expire_script
  7598. echo '' >> $gnusocial_expire_script
  7599. echo 'if (!$link = mysql_connect("localhost", $username, $password)) {' >> $gnusocial_expire_script
  7600. echo ' echo "Could not connect to mariadb";' >> $gnusocial_expire_script
  7601. echo ' exit;' >> $gnusocial_expire_script
  7602. echo '}' >> $gnusocial_expire_script
  7603. echo '' >> $gnusocial_expire_script
  7604. echo 'if (!mysql_select_db($database, $link)) {' >> $gnusocial_expire_script
  7605. echo ' echo "Could not select gnusocial database";' >> $gnusocial_expire_script
  7606. echo ' exit;' >> $gnusocial_expire_script
  7607. echo '}' >> $gnusocial_expire_script
  7608. echo '' >> $gnusocial_expire_script
  7609. echo "\$notice_query=\"DELETE FROM notice WHERE created <= '\$oldate 01:01:01'\";" >> $gnusocial_expire_script
  7610. echo "\$conversation_query=\"DELETE FROM conversation WHERE created <= '$oldate 01:01:01'\";" >> $gnusocial_expire_script
  7611. echo "\$reply_query=\"DELETE FROM reply WHERE modified <= '\$oldate 01:01:01'\";" >> $gnusocial_expire_script
  7612. echo '' >> $gnusocial_expire_script
  7613. echo 'mysql_query($notice_query);' >> $gnusocial_expire_script
  7614. echo '$rowaff1=mysql_affected_rows();' >> $gnusocial_expire_script
  7615. echo 'mysql_query($conversation_query);' >> $gnusocial_expire_script
  7616. echo '$rowaff2=mysql_affected_rows();' >> $gnusocial_expire_script
  7617. echo 'mysql_query($reply_query);' >> $gnusocial_expire_script
  7618. echo '$rowaff3=mysql_affected_rows();' >> $gnusocial_expire_script
  7619. echo 'mysql_close();' >> $gnusocial_expire_script
  7620. echo '' >> $gnusocial_expire_script
  7621. echo 'echo "Expire GNU Social posts: $rowaff1 notices, $rowaff2 conversations, and $rowaff3 replies deleted from database.\n";' >> $gnusocial_expire_script
  7622. chmod +x $gnusocial_expire_script
  7623. # Add a cron job
  7624. if ! grep -q "$gnusocial_expire_script" /etc/crontab; then
  7625. echo "10 3 5 * * root /usr/bin/timeout 500 /usr/bin/php $gnusocial_expire_script" >> /etc/crontab
  7626. fi
  7627. # remove old expire script
  7628. if [ -f /etc/cron.weekly/clear-microblog-database ]; then
  7629. rm /etc/cron.weekly/clear-microblog-database
  7630. fi
  7631. }
  7632. function install_gnu_social_theme {
  7633. 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
  7634. return
  7635. fi
  7636. # update to the next commit
  7637. set_repo_commit /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Qvitter "GNU Social theme commit" "$MICROBLOG_THEME_COMMIT" $MICROBLOG_THEME_REPO
  7638. if grep -Fxq "install_gnu_social_theme" $COMPLETION_FILE; then
  7639. return
  7640. fi
  7641. apt-get -y install wget
  7642. if [ ! -d /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins ]; then
  7643. mkdir -p /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins
  7644. fi
  7645. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins
  7646. git_clone $MICROBLOG_THEME_REPO Qvitter
  7647. cd /var/www/$MICROBLOG_DOMAIN_NAME/htdocs/local/plugins/Qvitter
  7648. git checkout $MICROBLOG_THEME_COMMIT -b $MICROBLOG_THEME_COMMIT
  7649. # download a custom background image
  7650. MICROBLOG_BACKGROUND_IMAGE_URL_EXT=
  7651. if [ $MICROBLOG_BACKGROUND_IMAGE_URL ]; then
  7652. if [[ $$MICROBLOG_BACKGROUND_IMAGE_URL == *".jpeg" || $$MICROBLOG_BACKGROUND_IMAGE_URL == *".jpg" ]]; then
  7653. MICROBLOG_BACKGROUND_IMAGE_URL_EXT="jpg"
  7654. fi
  7655. if [[ $$MICROBLOG_BACKGROUND_IMAGE_URL == *".png" ]]; then
  7656. MICROBLOG_BACKGROUND_IMAGE_URL_EXT="png"
  7657. fi
  7658. if [[ $$MICROBLOG_BACKGROUND_IMAGE_URL == *".gif" ]]; then
  7659. MICROBLOG_BACKGROUND_IMAGE_URL_EXT="gif"
  7660. fi
  7661. if [ $MICROBLOG_BACKGROUND_IMAGE_URL_EXT ]; then
  7662. wget $MICROBLOG_BACKGROUND_IMAGE_URL -O img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT}
  7663. if [ ! -f img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT} ]; then
  7664. echo "$MICROBLOG_BACKGROUND_IMAGE_URL"
  7665. echo $'Custom background image for microblog could not be downloaded'
  7666. exit 87524
  7667. fi
  7668. fi
  7669. fi
  7670. microblog_config_file=/var/www/$MICROBLOG_DOMAIN_NAME/htdocs/config.php
  7671. if ! grep -q "addPlugin('Qvitter')" $microblog_config_file; then
  7672. MICROBLOG_WELCOME_MESSAGE=$(echo $MICROBLOG_WELCOME_MESSAGE | sed "s|\$MICROBLOG_DOMAIN_NAME|$MICROBLOG_DOMAIN_NAME|g")
  7673. echo "" >> $microblog_config_file
  7674. echo "// Qvitter settings" >> $microblog_config_file
  7675. echo "addPlugin('Qvitter');" >> $microblog_config_file
  7676. echo "\$config['site']['qvitter']['enabledbydefault'] = true;" >> $microblog_config_file
  7677. echo "\$config['site']['qvitter']['defaultbackgroundcolor'] = '#f4f4f4';" >> $microblog_config_file
  7678. echo "\$config['site']['qvitter']['defaultlinkcolor'] = '#0084B4';" >> $microblog_config_file
  7679. echo "\$config['site']['qvitter']['timebetweenpolling'] = 120000; // two minutes" >> $microblog_config_file
  7680. echo "\$config['site']['qvitter']['urlshortenerapiurl'] = 'http://qttr.at/shortener.php';" >> $microblog_config_file
  7681. echo "\$config['site']['qvitter']['urlshortenersignature'] = 'b6afeec983';" >> $microblog_config_file
  7682. if [ $MICROBLOG_BACKGROUND_IMAGE_URL ]; then
  7683. echo "\$config['site']['qvitter']['sitebackground'] = 'img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT}';" >> $microblog_config_file
  7684. else
  7685. echo "\$config['site']['qvitter']['sitebackground'] = 'img/vagnsmossen.jpg';" >> $microblog_config_file
  7686. fi
  7687. echo "\$config['site']['qvitter']['favicon'] = 'img/favicon.ico?v=4';" >> $microblog_config_file
  7688. echo "\$config['site']['qvitter']['sprite'] = Plugin::staticPath('Qvitter', '').'img/sprite.png?v=40';" >> $microblog_config_file
  7689. echo "\$config['site']['qvitter']['enablewelcometext'] = true;" >> $microblog_config_file
  7690. echo "\$config['site']['qvitter']['customwelcometext']['en'] = '$MICROBLOG_WELCOME_MESSAGE';" >> $microblog_config_file
  7691. echo "\$config['site']['qvitter']['customwelcometext']['de'] = '$MICROBLOG_WELCOME_MESSAGE';" >> $microblog_config_file
  7692. echo "\$config['site']['qvitter']['customwelcometext']['fr'] = '$MICROBLOG_WELCOME_MESSAGE';" >> $microblog_config_file
  7693. echo "\$config['site']['qvitter']['customwelcometext']['es'] = '$MICROBLOG_WELCOME_MESSAGE';" >> $microblog_config_file
  7694. echo "\$config['site']['qvitter']['blocked_ips'] = array();" >> $microblog_config_file
  7695. else
  7696. if [ $MICROBLOG_BACKGROUND_IMAGE_URL_EXT ]; then
  7697. if [ -f img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT} ]; then
  7698. sed -i "s|\$config['site']['qvitter']['sitebackground'].*|\$config['site']['qvitter']['sitebackground'] = 'img/custom.${MICROBLOG_BACKGROUND_IMAGE_URL_EXT}';|g" $microblog_config_file
  7699. fi
  7700. fi
  7701. fi
  7702. if ! grep -q "GNU Social theme commit" $COMPLETION_FILE; then
  7703. echo "GNU Social theme commit:$MICROBLOG_THEME_COMMIT" >> $COMPLETION_FILE
  7704. fi
  7705. chown -R www-data:www-data /var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7706. echo 'install_gnu_social_theme' >> $COMPLETION_FILE
  7707. }
  7708. function install_gnu_social_markdown {
  7709. 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
  7710. return
  7711. fi
  7712. MICROBLOG_PATH=/var/www/$MICROBLOG_DOMAIN_NAME/htdocs
  7713. # update to the next commit
  7714. set_repo_commit $MICROBLOG_PATH/local/plugins/Markdown "GNU Social Markdown commit" "$MICROBLOG_MARKDOWN_COMMIT" $MICROBLOG_MARKDOWN_REPO
  7715. if grep -Fxq "install_gnu_social_markdown" $COMPLETION_FILE; then
  7716. return
  7717. fi
  7718. if [ -d $MICROBLOG_PATH/local/plugins/Markdown ]; then
  7719. rm -rf $MICROBLOG_PATH/local/plugins/Markdown
  7720. fi
  7721. if [ ! -d $MICROBLOG_PATH/local/plugins ]; then
  7722. mkdir -p $MICROBLOG_PATH/local/plugins
  7723. fi
  7724. cd $MICROBLOG_PATH/local/plugins
  7725. git_clone $MICROBLOG_MARKDOWN_REPO Markdown
  7726. cd $MICROBLOG_PATH/local/plugins/Markdown
  7727. git checkout $MICROBLOG_MARKDOWN_COMMIT -b $MICROBLOG_MARKDOWN_COMMIT
  7728. microblog_config_file=$MICROBLOG_PATH/config.php
  7729. if ! grep -q "addPlugin('Markdown'" $microblog_config_file; then
  7730. echo "" >> $microblog_config_file
  7731. echo "// Markdown settings" >> $microblog_config_file
  7732. echo "addPlugin('Markdown');" >> $microblog_config_file
  7733. fi
  7734. if ! grep -q "GNU Social Markdown commit" $COMPLETION_FILE; then
  7735. echo "GNU Social Markdown commit:$MICROBLOG_MARKDOWN_COMMIT" >> $COMPLETION_FILE
  7736. fi
  7737. chown -R www-data:www-data $MICROBLOG_PATH
  7738. echo 'install_gnu_social_markdown' >> $COMPLETION_FILE
  7739. }
  7740. function install_search_engine {
  7741. # Note: currently socks5 outgoing proxies to other search engines does not work
  7742. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  7743. return
  7744. fi
  7745. if [ ! -d /etc/nginx ]; then
  7746. echo $'Webserver is not installed'
  7747. exit 62429
  7748. fi
  7749. # update to a new commit if needed
  7750. set_repo_commit $SEARCH_ENGINE_PATH/searx "Search engine commit" "$SEARCH_ENGINE_COMMIT" $SEARCH_ENGINE_REPO
  7751. if grep "Search engine key" $COMPLETION_FILE; then
  7752. if [ -f ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml ]; then
  7753. # note: this might change to a --tor option in a later version
  7754. if ! grep 'socks5://127.0.0.1:9050' ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml; then
  7755. echo 'outgoing: # communication with search engines' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7756. echo ' proxies:' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7757. echo ' http : socks5://127.0.0.1:9050' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7758. echo ' https: socks5://127.0.0.1:9050' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7759. fi
  7760. SEARCH_ENGINE_SECRET_KEY=$(cat $COMPLETION_FILE | grep "Search engine key" | awk -F ':' '{print $2}')
  7761. sed -i "s|secret_key.*|secret_key : \"${SEARCH_ENGINE_SECRET_KEY}\"|g" ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7762. if [ -f /var/lib/tor/hidden_service_searx/hostname ]; then
  7763. SEARCH_ENGINE_ONION_HOSTNAME=$(echo /var/lib/tor/hidden_service_searx/hostname)
  7764. sed -i '0,/RE/s/base_url.*/base_url : \"http://${SEARCH_ENGINE_ONION_HOSTNAME}\/' ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7765. fi
  7766. fi
  7767. fi
  7768. if grep -Fxq "install_search_engine" $COMPLETION_FILE; then
  7769. return
  7770. fi
  7771. apt-get -y install python-pip libyaml-dev python-werkzeug python-babel python-lxml apache2-utils
  7772. apt-get -y install git build-essential libxslt-dev python-dev python-virtualenv python-pybabel zlib1g-dev uwsgi uwsgi-plugin-python libapache2-mod-uwsgi
  7773. pip install --upgrade pip
  7774. pip install certifi
  7775. if [ ! "$?" = "0" ]; then
  7776. echo $'Failed to install certifi'
  7777. exit 737692
  7778. fi
  7779. pip install pyyaml
  7780. if [ ! "$?" = "0" ]; then
  7781. echo $'Failed to install pyyaml'
  7782. exit 469242
  7783. fi
  7784. pip install flask --upgrade
  7785. if [ ! "$?" = "0" ]; then
  7786. echo $'Failed to install flask'
  7787. exit 888575
  7788. fi
  7789. pip install flask_restless --upgrade
  7790. if [ ! "$?" = "0" ]; then
  7791. echo $'Failed to install flask_restless'
  7792. exit 54835
  7793. fi
  7794. pip install flask_babel --upgrade
  7795. if [ ! "$?" = "0" ]; then
  7796. echo $'Failed to install flask_babel'
  7797. exit 63738
  7798. fi
  7799. if [ ! -d $SEARCH_ENGINE_PATH ]; then
  7800. mkdir -p $SEARCH_ENGINE_PATH
  7801. fi
  7802. # clone the repo
  7803. cd $SEARCH_ENGINE_PATH
  7804. git_clone $SEARCH_ENGINE_REPO searx
  7805. git checkout $SEARCH_ENGINE_COMMIT -b $SEARCH_ENGINE_COMMIT
  7806. if ! grep -q "Search engine commit" $COMPLETION_FILE; then
  7807. echo "Search engine commit:$SEARCH_ENGINE_COMMIT" >> $COMPLETION_FILE
  7808. else
  7809. sed -i "s/Search engine commit.*/Search engine commit:$SEARCH_ENGINE_COMMIT/g" $COMPLETION_FILE
  7810. fi
  7811. # create an onion service
  7812. SEARCH_ENGINE_ONION_HOSTNAME=$(add_onion_service searx 80 ${SEARCH_ENGINE_ONION_PORT})
  7813. if ! grep "Search engine onion domain" $COMPLETION_FILE; then
  7814. echo "Search engine onion domain:${SEARCH_ENGINE_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7815. else
  7816. sed -i "s|Search engine onion domain.*|Search engine onion domain:${SEARCH_ENGINE_ONION_HOSTNAME}|g" $COMPLETION_FILE
  7817. fi
  7818. # an unprivileged user to run as
  7819. useradd -d ${SEARCH_ENGINE_PATH}/searx/ -s /bin/false searx
  7820. adduser searx debian-tor
  7821. # daemon
  7822. echo '[Unit]' > /etc/systemd/system/searx.service
  7823. echo 'Description=Searx (search engine)' >> /etc/systemd/system/searx.service
  7824. echo 'After=syslog.target' >> /etc/systemd/system/searx.service
  7825. echo 'After=network.target' >> /etc/systemd/system/searx.service
  7826. echo '' >> /etc/systemd/system/searx.service
  7827. echo '[Service]' >> /etc/systemd/system/searx.service
  7828. echo 'Type=simple' >> /etc/systemd/system/searx.service
  7829. echo 'User=searx' >> /etc/systemd/system/searx.service
  7830. echo 'Group=searx' >> /etc/systemd/system/searx.service
  7831. echo "WorkingDirectory=${SEARCH_ENGINE_PATH}/searx" >> /etc/systemd/system/searx.service
  7832. echo "ExecStart=/usr/bin/python ${SEARCH_ENGINE_PATH}/searx/searx/webapp.py" >> /etc/systemd/system/searx.service
  7833. echo 'Restart=always' >> /etc/systemd/system/searx.service
  7834. echo 'Environment="USER=searx"' >> /etc/systemd/system/searx.service
  7835. echo '' >> /etc/systemd/system/searx.service
  7836. echo '[Install]' >> /etc/systemd/system/searx.service
  7837. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/searx.service
  7838. # create a webserver file
  7839. echo 'server {' > /etc/nginx/sites-available/searx
  7840. echo " listen 127.0.0.1:${SEARCH_ENGINE_ONION_PORT} default_server;" >> /etc/nginx/sites-available/searx
  7841. echo " root ${SEARCH_ENGINE_PATH}/searx;" >> /etc/nginx/sites-available/searx
  7842. echo " server_name ${SEARCH_ENGINE_ONION_HOSTNAME};" >> /etc/nginx/sites-available/searx
  7843. echo ' access_log off;' >> /etc/nginx/sites-available/searx
  7844. echo " error_log /var/log/searx_error.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/searx
  7845. echo '' >> /etc/nginx/sites-available/searx
  7846. nginx_limits searx '1M'
  7847. nginx_disable_sniffing searx
  7848. echo ' add_header Strict-Transport-Security max-age=0;' >> /etc/nginx/sites-available/searx
  7849. echo '' >> /etc/nginx/sites-available/searx
  7850. echo ' location / {' >> /etc/nginx/sites-available/searx
  7851. echo ' proxy_pass http://localhost:8888;' >> /etc/nginx/sites-available/searx
  7852. echo ' proxy_set_header Host $host;' >> /etc/nginx/sites-available/searx
  7853. echo ' proxy_set_header X-Real-IP $remote_addr;' >> /etc/nginx/sites-available/searx
  7854. echo ' proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;' >> /etc/nginx/sites-available/searx
  7855. echo ' proxy_set_header X-Remote-Port $remote_port;' >> /etc/nginx/sites-available/searx
  7856. echo ' proxy_set_header X-Forwarded-Proto $scheme;' >> /etc/nginx/sites-available/searx
  7857. echo ' proxy_redirect off;' >> /etc/nginx/sites-available/searx
  7858. echo " auth_basic \"${SEARCH_ENGINE_LOGIN_TEXT}\";" >> /etc/nginx/sites-available/searx
  7859. echo ' auth_basic_user_file /etc/nginx/.htpasswd;' >> /etc/nginx/sites-available/searx
  7860. echo ' }' >> /etc/nginx/sites-available/searx
  7861. echo '' >> /etc/nginx/sites-available/searx
  7862. echo ' fastcgi_buffers 64 4K;' >> /etc/nginx/sites-available/searx
  7863. echo '' >> /etc/nginx/sites-available/searx
  7864. echo ' error_page 403 /core/templates/403.php;' >> /etc/nginx/sites-available/searx
  7865. echo ' error_page 404 /core/templates/404.php;' >> /etc/nginx/sites-available/searx
  7866. echo '' >> /etc/nginx/sites-available/searx
  7867. echo ' location = /robots.txt {' >> /etc/nginx/sites-available/searx
  7868. echo ' allow all;' >> /etc/nginx/sites-available/searx
  7869. echo ' log_not_found off;' >> /etc/nginx/sites-available/searx
  7870. echo ' access_log off;' >> /etc/nginx/sites-available/searx
  7871. echo ' }' >> /etc/nginx/sites-available/searx
  7872. echo '}' >> /etc/nginx/sites-available/searx
  7873. # replace the secret key
  7874. if ! grep "Search engine key" $COMPLETION_FILE; then
  7875. SEARCH_ENGINE_SECRET_KEY="$(openssl rand -base64 32 | cut -c1-30)"
  7876. echo "Search engine key:${SEARCH_ENGINE_SECRET_KEY}" >> $COMPLETION_FILE
  7877. else
  7878. SEARCH_ENGINE_SECRET_KEY=$(cat $COMPLETION_FILE | grep "Search engine key" | awk -F ':' '{print $2}')
  7879. fi
  7880. sed -i "s|secret_key.*|secret_key : \"${SEARCH_ENGINE_SECRET_KEY}\"|g" ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7881. sed -i "s|secret_key.*|secret_key : \"${SEARCH_ENGINE_SECRET_KEY}\"|g" ${SEARCH_ENGINE_PATH}/searx/searx/settings_robot.yml
  7882. sed -i '0,/RE/s/base_url.*/base_url : \"http://${SEARCH_ENGINE_ONION_HOSTNAME}\/' ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7883. sed -i '0,/RE/s/base_url.*/base_url : \"http://${SEARCH_ENGINE_ONION_HOSTNAME}\/' ${SEARCH_ENGINE_PATH}/searx/searx/settings_robot.yml
  7884. # note: this might change to a --tor option in a later version
  7885. if ! grep 'socks5://127.0.0.1:9050' ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml; then
  7886. echo 'outgoing: # communication with search engines' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7887. echo ' proxies:' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7888. echo ' http : socks5://127.0.0.1:9050' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7889. echo ' https: socks5://127.0.0.1:9050' >> ${SEARCH_ENGINE_PATH}/searx/searx/settings.yml
  7890. fi
  7891. chown -R searx:searx ${SEARCH_ENGINE_PATH}/searx
  7892. # enable the site
  7893. nginx_ensite searx
  7894. # restart the web server
  7895. systemctl restart php5-fpm
  7896. systemctl restart nginx
  7897. # start the daemon
  7898. systemctl enable searx.service
  7899. systemctl daemon-reload
  7900. systemctl start searx.service
  7901. if ! grep -q "Your search engine password is" /home/$MY_USERNAME/README; then
  7902. if [ ${#SEARCH_ENGINE_PASSWORD} -lt 8 ]; then
  7903. if [ -f $IMAGE_PASSWORD_FILE ]; then
  7904. SEARCH_ENGINE_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  7905. else
  7906. SEARCH_ENGINE_PASSWORD="$(openssl rand -base64 18 | cut -c1-16)"
  7907. fi
  7908. fi
  7909. echo "$SEARCH_ENGINE_PASSWORD" | htpasswd -i -s -c /etc/nginx/.htpasswd $MY_USERNAME
  7910. echo '' >> /home/$MY_USERNAME/README
  7911. echo '' >> /home/$MY_USERNAME/README
  7912. echo $'Search Engine' >> /home/$MY_USERNAME/README
  7913. echo '=============' >> /home/$MY_USERNAME/README
  7914. echo $"Search engine onion domain: ${SEARCH_ENGINE_ONION_HOSTNAME}" >> /home/$MY_USERNAME/README
  7915. echo $"Your search engine password is: $SEARCH_ENGINE_PASSWORD" >> /home/$MY_USERNAME/README
  7916. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  7917. chmod 600 /home/$MY_USERNAME/README
  7918. fi
  7919. echo 'install_search_engine' >> $COMPLETION_FILE
  7920. }
  7921. function install_hubzilla {
  7922. 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
  7923. return
  7924. fi
  7925. if [ ! $HUBZILLA_DOMAIN_NAME ]; then
  7926. return
  7927. fi
  7928. HUBZILLA_PATH=/var/www/$HUBZILLA_DOMAIN_NAME/htdocs
  7929. # update to a new commit if needed
  7930. set_repo_commit $HUBZILLA_PATH "Hubzilla commit" "$HUBZILLA_COMMIT" $HUBZILLA_REPO
  7931. set_repo_commit $HUBZILLA_PATH "Hubzilla addons commit" "$HUBZILLA_ADDONS_COMMIT" $HUBZILLA_ADDONS_REPO
  7932. if [ -d $HUBZILLA_PATH/redmatrix-themes1 ]; then
  7933. cd $HUBZILLA_PATH/redmatrix-themes1
  7934. git stash
  7935. git pull
  7936. cp -r $HUBZILLA_PATH/redmatrix-themes1/* $HUBZILLA_PATH/view/theme/
  7937. chown -R www-data:www-data $HUBZILLA_PATH
  7938. fi
  7939. if grep -Fxq "install_hubzilla" $COMPLETION_FILE; then
  7940. return
  7941. fi
  7942. install_mariadb
  7943. get_mariadb_password
  7944. repair_databases_script
  7945. apt-get -y install php5-common php5-cli php5-curl php5-gd php5-mysql php5-mcrypt git
  7946. apt-get -y install php5-dev imagemagick php5-imagick
  7947. if [ ! -d /var/www/$HUBZILLA_DOMAIN_NAME ]; then
  7948. mkdir /var/www/$HUBZILLA_DOMAIN_NAME
  7949. fi
  7950. if [ ! -d $HUBZILLA_PATH ]; then
  7951. mkdir $HUBZILLA_PATH
  7952. fi
  7953. if [ ! -f $HUBZILLA_PATH/index.php ]; then
  7954. cd $INSTALL_DIR
  7955. git_clone $HUBZILLA_REPO hubzilla
  7956. git checkout $HUBZILLA_COMMIT -b $HUBZILLA_COMMIT
  7957. if ! grep -q "Hubzilla commit" $COMPLETION_FILE; then
  7958. echo "Hubzilla commit:$HUBZILLA_COMMIT" >> $COMPLETION_FILE
  7959. else
  7960. sed -i "s/Hubzilla commit.*/Hubzilla commit:$HUBZILLA_COMMIT/g" $COMPLETION_FILE
  7961. fi
  7962. rm -rf $HUBZILLA_PATH
  7963. mv hubzilla $HUBZILLA_PATH
  7964. git_clone $HUBZILLA_ADDONS_REPO $HUBZILLA_PATH/addon
  7965. cd $HUBZILLA_PATH/addon
  7966. git checkout $HUBZILLA_ADDONS_COMMIT -b $HUBZILLA_ADDONS_COMMIT
  7967. if ! grep -q "Hubzilla addons commit" $COMPLETION_FILE; then
  7968. echo "Hubzilla addons commit:$HUBZILLA_ADDONS_COMMIT" >> $COMPLETION_FILE
  7969. else
  7970. sed -i "s/Hubzilla addons commit.*/Hubzilla addons commit:$HUBZILLA_ADDONS_COMMIT/g" $COMPLETION_FILE
  7971. fi
  7972. # some extra themes
  7973. git_clone $HUBZILLA_THEMES_REPO $HUBZILLA_PATH/redmatrix-themes1
  7974. cp -r $HUBZILLA_PATH/redmatrix-themes1/* $HUBZILLA_PATH/view/theme/
  7975. chown -R www-data:www-data $HUBZILLA_PATH
  7976. fi
  7977. HUBZILLA_ONION_HOSTNAME=
  7978. if [[ $ONION_ONLY != "no" ]]; then
  7979. HUBZILLA_ONION_HOSTNAME=$(add_onion_service hubzilla 80 ${HUBZILLA_ONION_PORT})
  7980. echo "Hubzilla onion domain:${HUBZILLA_ONION_HOSTNAME}" >> $COMPLETION_FILE
  7981. fi
  7982. get_mariadb_hubzilla_admin_password
  7983. if [ ! $HUBZILLA_ADMIN_PASSWORD ]; then
  7984. if [ -f $IMAGE_PASSWORD_FILE ]; then
  7985. HUBZILLA_ADMIN_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  7986. else
  7987. HUBZILLA_ADMIN_PASSWORD="$(openssl rand -base64 32 | cut -c1-30)"
  7988. fi
  7989. echo '' >> /home/$MY_USERNAME/README
  7990. echo '' >> /home/$MY_USERNAME/README
  7991. echo 'Hubzilla' >> /home/$MY_USERNAME/README
  7992. echo '========' >> /home/$MY_USERNAME/README
  7993. if [[ $ONION_ONLY == 'no' ]]; then
  7994. echo $"Open https://$HUBZILLA_DOMAIN_NAME and register a new user" >> /home/$MY_USERNAME/README
  7995. else
  7996. echo $"Open http://$HUBZILLA_ONION_HOSTNAME and register a new user" >> /home/$MY_USERNAME/README
  7997. fi
  7998. echo $"Your MariaDB Hubzilla admin password is: $HUBZILLA_ADMIN_PASSWORD" >> /home/$MY_USERNAME/README
  7999. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  8000. chmod 600 /home/$MY_USERNAME/README
  8001. fi
  8002. create_database hubzilla "$HUBZILLA_ADMIN_PASSWORD"
  8003. if ! grep -q "$HUBZILLA_PATH" /etc/crontab; then
  8004. echo "12,22,32,42,52 * * * * root cd $HUBZILLA_PATH; /usr/bin/timeout 500 /usr/bin/php include/poller.php" >> /etc/crontab
  8005. fi
  8006. add_ddns_domain $HUBZILLA_DOMAIN_NAME
  8007. if [[ $ONION_ONLY == "no" ]]; then
  8008. nginx_http_redirect $HUBZILLA_DOMAIN_NAME
  8009. echo 'server {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8010. echo ' listen 443 ssl;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8011. echo " root $HUBZILLA_PATH;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8012. echo " server_name $HUBZILLA_DOMAIN_NAME;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8013. echo " error_log /var/log/nginx/${HUBZILLA_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8014. echo ' index index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8015. echo ' charset utf-8;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8016. echo ' access_log off;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8017. nginx_limits $HUBZILLA_DOMAIN_NAME
  8018. nginx_ssl $HUBZILLA_DOMAIN_NAME
  8019. nginx_disable_sniffing $HUBZILLA_DOMAIN_NAME
  8020. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8021. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8022. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8023. echo ' location / {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8024. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8025. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8026. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8027. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8028. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8029. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8030. echo ' allow all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8031. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8032. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8033. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8034. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8035. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8036. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8037. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8038. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8039. echo ' expires 30d;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8040. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8041. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8042. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8043. echo ' # block these file types' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8044. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8045. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8046. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8047. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8048. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8049. echo ' # or a unix socket' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8050. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8051. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8052. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8053. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8054. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8055. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8056. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8057. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8058. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8059. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8060. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8061. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8062. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8063. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8064. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8065. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8066. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8067. echo ' fastcgi_read_timeout 300;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8068. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8069. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8070. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8071. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8072. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8073. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8074. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8075. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8076. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8077. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8078. echo '}' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8079. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8080. else
  8081. echo 'server {' > /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8082. echo " listen 127.0.0.1:${HUBZILLA_ONION_PORT} default_server;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8083. echo " root $HUBZILLA_PATH;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8084. echo " server_name $HUBZILLA_ONION_HOSTNAME;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8085. echo " error_log /var/log/nginx/${HUBZILLA_DOMAIN_NAME}_error_ssl.log $WEBSERVER_LOG_LEVEL;" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8086. echo ' index index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8087. echo ' charset utf-8;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8088. echo ' access_log off;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8089. nginx_limits $HUBZILLA_DOMAIN_NAME
  8090. nginx_disable_sniffing $HUBZILLA_DOMAIN_NAME
  8091. echo ' add_header Strict-Transport-Security max-age=15768000;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8092. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8093. echo ' # rewrite to front controller as default rule' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8094. echo ' location / {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8095. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8096. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8097. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8098. echo " # make sure webfinger and other well known services aren't blocked" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8099. echo ' # by denying dot files and rewrite request to the front controller' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8100. echo ' location ^~ /.well-known/ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8101. echo ' allow all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8102. echo ' rewrite ^/(.*) /index.php?q=$uri&$args last;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8103. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8104. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8105. echo ' # statically serve these file types when possible' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8106. echo ' # otherwise fall back to front controller' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8107. echo ' # allow browser to cache them' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8108. echo ' # added .htm for advanced source code editor library' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8109. echo ' location ~* \.(jpg|jpeg|gif|png|ico|css|js|htm|html|ttf|woff|svg)$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8110. echo ' expires 30d;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8111. echo ' try_files $uri /index.php?q=$uri&$args;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8112. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8113. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8114. echo ' # block these file types' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8115. echo ' location ~* \.(tpl|md|tgz|log|out)$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8116. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8117. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8118. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8119. echo ' # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8120. echo ' # or a unix socket' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8121. echo ' location ~* \.php$ {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8122. echo ' # Zero-day exploit defense.' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8123. echo ' # http://forum.nginx.org/read.php?2,88845,page=3' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8124. echo " # Won't work properly (404 error) if the file is not stored on this" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8125. echo " # server, which is entirely possible with php-fpm/php-fcgi." >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8126. echo " # Comment the 'try_files' line out if you set up php-fpm/php-fcgi on" >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8127. echo " # another machine. And then cross your fingers that you won't get hacked." >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8128. echo ' try_files $uri $uri/ /index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8129. echo ' # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8130. echo ' fastcgi_split_path_info ^(.+\.php)(/.+)$;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8131. echo ' # With php5-cgi alone:' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8132. echo ' # fastcgi_pass 127.0.0.1:9000;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8133. echo ' # With php5-fpm:' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8134. echo ' fastcgi_pass unix:/var/run/php5-fpm.sock;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8135. echo ' include fastcgi_params;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8136. echo ' fastcgi_index index.php;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8137. echo ' fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8138. echo ' fastcgi_read_timeout 300;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8139. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8140. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8141. echo ' # deny access to all dot files' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8142. echo ' location ~ /\. {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8143. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8144. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8145. echo '' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8146. echo ' location ~ /\.ht {' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8147. echo ' deny all;' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8148. echo ' }' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8149. echo '}' >> /etc/nginx/sites-available/$HUBZILLA_DOMAIN_NAME
  8150. fi
  8151. configure_php
  8152. create_site_certificate $HUBZILLA_DOMAIN_NAME 'yes'
  8153. if [ ! -d $HUBZILLA_PATH/view/tpl/smarty3 ]; then
  8154. mkdir $HUBZILLA_PATH/view/tpl/smarty3
  8155. fi
  8156. if [ ! -d "$HUBZILLA_PATH/store" ]; then
  8157. mkdir "$HUBZILLA_PATH/store"
  8158. fi
  8159. if [ ! -d "$HUBZILLA_PATH/store/[data]" ]; then
  8160. mkdir "$HUBZILLA_PATH/store/[data]"
  8161. fi
  8162. if [ ! -d "$HUBZILLA_PATH/store/[data]/smarty3" ]; then
  8163. mkdir "$HUBZILLA_PATH/store/[data]/smarty3"
  8164. chmod 777 "$HUBZILLA_PATH/store/[data]/smarty3"
  8165. fi
  8166. chmod 777 $HUBZILLA_PATH/view/tpl
  8167. chown -R www-data:www-data "$HUBZILLA_PATH/store"
  8168. chmod 777 $HUBZILLA_PATH/view/tpl/smarty3
  8169. # Ensure that the database gets backed up locally, if remote
  8170. # backups are not being used
  8171. backup_databases_script_header
  8172. backup_database_local hubzilla
  8173. chown -R www-data:www-data $HUBZILLA_PATH
  8174. nginx_ensite $HUBZILLA_DOMAIN_NAME
  8175. # initialize the database
  8176. if [ ! -f $HUBZILLA_PATH/install/schema_mysql.sql ]; then
  8177. echo $'No database schema found for hubzilla'
  8178. exit 252782
  8179. fi
  8180. mysql -u root --password="$MARIADB_PASSWORD" -D hubzilla < $HUBZILLA_PATH/install/schema_mysql.sql
  8181. if [ ! "$?" = "0" ]; then
  8182. exit 62952
  8183. fi
  8184. # create the config file
  8185. echo '<?php' > $HUBZILLA_PATH/.htconfig.php
  8186. echo "\$db_host = 'localhost';" >> $HUBZILLA_PATH/.htconfig.php
  8187. echo "\$db_port = '0';" >> $HUBZILLA_PATH/.htconfig.php
  8188. echo "\$db_user = 'root';" >> $HUBZILLA_PATH/.htconfig.php
  8189. echo "\$db_pass = '${MARIADB_PASSWORD}';" >> $HUBZILLA_PATH/.htconfig.php
  8190. echo "\$db_data = 'hubzilla';" >> $HUBZILLA_PATH/.htconfig.php
  8191. echo "\$db_type = '0';" >> $HUBZILLA_PATH/.htconfig.php
  8192. echo "\$default_timezone = 'Europe/London';" >> $HUBZILLA_PATH/.htconfig.php
  8193. if [[ $ONION_ONLY == 'no' ]]; then
  8194. echo "\$a->config['system']['baseurl'] = 'https://${HUBZILLA_DOMAIN_NAME}';" >> $HUBZILLA_PATH/.htconfig.php
  8195. else
  8196. echo "\$a->config['system']['baseurl'] = 'http://${HUBZILLA_ONION_HOSTNAME}';" >> $HUBZILLA_PATH/.htconfig.php
  8197. fi
  8198. echo "\$a->config['system']['sitename'] = \"Hubzilla\";" >> $HUBZILLA_PATH/.htconfig.php
  8199. HUBZILLA_LOCATION_HASH="$(openssl rand -base64 32 | cut -c1-30)"
  8200. echo "\$a->config['system']['location_hash'] = '${HUBZILLA_LOCATION_HASH}';" >> $HUBZILLA_PATH/.htconfig.php
  8201. echo "\$a->config['system']['register_policy'] = REGISTER_OPEN;" >> $HUBZILLA_PATH/.htconfig.php
  8202. echo "\$a->config['system']['register_text'] = '';" >> $HUBZILLA_PATH/.htconfig.php
  8203. echo "\$a->config['system']['admin_email'] = '${MY_EMAIL_ADDRESS}';" >> $HUBZILLA_PATH/.htconfig.php
  8204. echo "\$a->config['system']['verify_email'] = 1;" >> $HUBZILLA_PATH/.htconfig.php
  8205. echo "\$a->config['system']['access_policy'] = ACCESS_PRIVATE;" >> $HUBZILLA_PATH/.htconfig.php
  8206. echo "\$a->config['system']['sellpage'] = '';" >> $HUBZILLA_PATH/.htconfig.php
  8207. echo "\$a->config['system']['max_import_size'] = 200000;" >> $HUBZILLA_PATH/.htconfig.php
  8208. echo "\$a->config['system']['php_path'] = '/usr/bin/php';" >> $HUBZILLA_PATH/.htconfig.php
  8209. echo "\$a->config['system']['directory_mode'] = DIRECTORY_MODE_NORMAL;" >> $HUBZILLA_PATH/.htconfig.php
  8210. echo "\$a->config['system']['theme'] = 'redbasic';" >> $HUBZILLA_PATH/.htconfig.php
  8211. chown www-data:www-data $HUBZILLA_PATH/.htconfig.php
  8212. chmod 755 $HUBZILLA_PATH/.htconfig.php
  8213. systemctl restart php5-fpm
  8214. systemctl restart nginx
  8215. systemctl restart cron
  8216. freedombone-addemail -u $MY_USERNAME -e "noreply@$HUBZILLA_DOMAIN_NAME" -g hubzilla --public no
  8217. echo "Hubzilla domain:${HUBZILLA_DOMAIN_NAME}" >> $COMPLETION_FILE
  8218. echo 'install_hubzilla' >> $COMPLETION_FILE
  8219. }
  8220. function script_for_attaching_usb_drive {
  8221. if grep -Fxq "script_for_attaching_usb_drive" $COMPLETION_FILE; then
  8222. return
  8223. fi
  8224. echo '#!/bin/bash' > /usr/bin/attach-music
  8225. echo 'remove-music' >> /usr/bin/attach-music
  8226. echo "if [ ! -d $USB_MOUNT ]; then" >> /usr/bin/attach-music
  8227. echo " mkdir $USB_MOUNT" >> /usr/bin/attach-music
  8228. echo 'fi' >> /usr/bin/attach-music
  8229. echo "mount /dev/sda1 $USB_MOUNT" >> /usr/bin/attach-music
  8230. echo "chown root:root $USB_MOUNT" >> /usr/bin/attach-music
  8231. echo "chown -R minidlna:minidlna $USB_MOUNT/*" >> /usr/bin/attach-music
  8232. echo 'service minidlna restart' >> /usr/bin/attach-music
  8233. echo 'minidlnad -R' >> /usr/bin/attach-music
  8234. chmod +x /usr/bin/attach-music
  8235. ln -s /usr/bin/attach-music /usr/bin/attach-usb
  8236. ln -s /usr/bin/attach-music /usr/bin/attach-videos
  8237. ln -s /usr/bin/attach-music /usr/bin/attach-pictures
  8238. ln -s /usr/bin/attach-music /usr/bin/attach-media
  8239. echo '#!/bin/bash' > /usr/bin/remove-music
  8240. echo "if [ -d $USB_MOUNT ]; then" >> /usr/bin/remove-music
  8241. echo " umount $USB_MOUNT" >> /usr/bin/remove-music
  8242. echo " rm -rf $USB_MOUNT" >> /usr/bin/remove-music
  8243. echo 'fi' >> /usr/bin/remove-music
  8244. chmod +x /usr/bin/remove-music
  8245. ln -s /usr/bin/remove-music /usr/bin/detach-music
  8246. ln -s /usr/bin/remove-music /usr/bin/detach-usb
  8247. ln -s /usr/bin/remove-music /usr/bin/remove-usb
  8248. ln -s /usr/bin/remove-music /usr/bin/detach-media
  8249. ln -s /usr/bin/remove-music /usr/bin/remove-media
  8250. ln -s /usr/bin/remove-music /usr/bin/detach-videos
  8251. ln -s /usr/bin/remove-music /usr/bin/remove-videos
  8252. ln -s /usr/bin/remove-music /usr/bin/detach-pictures
  8253. ln -s /usr/bin/remove-music /usr/bin/remove-pictures
  8254. echo 'script_for_attaching_usb_drive' >> $COMPLETION_FILE
  8255. }
  8256. function install_dlna_server {
  8257. if grep -Fxq "install_dlna_server" $COMPLETION_FILE; then
  8258. return
  8259. fi
  8260. 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
  8261. return
  8262. fi
  8263. apt-get -y install minidlna
  8264. if [ ! -f /etc/minidlna.conf ]; then
  8265. echo $"ERROR: minidlna does not appear to have installed. $CHECK_MESSAGE"
  8266. exit 55
  8267. fi
  8268. sed -i "s|media_dir=/var/lib/minidlna|media_dir=A,/home/$MY_USERNAME/Music|g" /etc/minidlna.conf
  8269. if ! grep -q "/home/$MY_USERNAME/Pictures" /etc/minidlna.conf; then
  8270. echo "media_dir=P,/home/$MY_USERNAME/Pictures" >> /etc/minidlna.conf
  8271. fi
  8272. if ! grep -q "/home/$MY_USERNAME/Videos" /etc/minidlna.conf; then
  8273. echo "media_dir=V,/home/$MY_USERNAME/Videos" >> /etc/minidlna.conf
  8274. fi
  8275. if ! grep -q "$USB_MOUNT/Music" /etc/minidlna.conf; then
  8276. echo "media_dir=A,$USB_MOUNT/Music" >> /etc/minidlna.conf
  8277. fi
  8278. if ! grep -q "$USB_MOUNT/Pictures" /etc/minidlna.conf; then
  8279. echo "media_dir=P,$USB_MOUNT/Pictures" >> /etc/minidlna.conf
  8280. fi
  8281. if ! grep -q "$USB_MOUNT/Videos" /etc/minidlna.conf; then
  8282. echo "media_dir=V,$USB_MOUNT/Videos" >> /etc/minidlna.conf
  8283. fi
  8284. sed -i 's/#root_container=./root_container=B/g' /etc/minidlna.conf
  8285. if [[ $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  8286. sed -i 's/#network_interface=/network_interface=eth0/g' /etc/minidlna.conf
  8287. else
  8288. sed -i 's/#network_interface=/network_interface=$WIFI_INTERFACE/g' /etc/minidlna.conf
  8289. fi
  8290. sed -i "s/#friendly_name=/friendly_name=\"${PROJECT_NAME} Media\"/g" /etc/minidlna.conf
  8291. sed -i 's|#db_dir=/var/cache/minidlna|db_dir=/var/cache/minidlna|g' /etc/minidlna.conf
  8292. sed -i 's/#inotify=yes/inotify=yes/g' /etc/minidlna.conf
  8293. sed -i 's/#notify_interval=895/notify_interval=300/g' /etc/minidlna.conf
  8294. sed -i "s|#presentation_url=/|presentation_url=http://localhost:8200|g" /etc/minidlna.conf
  8295. service minidlna force-reload
  8296. service minidlna reload
  8297. sed -i 's/fs.inotify.max_user_watches*/fs.inotify.max_user_watches=65536/g' /etc/sysctl.conf
  8298. if ! grep -q "max_user_watches" $COMPLETION_FILE; then
  8299. echo 'fs.inotify.max_user_watches=65536' >> /etc/sysctl.conf
  8300. fi
  8301. /sbin/sysctl -p
  8302. echo 'install_dlna_server' >> $COMPLETION_FILE
  8303. }
  8304. function install_mediagoblin {
  8305. 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
  8306. return
  8307. fi
  8308. if [ ! $MEDIAGOBLIN_DOMAIN_NAME ]; then
  8309. return
  8310. fi
  8311. MEDIAGOBLIN_WORKING_DIRECTORY=/var/www/$MEDIAGOBLIN_DOMAIN_NAME/htdocs
  8312. # update to a new commit if needed
  8313. set_repo_commit $MEDIAGOBLIN_WORKING_DIRECTORY "Mediagoblin commit" "$MEDIAGOBLIN_COMMIT" $MEDIAGOBLIN_REPO
  8314. if [ -d $MEDIAGOBLIN_WORKING_DIRECTORY ]; then
  8315. chown -hR mediagoblin:www-data $MEDIAGOBLIN_WORKING_DIRECTORY
  8316. fi
  8317. if grep -Fxq "install_mediagoblin" $COMPLETION_FILE; then
  8318. return
  8319. fi
  8320. apt-get -y install git-core python python-dev python-lxml python-pil
  8321. apt-get -y install python-virtualenv npm nodejs-legacy automake
  8322. apt-get -y install fcgiwrap
  8323. #apt-get -y install postgresql postgresql-client python-psycopg2
  8324. #apt-get -y install python-gst-1.0 libjpeg62-turbo-dev gstreamer1.0-plugins-base python-gobject
  8325. #apt-get -y install gstreamer1.0-plugins-good gstreamer1.0-libav libav-tools gstreamer0.10-tools
  8326. #apt-get -y install python-numpy python-scipy libsndfile1-dev python-gst0.10-dev
  8327. #apt-get -y install gstreamer0.10-plugins-base gstreamer0.10-plugins-good gstreamer1.0-tools
  8328. #su -c "createuser -A -D mediagoblin" - postgres
  8329. #su -c "createdb -E UNICODE -O mediagoblin mediagoblin" - postgres
  8330. useradd -c "GNU MediaGoblin system account" -d /var/lib/mediagoblin -m -r -g www-data mediagoblin
  8331. groupadd mediagoblin
  8332. usermod --append -G mediagoblin mediagoblin
  8333. if [ ! -d $MEDIAGOBLIN_WORKING_DIRECTORY ]; then
  8334. mkdir -p $MEDIAGOBLIN_WORKING_DIRECTORY
  8335. fi
  8336. git_clone $MEDIAGOBLIN_REPO $MEDIAGOBLIN_WORKING_DIRECTORY
  8337. cd $MEDIAGOBLIN_WORKING_DIRECTORY
  8338. git checkout $MEDIAGOBLIN_COMMIT -b $MEDIAGOBLIN_COMMIT
  8339. git submodule init
  8340. git submodule update
  8341. if ! grep -q "Mediagoblin commit" $COMPLETION_FILE; then
  8342. echo "Mediagoblin commit:$MEDIAGOBLIN_COMMIT" >> $COMPLETION_FILE
  8343. else
  8344. sed -i "s/Mediagoblin commit.*/Mediagoblin commit:$MEDIAGOBLIN_COMMIT/g" $COMPLETION_FILE
  8345. fi
  8346. chown -hR mediagoblin:www-data $MEDIAGOBLIN_WORKING_DIRECTORY
  8347. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bootstrap.sh" - mediagoblin
  8348. if [ ! "$?" = "0" ]; then
  8349. exit 278826
  8350. fi
  8351. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./configure" - mediagoblin
  8352. if [ ! "$?" = "0" ]; then
  8353. exit 462826
  8354. fi
  8355. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && make" - mediagoblin
  8356. if [ ! "$?" = "0" ]; then
  8357. exit 738229
  8358. fi
  8359. if [ ! -d $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev ]; then
  8360. mkdir $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev
  8361. fi
  8362. chmod 750 $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev
  8363. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install flup==1.0.3.dev-20110405" - mediagoblin
  8364. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade billiard" - mediagoblin
  8365. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade Paste" - mediagoblin
  8366. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade amqp" - mediagoblin
  8367. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade anyjson" - mediagoblin
  8368. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade py-bcrypt" - mediagoblin
  8369. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade wtforms" - mediagoblin
  8370. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade python-dateutil" - mediagoblin
  8371. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade alembic" - mediagoblin
  8372. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade waitress" - mediagoblin
  8373. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade imagesize" - mediagoblin
  8374. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade alabaster" - mediagoblin
  8375. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade snowballstemmer" - mediagoblin
  8376. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade docutils" - mediagoblin
  8377. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade Pygments" - mediagoblin
  8378. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade beautifulsoup4" - mediagoblin
  8379. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade WebOb" - mediagoblin
  8380. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade py" - mediagoblin
  8381. su -c "cd $MEDIAGOBLIN_WORKING_DIRECTORY && ./bin/easy_install --upgrade execnet" - mediagoblin
  8382. # create some directories
  8383. mkdir /var/log/mediagoblin
  8384. chown -hR mediagoblin:www-data /var/log/mediagoblin
  8385. mkdir /var/run/mediagoblin
  8386. chown -hR mediagoblin:www-data /var/run/mediagoblin
  8387. if [ ! -f $MEDIAGOBLIN_WORKING_DIRECTORY/mediagoblin.ini ]; then
  8388. echo $'mediagoblin.ini not found'
  8389. exit 737529
  8390. fi
  8391. if [ ! -f $MEDIAGOBLIN_WORKING_DIRECTORY/paste.ini ]; then
  8392. echo $'paste.ini not found'
  8393. exit 52762
  8394. fi
  8395. cp -av mediagoblin.ini mediagoblin_local.ini
  8396. cp -av paste.ini paste_local.ini
  8397. chown -hR mediagoblin:www-data $MEDIAGOBLIN_WORKING_DIRECTORY
  8398. # init with systemd
  8399. echo '[Unit]' > /etc/systemd/system/mediagoblin-celeryd.service
  8400. echo 'Description=Mediagoblin Celeryd' >> /etc/systemd/system/mediagoblin-celeryd.service
  8401. echo 'After=syslog.target' >> /etc/systemd/system/mediagoblin-celeryd.service
  8402. echo 'After=network.target' >> /etc/systemd/system/mediagoblin-celeryd.service
  8403. echo '' >> /etc/systemd/system/mediagoblin-celeryd.service
  8404. echo '[Service]' >> /etc/systemd/system/mediagoblin-celeryd.service
  8405. echo 'User=mediagoblin' >> /etc/systemd/system/mediagoblin-celeryd.service
  8406. echo 'Group=mediagoblin' >> /etc/systemd/system/mediagoblin-celeryd.service
  8407. echo 'Type=simple' >> /etc/systemd/system/mediagoblin-celeryd.service
  8408. echo "WorkingDirectory=$MEDIAGOBLIN_WORKING_DIRECTORY" >> /etc/systemd/system/mediagoblin-celeryd.service
  8409. echo "Environment=MEDIAGOBLIN_CONFIG=$MEDIAGOBLIN_WORKING_DIRECTORY/mediagoblin_local.ini \\" >> /etc/systemd/system/mediagoblin-celeryd.service
  8410. echo ' CELERY_CONFIG_MODULE=mediagoblin.init.celery.from_celery' >> /etc/systemd/system/mediagoblin-celeryd.service
  8411. echo "ExecStart=$MEDIAGOBLIN_WORKING_DIRECTORY/bin/celery worker \\" >> /etc/systemd/system/mediagoblin-celeryd.service
  8412. echo ' --logfile=/var/log/mediagoblin/celery.log \' >> /etc/systemd/system/mediagoblin-celeryd.service
  8413. echo ' --loglevel=INFO' >> /etc/systemd/system/mediagoblin-celeryd.service
  8414. echo 'PIDFile=/var/run/mediagoblin/mediagoblin-celeryd.pid' >> /etc/systemd/system/mediagoblin-celeryd.service
  8415. echo '' >> /etc/systemd/system/mediagoblin-celeryd.service
  8416. echo '[Install]' >> /etc/systemd/system/mediagoblin-celeryd.service
  8417. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/mediagoblin-celeryd.service
  8418. echo '[Unit]' > /etc/systemd/system/mediagoblin-paster.service
  8419. echo 'Description=Mediagoblin' >> /etc/systemd/system/mediagoblin-paster.service
  8420. echo 'After=syslog.target' >> /etc/systemd/system/mediagoblin-paster.service
  8421. echo 'After=network.target' >> /etc/systemd/system/mediagoblin-paster.service
  8422. echo '' >> /etc/systemd/system/mediagoblin-paster.service
  8423. echo '[Service]' >> /etc/systemd/system/mediagoblin-paster.service
  8424. echo 'Type=forking' >> /etc/systemd/system/mediagoblin-paster.service
  8425. echo 'User=mediagoblin' >> /etc/systemd/system/mediagoblin-paster.service
  8426. echo 'Group=mediagoblin' >> /etc/systemd/system/mediagoblin-paster.service
  8427. echo 'Environment=CELERY_ALWAYS_EAGER=false' >> /etc/systemd/system/mediagoblin-paster.service
  8428. echo "WorkingDirectory=$MEDIAGOBLIN_WORKING_DIRECTORY" >> /etc/systemd/system/mediagoblin-paster.service
  8429. echo "ExecStart=$MEDIAGOBLIN_WORKING_DIRECTORY/bin/paster serve \\" >> /etc/systemd/system/mediagoblin-paster.service
  8430. echo " $MEDIAGOBLIN_WORKING_DIRECTORY/paste_local.ini \\" >> /etc/systemd/system/mediagoblin-paster.service
  8431. echo ' --pid-file=/var/run/mediagoblin/mediagoblin.pid \' >> /etc/systemd/system/mediagoblin-paster.service
  8432. echo ' --log-file=/var/log/mediagoblin/mediagoblin.log \' >> /etc/systemd/system/mediagoblin-paster.service
  8433. echo ' --daemon \' >> /etc/systemd/system/mediagoblin-paster.service
  8434. echo ' --server-name=fcgi fcgi_host=127.0.0.1 fcgi_port=26543' >> /etc/systemd/system/mediagoblin-paster.service
  8435. echo "ExecStop=$MEDIAGOBLIN_WORKING_DIRECTORY/bin/paster serve \\" >> /etc/systemd/system/mediagoblin-paster.service
  8436. echo ' --pid-file=/var/run/mediagoblin/mediagoblin.pid \' >> /etc/systemd/system/mediagoblin-paster.service
  8437. echo " $MEDIAGOBLIN_WORKING_DIRECTORY/paste_local.ini stop" >> /etc/systemd/system/mediagoblin-paster.service
  8438. echo 'PIDFile=/var/run/mediagoblin/mediagoblin.pid' >> /etc/systemd/system/mediagoblin-paster.service
  8439. echo '' >> /etc/systemd/system/mediagoblin-paster.service
  8440. echo '[Install]' >> /etc/systemd/system/mediagoblin-paster.service
  8441. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/mediagoblin-paster.service
  8442. systemctl daemon-reload
  8443. systemctl enable mediagoblin-celeryd
  8444. systemctl enable mediagoblin-paster
  8445. systemctl daemon-reload
  8446. systemctl start mediagoblin-celeryd
  8447. systemctl start mediagoblin-paster
  8448. MEDIAGOBLIN_ONION_HOSTNAME=$(add_onion_service mediagoblin 80 ${MEDIAGOBLIN_ONION_PORT})
  8449. if ! grep -q "Mediagoblin onion domain" $COMPLETION_FILE; then
  8450. echo "Mediagoblin onion domain:${MEDIAGOBLIN_ONION_HOSTNAME}" >> $COMPLETION_FILE
  8451. else
  8452. sed -i "s|Mediagoblin onion domain.*|Mediagoblin onion domain:${MEDIAGOBLIN_ONION_HOSTNAME}|g" $COMPLETION_FILE
  8453. fi
  8454. if [[ $MEDIAGOBLIN_ONION_HOSTNAME == *"not found"* ]]; then
  8455. echo $'Problem creating onion address for mediagoblin'
  8456. exit 672652
  8457. fi
  8458. # web config
  8459. MEDIAGOBLIN_VIRTUAL_HOST=/etc/nginx/sites-available/$MEDIAGOBLIN_DOMAIN_NAME
  8460. nginx_http_redirect $MEDIAGOBLIN_DOMAIN_NAME
  8461. if [[ $ONION_ONLY == 'no' ]]; then
  8462. echo 'server {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8463. echo ' listen 443 ssl;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8464. echo ' #################################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8465. echo ' # Stock useful config options, but ignore them :)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8466. echo ' #################################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8467. echo ' include /etc/nginx/mime.types;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8468. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8469. echo ' autoindex off;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8470. echo ' default_type application/octet-stream;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8471. echo ' sendfile on;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8472. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8473. nginx_limits $MEDIAGOBLIN_DOMAIN_NAME '20m'
  8474. nginx_ssl $MEDIAGOBLIN_DOMAIN_NAME
  8475. nginx_disable_sniffing $MEDIAGOBLIN_DOMAIN_NAME
  8476. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8477. echo ' # Gzip' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8478. echo ' gzip on;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8479. echo ' gzip_min_length 1024;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8480. echo ' gzip_buffers 4 32k;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8481. echo ' gzip_types text/plain application/x-javascript text/javascript text/xml text/css;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8482. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8483. echo ' #####################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8484. echo ' # Mounting MediaGoblin stuff' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8485. echo ' # This is the section you should read' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8486. echo ' #####################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8487. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8488. echo " server_name $MEDIAGOBLIN_DOMAIN_NAME;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8489. echo ' access_log /var/log/nginx/mediagoblin.log;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8490. echo ' error_log /var/log/nginx/mediagoblin.error.log;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8491. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8492. echo ' # MediaGoblins stock static files: CSS, JS, etc.' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8493. echo ' location /mgoblin_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8494. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/mediagoblin/static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8495. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8496. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8497. echo ' # Instance specific media:' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8498. echo ' location /mgoblin_media/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8499. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/media/public/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8500. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8501. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8502. echo ' # Theme static files (usually symlinked in)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8503. echo ' location /theme_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8504. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/theme_static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8505. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8506. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8507. echo ' # Plugin static files (usually symlinked in)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8508. echo ' location /plugin_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8509. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/plugin_static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8510. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8511. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8512. echo ' # Mounting MediaGoblin itself via FastCGI.' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8513. echo ' location / {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8514. echo ' fastcgi_pass 127.0.0.1:26543;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8515. echo ' include /etc/nginx/fastcgi_params;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8516. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8517. echo ' # our understanding vs nginxs handling of script_name vs' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8518. echo ' # path_info dont match :)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8519. echo ' fastcgi_param PATH_INFO $fastcgi_script_name;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8520. echo ' fastcgi_param SCRIPT_NAME "";' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8521. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8522. echo '}' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8523. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8524. else
  8525. echo -n '' > $MEDIAGOBLIN_VIRTUAL_HOST
  8526. fi
  8527. echo 'server {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8528. echo " listen 127.0.0.1:${MEDIAGOBLIN_ONION_PORT} default_server;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8529. echo ' #################################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8530. echo ' # Stock useful config options, but ignore them :)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8531. echo ' #################################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8532. echo ' include /etc/nginx/mime.types;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8533. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8534. echo ' autoindex off;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8535. echo ' default_type application/octet-stream;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8536. echo ' sendfile on;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8537. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8538. nginx_limits $MEDIAGOBLIN_DOMAIN_NAME '20m'
  8539. nginx_disable_sniffing $MEDIAGOBLIN_DOMAIN_NAME
  8540. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8541. echo ' # Gzip' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8542. echo ' gzip on;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8543. echo ' gzip_min_length 1024;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8544. echo ' gzip_buffers 4 32k;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8545. echo ' gzip_types text/plain application/x-javascript text/javascript text/xml text/css;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8546. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8547. echo ' #####################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8548. echo ' # Mounting MediaGoblin stuff' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8549. echo ' # This is the section you should read' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8550. echo ' #####################################' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8551. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8552. echo " server_name $MEDIAGOBLIN_ONION_HOSTNAME;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8553. echo ' access_log /var/log/nginx/mediagoblin.log;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8554. echo ' error_log /var/log/nginx/mediagoblin.error.log;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8555. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8556. echo ' # MediaGoblins stock static files: CSS, JS, etc.' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8557. echo ' location /mgoblin_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8558. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/mediagoblin/static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8559. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8560. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8561. echo ' # Instance specific media:' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8562. echo ' location /mgoblin_media/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8563. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/media/public/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8564. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8565. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8566. echo ' # Theme static files (usually symlinked in)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8567. echo ' location /theme_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8568. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/theme_static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8569. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8570. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8571. echo ' # Plugin static files (usually symlinked in)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8572. echo ' location /plugin_static/ {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8573. echo " alias $MEDIAGOBLIN_WORKING_DIRECTORY/user_dev/plugin_static/;" >> $MEDIAGOBLIN_VIRTUAL_HOST
  8574. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8575. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8576. echo ' # Mounting MediaGoblin itself via FastCGI.' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8577. echo ' location / {' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8578. echo ' fastcgi_pass 127.0.0.1:26543;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8579. echo ' include /etc/nginx/fastcgi_params;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8580. echo '' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8581. echo ' # our understanding vs nginxs handling of script_name vs' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8582. echo ' # path_info dont match :)' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8583. echo ' fastcgi_param PATH_INFO $fastcgi_script_name;' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8584. echo ' fastcgi_param SCRIPT_NAME "";' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8585. echo ' }' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8586. echo '}' >> $MEDIAGOBLIN_VIRTUAL_HOST
  8587. create_site_certificate $MEDIAGOBLIN_DOMAIN_NAME
  8588. nginx_ensite $MEDIAGOBLIN_DOMAIN_NAME
  8589. systemctl restart php5-fpm
  8590. systemctl restart nginx
  8591. add_ddns_domain $MEDIAGOBLIN_DOMAIN_NAME
  8592. if ! grep -q "Mediagoblin domain" $COMPLETION_FILE; then
  8593. echo "Mediagoblin domain:$MEDIAGOBLIN_DOMAIN_NAME" >> $COMPLETION_FILE
  8594. else
  8595. sed -i "s/Mediagoblin domain.*/Mediagoblin domain:$MEDIAGOBLIN_DOMAIN_NAME/g" $COMPLETION_FILE
  8596. fi
  8597. echo 'install_mediagoblin' >> $COMPLETION_FILE
  8598. }
  8599. function create_upgrade_script {
  8600. if [ -f /usr/local/bin/${PROJECT_NAME}-upgrade ]; then
  8601. cp /usr/local/bin/${PROJECT_NAME}-upgrade /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8602. else
  8603. cp /usr/bin/${PROJECT_NAME}-upgrade /etc/cron.weekly/$UPGRADE_SCRIPT_NAME
  8604. fi
  8605. if grep -Fxq "create_upgrade_script" $COMPLETION_FILE; then
  8606. return
  8607. fi
  8608. apt-get -y install unattended-upgrades
  8609. echo 'create_upgrade_script' >> $COMPLETION_FILE
  8610. }
  8611. function intrusion_detection {
  8612. if grep -Fxq "intrusion_detection" $COMPLETION_FILE; then
  8613. return
  8614. fi
  8615. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8616. return
  8617. fi
  8618. apt-get -y install tripwire
  8619. apt-get -y autoremove
  8620. cd /etc/tripwire
  8621. cp site.key $DEFAULT_DOMAIN_NAME-site.key
  8622. echo '*** Installing intrusion detection ***'
  8623. echo '
  8624. ' | tripwire --init
  8625. # make a script for easy resetting of the tripwire
  8626. echo '#!/bin/sh' > /usr/bin/reset-tripwire
  8627. echo 'tripwire --update-policy --secure-mode low /etc/tripwire/twpol.txt' >> /usr/bin/reset-tripwire
  8628. chmod +x /usr/bin/reset-tripwire
  8629. sed -i 's/SYSLOGREPORTING.*/SYSLOGREPORTING =false/g' /etc/tripwire/twcfg.txt
  8630. # only send emails if something has changed
  8631. sed -i 's|MAILNOVIOLATIONS.*|MAILNOVIOLATIONS = false|g' /etc/tripwire/twcfg.txt
  8632. sed -i '/# These files change the behavior of the root account/,/}/ s/.*//g' /etc/tripwire/twpol.txt
  8633. sed -i 's|/etc/rc.boot.*||g' /etc/tripwire/twpol.txt
  8634. # Don't show any changes to /proc
  8635. sed -i 's|/proc.*||g' /etc/tripwire/twpol.txt
  8636. # Don't report log changes
  8637. sed -i 's|/var/log.*||g' /etc/tripwire/twpol.txt
  8638. # Ignore /etc/tripwire
  8639. if ! grep -q '!/etc/tripwire' /etc/tripwire/twpol.txt; then
  8640. sed -i '\|/etc\t\t->.*|a\ !/etc/tripwire ;' /etc/tripwire/twpol.txt
  8641. fi
  8642. # ignore tt-rss cache
  8643. if ! grep -q '!/etc/share/tt-rss/cache' /etc/tripwire/twpol.txt; then
  8644. sed -i '\|/etc\t\t->.*|a\ !/etc/share/tt-rss/cache ;' /etc/tripwire/twpol.txt
  8645. fi
  8646. if ! grep -q '!/etc/share/tt-rss/lock' /etc/tripwire/twpol.txt; then
  8647. sed -i '\|/etc\t\t->.*|a\ !/etc/share/tt-rss/lock ;' /etc/tripwire/twpol.txt
  8648. fi
  8649. # Avoid logging the changed database
  8650. sed -i 's|$(TWETC)/tw.pol.*||g' /etc/tripwire/twpol.txt
  8651. # recreate the configuration
  8652. echo '
  8653. ' | twadmin --create-cfgfile -S /etc/tripwire/site.key /etc/tripwire/twcfg.txt
  8654. # reset
  8655. echo '
  8656. ' | reset-tripwire
  8657. echo 'intrusion_detection' >> $COMPLETION_FILE
  8658. }
  8659. # see https://trac.torproject.org/projects/tor/wiki/doc/TransparentProxy
  8660. # Local Redirection and Anonymizing Middlebox
  8661. function route_outgoing_traffic_through_tor {
  8662. if grep -Fxq "route_outgoing_traffic_through_tor" $COMPLETION_FILE; then
  8663. return
  8664. fi
  8665. if [[ $ROUTE_THROUGH_TOR != "yes" ]]; then
  8666. return
  8667. fi
  8668. apt-get -y install tor tor-arm
  8669. ### set variables
  8670. # Destinations you don't want routed through Tor
  8671. _non_tor="192.168.1.0/24 192.168.0.0/24"
  8672. # The user that Tor runs as
  8673. _tor_uid="debian-tor"
  8674. # Tor's TransPort
  8675. _trans_port="9040"
  8676. # Your internal interface
  8677. _int_if="eth0"
  8678. ### Set iptables *nat
  8679. iptables -t nat -A OUTPUT -o lo -j RETURN
  8680. iptables -t nat -A OUTPUT -m owner --uid-owner $_tor_uid -j RETURN
  8681. iptables -t nat -A OUTPUT -p udp --dport 53 -j REDIRECT --to-ports 53
  8682. # Allow clearnet access for hosts in $_non_tor
  8683. for _clearnet in $_non_tor; do
  8684. iptables -t nat -A OUTPUT -d $_clearnet -j RETURN
  8685. iptables -t nat -A PREROUTING -i $_int_if -d $_clearnet -j RETURN
  8686. done
  8687. # Redirect all other pre-routing and output to Tor
  8688. iptables -t nat -A OUTPUT -p tcp --syn -j REDIRECT --to-ports $_trans_port
  8689. iptables -t nat -A PREROUTING -i $_int_if -p udp --dport 53 -j REDIRECT --to-ports 53
  8690. iptables -t nat -A PREROUTING -i $_int_if -p tcp --syn -j REDIRECT --to-ports $_trans_port
  8691. ### set iptables *filter
  8692. iptables -A OUTPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
  8693. # Allow clearnet access for hosts in $_non_tor
  8694. for _clearnet in $_non_tor 127.0.0.0/8; do
  8695. iptables -A OUTPUT -d $_clearnet -j ACCEPT
  8696. done
  8697. # Allow only Tor output
  8698. iptables -A OUTPUT -m owner --uid-owner $_tor_uid -j ACCEPT
  8699. iptables -A OUTPUT -j REJECT
  8700. save_firewall_settings
  8701. if ! grep -q "fs.file-max" /etc/sysctl.conf; then
  8702. echo "fs.file-max=100000" >> /etc/sysctl.conf
  8703. /sbin/sysctl -p
  8704. fi
  8705. echo 'domain localdomain' > /etc/resolv.conf
  8706. echo 'search localdomain' >> /etc/resolv.conf
  8707. echo 'nameserver 127.0.0.1' >> /etc/resolv.conf
  8708. if ! grep -q "VirtualAddrNetworkIPv4" /etc/tor/torrc; then
  8709. echo 'VirtualAddrNetworkIPv4 10.192.0.0/10' >> /etc/tor/torrc
  8710. fi
  8711. if ! grep -q "AutomapHostsOnResolve" /etc/tor/torrc; then
  8712. echo 'AutomapHostsOnResolve 1' >> /etc/tor/torrc
  8713. fi
  8714. if ! grep -q "TransPort" /etc/tor/torrc; then
  8715. echo 'TransPort 9040' >> /etc/tor/torrc
  8716. fi
  8717. if ! grep -q "TransListenAddress 127.0.0.1" /etc/tor/torrc; then
  8718. echo 'TransListenAddress 127.0.0.1' >> /etc/tor/torrc
  8719. fi
  8720. if ! grep -q "TransListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" /etc/tor/torrc; then
  8721. echo "TransListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/tor/torrc
  8722. fi
  8723. if ! grep -q "DNSPort" /etc/tor/torrc; then
  8724. echo 'DNSPort 53' >> /etc/tor/torrc
  8725. fi
  8726. if ! grep -q "DNSListenAddress 127.0.0.1" /etc/tor/torrc; then
  8727. echo 'DNSListenAddress 127.0.0.1' >> /etc/tor/torrc
  8728. fi
  8729. if ! grep -q "DNSListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" /etc/tor/torrc; then
  8730. echo "DNSListenAddress $LOCAL_NETWORK_STATIC_IP_ADDRESS" >> /etc/tor/torrc
  8731. fi
  8732. echo 'route_outgoing_traffic_through_tor' >> $COMPLETION_FILE
  8733. }
  8734. # A command to create a git repository for a project
  8735. function create_git_project {
  8736. if grep -Fxq "create_git_project" $COMPLETION_FILE; then
  8737. return
  8738. fi
  8739. apt-get -y install git
  8740. echo '#!/bin/bash' > /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8741. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8742. echo 'GIT_PROJECT_NAME=$1' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8743. echo 'if [ ! $GIT_PROJECT_NAME ]; then' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8744. echo ' echo "Please specify a project name, without any spaces"' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8745. echo ' exit 1' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8746. echo 'fi' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8747. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8748. echo 'if [ ! -d /home/$USER/projects/$GIT_PROJECT_NAME ]; then' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8749. echo ' mkdir -p /home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8750. echo 'fi' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8751. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8752. echo 'cd /home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8753. echo 'git init --bare' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8754. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8755. echo -n 'echo "Your project has been created, ' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8756. echo 'use the following command to clone the repository"' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8757. echo -n " git clone ssh://$MY_USERNAME@$DEFAULT_DOMAIN_NAME:$SSH_PORT" >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8758. echo '/home/$USER/projects/$GIT_PROJECT_NAME' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8759. echo '' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8760. echo 'exit 0' >> /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8761. chmod +x /usr/bin/$CREATE_GIT_PROJECT_COMMAND
  8762. echo 'create_git_project' >> $COMPLETION_FILE
  8763. }
  8764. function check_date {
  8765. curr_date=$(date)
  8766. if [[ $curr_date == *"1970"* ]]; then
  8767. apt-get -y install ntp
  8768. fi
  8769. }
  8770. function install_dynamicdns {
  8771. if [[ $SYSTEM_TYPE == "$VARIANT_MESH" ]]; then
  8772. return
  8773. fi
  8774. if [[ $ONION_ONLY != "no" ]]; then
  8775. return
  8776. fi
  8777. # update to the next commit
  8778. set_repo_commit $INSTALL_DIR/inadyn "inadyn commit" "$INADYN_COMMIT" $INADYN_REPO
  8779. if grep -Fxq "install_dynamicdns" $COMPLETION_FILE; then
  8780. return
  8781. fi
  8782. # Here we compile from source because the current package
  8783. # doesn't support https, which could result in passwords
  8784. # being leaked
  8785. # Debian version 1.99.4-1
  8786. # https version 1.99.8
  8787. apt-get -y install build-essential curl libgnutls28-dev automake1.11
  8788. if [ ! -d $INSTALL_DIR/inadyn ]; then
  8789. git_clone $INADYN_REPO $INSTALL_DIR/inadyn
  8790. fi
  8791. if [ ! -d $INSTALL_DIR/inadyn ]; then
  8792. echo 'inadyn repo not cloned'
  8793. echo -n | openssl s_client -showcerts -connect github.com:443 -CApath /etc/ssl/certs
  8794. exit 6785
  8795. fi
  8796. cd $INSTALL_DIR/inadyn
  8797. git checkout $INADYN_COMMIT -b $INADYN_COMMIT
  8798. if ! grep -q "inadyn commit" $COMPLETION_FILE; then
  8799. echo "inadyn commit:$INADYN_COMMIT" >> $COMPLETION_FILE
  8800. else
  8801. sed -i "s/inadyn commit.*/inadyn commit:$INADYN_COMMIT/g" $COMPLETION_FILE
  8802. fi
  8803. ./configure
  8804. if [ ! "$?" = "0" ]; then
  8805. exit 74890
  8806. fi
  8807. USE_OPENSSL=1 make
  8808. if [ ! "$?" = "0" ]; then
  8809. exit 74858
  8810. fi
  8811. make install
  8812. if [ ! "$?" = "0" ]; then
  8813. exit 3785
  8814. fi
  8815. # create an unprivileged user
  8816. #useradd -r -s /bin/false debian-inadyn
  8817. # create a configuration file
  8818. echo 'background' > /etc/inadyn.conf
  8819. echo 'verbose 1' >> /etc/inadyn.conf
  8820. echo 'period 300' >> /etc/inadyn.conf
  8821. echo 'startup-delay 60' >> /etc/inadyn.conf
  8822. echo 'cache-dir /run/inadyn' >> /etc/inadyn.conf
  8823. echo 'logfile /dev/null' >> /etc/inadyn.conf
  8824. chmod 600 /etc/inadyn.conf
  8825. echo '[Unit]' > /etc/systemd/system/inadyn.service
  8826. echo 'Description=inadyn (DynDNS updater)' >> /etc/systemd/system/inadyn.service
  8827. echo 'After=network.target' >> /etc/systemd/system/inadyn.service
  8828. echo '' >> /etc/systemd/system/inadyn.service
  8829. echo '[Service]' >> /etc/systemd/system/inadyn.service
  8830. echo 'ExecStart=/usr/local/sbin/inadyn --config /etc/inadyn.conf' >> /etc/systemd/system/inadyn.service
  8831. echo 'Restart=always' >> /etc/systemd/system/inadyn.service
  8832. echo 'Type=forking' >> /etc/systemd/system/inadyn.service
  8833. echo '' >> /etc/systemd/system/inadyn.service
  8834. echo '[Install]' >> /etc/systemd/system/inadyn.service
  8835. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/inadyn.service
  8836. systemctl enable inadyn
  8837. systemctl start inadyn
  8838. systemctl daemon-reload
  8839. echo 'install_dynamicdns' >> $COMPLETION_FILE
  8840. }
  8841. function get_voip_server_password {
  8842. if [ -f /home/$MY_USERNAME/README ]; then
  8843. if grep -q "VoIP server password" /home/$MY_USERNAME/README; then
  8844. if [ ! $VOIP_SERVER_PASSWORD ]; then
  8845. VOIP_SERVER_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "VoIP server password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  8846. fi
  8847. fi
  8848. fi
  8849. }
  8850. function get_sip_server_password {
  8851. if [ -f /home/$MY_USERNAME/README ]; then
  8852. if grep -q "SIP server password" /home/$MY_USERNAME/README; then
  8853. if [ ! $SIP_SERVER_PASSWORD ]; then
  8854. SIP_SERVER_PASSWORD=$(cat /home/$MY_USERNAME/README | grep "SIP server password" | awk -F ':' '{print $2}' | sed 's/^ *//')
  8855. fi
  8856. fi
  8857. fi
  8858. }
  8859. function install_ipfs {
  8860. if [[ $SYSTEM_TYPE == "$VARIANT_CHAT" || $SYSTEM_TYPE == "$VARIANT_MAILBOX" ]]; then
  8861. return
  8862. fi
  8863. export GOPATH=/home/git/go
  8864. systemctl set-environment GOPATH=/home/git/go
  8865. # update to the next commit
  8866. set_repo_commit /home/git/go/src/github.com/ipfs/go-ipfs "ipfs commit" "$IPFS_COMMIT" $IPFS_REPO
  8867. if grep -Fxq "install_ipfs" $COMPLETION_FILE; then
  8868. return
  8869. fi
  8870. apt-get -y install golang libpam0g-dev fuse
  8871. if [ ! -d /home/git ]; then
  8872. # add a gogs user account
  8873. adduser --disabled-login --gecos 'Gogs' git
  8874. # install Go
  8875. if ! grep -q "export GOPATH=/home/git/go" ~/.bashrc; then
  8876. echo 'export GOPATH=/home/git/go' >> ~/.bashrc
  8877. echo 'systemctl set-environment GOPATH=/home/git/go' >> ~/.bashrc
  8878. fi
  8879. export GOPATH=/home/git/go
  8880. if [ ! -d $GOPATH ]; then
  8881. mkdir -p $GOPATH
  8882. fi
  8883. fi
  8884. IPFS_PATH=/home/git/go/bin
  8885. if ! grep -q 'GOPATH/bin' ~/.bashrc; then
  8886. export PATH="$GOPATH/bin:$PATH:"
  8887. echo 'export PATH="$GOPATH/bin:$PATH:";' >> ~/.bashrc
  8888. fi
  8889. # set gopath for the user
  8890. if ! grep -q "GOPATH=" /home/$MY_USERNAME/.bashrc; then
  8891. echo 'export GOPATH=/home/git/go' >> /home/$MY_USERNAME/.bashrc
  8892. echo 'export PATH="$GOPATH/bin:$PATH:";' >> /home/$MY_USERNAME/.bashrc
  8893. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/.bashrc
  8894. fi
  8895. IPFS_GO_REPO2=$(echo "$IPFS_GO_REPO" | sed 's|https://||g')
  8896. go get -u ${IPFS_GO_REPO2}/cmd/ipfs
  8897. if [ ! "$?" = "0" ]; then
  8898. exit 8242
  8899. fi
  8900. cd /home/git/go/src/$IPFS_GO_REPO2
  8901. git checkout $IPFS_COMMIT -b $IPFS_COMMIT
  8902. if ! grep -q "ipfs commit" $COMPLETION_FILE; then
  8903. echo "ipfs commit:$IPFS_COMMIT" >> $COMPLETION_FILE
  8904. else
  8905. sed -i "s/ipfs commit.*/ipfs commit:$IPFS_COMMIT/g" $COMPLETION_FILE
  8906. fi
  8907. # initialise
  8908. su -c "$IPFS_PATH/ipfs init -b 4096" - $MY_USERNAME
  8909. if [ ! -d /home/$MY_USERNAME/.ipfs ]; then
  8910. echo "IPFS could not be initialised for user $MY_USERNAME"
  8911. exit 7358
  8912. fi
  8913. # directories to mount to
  8914. if [ ! -d /ipfs ]; then
  8915. mkdir /ipfs
  8916. mkdir /ipns
  8917. chown $MY_USERNAME:$MY_USERNAME /ipfs
  8918. chown $MY_USERNAME:$MY_USERNAME /ipns
  8919. fi
  8920. if [ -f /etc/fuse.conf ]; then
  8921. chown $MY_USERNAME:$MY_USERNAME /etc/fuse.conf
  8922. fi
  8923. if [ -f /dev/fuse ]; then
  8924. chown $MY_USERNAME:$MY_USERNAME /dev/fuse
  8925. fi
  8926. echo '[Unit]' > /etc/systemd/system/ipfs.service
  8927. echo 'Description=IPFS daemon' >> /etc/systemd/system/ipfs.service
  8928. echo 'After=syslog.target' >> /etc/systemd/system/ipfs.service
  8929. echo 'After=network.target' >> /etc/systemd/system/ipfs.service
  8930. echo '' >> /etc/systemd/system/ipfs.service
  8931. echo '[Service]' >> /etc/systemd/system/ipfs.service
  8932. echo 'Type=simple' >> /etc/systemd/system/ipfs.service
  8933. echo "User=$MY_USERNAME" >> /etc/systemd/system/ipfs.service
  8934. echo "Group=$MY_USERNAME" >> /etc/systemd/system/ipfs.service
  8935. echo "WorkingDirectory=/home/$MY_USERNAME" >> /etc/systemd/system/ipfs.service
  8936. echo "ExecStart=$IPFS_PATH/ipfs daemon --mount" >> /etc/systemd/system/ipfs.service
  8937. echo 'Restart=on-failure' >> /etc/systemd/system/ipfs.service
  8938. echo "Environment=\"USER=$MY_USERNAME\" \"HOME=/home/$MY_USERNAME\" \"GOPATH=/home/git/go\"" >> /etc/systemd/system/ipfs.service
  8939. echo '' >> /etc/systemd/system/ipfs.service
  8940. echo '[Install]' >> /etc/systemd/system/ipfs.service
  8941. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/ipfs.service
  8942. systemctl enable ipfs
  8943. systemctl daemon-reload
  8944. systemctl restart ipfs
  8945. if [ -d /etc/avahi ]; then
  8946. su -c "echo $($IPFS_PATH/ipfs id | grep '\"ID\":' | awk -F '\"' '{print $4}') > /tmp/ipfsid" - $MY_USERNAME
  8947. if [ ! -f /tmp/ipfsid ]; then
  8948. echo 'No IPFS identity was created'
  8949. exit 37895
  8950. fi
  8951. IPFS_PEER_ID=$(cat /tmp/ipfsid)
  8952. if [ ${#IPFS_PEER_ID} -lt 10 ]; then
  8953. echo 'Invalid IPFS peer ID'
  8954. echo "$IPFS_PEER_ID"
  8955. exit 74782
  8956. fi
  8957. # Add an avahi service
  8958. echo '<?xml version="1.0" standalone="no"?><!--*-nxml-*-->' > /etc/avahi/services/ipfs.service
  8959. echo '<!DOCTYPE service-group SYSTEM "avahi-service.dtd">' >> /etc/avahi/services/ipfs.service
  8960. echo '<service-group>' >> /etc/avahi/services/ipfs.service
  8961. echo ' <name replace-wildcards="yes">%h IPFS</name>' >> /etc/avahi/services/ipfs.service
  8962. echo ' <service>' >> /etc/avahi/services/ipfs.service
  8963. echo ' <type>_ipfs._tcp</type>' >> /etc/avahi/services/ipfs.service
  8964. echo " <port>$IPFS_PORT</port>" >> /etc/avahi/services/ipfs.service
  8965. echo " <txt-record>$IPFS_PEER_ID</txt-record>" >> /etc/avahi/services/ipfs.service
  8966. echo ' </service>' >> /etc/avahi/services/ipfs.service
  8967. echo '</service-group>' >> /etc/avahi/services/ipfs.service
  8968. rm /tmp/ipfsid
  8969. fi
  8970. echo 'install_ipfs' >> $COMPLETION_FILE
  8971. }
  8972. function install_voip {
  8973. 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
  8974. return
  8975. fi
  8976. if grep -Fxq "install_voip" $COMPLETION_FILE; then
  8977. return
  8978. fi
  8979. apt-get -y install mumble-server
  8980. get_voip_server_password
  8981. if [ ! $VOIP_SERVER_PASSWORD ]; then
  8982. if [ -f $IMAGE_PASSWORD_FILE ]; then
  8983. VOIP_SERVER_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  8984. else
  8985. VOIP_SERVER_PASSWORD="$(openssl rand -base64 18 | cut -c1-16)"
  8986. if [ ${#VOIP_SERVER_PASSWORD} -lt $MINIMUM_PASSWORD_LENGTH ]; then
  8987. VOIP_SERVER_PASSWORD="$(openssl rand -base64 18 | cut -c1-16)"
  8988. fi
  8989. fi
  8990. fi
  8991. # Make an ssl cert for the server
  8992. if [ ! -f /etc/ssl/certs/mumble.dhparam ]; then
  8993. ${PROJECT_NAME}-addcert -h mumble --dhkey $DH_KEYLENGTH
  8994. check_certificates mumble
  8995. fi
  8996. # Check that the cert was created
  8997. if [ ! -f /etc/ssl/certs/mumble.crt ]; then
  8998. echo $'VoIP server certificate not created'
  8999. exit 57892
  9000. fi
  9001. if [ ! -f /etc/ssl/private/mumble.key ]; then
  9002. echo $'VoIP server key not created'
  9003. exit 57893
  9004. fi
  9005. if [ ! -d /var/lib/mumble-server ]; then
  9006. mkdir /var/lib/mumble-server
  9007. fi
  9008. cp /etc/ssl/certs/mumble.* /var/lib/mumble-server
  9009. cp /etc/ssl/private/mumble.key /var/lib/mumble-server
  9010. chown -R mumble-server:mumble-server /var/lib/mumble-server
  9011. sed -i "s|welcometext=.*|welcometext=\"<br />Welcome to $DEFAULT_DOMAIN_NAME <b>VoIP</b>.<br />Chat freely!<br />\"|g" /etc/mumble-server.ini
  9012. if [[ $VOIP_SERVER_PASSWORD && $SYSTEM_TYPE != "$VARIANT_MESH" ]]; then
  9013. sed -i "s|serverpassword=.*|serverpassword=$VOIP_SERVER_PASSWORD|g" /etc/mumble-server.ini
  9014. fi
  9015. sed -i 's|#autobanAttempts.*|autobanAttempts = 10|g' /etc/mumble-server.ini
  9016. sed -i 's|#autobanTimeframe.*|autobanTimeframe = 120|g' /etc/mumble-server.ini
  9017. sed -i 's|#autobanTime.*|autobanTime = 300|g' /etc/mumble-server.ini
  9018. sed -i 's|#sendversion=.*|sendversion=False|g' /etc/mumble-server.ini
  9019. sed -i 's|sendversion=.*|sendversion=False|g' /etc/mumble-server.ini
  9020. if ! grep -q "allowping" /etc/mumble-server.ini; then
  9021. echo 'allowping=False' >> /etc/mumble-server.ini
  9022. fi
  9023. sed -i 's|allowping=.*|allowping=False|g' /etc/mumble-server.ini
  9024. sed -i 's|#sslCert=.*|sslCert=/var/lib/mumble-server/mumble.crt|g' /etc/mumble-server.ini
  9025. sed -i 's|#sslKey=.*|sslKey=/var/lib/mumble-server/mumble.key|g' /etc/mumble-server.ini
  9026. sed -i 's|#certrequired=.*|certrequired=True|g' /etc/mumble-server.ini
  9027. sed -i 's|users=100|users=10|g' /etc/mumble-server.ini
  9028. sed -i 's|#channelnestinglimit=10|channelnestinglimit=10|g' /etc/mumble-server.ini
  9029. sed -i 's|#textmessagelength=.*|textmessagelength=1000|g' /etc/mumble-server.ini
  9030. sed -i 's|textmessagelength=.*|textmessagelength=1000|g' /etc/mumble-server.ini
  9031. sed -i 's|#imagemessagelength=.*|imagemessagelength=131072|g' /etc/mumble-server.ini
  9032. sed -i 's|#allowhtml=.*|allowhtml=False|g' /etc/mumble-server.ini
  9033. sed -i 's|allowhtml=.*|allowhtml=False|g' /etc/mumble-server.ini
  9034. sed -i "s|port=.*|port=${VOIP_PORT}|g" /etc/mumble-server.ini
  9035. VOIP_ONION_HOSTNAME=$(add_onion_service voip ${VOIP_PORT} ${VOIP_PORT})
  9036. if ! grep -q $"VoIP onion domain" $COMPLETION_FILE; then
  9037. echo "VoIP onion domain:$VOIP_ONION_HOSTNAME" >> $COMPLETION_FILE
  9038. fi
  9039. systemctl restart mumble-server
  9040. if ! grep -q $"VoIP Server" /home/$MY_USERNAME/README; then
  9041. echo '' >> /home/$MY_USERNAME/README
  9042. echo '' >> /home/$MY_USERNAME/README
  9043. echo $'VoIP Server' >> /home/$MY_USERNAME/README
  9044. echo '===========' >> /home/$MY_USERNAME/README
  9045. echo $"VoIP onion domain:$VOIP_ONION_HOSTNAME" >> /home/$MY_USERNAME/README
  9046. echo $'VoIP server username: mumble-server' >> /home/$MY_USERNAME/README
  9047. if [[ $SYSTEM_TYPE != "VARIANT_MESH" ]]; then
  9048. echo $"VoIP server password: $VOIP_SERVER_PASSWORD" >> /home/$MY_USERNAME/README
  9049. fi
  9050. echo '' >> /home/$MY_USERNAME/README
  9051. echo $'To connect to the VoIP server use your username and the server password shown above.' >> /home/$MY_USERNAME/README
  9052. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  9053. chmod 600 /home/$MY_USERNAME/README
  9054. fi
  9055. echo 'install_voip' >> $COMPLETION_FILE
  9056. }
  9057. function update_sipwitch_daemon {
  9058. if [ ! -f /etc/init.d/sipwitch ]; then
  9059. return
  9060. fi
  9061. service sipwitch stop
  9062. # remove the original sipwitch daemon if it exists
  9063. if [ -f /etc/init.d/sipwitch ]; then
  9064. rm -f /etc/init.d/sipwitch
  9065. fi
  9066. # daemon
  9067. echo '[Unit]' > /etc/systemd/system/sipwitch.service
  9068. echo 'Description=GNU SIP Witch, a SIP telephony service daemon.' >> /etc/systemd/system/sipwitch.service
  9069. echo 'After=network.target' >> /etc/systemd/system/sipwitch.service
  9070. echo '' >> /etc/systemd/system/sipwitch.service
  9071. echo '[Service]' >> /etc/systemd/system/sipwitch.service
  9072. echo 'Type=simple' >> /etc/systemd/system/sipwitch.service
  9073. echo 'Group=sipwitch' >> /etc/systemd/system/sipwitch.service
  9074. echo 'PIDFile=/var/run/sipwitch/pidfile' >> /etc/systemd/system/sipwitch.service
  9075. echo 'EnvironmentFile=-/etc/conf.d/sipwitch' >> /etc/systemd/system/sipwitch.service
  9076. echo 'EnvironmentFile=-/etc/sipwitch.conf' >> /etc/systemd/system/sipwitch.service
  9077. echo 'EnvironmentFile=-/etc/default/sipwitch' >> /etc/systemd/system/sipwitch.service
  9078. echo 'ExecStartPre=-/bin/rm -f /var/run/sipwitch/control' >> /etc/systemd/system/sipwitch.service
  9079. echo "ExecStart=/usr/sbin/sipw -f \$OPTIONS -P$SIP_PORT" >> /etc/systemd/system/sipwitch.service
  9080. echo 'Restart=always' >> /etc/systemd/system/sipwitch.service
  9081. echo 'NotifyAccess=main' >> /etc/systemd/system/sipwitch.service
  9082. echo '' >> /etc/systemd/system/sipwitch.service
  9083. echo '[Install]' >> /etc/systemd/system/sipwitch.service
  9084. echo 'WantedBy=multi-user.target' >> /etc/systemd/system/sipwitch.service
  9085. systemctl enable sipwitch
  9086. systemctl daemon-reload
  9087. systemctl start sipwitch
  9088. }
  9089. function install_sip {
  9090. 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
  9091. return
  9092. fi
  9093. if grep -Fxq "install_sip" $COMPLETION_FILE; then
  9094. return
  9095. fi
  9096. apt-get -y install sipwitch
  9097. get_sip_server_password
  9098. if [ ! $SIP_SERVER_PASSWORD ]; then
  9099. if [ -f $IMAGE_PASSWORD_FILE ]; then
  9100. SIP_SERVER_PASSWORD="$(printf `cat $IMAGE_PASSWORD_FILE`)"
  9101. else
  9102. SIP_SERVER_PASSWORD="$(openssl rand -base64 12 | cut -c1-10)"
  9103. fi
  9104. fi
  9105. echo '<?xml version="1.0"?>' > /etc/sipwitch.conf
  9106. echo '<sipwitch>' >> /etc/sipwitch.conf
  9107. echo '<provision>' >> /etc/sipwitch.conf
  9108. echo "<user id=\"$MY_USERNAME\">" >> /etc/sipwitch.conf
  9109. echo '<extension>201</extension>' >> /etc/sipwitch.conf
  9110. echo "<secret>$SIP_SERVER_PASSWORD</secret>" >> /etc/sipwitch.conf
  9111. echo "<display>$MY_USERNAME 201</display>" >> /etc/sipwitch.conf
  9112. echo '</user>' >> /etc/sipwitch.conf
  9113. echo '</provision>' >> /etc/sipwitch.conf
  9114. echo '<access>' >> /etc/sipwitch.conf
  9115. echo '</access>' >> /etc/sipwitch.conf
  9116. echo '<stack>' >> /etc/sipwitch.conf
  9117. echo " <localnames>$DEFAULT_DOMAIN_NAME</localnames>" >> /etc/sipwitch.conf
  9118. echo ' <mapped>200</mapped>' >> /etc/sipwitch.conf
  9119. echo ' <threading>2</threading>' >> /etc/sipwitch.conf
  9120. echo ' <interface>*</interface>' >> /etc/sipwitch.conf
  9121. echo ' <dumping>false</dumping>' >> /etc/sipwitch.conf
  9122. echo ' <system>system</system>' >> /etc/sipwitch.conf
  9123. echo ' <anon>anonymous</anon>' >> /etc/sipwitch.conf
  9124. echo '</stack>' >> /etc/sipwitch.conf
  9125. echo '<timers>' >> /etc/sipwitch.conf
  9126. echo ' <!-- ring every 4 seconds -->' >> /etc/sipwitch.conf
  9127. echo ' <ring>4</ring>' >> /etc/sipwitch.conf
  9128. echo ' <!-- call forward no answer after x rings -->' >> /etc/sipwitch.conf
  9129. echo ' <cfna>4</cfna>' >> /etc/sipwitch.conf
  9130. echo ' <!-- call reset to clear cid in stack, 6 seconds -->' >> /etc/sipwitch.conf
  9131. echo ' <reset>6</reset>' >> /etc/sipwitch.conf
  9132. echo '</timers>' >> /etc/sipwitch.conf
  9133. echo '<!-- we have 2xx numbers plus space for external users -->' >> /etc/sipwitch.conf
  9134. echo '<registry>' >> /etc/sipwitch.conf
  9135. echo ' <prefix>200</prefix>' >> /etc/sipwitch.conf
  9136. echo ' <range>100</range>' >> /etc/sipwitch.conf
  9137. echo ' <keysize>77</keysize>' >> /etc/sipwitch.conf
  9138. echo ' <mapped>200</mapped>' >> /etc/sipwitch.conf
  9139. echo ' <!-- <realm>GNU Telephony</realm> -->' >> /etc/sipwitch.conf
  9140. echo '</registry>' >> /etc/sipwitch.conf
  9141. echo '<routing>' >> /etc/sipwitch.conf
  9142. echo '</routing>' >> /etc/sipwitch.conf
  9143. echo '</sipwitch>' >> /etc/sipwitch.conf
  9144. sed -i 's|#PLUGINS=|PLUGINS=|g' /etc/default/sipwitch
  9145. sed -i 's|PLUGINS=.*|PLUGINS="zeroconf subscriber forward"|g' /etc/default/sipwitch
  9146. groupadd sipwitch
  9147. usermod -aG sipwitch $MY_USERNAME
  9148. SIP_ONION_HOSTNAME=$(add_onion_service sip ${SIP_PORT} ${SIP_PORT})
  9149. if ! grep -q $"SIP onion domain" $COMPLETION_FILE; then
  9150. echo "SIP onion domain:$SIP_ONION_HOSTNAME" >> $COMPLETION_FILE
  9151. fi
  9152. if ! grep -q $"SIP Server" /home/$MY_USERNAME/README; then
  9153. echo '' >> /home/$MY_USERNAME/README
  9154. echo '' >> /home/$MY_USERNAME/README
  9155. echo $'SIP Server' >> /home/$MY_USERNAME/README
  9156. echo '==========' >> /home/$MY_USERNAME/README
  9157. echo $"SIP onion_domain: $SIP_ONION_HOSTNAME" >> /home/$MY_USERNAME/README
  9158. echo $"SIP server username: $MY_USERNAME" >> /home/$MY_USERNAME/README
  9159. echo $"SIP server extension: 201" >> /home/$MY_USERNAME/README
  9160. echo $"SIP server password: $SIP_SERVER_PASSWORD" >> /home/$MY_USERNAME/README
  9161. chown $MY_USERNAME:$MY_USERNAME /home/$MY_USERNAME/README
  9162. chmod 600 /home/$MY_USERNAME/README
  9163. fi
  9164. echo 'install_sip' >> $COMPLETION_FILE
  9165. }
  9166. function install_sip_turn {
  9167. 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
  9168. return
  9169. fi
  9170. if grep -Fxq "install_sip_turn" $COMPLETION_FILE; then
  9171. return
  9172. fi
  9173. apt-get -y install turnserver
  9174. # create a nonce if needed
  9175. if [ ! $VOIP_TURN_NONCE ]; then
  9176. VOIP_TURN_NONCE="$(openssl rand -base64 32 | cut -c1-30)"
  9177. fi
  9178. create_site_certificate $DEFAULT_DOMAIN_NAME
  9179. echo '##' > /etc/turnserver/turnserver.conf
  9180. echo '# TurnServer configuration file.' >> /etc/turnserver/turnserver.conf
  9181. echo '#' >> /etc/turnserver/turnserver.conf
  9182. echo '' >> /etc/turnserver/turnserver.conf
  9183. echo '## Public IPv4 address of any relayed address (if not set, no relay for IPv4).' >> /etc/turnserver/turnserver.conf
  9184. echo '## To have multiple address, separate addresses with a comma' >> /etc/turnserver/turnserver.conf
  9185. echo '## (i.e. listen_address = { "172.16.0.1", "172.17.0.1" }).' >> /etc/turnserver/turnserver.conf
  9186. echo "listen_address = { \"192.168.0.1\" }" >> /etc/turnserver/turnserver.conf
  9187. echo '' >> /etc/turnserver/turnserver.conf
  9188. echo '## Public IPv6 address of any relayed address (if not set, no relay for IPv6).' >> /etc/turnserver/turnserver.conf
  9189. echo '## To have multiple address, separate address with a comma' >> /etc/turnserver/turnserver.conf
  9190. echo '## (i.e. listen_addressv6 = { "2001:db8:1::1", "2001:db8:2::1" }).' >> /etc/turnserver/turnserver.conf
  9191. echo "#listen_addressv6 = { \"2001:db8::1\" }" >> /etc/turnserver/turnserver.conf
  9192. echo '' >> /etc/turnserver/turnserver.conf
  9193. echo '## UDP listening port.' >> /etc/turnserver/turnserver.conf
  9194. echo "udp_port = $VOIP_TURN_PORT" >> /etc/turnserver/turnserver.conf
  9195. echo '' >> /etc/turnserver/turnserver.conf
  9196. echo '## TCP listening port.' >> /etc/turnserver/turnserver.conf
  9197. echo "tcp_port = $VOIP_TURN_PORT" >> /etc/turnserver/turnserver.conf
  9198. echo '' >> /etc/turnserver/turnserver.conf
  9199. echo '## TLS listening port.' >> /etc/turnserver/turnserver.conf
  9200. echo "tls_port = $VOIP_TURN_TLS_PORT" >> /etc/turnserver/turnserver.conf
  9201. echo '' >> /etc/turnserver/turnserver.conf
  9202. echo '## TLS support.' >> /etc/turnserver/turnserver.conf
  9203. echo 'tls = true' >> /etc/turnserver/turnserver.conf
  9204. echo '' >> /etc/turnserver/turnserver.conf
  9205. echo '## DTLS support. It is an experimental feature and is not defined in TURN' >> /etc/turnserver/turnserver.conf
  9206. echo '## standard.' >> /etc/turnserver/turnserver.conf
  9207. echo 'dtls = false' >> /etc/turnserver/turnserver.conf
  9208. echo '' >> /etc/turnserver/turnserver.conf
  9209. echo '## Maximum allocation port number.' >> /etc/turnserver/turnserver.conf
  9210. echo 'max_port = 65535' >> /etc/turnserver/turnserver.conf
  9211. echo '' >> /etc/turnserver/turnserver.conf
  9212. echo '## Minimum allocation port number.' >> /etc/turnserver/turnserver.conf
  9213. echo '' >> /etc/turnserver/turnserver.conf
  9214. echo 'min_port = 49152' >> /etc/turnserver/turnserver.conf
  9215. echo '' >> /etc/turnserver/turnserver.conf
  9216. echo '## TURN-TCP support.' >> /etc/turnserver/turnserver.conf
  9217. echo '' >> /etc/turnserver/turnserver.conf
  9218. echo 'turn_tcp = true' >> /etc/turnserver/turnserver.conf
  9219. echo '' >> /etc/turnserver/turnserver.conf
  9220. echo '## TURN-TCP buffering mode:' >> /etc/turnserver/turnserver.conf
  9221. echo '## - true, use userspace buffering;' >> /etc/turnserver/turnserver.conf
  9222. echo '## - false, use kernel buffering.' >> /etc/turnserver/turnserver.conf
  9223. echo 'tcp_buffer_userspace = true' >> /etc/turnserver/turnserver.conf
  9224. echo '' >> /etc/turnserver/turnserver.conf
  9225. echo '## TURN-TCP maximum buffer size.' >> /etc/turnserver/turnserver.conf
  9226. echo 'tcp_buffer_size = 32768' >> /etc/turnserver/turnserver.conf
  9227. echo '' >> /etc/turnserver/turnserver.conf
  9228. echo '## Daemon mode.' >> /etc/turnserver/turnserver.conf
  9229. echo 'daemon = true' >> /etc/turnserver/turnserver.conf
  9230. echo '' >> /etc/turnserver/turnserver.conf
  9231. echo '## Unprivileged user.' >> /etc/turnserver/turnserver.conf
  9232. echo '## If you want to use this feature create a system user.' >> /etc/turnserver/turnserver.conf
  9233. echo '## On Linux: adduser --system --group turnserver' >> /etc/turnserver/turnserver.conf
  9234. echo 'unpriv_user = turnserver' >> /etc/turnserver/turnserver.conf
  9235. echo '' >> /etc/turnserver/turnserver.conf
  9236. echo '## Realm value.' >> /etc/turnserver/turnserver.conf
  9237. echo "realm = \"$DEFAULT_DOMAIN_NAME\"" >> /etc/turnserver/turnserver.conf
  9238. echo '' >> /etc/turnserver/turnserver.conf
  9239. echo '## Nonce key.' >> /etc/turnserver/turnserver.conf
  9240. echo "nonce_key = \"$VOIP_TURN_NONCE\"" >> /etc/turnserver/turnserver.conf
  9241. echo '' >> /etc/turnserver/turnserver.conf
  9242. echo '## Max relay per username.' >> /etc/turnserver/turnserver.conf
  9243. echo 'max_relay_per_username = 5' >> /etc/turnserver/turnserver.conf
  9244. echo '' >> /etc/turnserver/turnserver.conf
  9245. echo '## Allocation lifetime.' >> /etc/turnserver/turnserver.conf
  9246. echo 'allocation_lifetime = 1800' >> /etc/turnserver/turnserver.conf
  9247. echo '' >> /etc/turnserver/turnserver.conf
  9248. echo '## Allocation bandwidth limitation (in KBytes/s).' >> /etc/turnserver/turnserver.conf
  9249. echo '## 0 value means bandwidth quota disabled.' >> /etc/turnserver/turnserver.conf
  9250. echo 'bandwidth_per_allocation = 150' >> /etc/turnserver/turnserver.conf
  9251. echo '' >> /etc/turnserver/turnserver.conf
  9252. echo '## Restricted user bandwidth (in KBytes/s).' >> /etc/turnserver/turnserver.conf
  9253. echo '## 0 value means bandwidth limitation disabled.' >> /etc/turnserver/turnserver.conf
  9254. echo 'restricted_bandwidth = 10' >> /etc/turnserver/turnserver.conf
  9255. echo '' >> /etc/turnserver/turnserver.conf
  9256. echo '## Denied addresses.' >> /etc/turnserver/turnserver.conf
  9257. echo '' >> /etc/turnserver/turnserver.conf
  9258. echo '# disallow relaying to localhost' >> /etc/turnserver/turnserver.conf
  9259. echo 'denied_address {' >> /etc/turnserver/turnserver.conf
  9260. echo ' address = "127.0.0.1"' >> /etc/turnserver/turnserver.conf
  9261. echo ' mask = "8"' >> /etc/turnserver/turnserver.conf
  9262. echo ' port = 0' >> /etc/turnserver/turnserver.conf
  9263. echo '}' >> /etc/turnserver/turnserver.conf
  9264. echo '' >> /etc/turnserver/turnserver.conf
  9265. echo '# disallow relaying to ip6-localhost' >> /etc/turnserver/turnserver.conf
  9266. echo 'denied_address {' >> /etc/turnserver/turnserver.conf
  9267. echo ' address = "::1"' >> /etc/turnserver/turnserver.conf
  9268. echo ' mask = "128"' >> /etc/turnserver/turnserver.conf
  9269. echo ' port = 0' >> /etc/turnserver/turnserver.conf
  9270. echo '}' >> /etc/turnserver/turnserver.conf
  9271. echo '' >> /etc/turnserver/turnserver.conf
  9272. echo '## Certification Authority file.' >> /etc/turnserver/turnserver.conf
  9273. echo "ca_file = \"/etc/ssl/certs/ca-certificates.crt\"" >> /etc/turnserver/turnserver.conf
  9274. echo '' >> /etc/turnserver/turnserver.conf
  9275. echo '## Server certificate file.' >> /etc/turnserver/turnserver.conf
  9276. if [ -f /etc/ssl/certs/$DEFAULT_DOMAIN_NAME.pem ]; then
  9277. echo "cert_file = \"/etc/ssl/certs/$DEFAULT_DOMAIN_NAME.pem\"" >> /etc/turnserver/turnserver.conf
  9278. else
  9279. if [ -f /etc/ssl/certs/$DEFAULT_DOMAIN_NAME.crt ]; then
  9280. echo "cert_file = \"/etc/ssl/certs/$DEFAULT_DOMAIN_NAME.crt\"" >> /etc/turnserver/turnserver.conf
  9281. fi
  9282. fi
  9283. echo '' >> /etc/turnserver/turnserver.conf
  9284. echo '## Private key file.' >> /etc/turnserver/turnserver.conf
  9285. echo "private_key_file = \"/etc/ssl/certs/$DEFAULT_DOMAIN_NAME.key\"" >> /etc/turnserver/turnserver.conf
  9286. echo '' >> /etc/turnserver/turnserver.conf
  9287. echo '## Account method.' >> /etc/turnserver/turnserver.conf
  9288. echo "account_method = \"file\"" >> /etc/turnserver/turnserver.conf
  9289. echo '' >> /etc/turnserver/turnserver.conf
  9290. echo '## Account file (if account_method = file).' >> /etc/turnserver/turnserver.conf
  9291. echo "account_file = \"/etc/turnserver/turnusers.txt\"" >> /etc/turnserver/turnserver.conf
  9292. echo '' >> /etc/turnserver/turnserver.conf
  9293. echo '## mod_tmpuser.' >> /etc/turnserver/turnserver.conf
  9294. echo 'mod_tmpuser = false' >> /etc/turnserver/turnserver.conf
  9295. echo "${MY_USERNAME}:password:${DEFAULT_DOMAIN_NAME}:authorized" > /etc/turnserver/turnusers.txt
  9296. systemctl restart turnserver
  9297. echo 'install_sip_turn' >> $COMPLETION_FILE
  9298. }
  9299. function install_final {
  9300. if grep -Fxq "install_final" $COMPLETION_FILE; then
  9301. return
  9302. fi
  9303. # unmount any attached usb drive
  9304. if [ -d $USB_MOUNT ]; then
  9305. umount $USB_MOUNT
  9306. rm -rf $USB_MOUNT
  9307. fi
  9308. split_gpg_key_into_fragments
  9309. echo 'install_final' >> $COMPLETION_FILE
  9310. clear
  9311. echo ''
  9312. echo $"
  9313. *** ${PROJECT_NAME} installation is complete. Rebooting... ***
  9314. Now forward these ports from your internet router
  9315. HTTP 80
  9316. HTTPS 443
  9317. SSH 2222
  9318. DLNA 1900
  9319. DLNA 8200
  9320. XMPP 5222-5223
  9321. XMPP 5269
  9322. XMPP 5280-5281
  9323. IRC 6697
  9324. Git 9418
  9325. Email 25
  9326. Email 587
  9327. Email 465
  9328. Email 993
  9329. VoIP 64738
  9330. VoIP 5060
  9331. Tox 33445
  9332. "
  9333. if [ -f "/home/$MY_USERNAME/README" ]; then
  9334. echo $"See /home/$MY_USERNAME/README for post-installation instructions."
  9335. echo ''
  9336. fi
  9337. # add user menu on ssh login
  9338. if ! grep -q 'control' /home/$MY_USERNAME/.bashrc; then
  9339. echo 'control' >> /home/$MY_USERNAME/.bashrc
  9340. fi
  9341. if [ ! -f $IMAGE_PASSWORD_FILE ]; then
  9342. reboot
  9343. fi
  9344. }
  9345. read_configuration
  9346. set_default_onion_domains
  9347. locale_setup
  9348. parse_args
  9349. check_domains
  9350. install_not_on_BBB
  9351. remove_default_user
  9352. configure_firewall
  9353. configure_firewall_ping
  9354. configure_firewall_for_ssh
  9355. configure_firewall_for_dns
  9356. configure_firewall_for_ftp
  9357. configure_firewall_for_web_access
  9358. configure_firewall_for_voip
  9359. configure_firewall_for_voip_turn
  9360. configure_firewall_for_sip4
  9361. configure_firewall_for_avahi
  9362. configure_firewall_for_zeronet
  9363. configure_firewall_for_ipfs
  9364. create_repo_sources
  9365. configure_dns
  9366. initial_setup
  9367. install_tor
  9368. resolve_dns_via_tor
  9369. install_command_line_browser
  9370. enable_ssh_via_onion
  9371. check_date
  9372. install_dynamicdns
  9373. randomize_cron
  9374. create_freedns_updater
  9375. mark_admin_user_account
  9376. enforce_good_passwords
  9377. install_editor
  9378. change_login_message
  9379. enable_zram
  9380. random_number_generator
  9381. set_your_domain_name
  9382. time_synchronisation
  9383. configure_internet_protocol
  9384. create_git_project
  9385. configure_ssh
  9386. configure_ssh_onion
  9387. allow_ssh_to_onion_address
  9388. remove_instructions_from_motd
  9389. check_hwrng
  9390. search_for_attached_usb_drive
  9391. regenerate_ssh_keys
  9392. create_mirrors
  9393. create_upgrade_script
  9394. letsencrypt_renewals
  9395. install_zeronet
  9396. install_watchdog_script
  9397. configure_avahi
  9398. create_avahi_onion_domains
  9399. install_zeronet_blog
  9400. install_zeronet_mail
  9401. install_zeronet_forum
  9402. #install_atheros_wifi
  9403. configure_firewall_for_cjdns
  9404. mesh_cjdns
  9405. mesh_cjdns_tools
  9406. configure_firewall_for_batman
  9407. mesh_batman
  9408. configure_firewall_for_babel
  9409. mesh_babel
  9410. route_outgoing_traffic_through_tor
  9411. configure_email
  9412. create_procmail
  9413. handle_admin_emails
  9414. spam_filtering
  9415. configure_imap
  9416. #configure_imap_client_certs
  9417. configure_gpg
  9418. configure_backup_key
  9419. encrypt_incoming_email
  9420. encrypt_outgoing_email
  9421. email_client
  9422. email_archiving
  9423. email_from_address
  9424. configure_firewall_for_email
  9425. create_public_mailing_list
  9426. #create_private_mailing_list
  9427. encrypt_all_email
  9428. import_email
  9429. script_for_attaching_usb_drive
  9430. install_web_server
  9431. install_web_server_access_control
  9432. configure_firewall_for_web_server
  9433. install_syncthing
  9434. upgrade_golang
  9435. install_gogs
  9436. install_xmpp
  9437. install_xmpp_client
  9438. install_tox_node
  9439. install_tox_client
  9440. tox_avahi
  9441. configure_firewall_for_xmpp
  9442. install_irc_server
  9443. configure_firewall_for_irc
  9444. install_irc_client
  9445. install_voip
  9446. install_sip
  9447. update_sipwitch_daemon
  9448. install_wiki
  9449. install_sip_turn
  9450. install_blog
  9451. mark_blog_domain
  9452. install_gnu_social
  9453. expire_gnu_social_posts
  9454. install_gnu_social_theme
  9455. install_gnu_social_markdown
  9456. install_rss_reader
  9457. install_rss_reader_gnusocial
  9458. install_rss_mobile_reader
  9459. install_hubzilla
  9460. #install_search_engine
  9461. install_dlna_server
  9462. configure_firewall_for_dlna
  9463. #install_mediagoblin
  9464. #install_ipfs
  9465. repair_databases_script
  9466. backup_to_friends_servers
  9467. intrusion_detection
  9468. install_final
  9469. echo "${PROJECT_NAME} installation is complete"
  9470. exit 0