From eb57b63a1025ea0ec3f591a57e8dfd60aa281648 Mon Sep 17 00:00:00 2001 From: mag37 Date: Fri, 2 May 2025 21:40:24 +0200 Subject: [PATCH] permission checks, dsm readme, markdown (#171) * added check for docker socket permissions * added sudo-check to pkg-manager * corrected variable typo and some printf colors * and newline.. * DSM extra readme added * final tweaks, DSM readme * added markdown to readme * added markdown support to telegram template * removed container specification from compose up -d This will ensure any dependant containers in the same stack will restart, others will be untouched. * Rearranged where the url enrichment happens --- README.md | 7 ++++++ addons/DSM/README.md | 35 ++++++++++++++++++++++++++ addons/DSM/dsm1.png | Bin 0 -> 15834 bytes addons/DSM/dsm2.png | Bin 0 -> 29965 bytes addons/DSM/dsm3.png | Bin 0 -> 28946 bytes dockcheck.sh | 37 +++++++++++++++++----------- notify_templates/notify_telegram.sh | 11 +++++++-- 7 files changed, 74 insertions(+), 16 deletions(-) create mode 100644 addons/DSM/README.md create mode 100644 addons/DSM/dsm1.png create mode 100644 addons/DSM/dsm2.png create mode 100644 addons/DSM/dsm3.png diff --git a/README.md b/README.md index a8ec8b1..f751d89 100644 --- a/README.md +++ b/README.md @@ -55,6 +55,7 @@ Options: -I Prints custom releasenote urls alongside each container with updates (requires urls.list). -l Only update if label is set. See readme. -m Monochrome mode, no printf colour codes and hides progress bar. +-M Prints custom releasenote urls as markdown. -n No updates, only checking availability. -p Auto-Prune dangling images after update. -r Allow updating images for docker run, wont update the container. @@ -147,6 +148,7 @@ There's a function to use a lookup-file to add release note URL's to the notific Copy the notify_templates/`urls.list` file to the script directory, it will be used automatically if it's there. Modify it as necessary, the names of interest in the left column needs to match your container names. To also list the URL's in the CLI output (choose containers list) use the `-I` option or variable config. +For Markdown formatting - also add the `-M` option. The output of the notification will look something like this: ``` @@ -165,6 +167,11 @@ Change the default value by editing the `MaxAsync=N` variable in `dockcheck.sh`. ## :chart_with_upwards_trend: Extra plugins and tools: +### :small_orange_diamond: Using dockcheck.sh with the Synology DSM +If you run your container through the *Container Manager GUI* - only notifications are supported. +While if running manual (vanilla docker compose CLI) will allow you to use the update function too. +Some extra setup to tie together with Synology DSM - check out the [addons/DSM/README.md](./addons/DSM/README.md). + ### :small_orange_diamond: Prometheus and node_exporter Dockcheck can be used together with [Prometheus](https://github.com/prometheus/prometheus) and [node_exporter](https://github.com/prometheus/node_exporter) to export metrics via the file collector, scheduled with cron or likely. This is done with the `-c` option, like this: diff --git a/addons/DSM/README.md b/addons/DSM/README.md new file mode 100644 index 0000000..d786ba1 --- /dev/null +++ b/addons/DSM/README.md @@ -0,0 +1,35 @@ +## Using Dockcheck in DSM +Dockcheck cannot directly update containers managed in the Container Manager GUI, but it can still be used to notify you of containers with updates available. There are two ways to be notified, each with their own caveats: + +1. Enabling email notifications within the Task Scheduler (_step 6i below_) will send an email that includes the entire script as run. This will not include the `urls.list` links to release notes, but it will show a full list of containers checked, up to date, and needing updates (following the args included in the scheduled task). +2. The [DSM notification template](https://github.com/mag37/dockcheck/blob/main/notify_templates/notify_DSM.sh) will enable Dockcheck to directly send an email when using the `-i` flag. This is most useful when paired with an accurate [urls.list](https://github.com/mag37/dockcheck/blob/next063/notify_templates/urls.list) file, and results in a neat succinct email notification of only containers to be updated. + +This is a user preference, and both notifications are not necessary. However, regardless of the notification method, it is necessary to set up a scheduled task to run Dockcheck at a set interval (otherwise it will only run when manually triggered). + + +## Automate Dockcheck with DSM Task Scheduler: + +1. Open Control Panel and navigate to Task Scheduler +2. Create a Scheduled Task > User-defined script +3. Task Name: Dockcheck +4. User: root +5. Schedule: _User Preference_ +6. Task Settings: + 1. ✔ Send run details by email (include preferred email) _This is the optional step as described above)_ + 2. User-defined script: `export HOME=/root && cd /path/to/dockcheck && ./dockcheck.sh -n -i -I ` _or other custom args_ +8. Click OK, accept warning message + + +## Set up the DSM Notification template + +Copy the [dockcheck/notify_templates/notify_DSM.sh](https://github.com/mag37/dockcheck/blob/main/notify_templates/notify_DSM.sh) to the same directory as where you keep `dockcheck.sh`. +Use as is (uses your default notification email setting) or edit and override manually. + +![](./dsm1.png) + +![](./dsm2.png) + +![](./dsm3.png) + + +Made with much help and contribution from [@firmlyundecided](https://github.com/firmlyundecided) and [@yoyoma2](https://github.com/yoyoma2). diff --git a/addons/DSM/dsm1.png b/addons/DSM/dsm1.png new file mode 100644 index 0000000000000000000000000000000000000000..2b3672095d5f21154c30277b874d201c3dfc9285 GIT binary patch literal 15834 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 literal 0 HcmV?d00001 diff --git a/addons/DSM/dsm2.png b/addons/DSM/dsm2.png new file mode 100644 index 0000000000000000000000000000000000000000..3dd9b0ca80de884586b21ffb5737dfd86d9e6075 GIT binary patch literal 29965 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 literal 0 HcmV?d00001 diff --git a/addons/DSM/dsm3.png b/addons/DSM/dsm3.png new file mode 100644 index 0000000000000000000000000000000000000000..33b01fa4bc540d05eb8ad65deb79cc6315c7b37e GIT binary patch literal 28946 zcma&OcU%(-*RCBz^KF=gufU|lKX|-LdMFnYPz+m@!RFTlI60^&GBvzU|}V1ONK9`}f=&F9;NF1HW80jCH&Yti1C)D<_-w2X$3e;M4!zjn_Y?4;<+FDPXON{Yl{3 zUB1JsKkuhN+c^JeL^y5RemMP`0!Jmsp8d`?hbc@=dK|B;J0VLf3v2zX2mM==Y9I>& zIsIhh*xud__3SbLWvi&rsqW^fTw!+=!>4I=#Cam0`MvsSi9T%1q6evTR5{~>H%G>m zT~-cB$7yUzFmi#%=1~lE=~i6c3-h#p+RJ7i}w#*Lj%#Hm-HJ}t}AzbRm)Ed|3K276A$%9CSe zQ_z`iCJ0k=mIWd-%!G^^!th2J4MubJoC zKT+mASi%_SnEz@|sP7&QDwCshjJ4tW{T&*(wDCfD_Qj$rcj#RN~*HiVqvRN^VJ6`#CH8Mw){X*EXbtw+5oM~5|7(kJf9C^XvA52a4+${ou zew&1bHpv|g*=Z-NkTA32=KtEQ!-+T5yh!kgs^|$RjxrM)ca5mV5iHlB%DXJ@k{dUd zTs)3vB;8nJA}(n*zlu2df=+*TQV*Qcu(O)rR^#&6zw87k+}+md>7<{ph364jkqS|b z405>ou=$n1k@u?vm==dh@S05v@r{(`XZy(5u!eOcD-aQ!SdebRwhl_ixu!LtjW>Q` zYXp77bXv^POLNxhD~pf0o1QT)H5m5aua|>4V2I3U#EZb5=8!OrW67<`Fn)2V-EfEZ z@Y6~M3xyBtc1XW4vS*bCC?$I>7(r0Dg@H|(qp(StnVsOTfxMIZh33vYcw&O=!-7QJ zOSeO_B$sD)knf1Z(%DtdhUYA^gz>-*1@QE6s|eTIG|5%PA*VFpqgZZI>IH|k66Qi} z3yfL66WEl#2UD{4WH8$)-eNK#fjd>3IL%8{JMR^j&ACwr169HNe9A)rQ069@k{z%@X`IsF|k!V z0wG<$e6Kei$D?$(Wth0Lw$(unyL<4L@@e3n=H9O;j)5ybN8$&EXZJ%Icqx}dhLd0m z@&U4&j_>Z44>rBE#eX&Z6J&T8IOGCofyn#jKS75c2;t{0(b0m^yFWpPi#me{UG@Vu zu^0B8!Ah*l(*Yq#Es=?~g)kd!YaIbvxPk$(O2u9}00?70oi>2D^;5xT z{y*&M-7s0bt2HZp2ha=ddmwbak#nT`-{c6SQo-cZ_`S?>z@K3BNn()nMHo+*_TLd-i`aBzH3b8n zUPU+@Oww)6G%`}{F7p>GkF>c7jCX{V-BmbZKceoex|vuFj=*&e9LjaNxHu1}x>l}Z zR%WgOyQ+_DNe)@KmQUWDn;kB4dY_4;9_ui=%c5-;0;C*!z6##+F3kGGUz}F!wN&k} z_a;du{O%N)iK>R==7YR>`?ecHu(pdnLu?sKOK9}X)e-a^mBnm{9NE_!&s#}RY)8aV zl@ObylQAXPnTNkzXD3cHxfGYUcF(bJ5%-jjwzSg)q!-_vpM7VjS3&YXtyP$*74LEO zi1pnQ+$qhwuy9RxzbtKi$y(dkxO&)e^@>CP>lg6CTUObkKkHYb&E0BV$JD!@T_n_W zj|OaR`wn|pUq5DCsi?fgX!}O)@MKH-nwu!#woORQ6)4RpS@x9?7 z%ild3snMKL7_Bx^Wdm&?UZ_!Ielsd_Z&HDw_cjIw7L4P^Ebo7WcIBD$_+hAvV# zZhe-Ty)$w+bi!{0b|%eh+8qgk8r?0ks3yke1r+zb#4^{)2XVTfN^1Oe$GjLWsUpzZ z@!|)3oc_%)5T`dRA>C7klamwH6cRY%!P(TAY3>!k`E}i3?L4KgW3#*JMh$VfkD|1< zbu+!}ptr&O$R8()mOj9bkEUNN3&wf>O0eJ5g+RNy!JHq<;3|TgO`@+Yp?@>`K~B}f zSVJu6mcEV{c}DA5k2~GE!hG3i$n`VH(>!r&m{AxA}1(mXXDp==y#ESD$j|Ehd3%{yXA=W;K^c z*y=7L!)ip-TlXAl4kX-Vm(F?w3tvTbfv7t=o@31poRC6AsY5>`MUCU#yj+w`!8^Be zZuaRbc+D)oWYXC_N=e;AvhO;la?Qx(#$&L!$DwiJq>It#M08jKrlX?5UkPJfHKdC; zcz=yezV%34@FG@ZW;|C&i@gOLqBS5OUDNIL{gaqzE2;7fvv7oxg@NmF@i`M#RXdMk z%{YEdhP9!VY3eQQsDso<)P6|2M3*>(oJ~({!%kN-imdXpJ#8A0waP|Uf5CI@imQ_E zdh4rR{a&;ck;A}g?!NpwfgBX}wClP3O$*CT0x3UCMbhgk6?B%_O zP6_%!rW0PsKw=ep7iegdcVp zKx195Z@tgYa|S20*Q&I>&=IN2oypq4Wr2qrxVNs~!l|WnZal^Yz0Tr%^x)OttI&z9 zT|q}84^Q9A!KJ(()_d0x4HP}9?9I=P7~ndWDML_xomw0d7u;Sxe9)3oHr_O0loL2F zk%390wnctyhn?VXdTq^S{45tVQ%Kst)a=~6)!`o|beD}2U(9eyw*Ynqta{Q}$$*(M z-7w>7K3hg~QF=P&?H=W1Y9<`cui4|_>YcJIP~nX^U-rvxfRjgSdTt(-4po2QDB=!+v?bmbV!}8MeFZM2G*5D_1?Gki-g=n!R~_ z3sk^jZ={xOc46mP0X+x9gR&d_EAfoJ`$~>n5xMLnX03YL{>s_B&sx|;Ezl9k^j87HuoQpUOQXQbFjfaIf zfbtOkr`GyMi>P`1MnLhT{ zq7Fq(pDw#}*sjJ>=PPt>7a>INly35s^h~rw2DZ_ZPpKRuoA7|DI1l|6H4~Y7lf`%F zV_3oI+I!rAFx?DWN~J40QzkB(Ud8;r3SE@}vv9G+t@9(k#iE7!un6Y36CigwI)+}x z8~TM~wE^|dei*=_Z%kY+1od)N{qhXxHm&`!O8>qrq9;S!$}02H5JKAd*7>UHvYwk3 zRyK=`D;RVC?>s6l(Px&(e${6VlbMvy0tNcj$&O|~yS=^qAIgg+m*!PuJjdKj$}F6@ zBrKei7fsAu-x|9W(iEUd5d8Zj`uGr0R8}Sfl$(@1kNj!}{hX&)O^BtvtAKo59!B|) z-OindOS8I)zY(G-!tBVxBIky|oFW_XSAez*KYP`5`896fTQX3l0%!47+{$3`AE7Ce z?O8MqXxaCd{!x|xLz~{DtW=nxX;pWKV5kD2Rk*=o`A?>yYDbC$Jp#k0LQF8>8ZRfouZ`>}A?fAVyc;E*p zgXG4NHC3%j}wn-+nP=7?Ri z3G|MW?VOK4u4hBY^2&6it5R0S4cvU#L8;LullQLrNhio&~@L1zRuCz(kWrr z8y4RuGJ|?GqsUE(gmxA?#5o9E>HQ#zoZBi%t36stQ_tK{@Rm*r-g+cw`9)O*(aK%6nhg|A$p!*YuGt%VzZv%r zW1~ZdNHEg*2UxlAbpBuG0ORP}wb(xo(rj``zP@3LxfU{n-`~!UTs#Z$IkvJo*WYh} zd0kR;D(E0jhmzC#j9nXEbu{Vlw%z49P@|XFp4e|6H*;dK5Z72+KGnB*8VYd-%c4=s zu0JIAHW{fqB24XBmQE6<9>!!Q_NpaA8ubUCg*qymI;Y$JPz4_A5L1(Hooa~u;`XT) zPMu?uH|AkAin+@J6x7@u-~eQzc4ADe*_&IOYk@OQuup3pxxAT(21Fw=x1YDp& zE3LDuOA99Bxh`r5;XaP;Qa$lY`)0DEl4ZrO0gt$X<#MPXuFkMKcrgw_PMGUgGOr-I z4f7mt_mQYOGJ6^FY1ovq+v%>;)?tk!x{W%jp(2}E&t1FW;_FqCD+68LovWXv-H*Zu zu(v#vR|QJ^b%~TkCKsrA=R=W2V!mD47jzq zsa-Onw8~krac^fcxe{+a`_gl`S=v1ksj>A9%N>}M>NAFv*hHEJ`j4OzYcQStc!;O8 z7NiY_;`RX_QoUu9tOO+2H_RS41dk7Q9kT+jC>v%~l2v-eE;8vFV$*2PybyQ@r18aD z(^}h79kInH6U)<2Rxb`s@w2Q;^PjlK^)cUl)Pl^f>FQ=ii0B!6G0-L7gAD8#aY=_y zYj>o_EAmG^naE$B&37*%xhR?Q2yxn30)IHO$=TWyjfiYmtqCz_31N0Dj7fY4(f0nkKS>G#fy{x|)yxrp(BKZ|Q zsGyE>5$No%k}wnLLpfzAZTAq&j)QeR6CU;W%)HvTKN>(fkQ*J*BHM3TQB^+e5SfUY zM95Unq`fmsBeapIOkkpH_mInSHi`1qZyPtOo8^`=5Tu4p;|^H7TwgidPPgMryiVWk zB0K2t;^Wne@mcBje0|Q4{qZmOwO#$KQih=S=ic@3_sQi!3vA2|EC_OiP=nlzmbS62 zHVRLUYt%fjXyfs0;5_n|C~dA=DfLwLY!s7m+d>M3dZ0GV2)8V|)M<;4`3tZ@*SvXP zG0nIdY`K($SmDDr^(vi)J7+nMKbmTwP-@CZxvt1E5-WC+e)Z|~>gVCV=nXDqS6udQ z5|)p#Bs#2G9FHm!SndVQ`5gBKEN39GiYq-JF&5?c+f&Kq0<+r?jKZ-nIG#Q2@k~pV~Vg zFR-WkpHa3x3s_>Z9tVH1^FF~3)6~zyaUebWy941zUGtB)=~_sLG&aJgg2x;yk6B(7 z^&@UmL~lsvj{!bf>&!++^Gh!M>#4nZF624aZNuh;UcK(cx!~=@+LN5X2Fvf!GR3f1 z?TFKT(lC=vAYRpRn>XbCSnZYoL+vkUHyn?f8CKVg>85)a0t&~8znm^a>#zsuNtrY6 z&e<_eH3%D>D5!F0Q`~=DxBDgw@RE>_#Elv>+C!Ju=ap%7U|d#z1{`>jEykDQ>pec+5F@)gVEu2d z(|oSk7P(F0a)zh5jD4@bY#-2B8Rxgm8f)ynW+;+=tts>y(5>Lt>pAhpFL@AVer#nY zJ=Xof~C>VtQc@YqrcB{ zS($hd+bxc}tVP=WM#vkZr6qZjIx~;%Do1qr?S;_l$TMM75*rU`M`uREj(iHl|48@5 zoBcq$Xg!29MA7>B0|n&RKy>Kd)VkL20ZjBl~3f=c9iN=y*v%c(ZpSmI{&^8FNe;88 zIum5l43E#PLT=rjez!7PC<#9{`MYo}UE1a|t7vqBg7ORQOATbg_#O*aTHjnoQenCN zDcLbIQ=FE}(uwebY(XD~ME4 z)${T@fg;rfDXXBWjO`PG;MS&s>5`qVcaoA3hsDqO8BP%;J3`3UN0#ZIFi3dtM^cq; zk{STLr(3T6waVNBeQ_~CdCB7}??pC_BWcGKCGe}h3 zI29$#8WNpxrytKO&GqGP7kUf!aHUG?0E}S2G=n&^)xgpeTxaJM*3$3N`%@rkG_7T# z09d*8rBYd0q|0k8xTgK!qaTdT`S|>D&=tV7SBUcW2w%=0e15U`=%_c^ zC_Empnd_#e`eI)sC~e#dbJ~=)md$`c;L6+YG8~J&cM!rX+|q^Z-@%bTts-}-!g%v| zP5~~HPp>AMu8gr(e`+D^)=^FO@4Cik^mjxoH+I41?2z0(wuBskV7h4OgUpjRgMe37 zUPdlY?U&4nJ}JuaVi>BFY_LB@$G7 z;Ow3Bxj>rn6O+(&t3g5-0!5{<&*Icgv&LjnwUY1#*moxdD~zFk!-Q5E9L*x(vG$|2 zetIFjda(#J#b@{8BaKhM*BqZqll9s6v5yL!^Yje58>EY4hF4koB2OE9)3>m&FIl%t zs#2N~xW!RDT{7W4y@2@gl2H7jtbXx{`E^$_a6VtvG2|d;!2lD>tc`JO9nQmy1+i|# z*gqKYTTV(Dx?ffvu$c6KWW$sm%yF*n{+(Lgz)01o3fMb~%2!B8l((p~9%e*bv#Vi3 z^IH1X(@!?vj!5!YlX-$!4M+SZ2$V{yDb`3@V|p=-2b>06THnG;ZTu_?y@B>HZcwkm z@1>6B*_%&oqCf3yQ;~hV{I0Hx+NLiy%XRHGzsEnS7AV#*cy1LRqLb{jq}B?)9ffv133|^jM-@-75{jaT{7huv#Jo_pE(-wVIzk4zC#=L7 zK=zOxn8KIbiuR+E0Vp(2G3+!0dp^w}`0IB?=d}WwU*jYv7ZUwrm6pyg{_$^Ue!*5I zP&b24?XOMO3Cm2*w1-UtNjzIlDl@3Bb@9M@=OiuL&qJ}&GyJnAV;@{m#nQ>Y1!WS;I0)faHzh2I#s)i?%7EPuFj=<<7j*;Iv6!PFo35P zfzCmOcor6@2y?`9asEzQ zISJ?QCwY2EO9ms`6kfQ*W__#!uJh0oCugW+cyg}8*+HOl6e}8WT0PrNv*UfdkhcQL zWFFQx*2cIczAaBz#i1xQ36nFDqN_R?pCA8-@FsrkGbeDKrSGnS#G~v^yZ>iT@E>#R zA1|oydv1?k zx;LP3@H3CLo3W?oK8hq^#_Yni z2ld|pDn)M1l?vto`t(znutvu>ZlDu~%ySGY=N|C@`_NkImy}oT@EXA`OGaByTEaHBT@t-SZ$nP2O+hMX@($e^v;ksP1?y2*U}ndXE2UY3I=}$!KV4 z>E6+IC(NtAb9OQ&)HA03c_Gs7z=x1#Tw+2DeL=1%N41}o|J|$By~J%@wJ9npdWYNk zWm>>SYzI5p>(`AI%ud+aiIGyDQxXt~x~)6V300{h8utK?z#4((V4sns9+cz#=GFtwBnLv1kg%jA_P}v35b!!z;9&^cuy?b|MnCdA z`3=@!=QVWEH*l-bn$6Anh;Rs|?UT9Zw^wb`VV|98%}(mVNI^|q&|;*o1p@=1JKn16 z#PA+_hJ}&NGTq6)tP+*MEIG(^5PYz!eyhBlMSV3(1_NJ}bJBy(@%s%$Jc*jul5DgO zl?r&n4@dVzaa-C)vT+XZ%&zPnFIj>(r2nRWTT<3UJbT>M8VmpStzhg9zSj)$;8$2|*V zQpeTUl$=<0wXX}VG|qX{v%<1Aavba$(k5$mNREL4vL`%D0asQ39yv4isIh+d*?m3oXGfnq zR+{grR6d)uRnB*Y9Rr%#Q2y1Y!f?w9|8lv*ZYejfE28r*F2(Mca3ct07{+K27eUV? z>ybKJFkzpdNclz=NzcT&V#6dD{CB|Nb{KIbUn_YCc=q-$ARI@? z=On{?SnNqp^H=e)Hk_<^q^hNv?%NoXN*?^kFBtLu=KshA>?$rk`i|Yx z^cfz7p9%*PYDgFBEeJzJ1f$~nOJ6_evq$5q3wyU#NF#XlyDrSVcLqjt92i-l%`q@m z7ndmpi*JHQUPe08>?^sH2ZiW zXdU?!?Bk?_MooL*5I6VPQQ?Kpf>%j??o#1Y-BW`q*H875KR+f|8+c`BtFT=|!B6;D zdv~_^riwXjGyWZ2NBEn-TR4MnnpO4oShEER?8SKwt%DI#Jql8{ zv))S7ephNpyHT2wdD;Lpfu|plZ5Wz5e;D}Y~-V66!R9=l<%brgq2C2OGUEZSo zHQtrKx0v4A?xgyU^4CZg0N;W=4HY?Ske$!z+ar~fJ~bZk)abihbaHd~!0iRI9M=ay z0F=|(DlCwAP!d3Azmgurks32TZeL&T*D2LzrK(~OuDvkScl(RoY5s&VPLxBH<8-?o z@QJg*G^HTtvUqQ^%ac1Dx3g^f`1&c(>p}-0N+w~A(^4L6-?AnP9#S8^+#_BGIzEp% zj1E? zTy|- zv|{~vBVf}q3q}t4ZYhr9w4cBU>j14&03Q0*$S<6&FQqBm{5sDW=PpVIdZyWIF2Mg& zEkVgfqG@Ulj)E@_emPiPMWh3d;WLv`tLcKOuX3A8;DSu4_M;@cm6c&dwcE1evgh)S zMgJcU-rc}lN%Bq~epBAEP61;6#2@WlH7&te{%f0jpj-8qU%7JN&>CZwh4sNmB=U*A zZ4iIyEiK`si0o@KYMM8CKLnL;gaT1T3m4@y>XWE#YU(Kk6q>PEAQ#;d>`ALp)A%}k z=ig3+_2qehW4S{sf(?y^ZVMEy0B}Np{h~dzmB2{;MR?aZLV025jBBXd(DQqAOBT&*m zRGz85J9HK+*`SlxbI~Srtue>1ud)B zWBF3JCvD6iesNA7$0xxl)|k>TXp2yTQuAJoQInP(LAX@YA6-j+9Ze<*d1SP@Lk#Cs zgd2sW&E%>s(m3%`nyt7HZ{xK${*ljwxQ$;$!?ao&V-5G{lXDec5(Sywja{n z?kRAV6)AD@D2qhRrq3RSRm~boHU+DrBM9GGqtsSS9O3ujIKkieu9;VbBjQpGI%Y?T zhJuf^x%q@)c=4_{oRI)Sho^Q$@OwBCr^9Z6bPDKgT2l4gDS2N1_rk0NP3NuH;<`+c|~(%)(_ObWjqO+lYDCbAgJ%_+X}s- zvGsQOUTvRkr0@rTz6rLiy*kHPVlpzx!Yy7ty|{9V|4l6};{iu3IsPdP`uaZ@GJev4 zA+wP235k|_GmrjFitVxf6wLqQ6U1Z8OoVjfuX?dw(g00X(nNTxS7|yW--Y+H(Pm3& z0TS{_Rxr>HOH7G-;WuE$t>ZVT*K=D8QijAe&E%6;?$xd|`zTJhQZKEJ>hd`j{e~Li z3i8VBz{BhBm!7h*teBH7k;|~lSranOq_E(g1*CaI3lIC~Y$M~UGm4YDAb1HZJh(i- z@8)&R%t?)UWid-p`FS|*1I0^bd%4gW&D;-1}`Q9ojbim!{;_FK4mSk=_a}z zf4Mrm5lLP}5;9Ko4^SEpd#IGBEV_t>^u2>6#*P`;J1WWBtB`>Pd{HzAKj+fF((4f4J5U{Traa*q5J(mHlS;(-fR zcc)A^BiKWHL4f?2;1#z+gY$mObQU=7shKA;i({;#o*KEYe>SlR#Vz{@;a%GW1-|*s zV*2(tN6&_gN`V%Zvb2*C6S}II5sk>Ji{OV~o7@AZvg8WIeft#)_Vl%v(|#X+zB}9S zVp_zVyIf4vxH*?zP2|hff%=u>5L<=AK{e%~QA}+l&bY;uM+3d^q#1s{%Xq|@-zc9i zN=&7?@j_<7TYO6t%7xXtB8u?H=vv<5!x|FND&td8uR3Ukt>s;gWf{O zoml03X~8%|%&2rz{k&8CToAWu$d5r}oU=rh)Q3(|Fz_AqOLxbSlb!1m-4ff;e#91} zJo^gY%MKG!zmCq0D~oa@v#R*|B(|!#{6f^>CIgFm&3y1FS?I#7Ciqgo;7^pn-PL>Rn!}o zO4D_NYi^P(Zy@q4K3AP}VZzINxg*GMfoFUs2Hsayq`NAef?asYfO36c(ERa@cf3yu z7as(NGUIelgnb*8aaQK!^sR1r!s*8NB=lrfl^?^W*^fX}V5ZY{+j zR%%BW58_!~TZD>w>BGi|z2yk$kbzQS`7A~6DYT2bF<`Ps_Hb}7#YG%eKUNEEsN3%R z6ko56P>tWvd#+a8{3Ph*{w2rMh96RbrHG@D15Q}{&2&T@y$ve8ZV|=Xjg`2E?o(kb z)$>CHMj3E#xye#N%(|TVq`Q-gCM>8d_m@}?or7)t*z z&P8MknF52#=axgPs;7eu;YLRIp{&b#I}kNvshnrIp8yJ=H+rU`(=LXYh7tXIxql{V z9B|Fv-~MmX^jW~ar0LT~I|Ba~X{v*H@Na2qE59?fa{~~vvm9EzzX1>LzaiuQYUj0y z?TXXjbR9R9@h5-YDfJJU{vU$(&Y!a}T_QcN{&Vzwr33%6SRMa5;y*1sTIa7Ebq@{f z=kkd>tRk*;Lw;uO56w=tdSYwKo-jGr1+Y-F?QvQ5wraobQU9zb3e^ z)oEAoF?DaL--<>gQD|t=EP(Tf6aqeGhO;47|KRuc`-c5OSOsdQgECMHR5AT8pnE)B z(PhJbtx;!oaPu)nLUHN^1{JscZ@{OUy}-A|*`)=&7*)(TT@-S>MiuK$1Gpo0wCU)x zdjSr*3YQI7A9|tMYZu0?P|F3QdKaI(f66qNS~zRpG8;I84m<9d9j**a6|kH}N9Ilz zC|fy)272YBZ4nk*{b3ygt0~f{e*VNn0ZY&0H|DFfj)h)m)#HuyEa6tN$n_DY;W`1`IG%5=~g!_I0)$ ziXhp`g9V9M9|bs5MOH~deXn1B@5#WdEs))ti5EG)(8zZdOQ2z3qmHY4b{})wqqcoe z8ip_0!XMIlM#mOhokOdm{@RfAd*odg7$Dn}7Ci`>;lQwkMbVP-xJ-aK^SOzIh?~ ztmrrJWx=u`6WmqIj8=vFNzi5EKZwiA9oM{Kt8oAoimg#Fl3Gs?Oc7?DaohDDG~sRa z-l31U#kntfzoo0zM6h1 z7k*QS4Xipj^C5HOluV`l58BQQs)|0Ud#V?TEALuz1p2BlINti%Tgf$9bN)^~#8_j~ z8|dx8PcocO5ioP2F|8h<)kHy*yM?T~#9u-1`{Y!Q#F+UsX2se|U-?}+6&OL@!S15j zy`&1OA|w5r8a|`%3$NN~j3_~bR7oFm=BH=5>^Y-bWX@kT$pgZ(h`D=4)a>oPjcw++ zPqH$?Knrl{kR?!bIXROy(HvifPBJBM!#4Srl~$5y6!}pe`D& z8iptBke!+9f2T)v5nzit>+6hx&Kg$4Tux57i(PPo<$f}3s*J&5{g;n}n$7{al;A`$RrHnigZB(g`SnKX^w-iZj%&cFKMC7-2 z?PN3_j8Dw0+e#udsQ0N~iXAFVt15o{L0gPHM{T*vp1R`Rpg8=gwFB~uNdJ!e3OXI( z@lp29yt0JAjy|4re06rEAK&&yd}Zm_I+6%qxQknd+v#;=bND+0Ws|u}4Gf#y-hnIs zYG*e0s)woXHo^{VVFR)AYF6?p1UKPR!(1Cbw)w{F}tLtmy@E`3!n%?jz#xA;c@X;h#Ga6))xYxX&x zk5J2i?1poGRq06H0E`U1wHJphkf?t7=;=9lyd{6jy-XhqCLB*DL5T9X z7XXYjy?f?Iom07#2|i~REj~HTd6mnCls7(@H@kuY7Uk`{o>9t~TCQGYLF5sv`RW^1 z-bVM>tn`%zJXo7>rw>?E*gK4@+HZ z=3%9-el5`2@A6!a-2uQz#fY)+=BZ3XXOB$^a#)_Ayo22apsxUuvbR;x9C>AIk2t|c z>4{Tpfc`aHX9bzdK)gNN92DaOHJsa8#kVlu){=(qxbxJD5^f2smx&adcHhi zNY74MoXv$^Wu@HEe@_Uy@3Y=y~`nZoE*02TJJ$1dA;SwTQosDol%`r zEi6I9dWNucCQ$Zv^+Na*Fs9}D>sR22!^sd~i;%if)^nU*vZT-y8bTFov&g1Yb8C7S zoeH2W&tt3s97owF2u9c{$b8hTrNe!=pS-6w9d$V5DgqOe5O9xiRft0@c+V*TlXwnU zjWMY-dT2BhC#g-4uspa?WAOd<)=(Zh4t<1|kG+p7+S7uPx#4>{O{=e3cg-Yc?0kIU z#J4&uWs6js&MLo1W#v$B{vHFJ9o}+;ANMSkkCe$MF6AZ6r7fWAyW(X5NT&NWuV>{Z zn(|9)3FRE-^we-qqFSew-f*n&Q82830QfqF`)1P>fO&(A+DenjkoF>x;T4D#wLtu* zMdgnpYZ76}M5*^HFbqf0@~S<#y0QJD8Z;RY)wqq==>`xdu)#87ePA^r-RSy6@4a8& zEq#&XMYyNO5vJ7oj`84NY{PZYn^g?;Fv+pdxsb{qTFQX^=$rc4|A*g&O_N*a`0%N; zajy&n-&*ydc1TFb)$7iW60H&Cg1|k_7360+5|XRKkj|_O7P=1dGTvmq#o<&~)Xc!d zqgf5o;oM+;Flt$+wCK0#^6Nn3EoKQ~rFBzFa9gZVNE&=>gqPHAeno$du#~M=dpcj} zhCTocyPoULFNU&TSx$|7LN(ik&(eXM{$rj2skrh=h4ZKwNr+6K0V9GgZiZ^NRJ>I0 zyWZXZ*#gX3K?nC1oEG+&B1HiHyYsIhzJZS%zl)-CyGN84M1Lg+u>QHr)6)Majg&}= zqj6HnF9nOAH=gSEX2a=7Y2;T*khn7Eft6KMq7I_oYiCroSQskI_AWHO(T zO)>MJahg|Q^YWrc5ny!AX8qcaiX!MRguF2Luxv6GeL_m{^(CPp|AU1z8r3xNDNoi? z`q(Hv@-a&K=#agcpphQvQ&j|v2Ahrl3$UoGyGRb8Gww>DaY@w;#S{^pi;gS?A-<&N z;URff?jBTR9o@a%C}4X=7jfSY(HumaT<9eoq)>Q1J;gr;9&e?sLgClx2z0yB)Y)hWP&2N1<#m&ZRqobF;8ZS1=I-Y z8NlHS3`2(M{Tb->_B>Wl z=SgZ(GDl-RtkgVj-&n+a7s${K6;Y-G`Fj1g@+6dr-v%fNYa7)(Zd{(XzEDYbzgW5q zekBzYK1wSP$3Mj)b8abP@iNl*gY#crOigbr0W}WiNsfnFuA!VYF1(E132AhSws1{? z0s=kud!`K-z=1_O^SKCvvfZy_tEA_}+@x~NrCDmprzr-~*7C4DqgNSGSNX4!xQz=@ zxb|mYo1M3}W?+?uxSaVvVD4NcL;BOS@f+ZOtDpgAIpct6eXrDZ;Xmu<|12kYWj$|~ z;EmIZ%6|Xq>N+e-2D{?Fj-KRT z7UsHX?Yh5x^ET-%3ihb?CMr+|yK0`FZ+jh_%NY_W|GfcH|*|m`y5#HD9eH zOeh|H8tp?}7tI6`kZ<}~rHPW+GHTfPWdzXfJ^%lecHUu4ZR@&65m6LS0a=2SrBXyG zN>jQODWMpew5UiY6e%H;pdh*s0UKS4bclo=AVDG^ASLu3LJ=t;1dtM>-w|AUpL6!U z=iGar`(K_XnM~%GWsL9r-uE}flJ7SfTI&YQ#%Da$RHy<%brufSa1_`T)H4I2!XJfc zIDX)_c}qP+%D18XRBw~h6!iHkrAujJW!_dWUg_$DXQ{}{&{F1~A?CEKeFFNw-PXFB zSMLWS7H}cPe@eXkQisUa_MDhW%bq8Rj>g8RS>C}PN#8uM5J_IqS6#MO)@|War<`Pj z!dro#LM#b}OAhdhxmV;=Rte^z6JkX>c`yo2n3Y|5J`u1{NLzD9q~n>_c3)Cr&!swO zxouNb{a<8-C!cHK&wsac9r=Ap_JjKP5SJ-ex(8-=vVge6a{>M*&*_ucu9n!Us;aNJ zIS@LAn)KmoZW)BeEfoZeF_BDcFqe*91Zu1BVwz6ht(oNk- zrq8h=arP&Y6;xEZy=&?JA$Y+PeF7Hew{`s4i&>(4=%=!iA1!E*$+;W}@$Kyjh>?K6 zv@wHy##7$T=ENIbwP74-O>3&JE4q7OtE`+-kOBz{_8_3wxBl{oO$?+9K9tVT#&2iA z{l#6!k|^?D=oBFup2HswV2&)YkT+<2nIF(c)lNp1p@oDi$UXKX>Wye!^g zXe`HcL|#aAxx{dERus+(<*YV@XcY1<6_|2*==IV4nh~MeHY_39xxv~c`v~+wmWr}{ zt1b3Es{4qK6!0@|fAnb1z62Ie(od$X-78Olj^T1ic$=F-YKIcAtltfR|AG20}QveI0)nOs7b8)OF`~C+13!$O00moU~cNKciQGdyxJRGPqJ!G-hJ76Gy4& z^##67jJbm8mFMMJ-KPC6rPJ4c@rl&fXbV{>hah7=-2*3ga%qq#>szg(Lz6CtxAD6X z62Do%r@0pfyc_R$ZYp(qUw;g06=$J>h*>7Xub~(`KibJ zM=cS(ne0B*dIpGV-6~$?86jG{x2-z7A0WgGijREGVyv)Gu#I6dcJrtZvikEMVSU#? zBYI9IAI)LMa{2)#&~r|{pEQ%H%EEO?? zz8jqV@>rGf$Qqi`&u0q*Hg!B36hTg$fivvj+Pl1V^(|lPhpJw!m3*l&&Dp63r=JRa z%5(RiW~_Ez_O{M^Jd$~)irh5C|ERr5z0IZ2TB)xLlNaXMXzK3A^L1QwKjP?tko~>y zbC|rRaZ_lUGiI+3yihh5VB4dUVe6~5zauqkjbk}$UGjdqK6?5k{YqZplcy96hYb^H{ z^?Ex)wRpwXj%vj14-qFyzWhQy%)4_yTFzYB%ApqFP|01DIx96<{w~NiQPoIbu20tT z*M*!8s|+Xa;!~$XNuvUiFlzdBQ;4Zj8>uTKoS1|lI=bL35}oqB5MbOE%f86(JD`r! zant^F>UBeDpZ6_!mvQg570kU&y-kDVj)(}1G+Ud<)+-~dTp1zl+as8Aewm)YJ^UeY zul+fP&kSJE1c{?o`{sr!dm?4$NR4t1ZtPIpyd9b4jG3y~20y0uNViu+uf(J45Cz;Z z7E-p=>x`8wC*ib?Tjv96EA?dzw5GkUmJ@;@w`=S&-FXVIP?kJ&waZ-P8yS`dxDfYE zBJG{Tf@`y+McFa_ygWW5G5px4+$`qu$US%YCHlCMWD8HEYx2CWlXfv3p=msY%h_GR zHnCeb!lhDbYY~kJZSrW_GttYKt4&yoeeVQcd2fD$$J(?v8FcFvu8R%&x z&gfFo=~(qU@@`6+WbDiX+?c1~yxC)F<~W;R-Ef)4awpEIT1hat@zqj!F5mk{?bTNx zR;GO2!`M)YlGpNT|G>{-B{XRgJ(YdE9sX|0!f2qE;|MI>lBne#gtN&jvd_3X2!kXo zoUjd&$HDZN7#}8cVgM zs1us>o#U^1+66NDYwD#;Z=LgSf<$PytBESXS|AO*IJ0N z2#?7%52YnonG`5YO{=f@?{8C%@^Z;0%OQmkMw9)P@=|=+cFe|vc?YFhA9Urlc3a!C z;*W`%d1?Kg_lfeA*mLBIIgZ}=#OFiiHpzi~acImEmx?J2-uk^>*>2<2Db$&_cja$k zZShUaOs}6xT6_T+ShC@a&K$o$OadX^(6e_1s}$Hs12Nm6$O{cC|Yo@S<>47x`#0Q*rSTmu%3b)z1z#(0q+9ky+zHPRnt4xwixcDgQIJl zOm|@T!{U}tLAD-XF|0#l_%#WW$I4RO37Q=}oS_dI(gL(8%B!=E8^nJB%)xAgK8 zvlhau%MF`zs$UtgvwPbnH$Vt`sNM}JF5I!!N}bNT1>;1gbh8KbZ#NsGA=cK`->Ek8 z)hI3L=KiVKwL`(`nsW*JhRM08CfQGw=5LMWUCEDwiRbzBC-9DSWpW$2%MH&%v)L7G zDhjsYE*0tP3f`K6Z9;*yPhn7MJX`rIPz3a+_DQ^(Is<0~W$rO6yu*^g1GSB+lDYO< z)bBxUaV@Rigp!NNRv%G{8fAa*VSbKm_4~7sFU5Yeu_F_vImR6nV?125~Xz_h;VZzJou>*zY!1#zp&;px1pN_3pUD z24&`BBT(2vo!x7@ohp{P*!yAIUIpmEP8?$~Ru|0u$bp=QJBy&^ug|1!G2&$ErIc0O zey|F2W+Vxefr(wWa(68(;2=o5;E~U-ht4y=D~7wkypmrru#@$fEovFHQSz0X$!5yq zD`9B_9d|lubjRe$l4T`(hhfb8vtE)|Wk!a$aJgJa`jxA0RN1+N0&6cA(g=SFdsjMxIK8*v; z&gbIVS$#Kg)z#IVPp%_{K7G_$9q-W1W_}_70h6WC9hJqPphA`+Hbb6s3_s*2>ykch zULFy)XpkbbWq!h?|10vdr!nLy8iyc?d6tH!#{?Ym+DWUo zW2`jTZZW(=M!GVm(uo|komg~zY&%pWrj zf|!%nsc9-+)VU=grjDY(UqAN@N>r2a@&i1x{Z`(&lH69&pV@3xPx~_FB|MVnk;GrC zE??qWFnX`DMURjrb)ary2XgQCAoQO(%NuD}`%j8kHxNsf1wH5vC2Q8~L4kTK1qqLU z`EN8beZLuXem~dR>m2739gB-3i8Od8b5=qWTM)}xznr^e2f!Ugtvrzr^_0tB(rW1{ zb**&WENx@EZ&~dae=F3AR+u{Gi#dP(4mEA84vtszOFq*aQUs5VRFr3?{0S9c%{^@j zqG^;1{7Xu^i*Gh0Ia2^BMbl!p%#dd+4|!*D-%Tc_G^YiE!p6)BMKosgeEULZ`a&|} zi&9Uwst2v@LGx=M?bZ9+=Y8YjsjL?~#-F1&^x9KYHa}f5wVDKu>dTk@Bl_(lv$-Ht zkojv;dSaWueD|_6lg6@Wgit@KdVtNrgN&=+wMJ%MVikDQYM)ZSxsS;aMA2QVI^!lH zWwTPh=mYgF{K@{;u&vrS)sjsSJEo2|dtlga|FpG8Z0+$7zy8i`ft~-2Vgz&0e{Db4 z@0kx6jb`Y@;}>WRdzO^ey#~?0{POPv+n!(M6k(DfAEtu|^uPYOy&v7#EBqIv(5wF7 zS6zzpODPEh&tlQQdJh8FEaRNPZe?6ZtQ*dozegQP%!xk3cyrzIomAwH>UF68g3K6r`N6D zD&c?gqf?5gx4>oyRKx!`mfDuyy?mhELvL>sFK{9~-=hirJ~5(#b?vcW{%#$7arwo2 zZ~ERy*$XwV;K7hx{w+fmK?G5N)vIxP&x-#ya_Zz>qMsqr>i(ZiOCSXuu{Vl9pe^ch z-5LT$t8X739{z85Nv}rth@3weUWI?4I{yc#k}TjKm~JL9E*^fy@%Q$w2Qp4h1;~a% zE)t;0d)jdIKIJt1M(@~KDeU8ujI z2>(ySCzGO&4SULM%EK@-M@19^uJFI5wp6eC_u}RUpvS$0?xHvp`Ia zNGy*trshF<8z5Q9ar>DHLkwkKIEixWdP#l*=+JwG_n(eNTOyH_qrJs;#Dr)(<3LM4 z0TsJy@0R-edLFSdq5ciI8lQCf?P&vT!^{6Pn(=NqWQ0v3W|?5^;EH=}_oZzc^55S* z7p;pKb~~n+fXh??oLL{rIpwd)a=H%E}Da-(t7Z*83?))w+-8 zO5r$t8So(Hv$3jZlY&dx5jbIcYL1HWh(wg~OUr3TZdbDR@NB^b3Fo|X*OudRdF>~X z*+RBl&+wv)St+LN{b+H6%F>RgdZq{bLEv#Ky#y5#x1mS$c=?tes!M-WQs3!s^}s2- zRjV;6U2+i8T9X*Ds##k-bFw15`hsvs3f;HU1>XD)m}Kl3>KQ|mp8BgmXpXZfpKjT4 z>y4I190cx27*<`qww(F-;NS!uEWRLs60!AXrvu6SjD{m;C|s$ASqbw&?S_Z@!pKxs zl)7v5lhjNG?%;FB0d;t0p$o+RgWuaqpfJXz)%H|tdDqm|XSt<}WaZ@0f|m2xj`EyV zu0^%R&=a!RDnKU^&ge&_bX{VQyw)3|bRbcf%1y^mE5EO;!7cvr-E`Xb?9}v@L{JHB zcYM6DJu+ti`Ko9g(7B~QT8(;n=^f{l)N8nnTQv>i(pC3O{OW$hp|)FLk!nL*$id5= zOQSn>dF8HUl*{#rb}PyLqEpKYfSR@u>%Sr+E#&!%LKZ>YN83%V1ZV$y(Lx z1#2$Xwt!+YAQ$2Puld!DuSxIbeWgzO=ijS-m`USoBeC-Xy>od0Dm!!)F#vhEI7j zSPI3B9}p%FHxru^8|a3`+mvV1rXbYrTD`+33z9Tp6X``;?~Ni0#)@($Azle z)JkvRaCRAGiJj=HnZ!>O*gB4qk?nHIySr;8;jJ{pw!)ii*FcV;-3wFk>V*5*ZmtAz z_2_=6P{Mq+LQ4BJh`^@jRG?FXwQ{GCaea{0VCIV`f!GnF9X$MqYtWUTx)!eTphTsh zIP?dlC$5WyA=k_xzE-)kJUFK1q>6Cs+yN#2Lt*kB1 zH1|&2)`l{PUTmmi+By_1Rz0+1-sHbvU5`_@%6u zJ(k(pN%^J~L6dpCtBj}>s)y#VQ?q(_?S&(1-1|@)w61R3H6S}z#mPlgKE-S4Y%5Xm zgODrggkJaM+aFYw-tdm^H1wUn(mv%7nAogOyf7ftdf_k~Pa!L4`))kiJbSS!iO;m9 zLuL4KFm>@qirt_`*+mc{GP|NrzTzrSw|pc@dK}&Xix}-uI8cc^IQ{4NHqRV_%G27i zhS0Ax^=2ri8+WXqsE(R3?S|%XM&r>JZo9(Gu%!?ki9x$lI1v8WciB zN8!pMU90Y^CnyB%Y>BEfNcLdjbtRdxM!z56J1l)?5sF2+j9)Jan7HlvbF2mnlRs)h zAMW0&(Q*3}|06=)xfMtivXft!;e^E7%Z9{IkgRn2wRqcEEZD1@I{mVVydB|rPMNpgEg*F{9T>u4%ad)Sj9R2PE+5%Z=2x(X+oZP@JvHOm0b4HaRtyL+%pO7yY!A z){kfX>=jf4ofh>>WR$vUcL1m(!m2u9s~5FKXr)$hKY?KL^@LL}WIxX}^1NgOmVj=qvr zDrhbQNsL^)wAx1)k!2NH?7c~g!d}~spb;3P*8mSv_9XS!5sbeCDMdGL+D*c%U(L(l zDQzShW-nWzFSb1X5?*%TT6E$p&66VyAJEH|qjiR-k#-8!5DdPlF{cmIg>O~&4AZ0d zJbPT%!-m-M8wDB>Buw8md4cFeDxCd=!>?N}xDzs|R9}Y@_Ptec%%*}H%h440!2M(p zrQCksN?elTgh#YD<65u%AKgVX_KjEoLVz2b~hgd*YP^uQ!n$!X?A7X zjQlo8wt)-U=v%VP_qnfF7IdNKEu>&Tj^eS4g7A(T22BLGal z4X1m06_DJoV7BT`4;`AdqA>ce{8vi76@;5kvZyVaz~%9ySkWR5^EKelvI{)f&rC7A z*eO~)pk2moI#(8388~mLE|O3zWz{%T~t{ z4`H;8$lA_u+#fJd$kV@nn#`kI57qIMXV25?vkE9wy0`4k;^F-5wxA<^rS%y)xvzT} zcVAg5?lDodN$R>phV-w_Z#PF~3N~cf1B_&H1k?xKzt$~0ti5^W*Oay=a+*zxogXLz zo3{;LU#NI5?Zlyd@{q$Qe&SBbm=AtJwtoEZb`C=pho;+0r4o3$Z49WSyPaAsO?DP)#ijA^H?qqhqFKD-;EF{Bla0oOrLi3 zD{Ih8uT|G=NmTh{kw(d!Yv{EL;}s80`Dj2GnK8IO(RYnhZJMG-iU`Mwh=DqLX28f7 z*KgL%&h*w$V+E}|ub`+`fx9)u>Sa_J0GC?;?6LmcUvokmT0o-IVdZv8HsI3t4-i*+ z`FY;VS8LS_LYJP_QYQ8dwaB4XU`mTs?alNuQL13Ce(i`*HY8JwX`hbvHd-TIY7c- zlx!NBhGu3n2zbFi5x!}fQG!~|XWnN$$Upy&tocw$aPa=+Q0aggZXTXN;p@L&^8x)w zQCo^&JKfye-1_AyGfk76FQ9wq|H6@UKpvEPAfoPA-nTt<5t#3bfReHI2A%(Gp8c(4 zEZMbvxJPK;2V2{#y_ah&f}&Wt83}9#>9b4Lx$oj$ne6pH4%_c~?Qd=5;RPmmZI)!2 zoen%{aBe$4AFT+e$2-TKO-@e6w-u>CUyly{Kt#q%jf}edYOzlwzN)lnZCNgl3*{-x zati-Rf2V%z-Z;$<`oXRBOIOMWGm;q!J3v;CQcZoYY>XF5pII6-MF$9VWdHnlpRnb!Up&Nqd0?2kLYY*B+UoBzUyeS{Gd0AECU!OB3}pU1 zz%|$}(_W@u>Q)+6T2R{lI28OJeSn7PY~mj}dUAi*$;>UIYKfrqjXHv2{EY>)j8J|K zMphJ>J}DoCEd%cb+zgRg?0Y5b$*c?gQs5eLW+w4H|j6=z78PGn-vah|he@%y9xQ=$Uj! zED+5cyf?Zetl1;{Cy3?5&{*pS0E0u#E|r?ZFA=VSuL9c-D4nE1X(Sh*O?1qzu*VJ3 z2d8&0P4E2J?>Q8oej?>?zy4);eni#umAg$rfy{QA=p^5T;ABSj3ebc?=GR>nOZ+U| zJU38QTiiDI=#zSG1*Q6BZY6+jt%2_DceL+@1_d-&dXiVC#HJ%IN2y$q|2c?Akxm4h z`wk)J#y8qKRBEa6%k=6vw<%a(%gW4K`|9m4N>CY8^fnrm>Fj%1dw104CGq>Jch*`) z@6`C(hd3)Dwza>t*L_WczkZ4w{5 z!zHb|YPzkh?wvw&7Ub5|RWAC>gv#xc%5A1}QoqW|VtUvYjhe3s zz0R#Yn^^WN&kXgP*? z&|$$DZT-c-dZ5Y*m&N0hdrgsHfxA~dZqh0 z$&0-|fIHwvam+)_j|m6m;TO@vJIG_bcf}nHzKnZOKG>snBF=PYU$INx%CV92_z}D( zz?CX(5Bn%o1{2QbMYuywq@&~-TH`_L_8edD-HVo`1D5WclVR(lK8-)#_vMylyxrZ< znu}btfi(pm6uVbw*wGZH7~7N3-sd83!zq2aU%>bWCq;Z|E0DAS1fEh{ThSbk5hfSB zc;a08{qM<}6A%H+y@!B&wf(VkmD1g)TYYxK=(`$X#OEEQw`APn;NV;B9nOoiIYe0y z+aJJI3SW!49V88DH@KKHFq{1c>A=#MKR+D$BKRd>RL>oALmaSm9zDUhgILxFFMKj` z5DNTp9BU%HrTc7T#~>j=q37$zEDl52`r7(%I6}f_looEcn5xRB0{yr?ThguuD~3pM zsxQSscvXMo+Dkp|{Q)lYAe;V+0J{zGt1|q@sSyKH+S*vPR_TAaPgdu5?;hn zTHnXumo795@I=X%B6#{p%ljqX0PVvZcOu6|)ou*|{xoRVW3+f8H}?i*ZA6{8LLrl~ zGH0s{&(dIuoV~t)z0;y5>rp?TLzCrlt#sP?qk|Ci9U1PTBeMH~y-hLGO8NGiRJ$lE zknu}YOXeS}L$QW3EP(UGs7F%qWisdg^av!0k&_B{`vEnhp+$^un@=RPIMDW6eye(^{Z-T~+YfEf| zw`o$RjEOew|BRxf08W#`g)-sPn}ILast)Uay3>oMC)ZmGm%r1V|AXV-v5Q z25%T@SKD;iE+=fmK}6=UO?QlWNhY?3IT>}hdCpKvSJ~q>y7JuSt;aZtNz=*xZ9kB^y+ZzT zMW_=%U-wH6+Ce6NWCGIjfc@{6>v8{{^!W{Z!LcwsSveoGCr$s|W^vKz%!P^(fTk}T z_)^40!_dl#CI)o-482P?&!qaUkr5DM9#{>?GT+S}xOVAgwq8=}F6*<~qknxkl@AB| PVbZ##cN25{e(?VSn>wTH literal 0 HcmV?d00001 diff --git a/dockcheck.sh b/dockcheck.sh index 85487ab..4b5f280 100755 --- a/dockcheck.sh +++ b/dockcheck.sh @@ -229,6 +229,7 @@ progress_bar() { # Function to add user-provided urls to releasenotes releasenotes() { + unset Updates for update in "${GotUpdates[@]}"; do found=false while read -r container url; do @@ -261,11 +262,18 @@ binary_downloader() { } distro_checker() { - if [[ -f /etc/arch-release ]]; then PkgInstaller="sudo pacman -S" - elif [[ -f /etc/redhat-release ]]; then PkgInstaller="sudo dnf install" - elif [[ -f /etc/SuSE-release ]]; then PkgInstaller="sudo zypper install" - elif [[ -f /etc/debian_version ]]; then PkgInstaller="sudo apt-get install" - elif [[ -f /etc/alpine-release ]] ; then PkgInstaller="doas apk add" + isRoot=false + [[ ${EUID:-} == 0 ]] && isRoot=true + if [[ -f /etc/alpine-release ]] ; then + [[ "$isRoot" == true ]] && PkgInstaller="apk add" || PkgInstaller="doas apk add" + elif [[ -f /etc/arch-release ]]; then + [[ "$isRoot" == true ]] && PkgInstaller="pacman -S" || PkgInstaller="sudo pacman -S" + elif [[ -f /etc/debian_version ]]; then + [[ "" == true ]] && PkgInstaller="apt-get install" || PkgInstaller="sudo apt-get install" + elif [[ -f /etc/redhat-release ]]; then + [[ "$isRoot" == true ]] && PkgInstaller="dnf install" || PkgInstaller="sudo dnf install" + elif [[ -f /etc/SuSE-release ]]; then + [[ "$isRoot" == true ]] && PkgInstaller="zypper install" || PkgInstaller="sudo zypper install" elif [[ $(uname -s) == "Darwin" ]]; then PkgInstaller="brew install" else PkgInstaller="ERROR"; printf "\n%bNo distribution could be determined%b, falling back to static binary.\n" "$c_yellow" "$c_reset" fi @@ -279,7 +287,7 @@ dependency_check() { if command -v "$AppName" &>/dev/null; then export "$AppVar"="$AppName"; elif [[ -f "$ScriptWorkDir/$AppName" ]]; then export "$AppVar"="$ScriptWorkDir/$AppName"; else - printf "%s\n" "Required dependency '$AppName' missing, do you want to install it?" + printf "%s\n" "Required dependency %b'%s'%b missing, do you want to install it?\n" "$c_teal" "$AppName" "$c_reset" read -r -p "y: With packagemanager (sudo). / s: Download static binary. y/s/[n] " GetBin GetBin=${GetBin:-no} # set default to no if nothing is given if [[ "$GetBin" =~ [yYsS] ]]; then @@ -297,7 +305,7 @@ dependency_check() { fi if [[ "$GetBin" =~ [sS] ]] || [[ "$PkgInstaller" == "ERROR" ]]; then binary_downloader "$AppName" "$AppUrl" - [[ -f "$ScriptWorkDir/$AppName" ]] && { export "$AppVar"="$ScriptWorkDir/$1" && printf "\n%b%b downloaded.%b\n" "$c_green" "$AppName" "$c_reset"; } + [[ -f "$ScriptWorkDir/$AppName" ]] && { export "$AppVar"="$ScriptWorkDir/$1" && printf "\n%b%s downloaded.%b\n" "$c_green" "$AppName" "$c_reset"; } fi else printf "\n%bDependency missing, exiting.%b\n" "$c_red" "$c_reset"; exit 1; fi @@ -310,9 +318,8 @@ dependency_check() { # Numbered List function # if urls.list exists add release note url per line -options() { +list_options() { num=1 - if [[ -s "$ScriptWorkDir/urls.list" ]] && [[ "$PrintReleaseURL" == true ]]; then releasenotes; else Updates=("${GotUpdates[@]}"); fi for update in "${Updates[@]}"; do echo "$num) $update" ((num++)) @@ -335,6 +342,7 @@ dependency_check "regctl" "regbin" "https://github.com/regclient/regclient/relea dependency_check "jq" "jqbin" "https://github.com/jqlang/jq/releases/latest/download/jq-linux-TEMP" # Check docker compose binary +docker info &>/dev/null || { printf "\n%bYour current user does not have permissions to the docker socket - may require root / docker group. Exiting.%b\n" "$c_red" "$c_reset"; exit 1; } if docker compose version &>/dev/null; then DockerBin="docker compose" ; elif docker-compose -v &>/dev/null; then DockerBin="docker-compose" ; elif docker -v &>/dev/null; then @@ -408,7 +416,7 @@ if (echo "test" | xargs -P 2 >/dev/null 2>&1) && [[ "$MaxAsync" != 0 ]]; then XargsAsync="-P $MaxAsync" else XargsAsync="" - [[ "$MaxAsync" != 0 ]] && printf "%bMissing POSIX xargs, consider installing 'findutils' for asynchronous lookups.%b\n" "$c_red" "$c_reset" + [[ "$MaxAsync" != 0 ]] && printf "%bMissing POSIX xargs, consider installing 'findutils' for asynchronous lookups.%b\n" "$c_yellow" "$c_reset" fi # Asynchronously check the image-hash of every running container VS the registry @@ -460,9 +468,10 @@ if [[ -n ${GotErrors[*]:-} ]]; then printf "%binfo:%b 'unauthorized' often means not found in a public registry.\n" "$c_blue" "$c_reset" fi if [[ -n ${GotUpdates[*]:-} ]]; then - printf "\n%bContainers with updates available:%b\n" "$c_yellow" "$c_reset" - [[ "$AutoMode" == false ]] && options || printf "%s\n" "${GotUpdates[@]}" - [[ "$Notify" == true ]] && { type -t send_notification &>/dev/null && send_notification "${GotUpdates[@]}" || printf "Could not source notification function.\n"; } + printf "\n%bContainers with updates available:%b\n" "$c_yellow" "$c_reset" + if [[ -s "$ScriptWorkDir/urls.list" ]] && [[ "$PrintReleaseURL" == true ]]; then releasenotes; else Updates=("${GotUpdates[@]}"); fi + [[ "$AutoMode" == false ]] && list_options || printf "%s\n" "${Updates[@]}" + [[ "$Notify" == true ]] && { type -t send_notification &>/dev/null && send_notification "${GotUpdates[@]}" || printf "Could not source notification function.\n"; } fi # Optionally get updates if there's any @@ -525,7 +534,7 @@ if [[ -n "${GotUpdates:-}" ]]; then if [[ "$ContRestartStack" == true ]] || [[ "$ForceRestartStacks" == true ]]; then ${DockerBin} ${CompleteConfs} stop; ${DockerBin} ${CompleteConfs} ${ContEnvs} up -d else - ${DockerBin} ${CompleteConfs} ${ContEnvs} up -d ${ContName} || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; } + ${DockerBin} ${CompleteConfs} ${ContEnvs} up -d || { printf "\n%bDocker error, exiting!%b\n" "$c_red" "$c_reset" ; exit 1; } fi done if [[ "$AutoPrune" == false ]] && [[ "$AutoMode" == false ]]; then printf "\n"; read -rep "Would you like to prune dangling images? y/[n]: " AutoPrune; fi diff --git a/notify_templates/notify_telegram.sh b/notify_templates/notify_telegram.sh index 5113f35..b86f2a0 100644 --- a/notify_templates/notify_telegram.sh +++ b/notify_templates/notify_telegram.sh @@ -1,5 +1,5 @@ ### DISCLAIMER: This is a third party addition to dockcheck - best effort testing. -NOTIFY_TELEGRAM_VERSION="v0.1" +NOTIFY_TELEGRAM_VERSION="v0.2" # # Copy/rename this file to notify.sh to enable the notification snippet. # Required receiving services must already be set up. @@ -8,12 +8,19 @@ NOTIFY_TELEGRAM_VERSION="v0.1" FromHost=$(hostname) trigger_notification() { + + if [[ "$PrintMarkdownURL" == true ]]; then + ParseMode="Markdown" + else + ParseMode="HTML" + fi + # Modify to fit your setup: TelegramToken="Your Telegram token here" TelegramChatId="Your Telegram ChatId here" TelegramUrl="https://api.telegram.org/bot$TelegramToken" TelegramTopicID=12345678 ## Set to 0 if not using specific topic within chat - TelegramData="{\"chat_id\":\"$TelegramChatId\",\"text\":\"$MessageBody\",\"message_thread_id\":\"$TelegramTopicID\",\"disable_notification\": false}" + TelegramData="{\"chat_id\":\"$TelegramChatId\",\"text\":\"$MessageBody\",\"message_thread_id\":\"$TelegramTopicID\",\"disable_notification\": false,\"parse_mode\": \"$ParseMode\",\"disable_web_page_preview\": true}" curl -sS -o /dev/null --fail -X POST "$TelegramUrl/sendMessage" -H 'Content-Type: application/json' -d "$TelegramData" }