diff --git a/README.md b/README.md index f125eb9..f3ce6d2 100644 --- a/README.md +++ b/README.md @@ -45,8 +45,8 @@ directly. #### Infrastructure & security - [Authentik](https://goauthentik.io), a self-hosted identity provider. Acts as a central authentication system for other services. -- [Tailscale](https://tailscale.com), a VPN service. - Allows secure access to the server from anywhere. +- [WireGuard](https://wireguard.com), a modern VPN protocol. + Allows secure access to the server and home network from anywhere. - [Bitwarden](https://bitwarden.com) password manager, using [Vaultwarden](https://github.com/dani-garcia/vaultwarden). diff --git a/config.yml b/config.yml index 6e921c8..90631ce 100644 --- a/config.yml +++ b/config.yml @@ -227,17 +227,17 @@ traefik_acme_dns: env: CF_DNS_API_TOKEN: "{{ secret_cloudflare_dns_api_token }}" + ###################### -# Tailscale settings # +# WireGuard settings # ###################### -tailscale_enabled: true - -# Subnets to route traffic to -tailscale_routes: - - "10.0.0.0/24" +wireguard_enabled: yes +wireguard_vpn_subnet: '10.5.19.0' +wireguard_peers: + - KianPhone + - KianLaptop -tailscale_auth_key: "{{ secret_tailscale_auth_key }}" ################### # Homarr settings # diff --git a/config.yml.sample b/config.yml.sample index 08792db..41ec0be 100644 --- a/config.yml.sample +++ b/config.yml.sample @@ -206,17 +206,12 @@ traefik_acme_dns: ###################### -# Tailscale settings # +# WireGuard settings # ###################### -tailscale_enabled: false - -# Subnets to route traffic to -tailscale_routes: - - "10.0.0.0/24" - -# Use Ansible Vault to put your encrypted auth key here -tailscale_auth_key: "{{ undef() }}" +wireguard_enabled: yes +wireguard_peers: + - TestClient ################### diff --git a/group_vars/homeserver/secrets.yml b/group_vars/homeserver/secrets.yml index 6b20cf0..c5c2eab 100644 --- a/group_vars/homeserver/secrets.yml +++ b/group_vars/homeserver/secrets.yml @@ -1,139 +1,134 @@ $ANSIBLE_VAULT;1.1;AES256 -65613039323635313866393935363764363966366431393735376461646136623664376162383034 -6266323537353566646563626262366439353461366636320a643639626438343235353536653331 -63346131316132643364653436613164306534376465313132336361376665363565383034306237 -3831353265313465370a303633666362393832653964353631623932653862343933306163653735 -35663733383365323161653663366566353831333830656336353535613233333762353335373837 -65303437306363326338616638386236343730343161393935613330356165623161636465356630 -62323330633033306534383934313434623639666262376139333635396432363363326439336161 -39333763383539343332303930313961623935653833646537633737643861623838376631333930 -66626665636362303731663539316663326365343332626137396233663031623331313364333334 -30623336653836363765326162663764326561313234383532343962396238346663353262326166 -31626537626634313430316132653366376564373962323263376562326462313863333331343336 -66346238303832393137646436323263616163656237356631363735396237363930376664626635 -65653131613736666132643065663437353632383237633932303863313764366639373635623637 -38363463393661353330623164313030323731393564623565383330623330376233613164393634 -35333063326438343435393436393930313931373661333330643132646432653336613533633531 -34346136663139613637336266633235623438316361646432383136366366313935616439363336 -34643933313634343839383662323639636631613966383337616537313864303264613434386461 -36383032393430396662376438633639326437353162623236333263633835653337346262313935 -63653836383962616639616463643037633739316433313839373864383061653462326330366132 -64656266323531373836653337663063663931333762653165333939313738613830316137333135 -63663163323065666362326230376262613630643063396436333434386562346235316238316366 -37623762653164386464373163373064666330353937626166646438383834363165396265373134 -37613965383138643762363062306536333333663133323336313266386338613937623666353164 -63633734366238653630393137373862376535393332366437353437626431623066313338623161 -66396530666464306430393862643733346461626662643730393335383930316562303064633136 -62393830353637356565663966633265633934316131356661336239656231356137663532643633 -39356265663665323734393437303165646335333361643231386330613066333236323132343636 -30396566306461356131323930613863643833646535343837353366653665333866313139343732 -33383238356164643237383834323538633434653439373565393539343032343336333836376261 -35356337633437343536343432396535616136323633353930643639366165346430666665323663 -35613961323265363166656361316364623962373366626339303137386663356665373063353337 -35656536613938303938366663356232383634383433646539336635373230643438363935656638 -35626432653739623465653662363365663261636136363536323831636262643266636466353737 -62306239643662616439346630643632643339353862623731393839373065393563663965623939 -30393238633834323033646536313236653639373832346136326434653865643961336634333662 -32383362626265363639313035616133326435616437636238353161366465326366346535313036 -66386161633337613433306538643033323830356630663938323533393930643233633734373234 -35366131633166623535393662383235633661626234393039316636663538613565393164646232 -66386337356139303733633335366233663161363333663238633039373539323561303734353664 -38353131636463333632363866326532393139643361653633316265323731663332396337616130 -30366237636364643032366539306664343364623862396538386432643735316431646665616536 -37393335356663366237326630336536366337333238646531666532373035353665396565613333 -30616262356630616264353436386236626362363761393934633830306632386537326466313836 -62376634363137386531623265356466633066306333633063633035343430643033653262653364 -30353139356363643663613831373238646135633737623462386162376330623964613534666530 -35333530633263386161623030333533326539316335666563656636653331396231386230616261 -33303236343632313865633538633764643736323462333735656364303464353565663862646466 -64656638386336363065653564343232303333383832366266356230306261646133616263356561 -65633632396130636137373136663035653632323331343133346232306130646133663233323763 -63373836346538373763626164623166393833323435666665323732353334343933626432626337 -62336662313135343735613364343038343838373039613362363164643561646263303032336339 -66663064333833636433316239333062666437333532623066653132366130626163306439376335 -38366266663839353361363634613333373065353238343636333731316237643037626566646361 -34373435376162376166333134336431316366616634396364663139623861393261316636633432 -37326461306633326166636465343134663833343031656530303032333964663433613063303762 -65653261386661393436623032333430306362376433663036666230323661373631376536306362 -65303732623762323431333963333464663861633865323039346331393135356536366533366361 -33643132343039326464663362303361646138316437333565316362656534633866636638306162 -34633761626637383962303265383332656335396138656639616632353436333531303261373433 -63323939613734383662316535303334303338653831383532343932643365363339663765376561 -66393332313265336561373132326438666433313330663332623238356230396230653937363165 -38363637643239383263386266316530623335326431313065626464306162333265326430323536 -36343434366366643963303364636531313539363139373938353837316536316564353232363934 -64623331616566316539646238396132623332653837346164373464383562343838643532376331 -32393131653238643031336462613031386633366564326330396331663530326435313434363439 -65326566346263613132393130343037303461316462626664626164356133386666646365623333 -38383432356536306631633936373930316366393239636366316331383139326437653261336335 -34376361633962373839353765366433396434666635663961653039346235636661356438636566 -35306461383533343430343463656632346434343162643530343337333737666637646232303562 -30333433613861653536346434343432666633386265316263326464643139376236326636356534 -39346236353764613664383035386433613039643539343131643365343366333532366139306439 -63353664666232323237626131643864613832316261396566653732656532336461666463633339 -64313838666430383832323161326266653862303438633632626231316333363135383937653861 -61373336323561623666383832323064303035613530316334663832383561393764343661363133 -65646634326536613338316330326532613135306464323862373835353839313632323234353565 -35653836333330616338653034306234383562613330623063653732613764396439396536386637 -35313534626664613938373066313935653564366663383737613332376535386234326132323636 -38613231313031663439313139393633383463646231646634653362373463346334643436343539 -66643135393265656334323234666163616233646632623634326135383064316437643838653138 -39623639393231343062313063323039353862396665306461383766393236373530613233643837 -37313231613362636338623438646637366631336539366435633266373537646234346666613430 -32393163346263303636313835353536383135303433353337653934666562376664633036393436 -36306465666434366532646261643435396562643963333039653662316530393263626536663065 -63643432626661313664376633313139363066653332343962643362323130656530386363343930 -65376564363866343839626536653136386165323362396439333033376335343164336135313362 -39653261613132666134303233396630643031633038643136303830346263393139343365353139 -63383632616232653834653561313964616239363761393438303737306161366538366266363233 -31616666356639313065326564333365653764346135353932613065633365306335646563393261 -31316433313534643035333732363535623462333130646332653566646235633938363331616334 -33336263623731336166636432346634363337326361633961613632643465303937646364613339 -35373534666637656638333330363234343232303665653039383062633364396666386165643936 -65663636663962356435316531623832393162623436386334316134336239303830396438343662 -63623531336636373631613963663135393761666337326664666635353966626332353436653235 -66633363366535653866313434626563346233613963353638313535336639616366616463663265 -31396336633533326564396161303365343239633731663165313364666639623261653537663632 -35613735376264353333623536373365393830643165333434666566626366636638376264333966 -36343261653864633239336339326461633538316139396431623962323836623361653362663738 -33643566366234386639376234666664333038303439393234666539363262366361373962326537 -37313632323530653462383331353534643935393935343464343634383738303266383033656162 -31336362346538333464333834373763636533313234643832376232313532613561306337633666 -65363461316535613537623635346535343764333464316265626139626532636164636132383233 -39383133643931333232663736643538386431386131383036376531326365333238363432373732 -66343666316330666630366231363337623938343536393363653064336137623933316264313137 -34346132346563633935666139353037623066623236353362356235356133363062336530663566 -37373631343131333838303737313338313139393865326238376331323232616164396638653463 -38313032613962356135376430663237396439363464356534356235646233323965353064313632 -63393936633232636466653838643966396533333836653065656337373761343839613430393733 -36636339623639366566633061306136316635306234623634373134316264306532613831313765 -64383035636334653834623131363562343334343062393165336461663663653136656431636338 -61613834646133643536323336323938613936633231326536353130363639326561313739343562 -62356338303933376265333862653530343465386463363833613630613535646633336165386262 -37376361303231386434623939396530303462656661303539633734663835653836366131346136 -65393363666534626565343237343730336363393831326332333138633261383233363936643834 -33616436643338643935383137393536636639393434663435616263336633366538376535626464 -30343233653239396635333465646435326161323231386330323436313266643937386332633039 -35386233383262366566366438373662346531623061323433636138623863343737373235613566 -31373262396136623763303434353566663365313533363162353734313465336432626535356138 -35303638366432383365393364383965396330363635303130643365323566366633363530633861 -31646131643834323333636266323730626637353462646663653766646533383236303131333665 -39653839396137643334633965613733383831613832346237393432663365623234303864303236 -33666138356435363738646632633430386537643638636162336232356639326531636638623336 -64343065306663346436393932363462656236383531366365393637326130323033373565386431 -63666538613462393431653632643234623765366365623137643934656433313535363661636335 -39346661386532623964653538356430626638363864383466646630613065363435323464356362 -36626661613365363332653061353234393031396364373164633038633564336663636561323339 -38383531303430643635616439363462343735376432346437626632353737333130333066333062 -31356664333933646630323861666134636466353634666261313938363965396665616137346131 -61323564356536313531396435363662353832343763343639633464343633653032356665386132 -36303762303033386536343930376632656162396630376435663063643263386237386366663163 -32356331326237346131356636623930336262363262643632366663323337336233373461316239 -65626164306137316636333036353435303364316463343236633964346535303166353263313634 -63663336323336323064343761376233613136303836346663313938316133306463333064353666 -35666533383731383537393634646533363934633363313838373834613065633762663134326338 -36376264326434343231626536353032363032373362626536646466313330386338623962303736 -37663866366537323762323663306436373136383133353533656565333030373436636262396562 -35353232303831623238363530663938663838636365326237613165326139316564303536656435 -62633930653462356464303336303464363637323630323261333530386462313063316139373934 -3234373938623638353163373038333464336433633663366637 +36336563643861646431313932336264343162326264393032396436376530663137626532383835 +3430313233316661623330656533343366323665313336340a326161326363313639306464616337 +38666664363831303866356261346238386465666462336532656237346530626235383163316433 +3135616432313632390a303933666335303131393262613463646162343234336432656166623535 +63393463333235393562343532383638623364613662613033393362396338326135383862343031 +65343732343562636662323732623464353730633061663065616364313565643432653361636138 +62636139313330366465633266343761346234303065323433313236366336353237656631623832 +39363964373838633938363163313665333565393232623632306334383132393731666463353062 +36333137323933626338633061316139643465303762633665633131383566363464326666306438 +31333961386238653735376435386161376431393965643939353436373462323464336263356539 +63626164643831666162663735363365653565663561613635623736306334653164383433643966 +65356365313463333634356433393335373930663666646636323865376432363337386530313135 +32306539613235353064373963363933343931386438623939346232326333333563356162353233 +32396333356565653264623862663631383663366362366436363437666336323231363139376566 +34343137313235306538353835663363363239663339316238316533396339363334353632373435 +61343961356631363361623036323363363865343034616266343963636336386231633036373430 +37626366616539306332303265633366313834386536633934326366396165303732326261386339 +66386665356333633365633931313130313036346131643239653261363530323432626537343365 +61613266633537636533613539376534313834663565396636353762343361363061343061633666 +34616332356562636366626132613132376136336264356462623862353932316463316162356136 +38366235306433316136373162346165636464626665646533646664616665633566616164333936 +63356463386664643534353534636531303036633939336164636337383233643962653966323634 +34363736333232623264623263643966663835346336396562613732633438393562363362306662 +34343135393534393462396335353463343364356265343536306139333636363835313261396232 +38643830633137323937633463613538333735626435653236623132653365643837333432376230 +61646536633436383432373232393162383138356163373839643365373334323665313536616261 +39306630353063363133616661316662613264633236626266393833626464333230643236663637 +65303066643561303533656131636236646663376434666463623934383439646465323736663264 +37393533393236303230316565386166613231666461653532663632373333613865343237316561 +30336638633035616530303538613433383163343937303033363265346633333666373263323835 +31336534373161626630346163653934633164393938636535313936643835393037313733343331 +36376234346563333938333336316334646636643734636366343532646134313863646261393336 +66366661663536633665663232666361386665353263306461616462396333626665663537633064 +39333963313764633339663136623531316362363337633061316634343336626239613764393764 +62386631393035633763663935353961316436636631653931663833326332396531343263326637 +66656262373237373732396366383063323963666231393561313232623334643166316561323136 +62333161393837646164636463366561646466343333666535666636323064366234303061353130 +30616163633035626366626131303938373233626633626161643966643466323465346330316539 +35663332346334393036663438353231626662383463373339336261353331386637303265336235 +35626133373265333939323763666536393739663038363561373432376266646666613364386132 +38386334633036626131353038393732326265323837333139363032616262636266636566336366 +66356633643238663633613231323762323339333861373563646438363037373666613638623432 +34356136646663613163393662373263633033373961666337643165353930336535633464323939 +63396463373235313332373935346437303830363861666163396234306333356665303136383239 +61396166343936343264356564373135623538613738646439383737613661316165313739313838 +32303266316162623962626138653737623531646364323037663433356633393538353461363062 +64336531333536393439336131393032313032383266653561316338383062303861653764396331 +65616434313564616664336563363264326361396430616262663638353665313433306162636530 +31643035396337333366353334373430323436326237393433333535653861323864303633336361 +62323462396430646534646665656266313564613832393139313361646335356639303430646661 +38643635323063323263396561663236613339653236636638356339313130306262633238663730 +39646237393235386338386664343331643765643732653261653731323136363033656433343236 +35616462363264313238356664346465643566373661333630646166653530613764383565303630 +65393937376462303139356661373464393439316161623934626637376334373330313163326562 +35363339323961313432316562646530313962323562346231653332353065613837663139373638 +37346330626561303061383634653465646564373234633165666366373235646261376239363165 +32386632383365313263353765386662633661666264666263343237313534356563346665396233 +35393633316638386437353635663939373431653333656665303661353363316439313863643465 +33343263623132626562383866383432653930353830613438633466663363643332613231303232 +32333935626537316135643532303565306162326133353936393765303261376236623064363561 +30656237663432616438663338336331336365616564373163623039343263373934656235393661 +34333039376661386137353234333132386134386631663565303964386334616136396236356430 +64356265613338363130306237643231353035363038613133363034643531373130353061613562 +65306164613436646636303861663134653535653232353839316162383565306639646131393733 +38326533353233316562613238323332363232353132333865666638376137663264396362626632 +66363964613162383431613331613235666438643138626362386635663537633033306432343634 +62383734623833366662346537363133623238663761356238663531626539643731613437383062 +32303434386330623130343136353030623166326234373761623065643135643231366433373862 +61363431633531363562356464303361326137313735613766643230303866616435653064336634 +31333966653831306261393765616262636631373866393632323134353235646338396565363531 +39363435633137326138323031643136373335633431353337393230316631633861383661353639 +32633833373337633239643337353539386633373066636235623834643763373663663361336331 +38666563326238643365353630356431643833316630383062323961313532313261313137646138 +61353637323338613164626633613835623962646432383662356362306138396533323864616364 +39333763306438656634643331613634333137636333393665623335386162653230613162616662 +64363737303832346465656134643936383239393330643762383464633532653436356361353263 +66313136653062313863343832323337663831336137316235626235646130323932386135346330 +62306366343537363333646536373835666132653330353736336230316534623064633961613833 +33383738393162336536313537353036323137313532353265366432363035356632383133313633 +65666563633461393734343433313763643865373338323331306366616435323831353663396332 +64323437633434343533323938663836666339616334323663663261376332643132653831383131 +33656138353334383132616338623831363633393934353934323931326332646531643235393861 +37353666623133663964303333643830393235653466326662356564626365636531383265356332 +63383830383530626533666165613166306639323766663935343533353533323262376461323836 +34633466346633613962643861333064383834343039303439633961343732363061623463623465 +66656430666436656632396565356538663866343431386661333734393731366531656338363735 +37636438663938633264346633643632613264616332613964316362333230373365383635613462 +37386537646634326234343562616231653064643734313138326162373663626231303031313837 +33386237653338366632333336646237636362386330353965376630613734613430656164383464 +65373761396265376433353566613232353163333537613663316335646663343633646361303335 +34376131356635393465633166643164616435643465346539633733376263396162313133393466 +63346534366136326564303933636231643066306539323039326432613762336434376430616437 +30306663376363656336313866353833666164396439393864393866663837393161323137326631 +64303537663438656537616166303133396164326363643438373566326239666139376236343738 +31633666303337363631343031376537653938366534353964613137363136366232363736383363 +61643333666634633461353032353763613037383834663461393466333739623266663038323638 +66383463386461626132636333336163353964346533643139666562393930353636303432303537 +64623732663364393837333033363465623164646461386239376232643466626638396262616239 +34363031373462656233613330623038356637623262646237373966366464376130393431333237 +38343962346435306535303337633938356132663335393566613130313263623361383161643938 +33633932646362323534333636626630326632316339353335663631363665656530333764616163 +33366137656363396336303865633932336431643765336433323561303237393634356533396131 +66336432316166613133393238323832353263376635656362316631386266386635303461393831 +36326432343034336263326466643265633561346631613661646330333766636366356431356233 +64666133653435313531346564623463623361343031656637303030636538346233626236636462 +63633434353531363731303933313430623539396533623066616462643136323763393233333162 +66323662376561336130366533343338373430656635313330383562313661366333396236666265 +39643533656537363964653537363864313935363165333038313439616330313763623430386266 +38356132366430306563623937323466633061643031396433356532366263643662353065313832 +33666137343039383737393238363039653762353832376266336530383064333830373037623064 +35653263306661396339633866343562653165613530373837383262323263346430373936373032 +33633933353739323438383635616236306266653833646636656330663865626362313931363236 +61393031393035613263653330363262313031323435666237373737633037393832393233633134 +34313132353438626436333536346464396633633366343962626138396466396335616363653665 +37306436373966313930373038306438323439356339366531333632393831656563376332633634 +63393562386164353062626233363166376162663130393839623837326233396430383933633535 +35313138343765626366353637393036666165333430323536613732633036363662373865313265 +34366634656463333164393539333763393035393832333139373935653838373735386633303161 +64363961353632306266323633313163303732323635653432353230363063363564383265353762 +31643834363633353230356535376434633564383136393139666530303939633539336438306334 +31356235343535303666386231316464663137363436396363626231323939393762333632383639 +32653165333963623439643261386665346337666430323062343532663432356639616362353833 +37623331323130346166376138346537623234356464633466306362613638653739356366366562 +64633063643130376264626432613735663162333763323038356461613466653162353832303431 +32353535613633303862326262626665643735393436363131616561643265326538626466356238 +34313834306161346332313934613036336266313430656466363262393832383063656632393164 +63386130633433636137303065326565633761383236646533653331626137616530316337303662 +38636137343938353162643766326237623333663866656238356234356166363133656635653663 +37313032626563383132626664613933653235653637626330336631356237316365616635663464 +39323039376636323233363733373164613531356239656164643936666365326532653663363734 +34623139316632613534323831346661356137313033366462613763316334343563333838653339 +39316638643461393039346634353639646465306566366162306235323561613636386537323062 +6130 diff --git a/main.yml b/main.yml index 857db75..7f7dcf0 100644 --- a/main.yml +++ b/main.yml @@ -74,9 +74,9 @@ tags: - traefik - - role: tailscale + - role: wireguard tags: - - tailscale + - wireguard - role: homarr tags: diff --git a/roles/tailscale/defaults/main.yml b/roles/tailscale/defaults/main.yml deleted file mode 100644 index e365022..0000000 --- a/roles/tailscale/defaults/main.yml +++ /dev/null @@ -1,8 +0,0 @@ ---- -tailscale_enabled: false -tailscale_auth_key: "{{ undef(hint='Tailscale auth key must be set') }}" -tailscale_data_dir: "{{ storage.data_dir }}/tailscale" -tailscale_routes: [] - -# Version/tag of the tailscale/tailscale image to use -tailscale_tag: v1.70 diff --git a/roles/tailscale/tasks/main.yml b/roles/tailscale/tasks/main.yml deleted file mode 100644 index a0856db..0000000 --- a/roles/tailscale/tasks/main.yml +++ /dev/null @@ -1,40 +0,0 @@ ---- -- name: Set up Tailscale - when: tailscale_enabled is true - block: - - name: Create data directory - ansible.builtin.file: - name: "{{ item }}" - state: directory - owner: "root" - group: "root" - mode: '0755' - recurse: false - with_items: - - "{{ tailscale_data_dir }}" - - - name: Start Tailscale container - community.docker.docker_container: - name: tailscale - image: ghcr.io/tailscale/tailscale:{{ tailscale_tag }} - pull: always - image_name_mismatch: recreate - restart_policy: unless-stopped - env: - TS_AUTHKEY: "{{ tailscale_auth_key | mandatory }}" - TS_USERSPACE: "false" - TS_STATE_DIR: /var/lib/tailscale - TS_HOSTNAME: "{{ general.hostname }}" - TS_ROUTES: "{{ tailscale_routes | map('ansible.utils.ipaddr') | join(',') | default(omit) }}" - network_mode: host - volumes: - - "{{ tailscale_data_dir }}:/var/lib/tailscale" - capabilities: - - net_admin - - sys_module - -- name: Stop Tailscale - when: tailscale_enabled is false - community.docker.docker_container: - name: tailscale - state: absent diff --git a/roles/wireguard/defaults/main.yml b/roles/wireguard/defaults/main.yml new file mode 100644 index 0000000..c18ea4d --- /dev/null +++ b/roles/wireguard/defaults/main.yml @@ -0,0 +1,20 @@ +--- +# Whether to enable the WireGuard service +wireguard_enabled: yes + +# Port to use for the WireGuard service +wireguard_port: 51820 + +# Subnet to use for the WireGuard VPN. +# It appears the CIDR notation is not allowed here; the container is hard-coded to use /24. +wireguard_vpn_subnet: "10.13.13.0" + +# List of peers to add to the WireGuard configuration. +# Supports alphanumeric names only. +wireguard_peers: [] + +# Tag to use for the lscr.io/linuxserver/wireguard image +wireguard_tag: latest + +# Directory in which to store WireGuard data +wireguard_data_dir: "{{ storage.data_dir }}/wireguard" diff --git a/roles/wireguard/tasks/main.yml b/roles/wireguard/tasks/main.yml new file mode 100644 index 0000000..73b6e05 --- /dev/null +++ b/roles/wireguard/tasks/main.yml @@ -0,0 +1,52 @@ +--- +- name: Set up Wireguard + when: wireguard_enabled is true + block: + - name: Create data directory + ansible.builtin.file: + path: "{{ wireguard_data_dir }}/config" + state: directory + owner: "{{ users.worker }}" + group: "{{ users.worker }}" + mode: '0750' + + - name: Get worker UID + ansible.builtin.command: + cmd: "id -u {{ users.worker }}" + register: worker_uid + changed_when: false + + - name: Get worker GID + ansible.builtin.command: + cmd: "id -g {{ users.worker }}" + register: worker_gid + changed_when: false + + - name: Start Wireguard container + community.docker.docker_container: + name: wireguard + image: lscr.io/linuxserver/wireguard:{{ wireguard_tag }} + capabilities: + - NET_ADMIN + volumes: + - "{{ wireguard_data_dir }}/config:/config" + ports: + - "{{ wireguard_port }}:{{ wireguard_port }}/udp" + env: + PUID: "{{ worker_uid.stdout }}" + PGID: "{{ worker_gid.stdout }}" + SERVERURL: "{{ general.domain }}" + SERVERPORT: "{{ wireguard_port | string }}" + INTERNAL_SUBNET: "{{ wireguard_vpn_subnet }}" + LOG_CONFS: 'false' # Don't log peer configurations on startup, since we won't be looking at the logs + PEERS: "{{ wireguard_peers | join(',') | default('0', true) }}" + sysctls: + net.ipv4.conf.all.src_valid_mark: '1' + +- name: Stop Wireguard + when: wireguard_enabled is false + block: + - name: Stop Wireguard container + community.docker.docker_container: + name: wireguard + state: absent