From 1d97f1875cf24f0bb2b90815e60bb8e56ad7f332 Mon Sep 17 00:00:00 2001 From: Michael <12646562+mbround18@users.noreply.github.com> Date: Tue, 9 Feb 2021 12:29:26 -0700 Subject: [PATCH] 16 ability to change steam userid (#18) * #16 - Added PUID and PGID environment variables * Disabled auto labeler for now * Fixed timezone issue and updated readme * Readme changes and version fix * Removed Labeler --- .dockerignore | 1 + .github/labeler.yml | 15 --------- .github/workflows/labeler.yml | 11 ------- Dockerfile | 31 ++++++------------- README.md | 27 +++++++++++++---- docker-compose.yml | 2 +- docs/assets/install-menu.png | Bin 0 -> 16215 bytes docs/assets/main-menu.png | Bin 16383 -> 28787 bytes docs/assets/start-menu.png | Bin 26020 -> 36997 bytes docs/assets/stop-menu.png | Bin 0 -> 15533 bytes src/cli.yaml | 2 +- src/main.rs | 6 +++- src/scripts/entrypoint.sh | 37 ++++++++++++++-------- src/scripts/entrypoint_root.sh | 33 -------------------- src/scripts/init.sh | 54 +++++++++++++++++++++++++++++++++ 15 files changed, 118 insertions(+), 101 deletions(-) delete mode 100644 .github/labeler.yml delete mode 100644 .github/workflows/labeler.yml create mode 100644 docs/assets/install-menu.png create mode 100644 docs/assets/stop-menu.png delete mode 100644 src/scripts/entrypoint_root.sh create mode 100644 src/scripts/init.sh diff --git a/.dockerignore b/.dockerignore index 3c65effd..8b0eea56 100644 --- a/.dockerignore +++ b/.dockerignore @@ -2,3 +2,4 @@ target/ tmp/ docs/ +.github/ diff --git a/.github/labeler.yml b/.github/labeler.yml deleted file mode 100644 index a737907d..00000000 --- a/.github/labeler.yml +++ /dev/null @@ -1,15 +0,0 @@ -odin: - - src/**.rs - - Cargo* - -docker: - - src/**.sh - - Dockerfile - - docker-compose.yml - -documentation: - - docs/* - - *.md - -github: - - .github/**/* diff --git a/.github/workflows/labeler.yml b/.github/workflows/labeler.yml deleted file mode 100644 index ff64b21c..00000000 --- a/.github/workflows/labeler.yml +++ /dev/null @@ -1,11 +0,0 @@ -name: "Pull Request Labeler" -on: - pull_request_target: - types: [ opened, synchronize, reopened, ready_for_review ] -jobs: - triage: - runs-on: ubuntu-latest - steps: - - uses: actions/labeler@main - with: - repo-token: "${{ secrets.GITHUB_TOKEN }}" diff --git a/Dockerfile b/Dockerfile index 7cfa2437..a035e4a8 100644 --- a/Dockerfile +++ b/Dockerfile @@ -31,11 +31,10 @@ RUN apt-get update \ && apt-get install -y \ htop net-tools nano \ netcat curl wget \ - cron + cron sudo # Set up timezone information ENV TZ=America/Los_Angeles -RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone # Copy hello-cron file to the cron.d directory COPY --chown=steam:steam src/cron/auto-update /etc/cron.d/auto-update @@ -46,15 +45,6 @@ RUN chmod 0644 /etc/cron.d/auto-update # Apply cron job RUN crontab /etc/cron.d/auto-update -# Setup Directories -RUN usermod -d /home/steam steam \ - && mkdir -p /home/steam/valheim \ - && chown -R steam:steam /home/steam/valheim \ - && mkdir -p /home/steam/scripts \ - && chown -R steam:steam /home/steam/scripts - -USER steam - # Server Specific env variables. ENV NAME "Valheim Docker" ENV WORLD "Dedicated" @@ -62,17 +52,16 @@ ENV PORT "2456" ENV PASSWORD "" ENV AUTO_UPDATE "0" -COPY --from=ScriptSanitize --chown=steam:steam --chmod=755 /data/scripts/*.sh /home/steam/scripts/ -COPY --from=RustBuilder --chown=steam:steam --chmod=755 /data/odin/target/release /home/steam/.odin +COPY --from=ScriptSanitize --chmod=755 /data/scripts/*.sh /home/steam/scripts/ +COPY --from=ScriptSanitize --chmod=755 /data/scripts/init.sh /init.sh +COPY --from=RustBuilder --chmod=755 /data/odin/target/release /home/steam/.odin -RUN mkdir -p /home/steam/valheim \ - && echo "export PATH=\"/home/steam/.odin:$PATH\"" >> /home/steam/.bashrc \ - && chown -R steam:steam /home/steam/ \ - && chown -R steam:steam /home/steam/valheim \ - && cp /home/steam/steamcmd/linux64/steamclient.so /home/steam/valheim -WORKDIR /home/steam/valheim +#WORKDIR /home/steam/valheim -#RUN wget -O /etc/sudoers.d/sudo-lecture-disable https://raw.githubusercontent.com/Whonix/usability-misc/master/etc/sudoers.d/sudo-lecture-disable?raw=True +ENV PUID=1000 +ENV PGID=1000 +RUN usermod -u ${PUID} steam \ + && groupmod -g ${PGID} steam -ENTRYPOINT ["/bin/bash", "/home/steam/scripts/entrypoint.sh"] +ENTRYPOINT ["/bin/bash", "/init.sh"] diff --git a/README.md b/README.md index d1b4b818..dcc250fc 100644 --- a/README.md +++ b/README.md @@ -10,6 +10,8 @@ | Variable | Default | Required | Description | |-------------|------------------------|----------|-------------| +| PUID | `1000` | FALSE | Sets the User Id of the steam user. | +| PGID | `1000` | FALSE | Sets the Group Id of the steam user. | | NAME | `Valheim Docker` | TRUE | The name of your server! Make it fun and unique! | | WORLD | `Dedicated` | TRUE | This is used to generate the name of your world. | | PORT | `2456` | TRUE | Sets the port your server will listen on. Take not it will also listen on +2 (ex: 2456, 2457, 2458) | @@ -17,6 +19,7 @@ | TZ | `America/Los_Angeles` | FALSE | Sets what timezone your container is running on. This is used for timestamps and cron jobs. [Click Here for which timezones are valid.](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones) | | AUTO_UPDATE | `0` | FALSE | Set to `1` if you want your container to auto update! This means at 1 am it will update, stop, and then restart your server. | + ### Docker Compose ```yaml @@ -61,7 +64,7 @@ cargo install --git https://github.com/mbround18/valheim-docker.git --branch mai ### Usage -![![Main Menu](https://github.com/mbround18/valheim-docker/blob/main/docs/assets/main-menu.png?raw=true)](./docs/assets/main-menu.png) +![Main Menu](./docs/assets/main-menu.png) #### Install Valheim @@ -69,41 +72,53 @@ cargo install --git https://github.com/mbround18/valheim-docker.git --branch mai odin install ``` +![Install Menu](./docs/assets/install-menu.png) + #### Start Valheim ```sh odin start ``` -![![start menu](https://github.com/mbround18/valheim-docker/blob/main/docs/assets/start-menu.png?raw=true)](./docs/assets/start-menu.png) +![Start Menu](./docs/assets/start-menu.png) + #### Stop Valheim ```sh odin stop ``` +![Install Menu](./docs/assets/stop-menu.png) + ## Versions: - latest (Stable): - - Readme update to include the versions section and environment variables section. + - Readme update to include the versions section and environment variables section. + - [#18] Changed to `root` as the default user to allow updated steams User+Group IDs. + - [#18] Fixed issue with the timezone not persisting. + - To exec into the container you now have to include the `-u|--user` argument to access steam directly. Example `docker-compose exec --user steam valheim bash` + - There is now a `dry-run` command argument on `odin` to preview what the command would do. + - You can run with `-d|--debug` to get verbose logging of what `odin` is doing. - 1.1.1 (Stable): - Includes PR [#10] to fix the double world argument. - 1.1.0 (Stable): - - Includes fix for [#3] and [#8]. + - Includes a fix for [#3] and [#8]. - Improves the script interface and separation of concerns, files now have a respective code file that supports interactions for cleaner development experience. - Docker image is cleaned up to provide a better usage experience. There is now an `AUTO_UPDATE` feature. - Has a bug where the script has two entries for the world argument. - 1.0.0 (Stable): - - It works! It will start your server and stop when you shutdown. + - It works! It will start your server and stop when you shut down. - This supports passing in environment variables or arguments to `odin` - Has a bug in which it does not read passed in variables appropriately to Odin. Env variables are not impacted see [#3]. [//]: <> (Github Issues below...........) +[#18]: https://github.com/mbround18/valheim-docker/pull/18 [#10]: https://github.com/mbround18/valheim-docker/pull/10 [#8]: https://github.com/mbround18/valheim-docker/issues/8 [#3]: https://github.com/mbround18/valheim-docker/issues/3 [//]: <> (Links below...................) - [Valheim]: https://www.valheimgame.com/ + +[//]: <> (Image Base Url: https://github.com/mbround18/valheim-docker/blob/main/docs/assets/name.png?raw=true) diff --git a/docker-compose.yml b/docker-compose.yml index 848187cd..34396b32 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -2,11 +2,11 @@ version: "3" services: valheim: image: mbround18/valheim:latest - user: 1000:1000 environment: - PORT=30017 - NAME="Created With Valheim Docker" - PASSWORD="Banana Phone" + - TZ=America/Chicago build: context: . dockerfile: ./Dockerfile diff --git a/docs/assets/install-menu.png b/docs/assets/install-menu.png new file mode 100644 index 0000000000000000000000000000000000000000..4de998e7232301ff921678ed1072971df4c382d9 GIT binary patch literal 16215 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 LMTt@|1ONXIzvvk` literal 0 HcmV?d00001 diff --git a/docs/assets/main-menu.png b/docs/assets/main-menu.png index 1f6b990e968e32f5b21d71f5f66e86523a59fd5f..712d9b1c54fcd47bb8b78cc682977f5ee269199d 100644 GIT binary patch literal 28787 zcmdSB1yEe;wl#_bcXtSo;BLW5aCdhJ?iSo>T!SaLySqCC2=4Cg?z|@Z>~r?nC-=Ya zzW2YX_ftjDP1ovP{jG1#Ip&yStYBGb5d>IVSP&2p1Tj%Tc@PjV8xRoC3}{H;f7X(M ztAT$&?d3)IK}v`5_kd5{7=M!b1OieK3HPW60elW)BdTT(0)p7}`U~1;o&OmG#0FYS z@ROpm_R$iIv!u!k)al94XCZL`v!ZvX#AEL;^eLy5m4Zm#q34LhXg6WX6?*LHQ`XSe zs2D^FzEPX}dgD=aoukMSJWG}F4k0A*v(fX-u%_TkQc|MmX79}exy()~^UY$_;?{?q zWt0}%nf`i@!Vz4wIag1*@z|7F4TF8P)N#=?5hPn5)ks@hn27S1AdX#6I0Mi|>! zhJ7W$d4;0FYymgs-?QCJM?GhS-c-@Lz&57}~1 z|8SYggVsWQ)X~`8maTXZQmLJ0>mm2l?X*iY4xUy#(rHeFB-C{N_|pJ*POjIIkTz5^ z*NOEEn%@B5B7A;QNpN_#SX&Q05~Fe%OzUZTA*qU0giC9noQwnu@oUn2dEagDW#&8p z-beZ%vi#@Tt$x3AamZo-!S@7Rc{i+&=5!2|!rRN%44V^IqCca*!uE7t9cq8#*|DFk zxrZ)YX$!TlK)KyAB5-yQy?b4)k*F~c>AaG#Qc}n+9z#%mKR4Z>_y=fgW{{uhXy=6) z3+bsg+`QmKUl4lMzf0T5VNWYiSnDt4f2@Yt4KvJxH;r@yrTY@dP+^P&uj5AG>GzOX zQxj|G&wt0YP9n3OD?cwvtky_aT%rfTYDWa=ag#Az6%d|MEeibXOZcQjpCUibQZ;te z2e{IL6B1TeqOXUGvTgB+DtL5LWd|3)Gxp2g6{uI;{a$fnLuUJ7yeFxoU+|sUjJE^= zWznPy25G{`#~XPKzSrd>OoDE*(9IctOE04?NO#VnTwaNyqwy(;kNyLai~3%TT0_5* z1bv2&aF&1NXorp%S8xM(ubx5Uud`8vO@vOFHYZL;17r0#jf1j$<~AoT zr>^;w2w?}%Rf5(nAzEgt0fZ~jP0Cz85&*ZD+!+JPmmHESUsBu}b4YSLw|a;cn6hM+ z{47m#sC7OWf4qNC3KIp3=tx`A_ekgJEE)_pY+&`6%!ZJHC~mBtEo$ zkJZ0(?Y~24)3Foz-ule{FwntMPOV*(7?O=nnFic+yEsg^?Ub=eL5X$Prj8=ILYu-`jK|ivu>!1U6yeOYFe0ay0TA?X(y~UJxcrpszsP`AIKVM8k1k z8rKjoT@cVnzw8g*HEJ2M*Q6DCwb?Y67Lry$;#dDfM&^`E>*Je3a`OOyIK;20ngAYPk1<6?i2wcfkG@b?~dNA@ex^ z6#q43hyG_F`?rHt(cAZ`pP?7AXjNS2@ftg28llB_MDRr1t(@+Ro^tAAUP<_K zOhD%Kp4u%#KDDs_3je`K@7mINPO}{Fz{^Eu-1a@(u;Mum%=)8(@nX>D0r z7~=R4W_l0Y&#rR2LAJx7Tf&%SN0hJdE}tgWD{L$%jLIT=hfB;Ec65H8X2#~(Sw;rK zbyZkCunCr=zQ+E+gyZ~nB6sdux@EiDY1H3 zEO0w&wad$k81jYmG$Rc=R!MjU#cwUO5+tL8hrwvj<4qWjw-Mmmz<(x#a-Ni0+(v|b zn7$3>Q@t5kn%2EHSO7f)z`0YmP-?eSPV8x-j_sp^%WaKmgxMDU>R7}3eWSF_iVJzR z*Vv*oW>VgM=;@k^!`}*{;7!_D=FyR z0j^B}aqdij#MQw)Q`w(sCkU?#))4bcfVGHKk(YtxB_<8ddT^{Go~^2aZ24Q*sInPe$7fKa|$%(6`=vTr!R-=kF6O`KZw~ej?yvI{5VCi?W;GtHX6AdNXf;AL> zO+t&Qt=G!3+w{zTBqtcosUqxW)3=o~5&Zp41f$01UTc$H+{FO7C-M+wiC&5P#`BBYm!q`v^q)Gp zHOR=Axk{{0vTb%$&sBTyl~ZP#cP@B{EBSsZ?xCaaUjyQOI`o*hi*ubBz^wM#2FVrf ziq-4w5fbHKzGAkvjbPT7pR1n@km}Muti{CyFemghe}42V1;efJAW*U#=pxO=;I2}z zB@<}Ngu$|5?1Fjr(NFr7^2{VSI7`69<6x=IWF%#wKjl5wAd0qm^VxBaRu+*{sn4a~ zo1bLb)=<|cst4_H{raN$(4dP_nyoLmxg{(95Jbv7!8t`0h&3z=qbeKAIMeupo3Rh(+h^0_M%e*w-P>>8)(fvh4bbkb?*x26H zsix4Bh`(NHamsz?yYmcs;5m}utbyyiF57>HHvX2n{%3hl7@R$&mSi~%E!4lB{V^6f zQp>jUARoqApeSZpk7J~R8kwger}}g1NR$#kkN*+e)$C<(TdbKb)rs0aA&ybwh=aP9 zzhy+9j6T=;7yX@W!`sH2qWn|z`+Kp1)+Mi)SSa(gt=*su&L=hz)e2LMJ7nALR&nbPMlMq#$Zp z&Q6+kKhXP&Pa<~O`y6h4DjDrkQX>nlj5e;!nS=+qy%q*|3&nG^Y!@gQ;;A2S2s&R; zWr$tu+vQwSQ#NU;^0iLi*IPOoqKed6RY zM3j*w728oHhk328@uBo#m}&rhlWV7Xzk=f(!fjd#Y1-($`}z?Tjfv(>f5TinYuPdU1)rvaO&;wkm^8Vyk!xr0 zV=|T3bQ}>N_Nq%53?G=_ZN}8N5y_T#eOKtF0-Vq^y6mnXPYVbUOY58c& zQ^gb5u=)7#7ivWe21Ck5^E%+}FGZ@_D`w-6Bj>aR4<>{fAxSGt*RT>VyOb?b7YSP0 z=7Ww7$g}*C=A?l^UzrZAz)j!YbBs)Oedx1hUe;x8qf=drN#7VZw&#bedO{Go+8(ic z^^@1+QKMa^e=zh;l23w}d!Ol9`ceI*(NfpRy=kRfyFVRi)j=Qf-r+a^h0iEsE+5pS zr1H_%qL3~(u`INrRz;xh6VIBnJ0$NRZb;9El+|;8w0O=E)?{4BjE2E9QLY%;oNwow z8@eIEwM&%K4XhPmM$HqJBS*wKDXi1@ndQW4r z(8q*7!JK+4733N3IJR}2X7%4aRDa3|Hz+?=H>fsyrsxO4cdDWggTHti7-3|zLQ=MCljpX|rT&u$sHji$Pu=wK?>E4*Q;gISjr)()}HJ)meo0QBI zrkYM+nqN@8wwC&OX49gJ3t?tRq&jiRLMgWo^ox&b*5sc!Bf6h`4{lE0Qr;ueVKxS) zjGis9AI@X=A;f5`-$yE(J(bDFi^=dJZYQ%Ry}=t%S)+R+7p`;G9ycLk)6{S9xj6Mo zcH{^W@r2zUZ{JNcbk1*Li+iNI~$zeiFJ zhgDV{&#b{HPAv~~B+smPFavjhwT+gal-*J5m={)8RPR#H>3zaCoqH2HPj~--?Af%6 zSQg)!|Dca5&7BBC6VE75Dq|0W2L;n%-t=*g9$jK01i1m&&BfWu@BrI0o>AjoFn>n} zA&59k4k!EWyZAn%OsnMvC@ym2W{V&Ij#X9U2mkq2TEUNxU zrt;0)ENT<@_q^LYTi?dIz-eI7wOiA@bXN9XC7zWcj;)lo%Q4rf&{{QZ&Y+1oS7`HmPUQ`0 zBeEz8GEhVYFu_G%wDoO4>Zzi&U{Ld23m6TtJ<`M$QO`iwU)CwrkxW9J!h};OCIRc9 zVM=C10(~CmFO;9Hn(Fh~l4q{}H@*1(tLpfF*ujjzwxRkbBc&O}vyuuqZCz*V(I7*6 zPkFJOIj|3yAu%$BuMHUKn5`Z5o{q}9xp%gZ3hJx$q?7mc8K~hQ8$uGfyteFgwMUsA z#t_%zNtuQKPw3moyH$PH&2zgDR3UW{C-#a+;(r1^C+=+dw8KUsH4rpKfWi4p$QcPQ zV3=Oq8rk{5b$vLFI)85o8Y8=1x^20?BR{4V8QiZ)|FrYs6m`aa(irZT`0U^dv7W+u%(KRO|7(>=oMC54vnqCb&g!fw zg1S3;09_ep2j&MG8ahz&s_eN+yYMxI2h^`$QUnKh=vhu#-+@od0&(;pGYw^|8hec~ z{qQ2qBF*>h>$HAR84=-a9!dak_wC*p$bsa^Zj+ofjg-?Az&5&9;A(Ul>!}v)Bc=H$ zu%3Nt8LGOy8c|@6Q7625GCP>KFz0gl{>)LAhRUWN_Top$?$*q~cs#~zGbpf@`qI$2 zGOd5<-I0iIuO|NXk8@@RCx2tRk8bgu2a(9(03fz-oPI~Hx2x6_wX@I;C(7%`EW05( zF2wHk&_(R^mMrKc6K(!YSXTs|yzeq!st;Z{{7$Sp!G{K_NqEiz1o6(EQU$)^ zad1~2A5}_uIh$X|%-}vH@yCR3d{@?8nQF{Gq2_&21`pp?0a#8%2So(;Rvy=6oSq6R zcyKg~1{tdFNubYm4R7<>Ig7*s-#UL(@{LUayHf!wE@U$#`FFegi96cKHa8eb6+m$l z;wb{5ua6dwoLJClA*&f&TOm$;GT9~vOD{EDLb<64xdZ%u7$QNQZrVH?0&b9D?&_kD z$SqWBKq1?;%>gnrpAeIDUXTmmRGer?s|8-c*GwGdb@z=BWq~H&Lio|bC6N3yc%v+A z)m}{ZWtPW{!_$ZV_T(+5)B@rg>E6gOjS6>7@a(d0K2txul@y4aKc{xn>obs#6LzdA z)SjN(V+{;-=iW&~sT*U*3tM$NohY?0t4a8SoOD=@dvSx`M6UQKa3~7KVNqw<^_W#a& z@LiB+M9-0tT{0K0nO|#9U#d&+=T*L;=ad0E?o={J8>2=UR zg#1rnSoksWsgkDFI;QfItz^K6Q2&erj9*JeRx9FrMK>1k%%WLL9m|OJ#nhUd*!7Hw zd)>=M=f`)$-Q1500bXsE`4a7Ib$V)iSWgFFExd#pXzMR4Zi=NxjC!8znRV7()29v4 z<~y)CEL~auOf+FpAD|2tIKg|^9}FzqI4$iZL(~CYQ>+#md6odmg#vb@^+~dMgQJD{q7mg;S~l*w~90epso2 zGv#`_hZI`~MDTT+F4&_SZ~U-y{Ob~LGCimAN=+7;0!q@V1-@S|ot*_}m@vA&Ro4ji zk$b*&>?&9C$~@c6Fwv17Dk8D4M%MI73ykyyT#+2FrZ9q^HFl1E7@$tbFu#S=^lvqr zuO?(FTO7>`mD~!3-8c7Z>bEx!2FdVxX*&qQp{~x@5J~(}j_N9f9Td>tMhD!FRVsyG z?6&bn>zy_h6C>S{eeFg8N!Zc<-fTeI`lS9Mco~QMkHmxe4okNXaKO64#M%G7<;hVs zE|VNHEy|3pBOOP54y7jKHPNRv{4>$=l@?6(-?|_edDMX$UriN<6iS{1*4R?;+g4dU} z23A`Ji&hqdyVi7b%fWtS4Idr2Q)0Qe2QNrC%yEc5+S z&MI2BnIA(dYo&Sr3Vl&?$h^^vO&cSy;csFgpb?IJ7&VSbb%#J${MaQF5SAdX{5Q^U zZp+OnFjpLWLs`~xWS6@e<$O%gMsWtEamER6z%&mL_4G#wv0JY>A0cmq4*KY}-{)%@ z+)lRoXKRs1+l{~>xaT;i3cQlOBjwq$Mr)I)E$sFR7N21wQl`^;MD%vg3(+iW!TZ)x zZJ3H|m_21mcNZoK2C}SVshyXlJAY8?5AZEGK{P2p2EAxv4Z3q9^$Vm5LrnQGQk8XB z2RfQewjeZ@5_WUAK~W0mQjM7Cgce7+u0j{qz_&}ti~Ce_)R)x;)Ra_9zET9SnK9ZA|7ooFU{HuKNcj zPk6g3v#EB^d(13g(g1oTg;)zT`eU^!7%9d*dNaecs@y|x1qWX2yp83Du4PVRuUi z!{_Ej?oHF28KW%{71|bmNZfGL0g^gSJlnJ_H%Piu`)=x=P*kl5&EA{L?BJ{s@3j1@ z>e`+^-9N6k?fSEUZj_U*Y-qwd!q)yI3`Addxu8hwmmxTNWA?>avc8)>gO@?X|@ zx1IxLp?Cd1N)fqlefrKfq7Hp1F832oAg{zn_^PP0c288WPtZW^W?t6WIjewo zw;uy+@X@j^Fy*Jm<|5iOwF(izvKLwnfI=YSNAH;wb@_>z)}+^A{OW{(t6RXrcV#57 z_c^dsK=S`4$1s>5dob(??<|dPaqWl}adP8m!ZZbieUr4gKHKHpoQ9~$=@A#XG(ec1?As#G`4*7p; zo)B`=#~&g}G`snL*4DE-id|N(*_oS>GRm0G%;}Kq>tROEV)C{$%GVx?0C3$BP^iDa z^`=uMI&6ZHe_9Lb780qWy)-rdouKp-ZVftS%wMK7lGjuid`5<+dKo*a!uG=ZpkTX;7J6S$S z^-@h2-l<|*-^smgUDS`(;hmW@oAzrA^h*h1&Y}U6$vOhXbCgCL{Dv-3aFbg zEs8H<#u0mv&_pe`Pt2LYr7{iC49H%Qk*;H<;;@2|ncI2-buEo%2umc2Doz7vRpYGQ z&EeLqkm}$^S4cWy+#)g-k?Y(!RmWb2+Q|7j95`NAn7|!6;YBT53u|bXm5t09lVa3) zUJ;Xr<0OeQzLYzS@!rJ!gGcm%m5PIpn1>f$6&TXHwUqvhS{CVx_Z1&!TT2qJbwBjaTbAj|Q=4Pz=8gA4u zt&e`K>g;IvVw4I)wxOo)R>n0WDJt&=XJDGwBjQRg>;bIHEA;%VYXnIL$JJXW@Da#! zl*RBmQ^Q;9$SgM4L9n*qW%y1blkUGZYyaMb;j+P}5acwk`K`rsBY|@U>YlELo?>2T zPnNy%(1Ks}8vun9%0i^pBH8aBu~fL-N4wPryrCAgDs4XRcxoyXMW0>Z4&7Tp4exI> z73S|}3lDUF2QC0sw{iNZPCK#s2=SX2YCtM$w&ZJYjJxgE$vV#C znkcqWS$vNWbdY3;cPv8y1b+CopXN6R5Y7S)hM!Bo+-Bz%MTU9wTI{aI)}B7dX+U41 zf3v_}sRnx}ofdiutkZd&v56{HgGj&jb0PwhjJL0$dpevc?X(><|x=+9snP zHHjg1=r}w1PFWReDgreEKi*P)wdEA*Z#)25StZ7vokEK%E|x2i)3{ao*}lbM%kzWU zgTd*FNfM@z^8Kp@g2yWay}jW|^?dh^ea+hQWWU^OA3Sm>=637TY7UQYSDwY%)(#?o z3GMqf{U@^&JyqNWl$Dl0QXUvL1p0rG@*+NN$)YG}7l#dC3`$VG?l@pq$G0i*`Y2~Y z!RuG&8We){|KW(YpXpyBja*=dl+rmZly@aEyKNJ8>2mGpiK%FH#Av&w-hCL>F@4H` zy)cb4idjm}4ORB>vO9i!d_qn(sfSURS3sEoBjJSm}WSS&to0@W|Jhd`i)6wGt#G5TJK|4dL7t zl3YrmBsV1%9_t5XBUK{Y>ouc$+?i&hZP?E`ZCn_!qI*;Nh6cU>0BbEZ-u6sM45s%J z-m+}Ans2*!&NroktAbe{r}c0j#+UKoeFcaYBw+Q6r_aOJbiBe zRz0gSR*E@aaafXXEgKRLa1znY2NaylA0&jAlK&*}Wc>X2vQQSfflZqEl{oZOYZ74P z=h}I83-3P5iXLjs*&#%17|)>KIA%&s?0kz{pOz9D>FcH|`I(N>|4O7Qki0p>rh?BO z=ESM*l&CbLqrKI6K^-^>%qsy9f(yu6y(H`sEF!IFmH0HW$>&;R|Bg*UCwriw-)4TI z`FWZ@c*}KW{&Z05vvhXkS)oIfH33CjzRZQ$;X^QX@ZDqdw$3{(>6t|-w*$_mg3CXc z$4&Qk{@@gE5vv5i^fU4(25n)~v0Jx3kLF{(>h?dhGH)TFdi$0fQtw_jnVenUONq?f~dRLHT$&y8P?$ zH1^s93Z^NiXw)mdcYN&RgZ}(Uzsb20%o@E9lAyFKxCqtiYnGf{=1-OK&F5xOMVNFF zQ#^7bbD&NUfQ^+6mDQ+ThtJlHlFFcIHqpfDO@g{nybE~O- zDtK)SPqjCgH^Z4X3OR;3$-Gw*?(6R;fuF~Y#aBdUA;y}$!(^y$? zqTKL@9kn)D6(4z#-&BnI(9i~6>O}se@P5FBZKgiCJLd=dvFIX(mNY(m!eMq*DiyCW zCS-b}PVBu%)WLnzZ>mPE9%5}WsvY8d3I=AckyU0~$|>^V1&|NVhe=_elP3aI?N`L3 zF*I#UBuUtqcF^*CT9Mmibw=>ycUwNa5uDEu{Cwa?Yj4R=tAnTF-iM9Cg8@#0zpTFeMUrvm$7@)?GIGdE+)0W7esLZvP>q zVf%iF{i;EA2o^8w_|vCdo-GFam4nFDZ}Qs;#x6YJXoEv_^m{ij#O0$pCQ{)|1Hx|9+RJ?IVibw>Mk`g{=@tRL;u$V}E#BD#XTaL0evb}+qn3qu);i4p^G0>xrZ zUL~4^muCA@Lx8l~9H{5fsq8-2d-~D(j8Q4!U-Oq7{;hx~29GhDYWLe}hyThGM51JW`Zf`bZcA^ucZjY$pWkj#UJEne1-TobLe3Pj?=v zAFWp(@XZ>t<_%6{g!UmsSj@wZ&*@<<;~IO z{s3lF1*{{vLq26fgk>+R(6_1{r>)>BciG3QZ?Sz(0thwMLs!hD1Qg^^{?M2qu5f2i?!~sU6$cI0Tgp!9+Rq5=1!<*O-xc;*0X`O zY(G)u#7liCdxTpVDF#Rp@byG+r?RAB<@P?gER%1Je<7?BysVCk1}TLhvw-OdF9%gs zwivnR=4uSlVzf5!a)v2my(wK&?3R>#JVUq3ky%k>OTxX`aY>7kSa4ZHm9wQn`z3)J zyAUMP(SMyMWJ3KHLe>9=jh2car=^BuxJD4~)UC__?!~bR7ekY|%Pu;*e=SeGT^-4lsMS>1p~<_kd!4pvDvxb-iK_&5LrXT~XWi9KRWC3{68^ zLMAZB5VJb<57{a9Uf0u^DdG2?v6=V?w@-Zo;5~A=l<`(&3?XihL7Nev_!vz^NptzP z`mE_jN^dXdsFZ6U3OO?6w-Gd>m$T||B1ak>d-|_-a?n>NGd+Q$rl8<6HTeP3-1DG; zO5cdMOsWW`;C$!T)^}h%%M}Ph-h3ARxKs|lKer-i_edhCeGB(2PnGQyi|@9we0v_F zJLxp^Nqo~Yf90aHz*C@nyRg%Qr%L-cJcs(*#!jUFjUk1&0#}L_fSv4LIQXdG?iz07_Y^Ct-me zTF>prwOY+GTzS3`d*i#-2%Hm65G=2De{=BisS|RC+Z(ydZ*`y^Jb)Crg6_SX4r~Hj z5%r1mGx7sQ%&ODnV$xsVGEAY-L`Gv2m81a#dl%O z?zu8~O#rR5K;3yy0iA^t9)P-a-AC5X&>l|+tziuyDZz|PO52y2+xDp1gGhxVeHlvXDpqh8Ns z3i#Xy8fhGZGpD1F_YLe1W&hnZ_3&R-h5kwM{MS&Wc7z`}aWX(^P|CvF>ST3Dv^ zDfdRp;6cq4m#-qV_gc$-(^ERP@{=;N&G0a%Khjaa@y15F$pwSrAn8WN6$(bBB%|e~N=vf_`r)Pq9 zLPVWCUYGixt`sS%$_-A$nirc9H2u+%M!rkQKAVtq-FUAYNN&c$z3oLFpNqJxuj6Fns-U+y` z$+jRxALY*)`&fj5=@2k;zZIC4e6oJ2T~T&IOsl?YJ~e3LrZ<>7E3^+?HBlTNdbQ z^})uu4=8_yy9)b5rDORe?bKW3sLlWCIk0H|p}x`>!ieq`#*~V2MAB>d9xY*fgmgoh zZ9Ima_{kN~!tzLJ8z{7%WhvznrsE23J3rpgKO7NNp7J-B>N4wn4S>nFDzuusMQ)j? zRp7_?aD8okW$naLXO}evY^t2cx#%KEkizrEc5d6(RpU&a@hNbG|6Fv+*d_)>2H6*w zy)hl4A-<m_%b4Y3FM@=gi7pmdU zqH{UDtc&#uaKp+o(Gh&M0zj=?T$RlR66HeJp@vsiMlM&O+S7~7LhdNnIp|e^Cx}di^{duksDw+`Y|KX zabg;A>eh!9=YOMOHH$QXg&-nP<&oeUdl5HEQQj~Li8tw7Mbs%=C!qE8Y+lGmoBdC1 z7U`Q%pf)SFP0Kvu%s?UU>SG!X9P;!S28RDC=PO=*IeRf033pjw>vt|;^YT<`d|B0XAvkg0?vGUyL1Mn8lo;;Pf5q(I} z)C|=F2%0pTVuIORchvHBFP%P1P=ICn`6qP1`EOyZkmvE1sYKsZG1eJL=>}7E{Wn7Z z)wNpvb=@e@R-co!o{_!Ze0-@V`Ln4|KM&x9dl3znNY54_fNo zGxN~F24ghpx(rEo_tABD2adV1(Jfl~mQ7oBuD4Fv+U=Pg{-9mN#-X36CfAa2M`X5p zzNue)3vZrTr@z(b*&j9+koI$kJ?KDaNGA-vE<+U;$EU|nyZ4Oa0>xv{!At$nJ$p1) zvpTgFbAfa_z0D>}i>kXgsK7uWL-G^a%#o(!xSJ;4zYP0wHILHBh?R)HV>Cp$Qs?4e{=cm zrYKgOQ>~2y^t*ty!T7_4P2nVj`sZLMzVImK2CVIEH>=l~PJL`N4m+Ro%+L1LBl4WB zak0Fb9=!hR6stOgqWD{JMUS7d>T>!Zzxb3{jdSlM#oPj@>F7&rQ3Mq z|5bL;dG;p?7E-|NTN?KqQ?de-=X^)OqmB@v!MrY{+KS~?F!*fx03_0(l6|O&^DwVo z8Gp&Jk+1TpA7)UPYYFDxIDG8yTe~efGjU&RsEjrK_E)9zW)}PF8&{YTdb2e;!|#ns z>(phKmx*!YgeLc;09W%B3iCdg(lU3?MV@I0cUYa6*0)aJ)0>Xl>P{)TH$3?w`vUQB z9K5}wTw`@dJtI-3izU>iHWy&`j=6lho7U9w-#};<)6q>Te@UH2IxdqxQ(H#@@6(VS)|9iGapzH3)2fkvCnQT5~Q8rns|{qF2P|HE#`@00&7LI$lX?lG4Pid z;1t;26VC|hB;>xLB=t%9#yWEShuipaCFm=RkQp6~K;>I+qz93dmbUk{ zFsgpSQ2RJ|()|rKK~_LkIY%|Bw9={H3E(P786qq2L5&9IiKA9W>EqupD+gNDjiyiG z#s}d(lX=gL4LT-e8G8fZv_8Jy1o9Z7ewLuKJC%pQ{mAha;W%`9T3$Jrx}J{H^8Fhm zBCwk(`!hKkq_E&2p}_KI6ACQ~sUm2shpxoQBCdcZ8;ml}Q& zc0??B`5eXeIkmvkjHOWzcYO3C;Z*^?vvrTZ;LVmZMukHmzFZ&3bi>^C4?Yw1^(V{AwGRMKH{0!6;<#vW6Tw|8^0uKAhdYq5EI zPC%?7sKP>3Gu`im(OUVg%RPH7`bnLxWBf^fSag)g*fTcjY-i)j5%6+vyt_I$6045r zDUtruxs#3m+S)@@kD9QIngQx|;mfWD@71th72$@he^Z2`8wCi{ZCL%NkbgywHm@wH z!itdDCGWerh733W~TJ}XJpPqTaw&P^=Znc$H@Mu}4f5^aBSi!ryqxJ4iW;ZgBgV?~y^7N-c6b^Emh zY~}JCSqop;Jx1&P0-S#K3u%{L%DdCXo4%)whY2uV1)FaPMO?aHi@9@)rqk>t>Q~y? zeJPVIL}AT9>lIp_rvHAu`2eJ3e@8FEvTBee*w$^TqAa8XCv(;LWuX|w7TH1_F%i+y z2i`^*%oS`@!utuf&Og=JTVc_t@eE5-Wp21X2`Z|eOO9|;{$$D2 zTUo%}CcQ2!C(COB&GSC2<=lardWouij{XZ$LG1-sKfA7nx*t;YE{`b9fBQz_RUqzy zyBS<}PNR(3%Y#vXg+G?B#mqi8+eIsyFCmRPtQlWPoAFOXqVR`W9A3Z^B0So(M^*;t z=Ai;k60aarZ5mxbxNa8X3p$ERj5PN(ND#8gV*ws);tEQRusR?%?JB6*o< z{{{u-*RgZn{)P@?&W@vz9pBKN^rQ^BZC3w{{^QyXLmXHzZsc5l1 z$7?7SgGD%ZUWMlB9m!W>wa2g^p!Yqpkdkoufyke%>SbT{CD&9-wy64 z@m6Sg!qK0G2P90Nj@0f~!#49!!cs%l?ILD9jR%EMV|nvufj(Cp2NI>%4sja97JEkBy&(qpp@5b`agO&Rll6mlK(H|&gZYx! zQtFPpEm++VjTE4NgaANBZuT8J;0>HQykWS==Xb@5Q`QIh;5kUKDY*yWAXlPLd9Vz7 za($y6v>VE(QI+k)ED4|)b`L1wWgT*CSfFqkmgfk^IP-TJqNJrR|%u#rk}d6wbD;;k?UR zzQ*!-e|H-wKQc04TQ^v$bGDvF$$I)~n0b^tp9lLb#2@AP{)Q)gVyUxqM1bMR`>b`C zb&TH7W6^Ow1oNuq_$YXmxAnaR2CT=Kx@kQ3R$nW2O*O0IXw=TI^e07*Ss@sm6 zPFKMq-?6SIn)tA1{Dm^Abh{I88NOr6*gX)bYmRrN$-#4Or5}MzSJnovW!qyUDM{wz zXInU>jAma0<7a*?YrdySj~JEJWIJ3a`>W9R)c+c?4Mxz8j^5EA9yd`ZAO3F0D6p4F zX7^>9*xlrV0}&CFP!r0ntjSkt4V)BSXrHU)3TVW`Anlbyzuq>8$Ksyam49gz#Q>t+ zSAXgoG3x5Jc)@z%KUM|Sk?DAcE)h!}&VhH$Xa}yWwwln!-qGw;Qz_b*hkijgv>|@4 zBu-neBU!VQzIwgY;~oGs&0!Nd;&_pJmUu0(m2Nqa%5xq9`6UXb*U8?CdnQCrs9g6xy)V|jZf4R4a zK8tf;xdlo_*m1@RI=Wu-`TUm z1jyLJ4hqTTo!;+OUuR z^n&qEx~KENLXa*w5)FfEZK7c8=YnZ2yW;v;y8D88k zxfg^1S1=l9hInq2IoPI=`Y#pdCa2F$r^DR79xB-m*{e4!BDXCYq2g2+e|oWU;`VSb zQl`N@jA%Zpil`{cnnv4y5P3|FiOA`boH+us+TiOiN6AhkVyW5o)IYN zbTb35MXq~3&9D2JvPQ(eYxUi~Vx^Ud2l0feFBuz193onz-a}ehYXCf?vh`??ng-%aQ>$`R1UzXW{Cp?dhK!iVBxZ|V9&Akgv zLtzxjs}asCklVGj1atlA7JsAss&ER?!Er&K`6p;d0{$!ikP40Y*G*VP&^&QcUu97L z)m>Qr1_b{18Z`cYqF)UA0V2IMO^Ak7Dl{~VZGn*HS7Dg~T7vjb!^PCzO5Q~6A4V{t zp$nkA$@vi-E7X71a<xK8VSpPDAeGypBuQLX6JRQc#f1$wGoO$%Cthj(IG!!0mJ-;5q?RIm~g4&FD2!sw^;uyvDu5k|%* ztSv}q6Ev9kDz^J9&S5IG@x%{=c8aJ#Yd5E*Ve{-<_PZ?=$c%=uEbnx1@H38nS}bZOg2mqF8>od1ZUP*}Xa)hYFEq$r;ZF+D`Y(_%FMB7X|o@Jrv;7b|_J(`G0&sudBxweOz zB;yMGe|X(ofqpDX_Alywm_&e#!6NDM9t8YQiS{2ffLQBPX(d8OKlP4_FR0SmCA=?P1GvsdAP8(g3cMb`%;e864|K^vA8^8LkPoZA7RfnbS zMNrt4lZoj>?3cbzCK7lTpo}4*b*D5vHF*q&JAKw#|B=peqRex;H5;>EkQfzyy#ms_&@7+uslm~mYZA}=QOThom5}=q)$^$-Ai{|PT z9h3m+9&%%jaYpQAZa$l=zA%7L7J* ze+p3zpD(|ALae$>|EgUSGJceR-`daWda%x{MV_KynPYD?g}Bx#3BAA9i26@)KlC@I zYwK>WXPdyfy7~f5lkTfx_&d%LX0Ska|GJ{!=!p%N^&=_jILL3Brg8N{(8%|?L6tAvpK%w>tLc?M;L1=dF~8ktRu&cOXb6osMRG?_ zvb2yZa+JA5%t!dHvEJ0fL@-t^g{D|h5ojLxVYPraawXIbYy7{Erw(|n{-N35e8`Ck zbWn~P%eUrg{+i^!vB&TG!!x>h9LipWzAHBU+n<;55r-YWJJWQ*r~St*qbqfMq`CK{ z5_37HnmZy5oCYSH(6>J5;;=<;HLb&Pw`<@Szu53C4|oD{xDwhoQnv| z@})jP!RIxEqvvy??D&}RNYI4%xr6rwOJmJHVg=SRNISwd{H1fgfZA4^a&khjjXT{g zKZuH6S$HetzHA0)Swi7adcDJ#kUM)guzCfFfBiwv_^Py(+xy?{WX@#bH#IG31x_U_jBSOeXi#6S%wx{vj$g*e`dQ5EbA8HegCVO?qy+$%LX&8psE@ewOAUl&~XRsOHq&O4sUKJMcwBV?3u?3uDhM~OHxEA!ZU z9(xnAWhW;jyEtU;WF2JZ5VGg(WM(TPA@jLt-0pHe>-9W;`|G;S_450DKjZzaBx{Vd zleWosgQJX%igK01Em;N-L5y>-Wv#DTj=euwOPks9Ldevu{vu-IY8-^3X3!UzplBFc zaoh(U^p1`KVtrQoR&3INdvdD}_UDrsk1w-A#;9_M=MM?bf4fQJd!6n{#4U~3b-90# z)b^r-Za~*O)#q@Z&th1lg|$Qye%ctN2L{JzW_r^p3XbWucVVW+G>)dF;1ObuI|`NhTuW>~SsuRCrT9>>3M^OY5Q zE!s!yJeUmnzthWuug!cG+jYv^Xhf?7Z}L-@T%=#B9oUjMbwqy+#jTmOy=|aqgac)F z^swZWzJu;5vbUm96;pZ2JGC}~pY)mB)tkMnaIi-f*Sfg9SOq|h6W zICH`Z8}8Z=76hu0?M-+ZiM&*6n4k0^mzDMn|D++m5|CML&VEcj@j;Ww>(QjVgM_?| z0rPowk$EQ&9?(y=E72+yMN!Q?H~>|QdQO>)r)oZE+FLV(e^&?$hR05(QxN7hzTfgF zP({2g&SEm7?v0whi(`ooKTYd2sx$WAV-@Gnqfzl$w!Zd=W8r|5a@-L#i z*&!4v^4=p2jzGvsl_R;QDxO+Y1x|a%sF!@9sY;p8lX)H@v%vibG(g)xrps znYJYMlR*k!sr|2uCkPeb(Pr66WcB+|Aln>1yQT2XiRqOTKcY)Tfkb8}(i8YndNZQm z*Vmi@RZGMVm*4~!)ezP-c=!CJE!?0kzPifjAbJZ#kF`}F->U0;ekme2Xy+~TBKKwp zUyjCu3%ir-`n1C!`?v;kf#v|Dzm86+wP6T8TaGgO9~dpSYqg;+X=i(`q<~|SqQeL;{6~=)kbe4v@C8|ozc#Fd(AqvrJgu?^pM2^XRGOfhILBelhntt zbVO5|za)*JQ73u~7D8XMJ0r2Zt#A9uN3D$YWO&3x>eZGhRCRK_XFQv zh_wa7lLCb$R`@t^zepWsfPb}7>*KstdJ!604vKKgXDyGPehJJGR%xmBD=z*cJU&x= zvmI905h40w5qFcFO-@`=%s_eRt`U#DF*uYj-|4M+=+0=FV(`{J6Z67qeqcu z<}3YDXy&3RvWC+%1{Wx0+0wYO*fa$%h)g&*5YF1{%C?>Bjd(j{5ldCkDQP%vPX=w; z$6{-V_HPmUu0Tv(sOenQuFF5{&lD@vzKNx_B`IQ#gBBzY_l+>{lc4HD%*(~GT`O0N zH`dbIIK`A`%+h$ao09X1vP*^aRIE*+al)S|?lV=%v_qUUq5D`vf!9=iR8Ot% zjrd>vV8BUV_mZYBV@BAhRurN7ZYwKizXKSxu?_{Ds0k9O>}q1HM<`sPh>XT<`G$1$ zWVYkUE4C0dNOt%qK_hslFpUn8TmOM<_S~U^nm4`1W`2DKmMEkAps4nKZUXqgh9a>Dd#Vj1!9LdXij<$aya!Wu(i*0H@JN|$fQ@*eq! zbJReNEg4qj{NifI)?D9K>8PERDEQORA+3~tz|aH^$D7HO&{B!e)>|H$JFM$x4w$$gF!i@FP`==GuvwJOjo1;bZhdn-SOl44>Z+F3eyFKH8k1A zrUTy!Dtg2HCFjP`hXNLU^6vs}`0C{c-Ci%|*g~|v$&qXZ zamchskS+?(Z!ocsb)X0=pMI3Mf}wl5Wwg@~`IGbGWr=+vwPN2W`vs@>Ao6u9lfVi( zAn6%czg$g>1s>vt544B=PM(mMbbg>&1Ai2Suu*A16Jpt|^zh8Q==sY;p1E9vcyI)U zg(cN+sorR8W=3M6(|0NGX8ufyQ>^3N7bfNWr`>du&Z*a7_I0!#rXs{Aw!9%a3ZmFr zCn~>UZf5aM)rts#@ZABvg?I(j${c&j(`^>4=j*HIEwQ?mRbRa8E@EdTT2U{6%2ViU zrBpx$_HHzkJWU9xU^} zK%=8%4h$Ww5Nw+pRmAh8%b#8$2nov(w~s_0`7W#_#Da&Ox^~3D*8v#EI!x3AWz*F4 z4N`O2UN7YBdV?k}1?IyoHdo5qwXq5P;P+l-y#CV@j*H(`FI#Dg znI;Zr5~bJ^%2 z&(u}!;kPpl!BEvglD^ev@6ba8+(_b9>Vhqo1dJL&)EvdBbc&NNegQEz+p@+=OB=4G z#5sC(dP$C7`tsPw<~_{{>Nm<@_N%dGUrZzO8&XUo)dHyUyl=e2JRR=cpJT?hkudkY zQlndTkY%2zFy${`rsl~8jgtFUwi?lWXu*56%lh9ywFoWz=R!V@Y2DFrh%3og=_Y-y z7!VTdOfH2cLBD-e_7XO|T9|;_>IHcbz*F_+kxIL0i^eGT?WQvdt|m_SWsi^sQ5P22 zU7OK2n|QYGcn^>cH4ZVRo-d&=LEZOAp72q>frb?0HF**>`yc9y83nI&j@WKbrA6?% z?@D3YUsKC8KL)n8y_|y`=W?p=5q+-W@7k{ zDTvGm%>9nr_p-aVi}jUAR)fpu58v2Yu7C$d5sYT

FqV2Q10lJe5h+FF5q^P{VS$ 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 TONj#(1)jMlr65@-Zs`9XvV;>a literal 16383 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 OgQUe3#PXj$_xXRY+-f=i diff --git a/docs/assets/start-menu.png b/docs/assets/start-menu.png index df78cb4e062c6b5ac32503f8ccf33f13444f8c9d..20663d5869a56f4ec95bdf9faa3f4b610cc9149f 100644 GIT binary patch literal 36997 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 literal 26020 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 diff --git a/docs/assets/stop-menu.png b/docs/assets/stop-menu.png new file mode 100644 index 0000000000000000000000000000000000000000..c15d3bfa7910221aec30f69975c939d3ce2c513a GIT binary patch literal 15533 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%0AL?Z&|2KMviP^6J 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 b3$Gi05GCpwmkjKRG2AN&c~GI4zR&*ww|;=5 literal 0 HcmV?d00001 diff --git a/src/cli.yaml b/src/cli.yaml index 4722c314..d46c9e5e 100644 --- a/src/cli.yaml +++ b/src/cli.yaml @@ -1,5 +1,5 @@ name: odin -version: "0.1.0" +version: "stub" author: mbround18 about: Installs and Runs Valheim args: diff --git a/src/main.rs b/src/main.rs index 7e1bae0c..dbb94806 100644 --- a/src/main.rs +++ b/src/main.rs @@ -10,6 +10,7 @@ use log::{SetLoggerError, LevelFilter, debug}; use crate::logger::OdinLogger; use crate::executable::handle_exit_status; +const VERSION: &'static str = env!("CARGO_PKG_VERSION"); static LOGGER: OdinLogger = OdinLogger; static GAME_ID: i64 = 896660; @@ -28,7 +29,10 @@ fn setup_logger(debug: bool) -> Result<(), SetLoggerError> { fn main() { // The YAML file is found relative to the current file, similar to how modules are found let yaml = load_yaml!("cli.yaml"); - let matches = App::from(yaml).get_matches(); + let app = App::from(yaml) + .version(VERSION); + + let matches = app.get_matches(); setup_logger(matches.is_present("debug")).unwrap(); diff --git a/src/scripts/entrypoint.sh b/src/scripts/entrypoint.sh index d53b1920..24ba60d3 100644 --- a/src/scripts/entrypoint.sh +++ b/src/scripts/entrypoint.sh @@ -1,29 +1,37 @@ #!/usr/bin/env bash +cd /home/steam/valheim || exit 1 +STEAM_UID=${PUID:=1000} +STEAM_GID=${PGID:=1000} + initialize () { - echo "###########################################################################" - echo "# Valheim Server - $(date)" - echo "# $1" - echo "# STEAM_UID ${UID} - STEAM_GUID ${GID} " - echo "###########################################################################" + echo " +########################################################################### +Valheim Server - $(date) +STEAM_UID ${STEAM_UID} - STEAM_GUID ${STEAM_GID} + +$1 + +########################################################################### + " } log () { - echo "[Valheim]: $1" + echo "[Valheim][steam]: $1" } + initialize "Installing Valheim via Odin" -# -#export TEMP_LD_LIBRARY_PATH=${LD_LIBRARY_PATH} -#export LD_LIBRARY_PATH=/home/steam/valheim/linux64:${LD_LIBRARY_PATH} + + export SteamAppId=892970 export PATH="/home/steam/.odin:$PATH" - # Setting up server +log "Running Install..." odin install log "Herding Cats..." - +log "Starting server..." odin start cleanup() { @@ -34,7 +42,12 @@ cleanup() { trap cleanup INT TERM EXIT -initialize "Starting Valheim Server..." >> /home/steam/valheim/output.log +initialize " +Valheim Server Started... + +Keep an eye out for 'Game server connected' in the log! +(this indicates its online without any errors.) +" >> /home/steam/valheim/output.log tail -f /home/steam/valheim/output.log while :; do diff --git a/src/scripts/entrypoint_root.sh b/src/scripts/entrypoint_root.sh deleted file mode 100644 index f7fa4bc9..00000000 --- a/src/scripts/entrypoint_root.sh +++ /dev/null @@ -1,33 +0,0 @@ -#!/bin/sh - - echo "###########################################################################" - echo "# Valheim Server - $(date)" - echo "# STEAM_UID ${STEAM_UID} - STEAM_GID ${STEAM_GID}" - echo "# Running setup as $(whoami) ...." - echo "###########################################################################" - -# Change the STEAM_UID if needed -if [ ! "$(id -u steam)" -eq "${STEAM_UID}" ]; then - echo "Changing steam STEAM_UID to ${STEAM_UID}." - usermod -o -u "${STEAM_UID}" steam ; -fi -# Change STEAM_GID if needed -if [ ! "$(id -g steam)" -eq "$STEAM_GID" ]; then - echo "Changing steam STEAM_GID to $STEAM_GID." - groupmod -o -g "$STEAM_GID" steam ; -fi - -# Put steam owner of directories (if the STEAM_UID changed, then it's needed) -chown -R steam:steam /home/steam - -# avoid error message when su -p (we need to read the /root/.bash_rc ) -chmod -R +r /root - -# Launch run.sh with user steam (-p allow to keep env variables) -sudo \ - --preserve-env=NAME \ - --preserve-env=WORLD \ - --preserve-env=PORT \ - --preserve-env=PASSWORD \ - --preserve-env=AUTO_UPDATE \ - -u steam bash -c /home/steam/scripts/entrypoint.sh diff --git a/src/scripts/init.sh b/src/scripts/init.sh new file mode 100644 index 00000000..21aab4fc --- /dev/null +++ b/src/scripts/init.sh @@ -0,0 +1,54 @@ +#!/bin/sh + +ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone + +echo " +########################################################################### +Valheim Server - $(date) + +Initializing your container... +########################################################################### +" + +log () { + echo "[Valheim][root]: $1" +} + + +# shellcheck disable=SC2039 +if [ "${EUID}" -ne 0 ] + then log "Please run as root" + exit +fi + +log "Switching UID and GID" +# shellcheck disable=SC2086 +usermod -u ${PUID} steam +# shellcheck disable=SC2086 +groupmod -g ${PGID} steam + + +log "Setting up file systems" +STEAM_UID=${PUID:=1000} +STEAM_GID=${PGID:=1000} +mkdir -p /home/steam/valheim +chown -R ${STEAM_UID}:${STEAM_GID} /home/steam/valheim +mkdir -p /home/steam/scripts +chown -R ${STEAM_UID}:${STEAM_GID} /home/steam/scripts +mkdir -p /home/steam/valheim +echo "export PATH=\"/home/steam/.odin:$PATH\"" >> /home/steam/.bashrc +cp /home/steam/steamcmd/linux64/steamclient.so /home/steam/valheim +chown -R ${STEAM_UID}:${STEAM_GID} /home/steam/ +chown -R ${STEAM_UID}:${STEAM_GID} /home/steam/valheim + +# Launch run.sh with user steam (-p allow to keep env variables) +log "Launching as steam..." +cd /home/steam/valheim || exit 1; + +su -s /bin/bash --login steam -c " +PORT=${PORT} \ +NAME=${NAME} \ +WORLD=${WORLD} \ +PASSWORD=${PASSWORD} \ +/bin/bash /home/steam/scripts/entrypoint.sh +"