From 0995f3846c9593c10fcbd289dcf17beff2b8abe6 Mon Sep 17 00:00:00 2001 From: Kanames Date: Sun, 5 Jun 2022 23:07:35 +0300 Subject: [PATCH] Preparing the space for the next example the 4th one --- .../.gitignore | 33 ++ .../.mvn/wrapper/maven-wrapper.jar | Bin 0 -> 58727 bytes .../.mvn/wrapper/maven-wrapper.properties | 2 + SwaggerDocketAdvancedDetailsExample/README.md | 19 ++ .../Swagger-UI-without-modification.png | Bin 0 -> 106994 bytes SwaggerDocketAdvancedDetailsExample/mvnw | 316 ++++++++++++++++++ SwaggerDocketAdvancedDetailsExample/mvnw.cmd | 188 +++++++++++ SwaggerDocketAdvancedDetailsExample/pom.xml | 54 +++ ...waggerDocketAdvancedDetailsExampleApp.java | 14 + .../ro/stefan/config/SpringFoxConfig.java | 32 ++ .../ro/stefan/controller/BookController.java | 18 + .../src/main/java/ro/stefan/dto/Book.java | 23 ++ .../src/main/resources/application.yaml | 6 + ...rDocketAdvancedDetailsExampleAppTests.java | 13 + 14 files changed, 718 insertions(+) create mode 100644 SwaggerDocketAdvancedDetailsExample/.gitignore create mode 100644 SwaggerDocketAdvancedDetailsExample/.mvn/wrapper/maven-wrapper.jar create mode 100644 SwaggerDocketAdvancedDetailsExample/.mvn/wrapper/maven-wrapper.properties create mode 100644 SwaggerDocketAdvancedDetailsExample/README.md create mode 100644 SwaggerDocketAdvancedDetailsExample/dev_resources/Swagger-UI-without-modification.png create mode 100644 SwaggerDocketAdvancedDetailsExample/mvnw create mode 100644 SwaggerDocketAdvancedDetailsExample/mvnw.cmd create mode 100644 SwaggerDocketAdvancedDetailsExample/pom.xml create mode 100644 SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/SwaggerDocketAdvancedDetailsExampleApp.java create mode 100644 SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/config/SpringFoxConfig.java create mode 100644 SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/controller/BookController.java create mode 100644 SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/dto/Book.java create mode 100644 SwaggerDocketAdvancedDetailsExample/src/main/resources/application.yaml create mode 100644 SwaggerDocketAdvancedDetailsExample/src/test/java/ro/stefan/SwaggerDocketAdvancedDetailsExampleAppTests.java diff --git a/SwaggerDocketAdvancedDetailsExample/.gitignore b/SwaggerDocketAdvancedDetailsExample/.gitignore new file mode 100644 index 0000000..549e00a --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/.gitignore @@ -0,0 +1,33 @@ +HELP.md +target/ +!.mvn/wrapper/maven-wrapper.jar +!**/src/main/**/target/ +!**/src/test/**/target/ + +### STS ### +.apt_generated +.classpath +.factorypath +.project +.settings +.springBeans +.sts4-cache + +### IntelliJ IDEA ### +.idea +*.iws +*.iml +*.ipr + +### NetBeans ### +/nbproject/private/ +/nbbuild/ +/dist/ +/nbdist/ +/.nb-gradle/ +build/ +!**/src/main/**/build/ +!**/src/test/**/build/ + +### VS Code ### +.vscode/ diff --git a/SwaggerDocketAdvancedDetailsExample/.mvn/wrapper/maven-wrapper.jar b/SwaggerDocketAdvancedDetailsExample/.mvn/wrapper/maven-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..c1dd12f17644411d6e840bd5a10c6ecda0175f18 GIT binary patch literal 58727 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%0ANsA|A3-jj|r`KAo%oTajX3>^E` zq{Nq+*dAH{EQyjZw_d4E!54gka%phEHEm}XI5o%$)&Z+*4qj<_EChj#X+kA1t|O3V@_RzoBA(&rgxwAF+zhjMY6+Xi>tw<6k+vgz=?DPJS^! zei4z1%+2HDqt}Ow+|2v^3IZQkTR<&IRxc0IZ_-Di>CErQ+oFQ~G{;lJSzvh9rKkAiSGHlAB$1}ZRdR^v zs2OS)Pca>Ap(RaSs7lM2GfJ#%F`}$!)K4#RaGJ_tY}6PMzY{5uHi}HjU>Qb~wlXQ) zdd(`#gdDgN_cat+Q#1q&iH{`26k}U3UR5(?FXM>Jm{W%IKpM4Jo{`3aEHN)XI&Bwx zs}a_P|M)fwG1Tybl)Rkw#D__n_uM+eDn*}}uN4z)3dq)U)n>pIk&pbWpPt@TXlB?b z8AAgq!2_g-!QL>xdU4~4f6CB06j6@M?60$f;#gpb)X1N0YO*%fw2W`m=M@%ZGWPx; z)r*>C$WLCDX)-_~S%jEx%dBpzU6HNHNQ%gLO~*egm7li)zfi|oMBt1pwzMA$x@ zu{Ht#H}ZBZwaf0Ylus3KCZ*qfyfbTUYGuOQI9>??gLrBPf-0XB84}sCqt5Q(O$M& zoJ+1hx4Wp#z?uex+Q1crm2ai?kci;AE!yriBr}c@tQdCnhs$P-CE8jdP&uriF`WFt>D9wO9fCS0WzaqUKjV_uRWg>^hIC!n-~q=1K87NAECZb^W?R zjbI&9pJ)4SSxiq06Zasv*@ATm7ghLgGw3coL-dn6@_D-UhvwPXC3tLC)q3xA2`^D{ z&=G&aeSCN)6{2W6l@cg&2`cCja~D2N{_>ZQ)(5oSf!ns1i9szOif~I8@;2b)f2yQ5 zCqr{lGy5(^+d!<0g??wFzH^wuv=~0)g55&^7m8Ptk3y$OU|eI7 zIovLvNCoY%N(aW#=_C%GDqEO|hH3O9&iCp+LU=&CJ(=JYDGI;&ag&NKq}d;B`TonC zK+-t8V5KjcmDyMR@jvDs|7lkga4>TQej$5B+>A`@{zE&?j-QbQWk4J*eP2@%RzQ{J z?h`1~zwArwi^D7k9~%xtyf(2&$=GsP*n-fTKneej-y6y(3nNfC7|0{drDx{zz~cSs z<_+d2#ZDst@+`w{mwzmn?dM2aB;E;bS-Opq$%w@WnDwa$hUGL90u9c=as)+_6aO10 zLR|CR8nr<2DQTvkaH0QDsyn@TYCs7Nk3lN}Ix$)JM0*zf=0Ad$w9j723W#%{r8V&`{wx-8kSv#)mZ{FU%UZDIi zvbgLHyJ>z0BZe`GNM$Q;D6D48#zc9s(4^SGr>u-arE}okN62N{zuwX)@FL5>$ib=b z5Wtm~!ojD3X|g59lw%^hE?dL;c^bgVtBOkJxQR{Eb*nR1wVM&fJQ{<))bn9e3bSlu z3E-qpLbAE(S^I4mVn`?lycoV!yO!Qj_4qYgsg7tXR)Gu2%1)5FZu&lY7x>bU`eE}x zSZ5c`z~^&$9V?eEH!^Rp-Fz3WiCvEgf`Tq}CnWRZY+@jZ{2NewmyGUM6|xa3Sh7)v zj6d&NWUVqu9f-&W)tQ>Y%Ea!e76@y!Vm*aQp|wU5u<%knNvHZ!U}`fp*_)mIWba=j z*w9~{f5pD;zCmEWePjM#ERNiNjv!SnM-&rGpB9Nmiv}J+hwB&0f_+x?%*lgJFRHsqfFDPwyvh8<*xLT0u_BeEHw{q+UGj=$4udEx)Vq#sV zKB3+_C!RUKy?ac3-`+}dL2!D_2(5=8&@hBf`-AbU`-<_3>Ilqkg6qSI>9G(@Kx?g<0h0K&31$AR>R%d}{%DyXPss$&c^ja7NR z$0AN7Fl$>VpGxqHW15CjxAa6DUVmCpQNbOwBv8D^Y{bXg28> zEQE9xl?CWh0gS6%Y=G4Cy($Vb>jBb2f_dm#0_B<_Ce`|~Obt_Xp^nkR zK%o_`{h1XkWn}i|5Dp#q8D(;k;2|+{DAG{2gJgPNQ=KZ=FKY@d>QEu6W;oLsE(1}< zpnwSEj(K{Bu^#CXdi7L_$!X`QOx^tA1c{&-XTHo3G?3(H*&VM~*Aud?8%FU=dE&kV zJ$SqZoj^g@(q9x;7B30J$(-qUml{?3e+I^Cf?X0PpLr}m zS}W9`QaCwINRU&D5>j9O*j6S}R1`7{5+{d-xUlI~)U!^4+*b5tkuon-Msz03Z{{Kp zH!GAXoyr#1K;t5o#h#a%Lzj3XQGqM0TRnfu$(fsQe^wb_?W!m!+7r55q>svWN`k~T zS(gk9bi|@+8wg;dR<&0f;MpwQbY27$N{{laPQk3@3uCz$w1&jq)`uW*yn!Pe-V^%Q zR9)cW;UB~ODlwolWFAX?ik#_|v)AtHNwoq72E9Jg#v2e5SErf+7nTleI8&}%tn6hf zuz#5YtRs94Ui&E_1PakHfo+^t-{#ewhO*j5ls-zhm^C{kCARNEB1aORsxE!1SXBRz z6Oc-^#|0W6=7AJ;I|}pH#qby@i^C+Vsu9?zdtkE{0`oO_Hw|N=Lz9Is8j}R zI+8thGK?(KSZ5ZW4nQG1`v(=0Jd*0gIlavVihzo#fPaa=}(Rqdxl3^6O8K+{MqU`;1iTJ$<^k)Nms(A$j?A-wHJKvh9 zUHW3}JkE;x?FETPV8DFTxFLY8eSAd%C8vp?P_EuaMakmyFN_e?Hf|LBctnncUb}zF zIGP4WqtKCydoov~Bi<_I%y%$l+})!;SQVcP?>)9wM3q-GE6t9*LfoePBlo{gx~~e{g_XM5PQ8Y5dsuG%3Xq}I&qcY6 zTCo?<6E%)O$A2torq3-g8j3?GGd){+VHg@gM6Kw|E($M9}3HVIyL1D9321C zu#6~~h<<*=V7*ria%j^d5A;S^E;n!mOnFppfi+4)!BQ@#O2<|WH$RS~)&2Qol|@ff zFR#zmU(|jaqCXPA@q?UhrgbMO7zNXQYA@8$E+;4Bz7g=&zV-)=&08J_noLAz#ngz$ zA)8L8MrbXIDZuFsR_M(DsdX)s$}yH!*bLr{s$YWl5J?alLci=I#p`&MbL4`5bC}=2 z^8-(u4v2hs9*us}hjB!uiiY6vvv&QWJcVLTJ=SFG=lpR+S4Cd91l}oZ+B-*ehY2Ic_85)SRSa% zMEL~a3xrvH8ZnMIC!{9@pfOT7lrhxMf^8N20{CJXg}M35=`50S;6g-JYwjwj!K{^) z5Bohf6_G6z=+0V8&>F8xLbJ4mkCVu^g66#h&?tL z9odv&iW21IAh~y9D-DupKP-NcernF2(*RsFkAsM<$<>@-Cl1?&XAi4+Mh2Zm@2x#u zWH&J^1=8G|`|H2%94bnjUZyI>QACu9FS}^$lbtzzCz4AMspqGYEwFFM<%G!Oc$+;7 z3r_L!H~PR}5n8+3-&4v*fFr$uK{y_VamM0*TKn^))nQsn5U?7Iv?`4|Oy&m6himAG z%=a;2ji3f_RtDPqkwR>ISxhnS0f)E`ITo}TR!zIxPwECZy#jzo%q{BNYtd!<IP_S+=*yDOk1GgwLqe!d9esV@3$iVAm1!8RoE| zqnTz;5a)B(~~KcP)c>?+ysFAlAGF4EBor6)K{K*Kn>B(&QtMAkR^ynG%k%UbJpKM zI$}qQXXP3PISHe_vTFssbcL`irhG2zN7J((3ZFmh*bnPuiK~=#YG=820hXqOON#HI<0bvIT{z&SaqRvqaMG-d5<06zdP?-kIH{%UMR$Xn@S}Hx3 zFjg}6no}vN_512D+RIn-mo9^_Li-)WI5%VigYt{Jd!RyI%d|-LqJU$y3aJ*a$y6$1 zjyTuIF2&t>1rPlw&k5OVLhrYBvk5Vl8T(*Gd?Alqi}> z<@-`X_o@9EOB8Ik&?|;lvKHFU@#O+?T!kEf&oJUaLzN;>!}!!e1WIs(T}V#Irf$AK z42`x`z-9ogxd@%CS;D5S z2M^b;Pu)q)c&_KBO!va-4xnI57L7V@*_I_r4vU)z>xk5z6PDVqg92R7_iZH|VlO_B z#8R`5HZVn?ou>czd>gZ~s;w4ZkzVXJNP8FiezlB5JXe6Z-OLsDw%N7!(135!Vl2Lb zLYI79?U{h#W-_#W6hf`<$BQHJCu5ehv?IF+-uxUqt~j!ZW1cxfiEJal^q7~RMWQ0a z2CEaPa1_p|P6qRmmeKgas*N}@(2tH%U37-<5i(DSnVOFFxg-Sv%7&{hPeRh{U`&ufGz=V|JdYQ2sG5 zk%3JimSwQFP=Yr?u_beSG^B$nnh$4hrxb4lpTTiUFRQEZ3ulr+L3m;>;Io?D;jG6Wjj!b)nsZds<6 zX@cD%+aVr!ra~F7HYr`TB!|y-t)HSb^FQt zbo+_XP44IWJGGxg73JyhBjKMSv`77ngDOw}6Eve6ZIol$Q5s65d(1-sP{BU{1_y)7 zF8sh5A~jxRHk=wq3c5i3*e&otCd9>cstT?IQ&D4slC-&^q!ut1;WAQ}fE}Y+jU}r{ zmpSI%sW?})RAm8}$WUU+V$PmQOF5gSKOGQ2;LF-E(gd<67rYu2K| zom8mOppa%XJ6C(@I7-*opqLn73e9BMFStaBER?suJ{jte1$vA%z?$_`Em=a=(?T-q z*A=VZOQ`P{co!*UUKyV@Rd-c#*wmb7v<%rN=TGFmWmqhbj#&+?X|3bZYAjbNGTv~O zs7SIYi3VgW6@?=PGnbNNZIWaY^*+ChW&a)A$uqH8xxehwx2`<1w6mag?zuHbsVJiO$a)tQ zuBBoR>rLfhpA@)Qf`8BwRMx886%9HP5rOR%YCy9pQ|^Xw!=Mcnwx8j=(ZE)P-tJ&s zON&Nsr%14jS@K+IvrJj720NkCR*C(j&aI$EFCV)w$9M<#LdihyRKdzTjJPI|t9_S} z--#oF#;F?Y1KN%_yE);Bxv}9PWZphz_g5mReOKR`y%9UZ=n}GXWw?E$T1%NAfK1Ad z|0$Lp^;sntA>}=ybW)mkxNv1?hkZ`<8hCemcT5 zYl6$I^bhXDzPlz<>6zOy3Fu*3?>#q$;1fJ>nuxyx#&<&x6Y}j zCU&VmtCJ`;aYN+qP}nwr%s2ZQC|Z**axS^?iGu+x^{{>FIv!k0#HaXtEG=*C7kPe!mMnknbn}TKpp6Xv9 zVvq&%A3nmY^N*XTg&+=wO>(|{uTwm;ZP9@+M)6%T zwXPh-&{+aAfv^ZCzOEb;yj>A=f5Pbu)7T{9PT3u>#w*%?K8jqEF%I>A?q;E%CXn)f z|0ohNa5DMv@HVk^vT(L=HBtH*Vzo81L?)M=g7)>@j*vUx?S zxqZo23n3vn@K-Q@bx3lLT+5=fB_oz8+p?P;@*UU<-u)jb5WFEXzoc+8*EC5P6(HWr zY$mfFr=L&G>(jvl8US2fLQqTzHtAGizfR*;W4-kN2^I>L3KkXgx=e*}+i*N($}{?c zi=Q67G)oEMW{|Gdsm{)|V)5Evo}KLj%}gIe>98FFoNTLrJX z-ACRdewnT1w#Egct%wpGg~q%?!$}>$_UJPC4SP0^)G_$d4jN0jBEx}+rcd*^aDtnx zewG{`m!oSbQ?A~FZ6L{&V0hUE+b$DxjO_;oskFha>@gzy(jDnzGO>z3Tzz|i&Dakg zFid5$;SFxINis^4JzK5XIVabKoP`=ZWp|p|t{hTi8n|#XE=-rINwJ*blo?=%Se(qw zkW7x5Qs(LV5RVGxu2e&4);c73lY#0(iZo1x=MY;7mW`uUQIY+$_PqH`4a`6O#urwU zE6(FrvyExmB{c5z*YAj_P&t??F1t6TN2N!$N#~02u(t(PDVyD)$mL3hqKQ4E91N#GOIngPr&pUb-f_Z4*XV8`p1pq+mzrUlUY=4~i|3RDo;Lo36U}uwm zaOah}mO8c@%J*~~{Up7_7->8|3x<}WemgaMA}h>xD17Fey@V9;LgjQFSBS(A<+2kCP9( zlkD%;oXzWtZ_hgu0IxeTjH`6=vi|t_04Btl32=g8swD1oZguWr4|lx0RuXoDHbh27 z+ks?gkVWYnr~_{h+PzQjQ(#8kaJai4We{F!JuqCzU0t*+H{n6i3;K<>_6XUn1n)}) zJ?}JCUPYhT9S1Hi-M+$(Z**%fz7Z%IiMN6%kD>wh%r4#C?Ge4{>w9o??Vbehy9!3@ zffZs8?LGxyWQr@yB(|%~Aa>fVj3$O=i{K*f;?h-a@-ce{(cY8qByOCA1r0;NC}}gr zcC^fCa$Ot`42n>`ehclOAqBo7L&D6Mi=;M5!pd@jj$H z?U7LQWX_u7bHpBzF7L-s4*`C)`dUrbEIgKy5=QHsi7%#&WYozvQOXrNcG{~HIIM%x zV^eEHrB=(%$-FXVCvH@A@|nvmh`|agsu9s1UhmdPdKflZa7m&1G`3*tdUI5$9Z>*F zYy|l8`o!QqR9?pP4D7|Lqz&~*Rl-kIL8%z?mi`BQh9Pk9a$Z}_#nRe4NIwqEYR(W0 z1lAKVtT#ZTXK2pwfcCP%Apfo#EVU|strP=o4bbt3j zP?k0Bn$A&Xv$GTun3!izxU#IXsK1GQt;F0k`Tglr{z>v2>gCINX!vfs`aqag!S*AG5Z`y-# zUv_u&J4r;|EA`r!-gsoYGn<^nSZLH-nj1SRGc0MRG%LWVL)PckFn9z!ebIJ}eg+ix zIJo7GN;j1s$D6!({bYW)auypcB~eAWN;vhF%(l=|RR})$TOn;ldq^@8ZPi<%Xz~{Z zQQ|KAJ@JHaX!Ka2nhP%Cb^I}V6_C|e1SjOQpcPMMwfNz#U@Az|+rmH*Zn=cYJu-KR z{>f++Z~P=jm)4-7^yc#52U4qeNcBRYb!hhT3Q7Ngu5t@CvY*ygxu^Eh?2l6= zhdqN{QEaP(!p>1p1*toD!TllHH6EH~S%l9`mG62dyAd+?}1(vf@N*x^6vhEFU<-RqS7#12*q-xtU z5d|F^n%WSAQHnm-vL)4L-VvoUVvO0kvhpIg57Wf@9p;lYS5YfrG9jtrr?E<_JL{q% z7uPQ52{)aP{7<_v^&=J)?_|}Ep*`{dH-=cDt*65^%LodzPSH@+Z~;7sAL}ZECxQv+;z*f;(?k)>-Lp@jBh9%J`XotGJO(HcJc!21iZ98g zS-O!L9vpE(xMx1mf9DIcy8J5)hGpT!o|C8H4)o-_$BR!bDb^zNiWIT6UA{5}dYySM zHQT8>e*04zk1)?F99$dp5F^2Htt*jJ=( zH(#XwfEZ`EErdI~k(THhgbwNK9a(()+Ha1EBDWVRLSB?0Q;=5Y(M0?PRJ>2M#uzuD zmf5hDxfxr%P1;dy0k|ogO(?oahcJqGgVJmb=m16RKxNU3!xpt19>sEsWYvwP{J!u& zhdu+RFZ4v8PVYnwc{fM7MuBs+CsdV}`PdHl)2nn0;J!OA&)^P23|uK)87pmdZ@8~F$W)lLA}u#meb zcl7EI?ng$CAA;AN+8y~9?aon#I*BgYxWleUO+W3YsQxAUF@2;Lu-m#U?F(tFRNIYA zvXuKXpMuxLjHEn&4;#P|=^k+?^~TbcB2pzqPMEz1N%;UDcf{z2lSiwvJs(KhoK+3^2 zfrmK%Z-ShDHo^OUl@cfy#(cE=fZvfHxbQ!Chs#(vIsL%hf55_zyx>0|h2JT=|7JWo z+Uth3y@G;48O|plybV_jER4KV{y{$yL5wc#-5H&w(6~)&1NfQe9WP99*Kc+Z^!6u7 zj`vK@fV-8(sZW=(Si)_WUKp0uKT$p8mKTgi$@k}(Ng z#xPo-5i8eZl6VB8Bk%2=&`o=v+G7g|dW47~gh}b3hDtjW%w)47v#X!VYM}Z7hG1GI zj16;ufr@1^yZ*w3R&6pB8PMbuz%kQ%r=|F4+a!Gw2RBX6RD5c!3fU@+QCq#X7W@Q5 zuVQ}Uu0dzN+2mSX5)KV%CsU;2FL%B6YT`10$8JR^#;jOO1x?t()Q_gI zxpQr2HI0_^@ge0hNt&MQAI`yJ1Zhd-fpR{rdNmRkEEDu7SpB)QOP4ajV;UBZZZK<6 zWds;!f+|}iP-kqWAH#1@QisJpjcg`+s80!LhAG@(eMad|zcln~oE8}9l5!K{^zf~( zd=HArZ5+Mryc$uNa`@|GSdOX=y}8GZc-%p8W@OM)uk2DfmhQXCU1E#y3XJ>|+XdW2 z)FQLeK38}u_D(5E{GV|YT^rI4qds2{-r<@@@@SG@u&4LbC z5o|KKqVM{?wk$5>2?t*I?IHdh~gljn_2m2zqZNJEEz4Mb$o&I3_UAg#$B{0u$uF4-q}{ zzs5+k@qOe08!CGLGmy3eRrcuqsgB*B>i8c3>3=T^Hv>nL{{u)jtNc6tLbL7KxfUr; z=Pp14Nz+ggjuwd~*oRJ)xWwGwdge+~b!E%c3Gzw6`vT>CCxE0t6v5Z`tw1oKCcm68A~Dbc zgbhP6bkWwSQ=#5EsX*O9Sm^}EwmQQzt2V2phrqqe2y)w8;|&t6W?lUSOTjeU%PKXC z3Kw$|>1YrfgUf6^)h(|d9SRFO_0&Cvpk<+i83DLS_}jgt~^YFwg0XWQSKW?cnBUVU}$R9F3Uo;N#%+js-gOY@`B4+9DH zYuN|s&@2{9&>eH?p1WVQcdDx&V(%-kz&oSSnvqzcXC3VsggWet1#~bRj5lBJDo#zF zSz))FHQd8>3iSw{63m`Pgy_jkkj9LTmJ&!J(V0E~&}HJ4@nXp<(miz$sb;(I<8s!7 zZyezu!-+X81r03486gAlx@n#aKx_93DREBtNcYln*8oliQ zbh0~SkAgHXX%C6}HwN(TRwaK2k_$Y}PxKId;jYt=S1Bf<8s@(IL?k3u1(f^V%TYO1 zA_jPf*V)SLEZFWS#y>M&p$LoSk+%ubs`)H%WEZf=F)RKh&x;i)uLIGJ94~A4m$(;S z;1rQC{m>--`WHFcaFA&5#7~vz|5S;{fB(7pPnG;@$D~C0pZYNEG?B8X*GB2e4{Qk; za1oop8OvHqs1Lk6B`AuYOv4`y`IgM315iTr{VUVc9WeOG;xE z%eDQgE4rb_B%vuT>N?^K zRvPnQwG%7RjO26+DY!OXWjgBu4^!)W-+ob_G&nX++))pD->QdRCo0spZN?Y*J#@-q z)fk-fJvZYz8)GSxYc^oXYIM;Pw}ftHW+a3dis#dXx^OS^m-~FlwcVr6MXv78fNI!i z51K-2t&!&IZ4(GF=mT@;qIp!&R(I@UiWPPz)%Us&(FdAAGxZ-+6^UZ7em`J-F#_3r zLkHym@VAnZFM$J~?0b@&O`l4YXyvOQ+OqalbZ0{g{qD{neY_xno1ZpXlSJWM=Mv(~ zvK{?O>AcXpbd}+hn{~*>weZwDTURX*M^9RkOO#DUfRW1;comKg1bn+mlsrNY8XDyW zgWg9~AWb_1^D8zsD4bL(1J4oinVy0Fimrh&AC}Itl;IH*p4eU_I;SWkOI!9tAbi3B zO@0=q#LHAc>z?ve8Q&hsF(sR9lgf_99_5Kvuug<^&0}Y&m)YjI?bITGIuh}AJO|>z zc*`Mly$>TA={AIT#d%JuMpXHDt($qkc*3UTf-wS$8^awqDD^|EAeA{FoeyJfWM@QX zk>vJ4L|8DU7jg_fB^3Qvz*V$QmDl*AXdw6@KSckh#qxjLCM8Nba!dTkJgr(S@~Z0a zt8%|W!a~3zG4Y&X6xbLtt^JK5;JT($B`_9bv(BjRTfG_Y`tg3k-}%sQoY@F|=}}${ zwmW%Ub6jPd)$;NA0=b7w!^2dE-qvI4)AVr`yvkabJcGwvuQ2rAoRlTjvCC^-$2BG} ziy0<6nt8;J67rymwm&wVZ8E7Krouv2Ir@-GQ%ui6PR42KHKms3MK&Z$zp{_XAVvrd znK4cbg)Ggh5k(4SlFOM9yyRUlVH1oo%|6Lu9%ZxZW28!c9Z%H5#E?B?7H7ulcUtirB<{s@jnS(-R@we z^R#{Mn$#JXd~5sw9rU&~e3fYTx!T&hY{S<~7hviG-T$<4OPcG6eA0KOHJbTz^(`i~ z_WON4ILDLdi}Ra@cWXKLqyd0nPi06vnrU-)-{)Xp&|2gV>E{Uc>Td`@f@=WYJYZ^- zw&+fjnmyeRoK-unBVvX>g>wO3!ey<+X#z@8GNc9MD}khMO>TV{4`z zx4%!9|H6k|Ue;`M{G6d!p#LL+_@6WMpWgF7jk*%$D_JB3c%D`~YmHRJD1UNDLh;Tf zYbbKcv9R(81c4yK+g+1Ril{5w#?E}+NVz>d@n48C-T-(L?9a9W`JV*{dan-sH*P3_Hnt~iRv)}ye;7$b}^4l%ixphDK`G#b!4R4qoouT@*A zZ)kQa)e94??k7N>tqoRl>h(9DFq&92=z|F!LJrh-97EoFL|Wt2v}>(zG1*#aiYA_^ zM_&%_G^g*O8x650e>m!#MDmwRub!irY>^^|L=!4^%lBr;?}mvgP3y~^mSdKSm^R~WAt7T0_ck0mA`GS)J^SYTo6^vQ|vuM7!92&@$BhtcQ^Z4h2)aN zh~EQthyjn1(eI~$FtuHH!|x(iHU{9k40k5nPBwB)X@8Lo$P6u81EeoNOGRct%a-LM_4y3Ts z7ki0PWAO^Es6c%M*SSRn)2|NAoUsKyL%))uVx7?5lkrk`njxs4q@M~x+8%jr7xV;- z|KC=g3aTZO|y|g~oHXB6b42(|J_&fP2Y`*;L07H2d>{~JP zFNGl$MYUG(Qy3dR?9Bfdg8#peGRiVP8VYn@)6T1bj*v)s6q*7<6P(ZVm4ZnTA;rOHSd>P`_5uT0+azWdV`gIvLaJ1o*DB}&W6LCgX|BycgF5qd z!)}dT#A~4*6{1=Bd5VV(Qa2h4x9m#2X711z(ZN>i&cn`BopG*5P`CD*HfYiQmXNGk zhgqcHPBrJP$Z@PLZ4}d-8^}%X^LtUDHq&;~3}lUyrxxl@|IS={GP&6-qq&Iy5gKW- zC@$}`EEZd}DOSeSD+v_x5r_tpBWfN0gDa21p(@TAIrgWQFo7NO@slI6XOAML_lN;3 zEv~}LlMbGWKu}0s$tO-vR)wD!=olGcA?}vU;lRu4+Zf z?nCD7hBmA5`U9P#W8-*0V1=OT-NI0k&_`UZ87DbpYq_=DBdyNDchZ<|V1f%dbaa7i zf~R+6Xt%G)VXlM@8REfP3u#7UPadWYOBMsQ56fHRv!0p9R6q>Rbx!n|IY0goLb%{+ zzy|5WXk+(d@ChzOWatIV1lc1F!(uEOfEmMd;v`|$Kt3X2Uws;%@OV!E86PN?CeHV& z=4#TX{J8RWaH`)!J<8AUs#Ar{6Am^8M{S( zc%K7y2YbcLUz+*eDTXdthNE)Lm^P&*e^eV zilOS9)TVKgr9_^_M!TJ^44v<YF2NO=h(oOr5jYxVTxWk0XJ8n0{F_SOH%49WMk*Sg7`g6B(=^< z*rLAW;8I5;1?;Fh{N=f;kxjLpj}u^mD|k8lih|G4#}wEG1j`HIG( z8y;BMR3cE01e?(+k8NLR|Z+)#>qR^iMZc=BkcixWSKYmkaHpIFN?s%*74kc&wxwB zrtbYBGz9%pvV6E(uli6j)5ir%#lQkjb3dvlX*rw5tLv#Z>OZm@`Bf2t{r>u^&lRCg z11*w4A;Lyb@q~I(UQMdvrmi=)$OCVYnk+t;^r>c#G8`h!o`YcqH8gU}9po>S=du9c*l_g~>doGE0IcWrED`rvE=z~Ywv@;O-##+DMmBR>lb!~_7 zR`BUxf?+5fruGkiwwu|HbWP^Jzui=9t^Pmg#NmGvp(?!d)5EY<%rIhD=9w5u)G z%IE9*4yz9o$1)VZJQuppnkY)lK!TBiW`sGyfH16#{EV>_Im$y783ui)a;-}3CPRt- zmxO@Yt$vIOrD}k_^|B2lDb2%nl2OWg6Y)59a?)gy#YtpS+gXx?_I|RZ&XPO`M!yl7 z;2IS@aT4!^l`Tped5UGWStOw5PrH#`=se%(ox%gmJUBk18PsN$*-J8S%r51Y$i!4N zQ!rW%cgj44jA~_x%%smSTU2WG_W0c&PB$A5*kl8{$|865+lSIX~uyDT`uI7qnS!BPAg1Wwrc0e)8Usf zv9^E38H&hWSp5!@K8Qinl|)9 zEB?NMaxZK^GB!PUf1TBw+`H&jFSNI=Q@v5$Ryf-y^#IuXO#vsM5R+9@qz#z0fD0GP z9|Hj#E>?<=HTcsF$`xn`je~D&3kF1Qi%dfH{sKh!~(IpgjkDGQn zQx2F9rv{*x2$(@P9v?|JZY)^b9cd+SO6_1#63n-HAY3fE&s(G031g2@Q^a@63@o?I zE_^r%aUvMhsOi=tkW;}Shom;+Nc%cdktxtkh|>BIneNRGIK{m_1`lDB*U=m|M^HGl zWF#z8NRBduQcF-G43k2-5YrD}6~rn2DKdpV0gD%Kl{02J{G3<4zSJ1GFFSXFehumq zyPvyjMp2SLpdE5dG#@%A>+R3%AhLAwyqxjvGd{I7J`Iw{?=KKPRzyrdFeU}Qj{rm{351DoP_;vx zMo*s+!Gwgn;${(LXXO(xyI@$ULPZI|uzYR%`>MmW6Hcr1y2aM5b$grFwW_(9Fzz$Q z$&8dKNdWvBkK=iYWA|0}s1B7>8J$g*Ij_+S9vC1#jy~uA8nr)yY)a+ zoJ=e>Lp`7v3^tQN<&6UpDi{c1b}F~fJ$9r=p=@U^J_7bOck$5}ncVjYB0yEjbWrhe@E`j64yN3X?=k_F3BalH$aN zV=94?wDNv=BKLB<1*xU|65Zl!%51r5sHQ?qCggCw;$2QfCZ$lN40WPL=n^{Prf^QS zjbZ&1MRGgiZ2T)}DpiluFr#q*!AZJ$1v#d10YQ{>wQ5px!y28-1hCZ7lwvQnQYN*U zOg9BpvB0A$WUzFs+KWk1qLiGTrDT-0>DUpFl??l(FqWVz_3_Xzqg9vTpagp- zZcJ!5W?|0G%W|AJVVHJ7`u6@<4yyqMGHj@kpv`P+LV<)%PM__Rz&oq~t-*vV12@NR zoEVPz<2D>O==MlNI`;l8Gmv49&|1`FR!}2`NLRCqA{@`imLz6zrjS4ui0)O;!Pu&?KPAcX)?tDPS26uKvR(ry(p{6kiXPoZbnQ!vx6dLu zZCaj~Ocr$h##KqsD;9;ZiUwhmUd%5lrwczWr1Yn6V>+IK=>51;N7JDkrm1NY-ZBes z;FxeOTb^HAyA+~P2}WvSSu_fzt_K=(m4wUp%c*^hF zEJ+1dP0{0B8bryXR+qApLz43iu?ga<5QQxTa$1gMCBq0W=4|DTv4nY4T*-^Im%>U~ z)98;hc(d7vk0zAML$WnPWsqK>=O-FZSLI3_WQKr*PCK=(i6LelZ$$}XXrD5cb~VXz zT%egX>8e;KZs@jcD>cL9VP(Q}b0r~ST$Mc%mr1cC8mqRUQc|N^9@Weu$Z|KeczK7HhSFeFV0i)MQmwrn7CBL=p`_9n?nh320m}6-MSv3L7I*<*56GR zZ`zI^1zyC7F#*zVL@M)F2+oqxydaiQz?|ODmqs|Ub8%&KXk9P3P7<4tM?X{~!;Ygw zt=h7)AYGDO9F&wV=BhCyD9exr#YM_-<;Fo~iE>IBEXK$%;JCUAEr;lR&3S_DUy_E) z#!oCYdENVE9OaaeaIrPk-odMtvdFG;ocA#`L6AifMu0og^?Oy9F|Et9q6 z8;3_|9+Io@hqYoN;58x1K&OP!9Vd#dzhTRjB2kI?%31ceHb#Q~WqJV5lw;@b>4@Rd z={z1S`d05YdWC*RLc7sR0bVGSytn-a3`JZL3|d8KC?vj_70Vi4ohP9QbU&Q4?Zjd0 zSZA?KbqLBsJg(qj>fycto3`zN-)lDe4{Ij-QfoBn@rT_tTszA+CnM~xWmE(4zfpCQ z;zPJfl3=ctrggYM!KQg;V{J;utMMF9&BfOe!<{wU0ph?-VQ%cv3B%fFiW?6xBPdf0 zD-HhEU?0C`G@7e+b-=8fj=TP3mdz&SIQ}Nd`*G#DTz9Y@b zaoDF}Gx7ZhPzpDhi^fA7WZ)EAEFv;N2*bKp0T za0t<^1|Zc#`A+?s$!$8eO4CK~PUFECC3BwNR4f)!V&-Y>$xg(%T{MtrH|CPcO(Lf> zE_meE1?6S-qlV^p2fh! zT11Ub)hHw!_mpFDMIAFB`%Yal+`1IXV>b?%!q^Ps%8nh8wtjVGlF-!5x*D29WJ4=M zZ7X(QvKe$YZNgM(HibD7+VO5Q29?@HzS?k$c|3B@JI6dlLgu5S&LbU4=4p-Yn||z@ z4p05vq*k*pbOV9QjVTMp8`c$?t@~!$8&5AP_sz@tk%a$nWHMh-Gm{WS5+q)5W6pU# za@YZXJCLTpZ}zb=$HCYbIm->?Hu6XIBz_d7)n1+3eSLzGVoNQCTHcu9qS2@({0sxc zu<-mhx@Xz_*(S1DEL|d0`YV7uNevL*Y6|DAQmvSp{4DzPL@>hqJ?`FjvIU;<&}YEKDmFUGSBYjRmK{Km-1m%-t=fFfI9kV|POH|SxvO=P+><+1JK_lt5F6fTPf8PXU+lYEJz__** z&>`4F2F8EWE+k7ZsZx9%!?A56{lsk1juYw5zN)V+g$d^Q^Gm}fnHKA6L^36=`e;p% zp{;JD$X3%}O7qINR*2<>a422}_hmc=)-A7B-1#2v85jN5K31t0DtmqON-Dim`XIR; zOo`KRv)gtn?stp*`^f>}UDnGYGnJAbl(4srd>(5fo2#oqi>#bus86EHfeItFIu$+% z;lE|3gjQA`BXHEE5JdcjCoethN`@NEc~zm6CYf@LJ|hT^1>l}gRl7oDHMnw!*5*IC z@@Mi=gO=lZSnWln`dX^4Bd{9zYG{HNIX-87A#5OM%xu*%V?7K3j3CHcN*t!zNK4N4 z!U2?a>0`8m8}UQshILC0g6-k>8~;SRIJ?vQKDj z@U{DrstWIT7ufyRYox^&*IyHYb$3wtB}V^0sS|1OyK#sDc%sh+(gy&NT9j4Aa7J0C zPe$02TylMjad&|{_oe3`zx)Cqns?6qThYue6U=~j5+l0Po4`bX*&9V@a<-O;;vCzm z(af&;e<^}?5$7&MRW$eb*P< zX|33QmDvFSDFK-qMz|RF|Eedum@~W zt~8C1@i8@LammTr)rAgKm8X_SczCg@+@LeWpcmx;VL;iLQJ;t%Z*|XbNWUnHX|o=Q z%bsXc%bw=pk~8%3aV-w(7E$co9_cHQ$!}Ep6YcoCb7~GQBWl#4D!T8A5!P*tSl4FK zK2CX0mjmosg6TSK@-E-He{dm0?9h{&v~}OX15xgF<1-w4DCypYo22%@;uRq`ZFld- z{Uqof@a@P5dW@kfF-`1B1(!R>(DHb&$UXY%Gd+6r?w8klhP&ldzG*6#l#VuM&`)ki z)f$+Rp?YYog9u==<#MC%1daG#%3EOX9A{7$`_(s#_4mV`xZaB+6YlX`H4{}vq;)TF zo~fR@do6EZIR?413A$V6o^fq&QV7P(bB(9m1969szOosyhZRYciAWXe4@u-}s(LeJpuIkSx)XvjXmvVEseG zJvWN4s|$6r;s(3F+cgeh4DMEq??h!$eb^5h#`whT5d03qfYpol8dCim)A^NG1-H}} z!b)V8DTL2Q8@R2p`y4@CeSVj9;8B5#O?jfl-j<$Quv?Ztwp*)GvQ~|W8i6?-ZV@Lf z8$04U_1m{2|AIu+rd8KW`Qk|P1w(}d%}cjG6cxsTJ3Y&*J^_@bQgXwILWY7w zx+z)v81rZv-|mi>y#p$4S7AA760X?)P&0e{iKcWq4xvv@KA@EWjPGdt8CKvh4}p}~ zdUVzuzkBlU2Z+*hTK214><61~h~9zQ3k+-{Pv~w`#4|YdjTFKc{===9Ml7EMFmE!f zH}U3O{Z`DuJrBZbz~OjSVlD6uZSEeNK8epja_LanEh8v;_$Eg9?g*9ihMoat$#qd^ z?;x?a*y3-pW#6|kF^<$w;2^~s!fc;3D~#&#WYZfK@3;bO{MvmN?>qy%_%v`BVCgfC zdwL~(H14Gr6w(1CX|R;zhZh%?*Q{hxJH`MV2)@Jg$pbqjZeL+LO7^vwgi!@3yn@NT zU91-{;BWIi8bV-j-YR|A9Qs?M?e7Ru&Onl1(Sz(kxAw?LEbd+Le%Z43rZgb2h2m|e z^rblc;4r+}?@tC(YIBB_qpQL?_kg{;zO#6JD9{;HSUgf@zIZ)}Bh4wFZIs>meSd}f z4iF~nD$KAV6CVEw+{YOPrW~~y~Y=?snG4dE3edN$~SXh`!c_F zUsQ1M;ARz&v0mIbfP}aLWZ&cBPU+DU{l+0}_>9DZGL{@}lF6QCtgAg;EWUu`D$Evm znblG}kC!}Mw)bR~U;+S}T9TVc6lXWR!LNMm)nmxr*ORkv#&UO$_WQpt0WdX{A=bjC zV^lB~(r;y!C4$Rk0fWUR|09O?KBos@aFQjUx{ODABcj}h5~ObwM_cS>5;iI^I- zPVEP9qrox2CFbG`T5r_GwQQpoI0>mVc_|$o>zdY5vbE~B%oK26jZ)m=1nu_uLEvZ< z8QI_G?ejz`;^ap+REYQzBo}7CnlSHE_DI5qrR!yVx3J1Jl;`UaLnKp2G$R__fAe;R(9%n zC)#)tvvo-9WUBL~r_=XlhpWhM=WS6B0DItw{1160xd;M(JxX_-a&i%PXO@}rnu73_ zObHBZrH%R!#~pjEp~P?qIj4MdAx@sv;E96Doi$eO-~)oUz%Z0Tr4K`-jl06Il!9{s zdjF*1r{XU?)C(%XKPm;UnpnDGD%QL3pgo0ust~+sB0pa|v37>E1dp*Odn)n=DY;5j zDzSAkU9B6F$;|##_mrDe#%hd7pC1u`{9ZKeDdtkyl&4>H=e)Fq@}$UffPt1#cjYZg zd%O%xpg4~brEr>AnKT)kF@`cdX4tMlZ#Vk!l1Xz!G970p`Gkv^lk-|>jmt0W5Wu6woGf?hNA zXO2?BG)<{`NsYAY#3|L^x*=rS7uWU~s<*UhTC8AYc#lGP-=Aw1I)@y(<` znQb^nL~$rlDbsdAc4nc#{+$_;Z4iY;Pi0i9Q;>ZB3+IjWLg_r40-Fso^xF<*_s7Tj zujFrMH{vW3PmCndjQIscnQE%`Qj|E2kidi#c&PcWIMyH+e#7!l`<$_)*pDP$!49pY6w!bN)j8~A1wV%gIakf+vA04 zV)_Q=QMPSj6$M2Ar#KhhxsbZUOq3nZHh8m0?Fr}I6N(Fk zkhXM(f57yOa8vn^97J+g9ISPa=-**6^8ZX&g=z+m&6~x<1>)MyM&tpbWhSf8#+Pcd4rVK#)NSw>1eLKHTO z44A@sc_}Ypi#ggFRbDRFV(IhOnRU&XPrQYh9`mVMo-^U$&AwsXooSRUFqJ7)XUXCK zFpt;gJ}9QTN9xy9$=3OnRkjgUuQZ`X)!}LBm~WUIEKuK-Z%}f?2?+MKucWU<3)>9G zxsz~2pHut1AmH<@66;LdCB9+dSpojE4ggrYS?%icv*Rpi?G0Q($^`(g<1&Z){O_5B$@f#;I2-+Qa1P$a@=u-vOY5vqo z|6G67X;*A|V86ZET9OpFB&02twZtc2K}~ASoQpM_p{vJ{-XvA8UmQa4Ed%fS{D@g( zr_aY0gKw*=2SIGznXXKFo$r0x3)@bq8@4od^U(L0-jvTsK@qYOWX?2G_>N+?;r{TU2{M>V0zid zB_Zu?WSnRl@k?oE*gsgv;jH@+ z-}BDGyR-ls7$dz{e( ztv7lI2|OxNkLD4zc3xGA`!d7LiSdOys4H!8aA(_c0Nm*uLjS4TW%Z3v>am1nwQ_lI zIs85Uufd;cv-(4wi(Js;QsL#|qdv)n;r_?puaK*1>zTC@d=#sK+q1YF_Q(5B%%3TtI8&bNs_e8vIb;oc|Rk`F~u?|A?jj{c={?{Env{mW#q@8 z)#WEgt4B6b&X2?o3=b`ilz;)-h$t4;hsxPDo-%5C(7m#c9tZF-U`vcx0HnVtf_X(}4Tg}4wx(=y!@T7{)4;I_p95mBhikg-|U9z35q`|!1+Zz@97 z(PFE5jCv|=t;^=(CLqYp)k90rV4ZSiFDAhD8YOCzv{}1WDuB?epORibW36);q(Aig ze27@D?lN-ZyjuB4GsebA$;+(KGiOtCe6Bfd%GKRty>dBS1GUe}MXgnu61UdgO=m1& zE(eECPF_%J-lU{;R)eQJot;;}Wch$-8Z|lxN*AAdc;bkpbD`W}F=Z}^Cy(SKyfF#+ zQSalA%JDDAu|77$M3E|kv==3vx~pFPw_<+9xgcE#oigh*>#QsA2}sTYO7uY(h@dhR zHJBi^bb-`1?<1cGFZJa8Akzs{H^$N<)5@hlXeKwt9hD5^5K&`pdHOI92p<7XhS?>| z(5h9KYctN|H+W~Xh2N4W+yjMyBm(AdewjX?PBuRU$^J zS#+U($K6rhFFzf z0q*kJ>B6xI1qAti?H@X@dxtB7_vT+Nj@PNxr?CSK#xqE6jh5S{`nH#zzvjOId=i1X zK(Yjl!7KF(73GXYLVkQA5irn|v-ArCqwi)CM8X&m!#@NQ3bqmQlfurU4qT`zl_m^C zhpk?mfVvy9L|)*+bW8&NY4lG$@0_PKfO9+~(zrbn?wECGi7472W{H&dRPZum^Qf z73C-TR6$#q>XJgYnUgV!WkbmRas;`TY#7CxPXIEGwT6VPBDKbyr#|C2M%q|7l#Ql< zuM}j=2{D+?SxT8?ZJn&Z%cRN8Gu@y(`zV(lfj1T%g44(d#-g&@O0FL5;I9=?bW>!M z%c3J&e}GThdean-<||jUh zlLP`UeKBhhrQ?HHjM3}kfO7Z=EKB%+rs*t+nuBoeuD2yk%n32SA?-s)4+DsTV7U&K zyKQO2b2*tQT}#((=#fkb%hkRkt^%tY&VK$hcs91+hld zJ%lgC!ooILC&|(Z9$zzk=Q0*%&l7wwyf%nv=`C=OcPjb|Q%@9*XkPGFrn+bxp?t^D z!_qO=e-;bnT)^0d|Ex9X&svN9S8M&R>5l*5Df2H@r2l)VfBO@LqeVw`Fz6TSwAt^I z5Wu6A>LNnF7hq4Ow=7D7LEDv3A))d5!M=lT3ConlFN`5eTQMexVVs* zH0tx-*R+-B@&Lp`0V4j6Uy=LJmLQRY_6tH4vnV{_am%kkv|{CYkF}4Wn6U+|9Xre$ zJkO;_=dtw`@aEs|^GlO-zvpp-73H;PYk}V5RrH83G4SVkRJ0YSluQa8pKejcqB4u~ z^9^lDR|?7vEo|jITtaIFI6}1;vTI6n(d0kDGQUJuk>>sqdd7#VBF;?_dM5i<+VMEq zc>habJK}_0eEsOkdwv48d43jKMnqYFMnYDU&c?vi#Fp+S)sxo1-oVJ*g!X^^K! z>z!G8?KfU{qOnLHhaEF4QRHgOpfvoo7@=FG(2ZefYJk- zZuA9ubiTTP9jw9Uzpx8FfJBFt+NNE9dTlM!$g$|lTD za4LMNxWhw8!AV(x;U`IV-(bK@iQ%#QSmq8D$YqLgt?V#|~% z;{ST}6aQbOoewMKYzZT@8|Qq z@9SNBu1UErolMjrhJW-Id&7y<0I<+Z-lr`IHMh1;M)n@g|hx_T-maO`s{Tuhax}EjC zS;1kdL*A3BW5YZXgD|0zm)g3_3vMs>5xgHUhQDl19lfQWMcfLTsw$)amgDs>bW*Oe+$UK^`ioL%F0Ua5vb%II+EGS>*I zw)AmqcWBZpWH&Aswk_FJT=J|^Gn=MfnDTIzMdnoRUB91MeW?e>+C)g3_FDN8rN$(? zL+kH!*L}rq`MK`KDt^v4nUJg3Ce-`IW0Ph0?|}Puq5WIS_a7iEO;~mGQqqo=Ey;ND zhBXA^$ZrCc#&0}dMA&@)&TCq5PMzgJPafZCg-6$R zRqJ2+_t+dGUAY@~xPzU3`od7-(8nnuMfM-4#u`Q~`l-CUGC7u*^5VwH`ot;Ck#R1% zRr%?;!NrB$w^}NW=GGR}m!3a9bh#wXrq?fF7j-IS?E_!GaD3KYzcXhCUHhjEl-6b# zCmIF#4y@HN=^#uIz zRFl8D)Ri1<(Kr~Hoi_MtXWP8^AyTKxi1)ew88bV{*Ok8w8YLXBFW0sRJ<(vU{$ym| zz)feLQbz3k;_}2_{-bW`h~t&2$ObtlbS?k2k|5Kbu?FZLDMTVW_Z6p#A)c)`3DD?a*hxHS2Zj zcIiebfsINfWvwY7Z{YOlIQ61b`j=%6{>MPs+`()Q{wq0z0?|jwRN(1IrMQsj40BHx zvBC_Xfcr;55&}MeoP_@#nz$avCh%FJfE5NNAE~fW@L7~f8Y=?Wno31128EYOK8+O! zc4Vaj-DCsB6CPH$?pQQVbb_(tg^x{$STYM_WKLtrh-_-Hq-M%Ubpt6$mCHY!B{ISD zz}grIo^bNVDw4={SA2*nDNq5`e@ZO5r4TbQpHM)~qfD9!s0h(Jf>vYd;I~j<2fD4)_>ctbwNX6S*8>i^*4 zYKI5<4}d;hM!!N|A$@eg09J|HV;!UUVIau_I~dxZp#?a3u0G)pts6GKdCNk>FKxdh_`Xu!>zO3Kv?u+W6cYJPy!@=PuY868>3|Zg} z$7galV~M`d!q(`I{;CJsq6G9>W0}H6gVY`q7S@9s8ak1r{>}*Q0JyH&f!f8(NZxhC zkn|KS64r^A1fniFel2KkxYByk%erCx9UgFLI)`yuA)X z8SU?6kj!numPNCAj}>1ipax(t{%rxU;6`(Nqt$~Z4~76TQ$9d8l`yJ}rniII%HbH= zlS_7o!qB{55at^>N!Voer%)`KMh9Yd@Z?~nc19*hs)NGN954`O9zA&&vJHbm&|D@E za(&z6A=3NfC;>I)hlI@ulP8E@W-ziGe{iCf_mHvWGldxw8{ng-hI({EtOdALnD9zG ze)fU?I(DNt)Bzdd9Cs^>!|+2!xv1SK=I zJ+y_;=Sq-zqD~GKy@{5(my&aPgFfGY&_mayR_)?dF_^Fwc-n!UAG+fQQGfjWE-1MF YM{}PByk10KD_nuQ4E7Du?}+~TKh4V)`~Uy| literal 0 HcmV?d00001 diff --git a/SwaggerDocketAdvancedDetailsExample/.mvn/wrapper/maven-wrapper.properties b/SwaggerDocketAdvancedDetailsExample/.mvn/wrapper/maven-wrapper.properties new file mode 100644 index 0000000..b7cb93e --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/.mvn/wrapper/maven-wrapper.properties @@ -0,0 +1,2 @@ +distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.4/apache-maven-3.8.4-bin.zip +wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar diff --git a/SwaggerDocketAdvancedDetailsExample/README.md b/SwaggerDocketAdvancedDetailsExample/README.md new file mode 100644 index 0000000..298cf9d --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/README.md @@ -0,0 +1,19 @@ + + +# Getting Started with SWAGGER Grouping + +This folder contains a section of the tutorial course regarding how to use SWAGGER API's at maximum and make your application much more friendly for external consumers. + +### Reference Documentation + +For further reference, please consider the following sections: + +- [Why You Should Create an API Definition and How To Do It](https://swagger.io/blog/api-development/why-you-should-create-an-api-definition/) + +- [Grouping Operations With Tags](https://swagger.io/docs/specification/grouping-operations-with-tags/) + +- [Grouping APIs in Swagger - DEV Community](https://dev.to/s2agrahari/grouping-apis-in-swagger-55kk) + + + + diff --git a/SwaggerDocketAdvancedDetailsExample/dev_resources/Swagger-UI-without-modification.png b/SwaggerDocketAdvancedDetailsExample/dev_resources/Swagger-UI-without-modification.png new file mode 100644 index 0000000000000000000000000000000000000000..be085e3d518e099f2e7546cc32d37db1ca60d7ee GIT binary patch literal 106994 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 z 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 ~ z{)$QI@I}RO$oiw32Nht=I-Lq{7YRJZ74BH;nT%~I39@PaeMJDoEI&`$g&c!ec1-Cad!h?!e*?1uKq-dfOW*_rl+=w11|T=ZPqu?_=c8zjfT?1I*LH!U~4^AMCw% zSd&|~FB%XmAfnQgt}aBSDpI6d5EUUR(o0apsFZ+|&=W+8AfO^3(o{sG21I&EP>LeG zOAR2sgaDz3oEdewzvW8ydA@z_-S_P0u73<*-gnM9<|w~W=9tFrb9Y8aj6>tr(FgQ1 zVev+UJ$E~J>_-56$5FFC)HncsxpgEc@72aQIHqN^wOJjBlR;XiOSOlBZ; zASIv94~^$a+8=yC7YXL$T`) zEGIR1?3WZT*@R42Q|v9eTZCLy`B>TLa=eobw*6x4XtlGk^>MQ7#aZZQlCj?HQm(wR3OKm-=(-e}gjTw19HeS98Pw<+`?G%pRO;-XY)6Ob-SG zgH=l0@lSdRa8%U6|%RLr>Z+$Y|LnMN`oC{9|2?6D=VCrn7NB zu%^M!uN_VTXg6saTO&2Cdf08A_7*{W-h;{9Cdn+_VZs#>&^tOn{}cOpae6lizCQ;r z@2i`J7jA=5ZlBt89C$N!7y3$Q2qe{v3rm2n8Ix;EdBH8=N-sW=SkX#7%38EJn1S&h zvj4_df8w`)$o>zv|D$C7Q8NGNb~;e(ACpRTkZCB%e@rS(vVe@nKS+kQKK=hQfJ|e= zLsbs+xvg?Etrfv&(}(J(XfW+in#x+vEe;JtmVC2zSZLC$eyl0DH$ceSb)jsA$43$* z(~3J~t!G#-ZpH=d5D3ceBR^a&oepTBcm9=WtIat)TRuv(&!Ma1`jqxxEHPBk{=2{dUpZdH>^5WZH}GM!esw80Ks?L*5(9$ z2Bj^ULLpyN-E5}ZrZ2l)fBT${Z0ziOj|*j2=I$t4c&sq;%rX|z_x{zEZfXQjOElf` zXF!X#!U05k2I87|692Pm6X1T8D2rXfjb1(tLLav{{w{ge2l{viTo;2RX3z3c{0qYNHADb-NG1u8>%E{ zzS!I{STbK90&<3mJJi-^jRQfmuq@v9`v8}mo_!-BB@B^7++w1!5;N{GKP;7%wIoZA z3A*AjMW#Wy9KzC?`1>4XQkmG9iOzRcS`wgmuao=Y|2ArEaq7j=d^rNO*6r|-O}<)l zV_7}cX>fip1nYECnNZj;a0ab@iV?Ot=Sz%V>f>MPr6eiLC+AgG^1yaN-J8Q#4Ne=Z zXhBSq-ef-qZnS(a!#n~w>m|1p*=cyXVD3%fdgt^dLo6gN(f0NBX^6xg*XPb{` zyz72JuZ1RswOCXOWg%#_1dm^tA(Bzd8RNJc;HBeKE(8Jayc(` z(mjwC1jvw;xG6ztO}a>(usVubuSPvYk>{0GlYmO;yF4kHRfanR*?x@#Tk z{}v%|Lt$!t>}b?R59=yOS19#gVcuzIV8IE&653 ze|pOQf)BGmjAHi9xbnFd;b1_Wyt-F>Ad(`_gy@=M{KAG-;~}V!<*)bie%Tm^BZOEt zxZhlP_3&>n>fA{@VyW5+Q+z^IB{9-5b4`7{Iav456*g_wr|f9aSd>{rW3#*I+Cx&4PxJ_=x=*7@qAs3vC7S+E~sGuYrfI4Q4#|_hh81dP(-J zy$Ki^?ejXTTpF~`qtt`q;4oc)@H;u`g$$IPos?eBRFJY;^TR&Kk)nhzM<=X)UTz?!yMBp6Jb-R=5-MadeMR^q zUJoHYsUTXUcb->t3)rb0W;*YyZZhKAQ0glI?Bsr8OEDq%+3F_kS7SAQD^C~SFD(NJ z-9zTDguR9_IXrIIj>uT^VI9O?-37rk{#8GY>DnhC;B!m!(la}Od0}{mVw^up@$&%uam>9t2WBq<-(O_0_en^-O zbHl2U1~I}k9CZ}M=^4Lkv|^*PgJM*@(4fDcr2$Hwx+$Vix=<)z?JOi%tG418HQ1ou zzUrn$DL=t5Rip+zY#ybuGXFe#h}mI03L&_05q=e3Zf8nSd@~uEACJU*YU@W;*KZlj zC?>?%$EXgIOF#N@jFwD1>|7ckZ~8{^7R)UdF1`p+E*Lzq>NCSmSy^yyAhxMJ_|kwC z3B`_hIW*;Lrl1x+;Dw5i!;^kui9D3LfpDhg-324htp}Yk9%jmGUmN0$It|L^B9@n{ z)daD#tk_FM;E)T5_T2zBtp4rSl!&fKh%5hdo%L#KqS}P!;*i>zbQY9mg5ip9ZK|}( zD<3h`p2Hgf8x;Wu+jBk{T6@14EV|MiF!4L~xw%!`iP>r3!q|XJ_I#$3Oa$*xmRksMBo1`#WKSgVlwl`EN(LG#&R$zR%MT~3ig7?NOKW+{8!&A3 zww;D1_;2CR8Pxon7`vb-?E0{-&=fPaJI{79;3I5(kVi{~1+B%wD|`U(``J33j8?$! zxtyXD|Jy|Nox6r81%l-2d*wvX^A&wUl%Jk92BlCWJ z^;-i)t%VYnr}-L+<~*8b3YHUFPzM$>R=;)(5&|>DATwB@Bdfw;=tiT|tzV%^rG9B+$d8SIJd4AvVA$pPleCU3*N z42M=@Qqb9U<7VuIc$KB}x*S)tZ8j<*|DvY9YutIJ zcExRqD~?ay_7NWvFyI(yRWU+TC(4|cqU!BFap!a3H|alX0R{t`tV=dq@;_YC@e51y z?P|+U%9x)IE7K&hO!RfMqcjN%+d3I0u0A5CpAfy@!Gbm*!OJ-+_*5B62HoqO6Ai*L zmEkKp}?4Z8t*JD0_8;lH&^K2wKy@a^lH}XW*Oz0NtZN}yFS?X>Nt0o*5 zl*nF|SBKB|4))iY7H3A<9{BRR5KQbeocv>gXMdGi@G~AcopkGAXA?i`C{f1Y3s49& z`r>+QB86u;ai<_=OXtEi{D-bP3JfK??%hr4)jP77bCGE0(elqijoJ=!|>`dlEp7($A7{-cl>GsGr>$IC# zjLS}8yAY-R1uchOo*>j-6zOnJd4p2BYc;``P-W(PEPvK>z$`bh!$TXJ;5ses{?4mX zH;b=m(9PU}uchOrn%4s1K>pyoW3>szt7<3<84@!EnjNmL=n~;ZlOQM67SU}@xk)`f zS1aMLI?P^WvREcj?|QQXb--B7XPD(;JX7Xi9JaEJ6&=+L&2csX;Cy<+s&rM32{%L; zn|8il)o*9o_F@38ztMh&$RX3$t(5phjIytEPO?9DWWvjf^FyWpqt*D#%nFYc$e>Z?Qm$Ey^xN~3Ud;yF*Fyy!T4(zl(de?U@w8lB7p1-@ z)XY<~&X~Xyk7RV6Ms}y$yww{ZZJw;Lus-tmw>^GqWjp9@=OMA@6C=+5 z-EXz<2ZQDbKZ*jyB^d9tyjU=3Y(g?0=Q$OK-J|wa8i4>~;3(O71&cpYPXgHE!U?uW zFk=Pc=48`&h{EtpDvj=0xK+>^Na?=1Ie4ICHKXe;_`K^KZwI;=_6V1y{Ea$HTaW() z;G$X7%N?JTYj;r7ZpqzIOM}dy_6tV(`^4NpWyJgpc48hJo*eCP#h(%Q*y*iMUA@b|`%A^!% z$bm5Bcg^E2p7`v7#iX!`qt*N^LTj@h*~5V6n%;b3`&kPkut2NxG0Atqq=#Q`rsY2D z{pC9q5UW&(Fv`M^L-T`%VEK(^=2Q53r^Zv;#1A&IqWb6iVus4ru$+_$QFB2av-gQY z&4LaUyMo!W@X1U#)>A8nqJSadZiQ>q1CZa%^LNTH&2cT)Bg;6#R2B{Sm0hJX%T|kA z#|E&Uc}@>A9owk@iUcYn49s~=^6f&X{vYa8ehmzi4atVIy$Ad-zT+9H1uRIr#f`>= z+Ulds?rK8oi}_fA{`C?0A#2#0aS4S?5!slNNeH13)dZ(KZGn?wp@C1J%v%mtO1WQK zpK91}QXbmd5J+{#;}>3w>Upc=KsqzE{Sy76;Qy_Zc$ULAKVx0s?6z{$r!9&Ana*6w5qAbL02|HU(Z#PB z{48EOYXV+tJAU8U2DCmaxps`5?gP{^+B}W_hJu9udn)BBAyFJ)X|Y8xP) zIZC_YhMM5FQ28FH3I!pRWfD|bq>p%jva_1s@gk+49YmMLyc(n!&489iW?Q%S@I2d& zW*1Q8M37sN)v{`fP-2{DyzrU7>*Jq)F+7K#JrElBh0+~9Bp|g?4B|_{5Z8UOLU(ci zd(`!2=Q%SU+=Qn_yol`}ZktIq=$}y=V#=yJP4Atx9D4w)ox-Xf?jt_IRDyV@1SCFS zWG#bQ#9gMrT@Z;&g)GlxIP{L|P`Zx(Vw~T8z*R9xmQDt`R^Q&jjN`MMACCm`W74(f z%X45B;t}6Ce*69}i;D9Eirn)+!dNI+fl}$a=6k^MME>sh|EhpY{SjDvmck{N% z&Y$Rw?gKZ$7j1)ol`{T+5XJm%Ut~eOjP*TPn*%^$p6%2&_5-VB(XgZ|W{egd!vEVq z+joh73v{C?NBT8BYPIkOyXGT6K=lss`u?KuZ$JD~o%k^$Cej8MWn=SUxl;9NNjEr{aF#et)w>$8$QE*%x|l=XjhM{?ln2@KBl*?iCi1H1 zzK+VPCW`*DCx7|D0@U5l?!TbgLOs`EplB7B#uO<434?CLzdvAC=xxH^4Qo1cNSQ>^ zmIDz*e?DehxDR2>`ey+<$F`}1-N)Q*h8Si>EeRqh0nFZ+s1P;S-EzU-{NN=i zaz|G#X@XCI+fS`Bxee_g$}H}1((FcIuOw!(Px+gj?6yR;Mwl)@g@knr*Tl#i1+Ww2Jn|Fz=$R{YREnW z<1U_pGe`15!anq9d@M<^Kt6FDT*b?(ac~eIlK$A0`?wr%;X!$a7br{I>s#kI{|N;8`{4AiTo@oJVPHvK3ISJ~x5&m77fuR*5-%aBE%#j=#v)VR56RNF$13{HS;4G8cG9Ej*W{e?(s zN}NTuCZ-UC_{#`xt6o@L1BEa~eBbBkjd8-@gMLu@oQy$BdShLS+&FiHwd2na-z~6tfFlfvo<41$ak7Vn(yPNP2#A1^(ec}sd-1IKV zuSoV!WTG=4zT;I`r0 zr%$l{ElC3KkudeVYgs8Y`!2XG)U59H8>=n2qpHlxe6H>1>)R4y6;3J_&A7GO4_W(( zGLC#0eKVq!H43PCfGhp1cE}o9QW8YvAcUSt1rc>ZMlx zMvV4hNHzf3`0mNuN`O@w8?qH`_Zi-T3*U#o;a7@Woe2yN)(GogQCh8f*r4r)0}3r| zzht+w@bw9DS=woQ>&O21PGf?axt>S4o4wau`@YpN#Ti-mOH)mqUI#?c$cp+cixo3# z?v59iT;KWk6+w&FsH*Xs?4Tb>J5G`ZA~l54tUXB!w)?~bh^+eS98^*Y=y-Q?I8)@3 z^2v)qzoEUKxL8pPc!M^R;-25*I%A-HQ$bFKmgNBG7q$A9g(hDqFxaqvzsNcL<%tMz zaY;(IM7kcN=ffLA+P6%|iQ<`NM|zaobijTotzFk+1q{ifKDUeJ+o_&XCWvTBK4y11 z2f{rsZyHU2ph9OTT_FDt^8cL|{z3kKfj$36=kknhLe__+R31fV(mkuV#uUF+!g0sw zDWrf~-&YRASM0X-y&q5c0P^W6iNB#9%=+U+bquw&9UMWY!M*U$Q;w+`pl-;C z+Ir$^yO9D-Y_oOetqAZ+z3HrHPXJ|}pal^+;QO(q(KN!zRQLO@XLA0B65H@Uz;JeF zUcq9hfWzEVe0jm-lep})vH>1w*RFh1tVC$sdTpu4V7l3sD%e-=wlW3E)B3#f5A-NA zO63p4OU8p>-}6oboX7`Z|Ii;G)gxdKUzm$n{G^!~IB(}(e|776C13r6FM@mg%05aj z-~W!k)a+GVg)_@6p#1VIUTfE8eSctZ-)m%AR{pzgiv%Hg^J4|$cc`tgYOH4!smOH6 zx9d>svcUZhM_C-#24+MD-+z|QpUw4F=jZUTKU2GE9A{TWkJ*{tfEBo$`4z3yVnf5b zz~vUv`-phX+0&zonQnsX6eMM==J4P~R_UmniXBO>DVn59x6bV_U=ZE8k&M$I=n{~6 zG-`jNE5x**tPmx#P;IWi^{(jYe%}^Rf6WUrzC%enpZ}g6{AJw&w=!he{yMv>l?ZxG znU!7k6wLysc+K9@IeL8VB*31hc-o|?0e#juu3O>|L4WL0>`}5LOcbqD93f7pjn^>{ z%!8LP>=uJTVhv9_9!Y)-aSfTxC(H=oPS~pD(kQi}3I?@?Pw7VS)lg`&N`#GlfP}vwpZ)d|QSxwOp!ZI1V!QUkmi?(OVl_*FBr;FZ3`j{G|h2 z={j9y7z3tkw^)}7r^fIf*0YGqfLwn6(wjB7ahxI-3;XH*HGd(M+nk%B%3atatGH#> zZp~}-`Guk<5I&!@^?-GGO!nd+_^!MFrf&g7W_$;_S& zsUil82-?Q)QX0_o`sTh;pzlP<4f_^7QIKb;e^+`yAZQE7gnLi>qPVh28V>D7Qo%gR z^JA{-X$fIry>7y)8}=33;AJA2eZ;}eyA@eMxr}(x4aJ$F_2y2pAIPO+y*#GYi5b%p z-8HoBxQ7VB|mpw-@lC2t39aB%Bq zeXTXn03D#a!7AWN5}&-{M@y8TeCdoCv5BYTu-ytNs%q-f;^TrfTf{@8_sj~>8oSi4 zFnxR1Rrm_x@b??-g7>Xs*r&l)vrRJ=v?kVrO1x zR?q^vL@LfRg+p}%P6*BEU-|4hj3Hk$T|NLc_m~0u`4#NvZHfz`WTiU);uc&r*{#QE zym+u)GeJlRWo;1a-E&1tn)V^_txnYSJw9tR^0R*JEwwR{oJ&%XtUw95xxl_5+;X%I z5!TY-VMh3VWZq*i2R;+jE$O*&0a9YA$zS3O?I9bU@$3kz)}sszy1tA_NV9(QnC2!v zdIS>GFK-?ZVZzCs{DFmfPq9)4*+wg@)}XOMkm?`$sk?#N=D<}1G6S9Kl?oASP?B5R z7||R|lR{~g5DZX}|!C55jn%(%~ad9cpY1eE3aTn02o z2tw)gDOe??K_NnJAEJr%*4{^TI(HLseXK)uLdu-U=Ih-K!+R$MM0L8aI@6W|X;9c< z1OJzLYMtVNh>}gqPhU21ELGbg3ijKPt3V74*)N!kLUg&L9{3OZ_%BX{PYA$!@*~47 z)1VYLzgSH_Ka`rmpC)!DRBK~A40={#1suMRx(7R>hXsQ?yyrg@tPY7*#-LCJCF{4d z=XT(!Qk)1WSeo)e?NpLlIp;~*;!@#}`IXxw>|77jjrQ!bs41LlM}(%(K$DBm+{p}ZuE2oXaOSF){+yjS65FQo_&M@$G|qw%0rdb(jFnBmh8Omp4i zC?vE=uQ9A5MaiW)qT7r)Zez!leKcVrH^7@xBj0p;K`0EF2-QCU40`OxJOxhnDKC@t zt}T=!*C&Gq({s$ZrCdjvh|30QLPEv!>YnQZfgJUoTBfB#m0|<4iVXG-Gw*E_TMqS1 zB7$MVD5P@7w1>z5_)%u3Ppq^UZ4%yEb@R8UH>aK@K2AF z|E?Y>|72nQ$-?|a^#89;ELzz5P)21?UnwJ$jaNLDG;No9Gtk4YyJO58K>JJMc%5?4 za@alPi3>HH@s%fy)-x~M0U9E`IcxLN<<|NhlgL{q{+W`IF(@RbdO2(ymNWHs`?mU(GX_#%}v#-a@pQwa)aRaK1INzn<<#94bgd5F1tcAPVgDbEZo*M z(r+6&$Hs$KgB9H}He{^#5L}kvSDM3JGA`^A@&egJaTrH+FBC2a>Zk6eA`GsyF2c3ZDFRD%+1~Ht^i*9M>)V*pNx` z#y90uX8Th%^2r<@g6ou|AbpKRa-0xCC@d6N?Z(cA@tJ9J@~V)6?IsrUfbBnZsaxLL zewd8YC9Dhh^|d%xkM%als7?ytBv$LJ5C28Pf1oHuaFxJ}MT@wbHn25yO+Vsw`Hde& z6Ci@yW!&yK4RcP{aJHPBn_ZYX1ey-Lt4w=3N?vpA8*oi*sU{QmFP5#Q7I+P|5-dVE z%1KXgho<-+l6+AP-;mR^D+6S>@?^voRtZH z!{+n8S|%^Asg=;1bhfE$7UNKZ0`(@9J4S;U(6{J6;XE=4vW?A(%VR zYhE1v3H+1qiO_6>>l=2SOF2SV(uodUk52UQOjUar~FVI7H9%Qk^>}wl9fl9W=+QjmHexd16U2T zt5*%6hy|wE5@%a+NMDy)h?j{?aHkL%zxd7D>?5S0nFALt25N!Lg}i9pDeJQW1bpSJ zYLfs^c}RDwBx-Z_E|cpZva%3u{>WqTw9?Q!^3gIyH>bOKlpXk{ZM}!~f(Aor#Trt>N4M+tUJJ{AOz|41hv}$<#S87dNLd^E=GCn})>d{!LDNJgNy{#}WR^+pmFKCJrOB*f+LOg-=jO128#H$B@l z4YvvIUJ?rQ7Ul<)TJ)F4SORSF$YgnJcZ0&t z{IEXJk~@8$g;y#%-3A=5FKKf)bN59nBh2`ApaVpoCi`}MUfKv{oMt$M-hhs&jLaalm#^kd_CEupC@582U^)d z84zlg)TbB2&;`e_QSK$*G|hKYR(le{L@7Ba{TNV_EoZz*UKnV2Nbl1&paRkyY=#b% z<U84JtOlykCTT$)Q~svD5G!Zd-%OzRaSL>0Cb?BVI(l)hQR?KI>sw*Ek@liq0_t zYfF@&zU3iy)a$Pr&*=2{G8UQD#VE>b)J-;EthB!u19XAVQNcdfmPil`i;}mQ+)5b@ zl`mK<%&5zjq@`1~9{;1Uc*m;R)Jm!GP0%p@!<|Nd5Ex=BkI4f^i3>`unP@7E%3^FM zo702;!tTEUSG=5^OXcjX$BKW;J~H8k*}4_)fxCy}=nX9fh}Ygf^_Nh`Odco!>Nbg> z1qIY!fJ|k>gX0S<}8GMmtC);DNe1#S6WRn-5_j;cqL#!P_j~1?m_#6Wd9CMGa(*S`J ztz?dLT}Z5jZh*)(bjx%G?I7)?vp@}>Z2-5WZACkdJKb|;L37xof^puYKBP%xF7QP$ z_2Xyez);^zV(omW3!Y@MFDlie9j~kb4}2MOlcP3$mW5lo}IB{_;Kl#{r| zUqWI*qdPl7I_(saGmx9fR#}%L;Nh!^(boh3X<{V*-F1F^!h{=N)VHE(7!Mr)S?0u1 zaIY0;yyv7?uE>nrCZ`99wbP};5iH<~T*AEj-2ge}By{rCLFfHaXGXwBboSQ@JYcn; z91{$9E=ot#Fd3py{$_{P?tfDfu7Yv2>2SmmYJEETR^T_VHJ|epdKp33cd>ojzbQD1 z;^1V~zb6S_Hsg|Q_CA~)gAY}8nC@L`7P&&3XWvob%~ux<1UO|?a#C6d5e9@^rSz@4 zNX!WaQxfk(&A($X>R+Zo#55lxs^6*#$i3!%U4s>{1ke2md^IRuw0SNvRiwRV6 z?tY|wnYuW^4!MU#3y|epgK7buQt6Ei+@bHZX7q=f}wf2`;ek z_eZ(Jt;ZQ=F=e6~P9_y`7+1?rD6v~F_We@O|N6t9r6>nQK#P;qI5(~XKvMeuUG=Fb ze)}uKES`*oApuiM&|dLwpm;@_&snt|0qL2D4*U;6wRM>qX2vO55;S4E8ob96i5!^z zUYn+ybP7>_CN0&4|0NUB<0mBr5frc7hA)&L{snXVI<)W}WG{PyW~_P?#5VeLT;e*{R6n0!?}U186{<*N1P0(RyzT0Gz)jZKk) z5bWYa!O$z7s(ztP!BNW1qD(qEy8}FEMtDJz0!f0B?N*MhVCtEExm>=IDv;2?KQ(ut zrW&7o*+@-i2g|nLUy1&|{NQsQgb2v$7N9?_YuRJy`>TL{%~e;k(hmY-7->tVBIqqh zZ<@+v4TJ;TBHC1?985LcNUE}E+-?1%!>Cx_9<0&uaZIV=Ou?AnuBDj}wTF&_uXM}IKlA%89nl02 zdF{d|shKa3!m6Mp-pB|sm}Pp-pqY@enmK1%X+vS5aU{-)RxP3cNOmIM8bx+J1G|3I zog)eeWE7VTVZK*^L3!(5EJe#>s14?&k;E{2p;JNNPzN`pTDUfJQ@15W#^a?eIF-K+ z63fthjh>aDu&Sj+#;+mZo+5ZyFoqxOJ3?VPQxzhqr{#f4Goqm~ed+;^DRmrUwNnSX z1t~h51|-g4sI%&F5xBJYUi}@N5jjDK8sUq>kagxmFDrS?eUO=e;V92r*_XALalzWz zFQE}BR;M{uq-jafBzXHYJL5cHvH1|sSJbn!k#cYDSvenom}43TNR1pqZVP?amQOhJ z-c{Qkw_VZFe!{s8(tAEx4RE1$Y5yS82 z@Ij+}@Ex}Jnu*IQdgf|o$9XeFH+NhX(mmtqznpv}pIrCC_0kP|=|kYT||>o+5n9P=&;M#F3thqIuG+I2U!| zZwS^F`u9seqpX3t_MCX=5;B$+!gJCD8xm)3bo(!EcUEOs@=gd3bSM^eiy3Aq8ygy(Eb1>gsS4 z>2spG!z_XF<(q7Mb*+08BHbPIbjbbOB8s+L-so@gK*3=QrC-4nabho$^9+flpR@so z<4z3L8ySV_Q8=sU-RgcAHd1eBk;Uv2#+9*P315|2Yd+aq$CtBso0enI4p2w85Yq_jI%TTY zEjE<2QBBOZmCnn)VLN4|a)j4I+lcoRsF8of?NY zA1Ji%UDHvhYL>Pzn?+M#*SIeAy1JUUZ6!W}_ zX6)4T&BhyUz#t}Q+-`HObCL)s%xjZEM*fqQ6PJw>;ua@%+W12lw+f?w`v<*==@43A z=dlAfjnIq=U+#-rL_wId%;w_zqZm8qtEL_q3zNFr3{bubZG_$ZTkA+3l^xj1hsS8V z3cT4+LY=`T_t0eYA@F%Ubw~6A#?GD>htYL)?MTt$k(}-auq2(;xRJs#j~hC4=EDr; zvq$j&+!)NKn! zfpt{hvV}ck>|ETc@Y}L~{fZ9n4Ew*m=i=aj?#iel-@04n&op@vDQo+7?b5UL!C0Cby2JZ6BFizEnpr z*Q%){)Gm_qy|)(k=9XXc>RuNqjVYh*3TU{rRGdWdo=sY~2=8@tfAG9STGbcXzx=K& zp|<5?`2+Zat05wFddFqvZ&)pv5VhcH-8Vl6ZCcv@`;JnVhL;A531F@-$p1r~!Bfko z=Nl`PijVHW>+wR&_9h{#ML9E_DjFGK^3X(xi&$XG5o5#^3v&tU7RjgK6tdGB77LMx z>gN2qsJE>h?OeF?@RSlwq4!Fekxf#u zkUEoJe%ILBfVJ;i zp>D#y-0l!^9XX-$22JuTV}TG*;GdY{d0s#kOO7hJo&(H!I!iT6oY{U5v0g)}nkD(X z)`N&r%*rMu>+KnA+-6ex^Ry@V$GLFBcB^u8+AJ1HC6yP!f24~C(%NWr9ax*(7Tluu zJ|KBKM;$)Br!LY<@(>!43n_EBZPVW}XwFoO3OzxVM}IM!AD?WMxlsnuuQ91V%xbh! zXuXF1x|gO*Yi_#)Q95GhU#h{tf;YK8B)0~X!*l~qSM&v>-jgByX@6Vk?c46*72*^o zr-{;L_ip)Kd9;Kidd>S7lwFKOIP5X8_of*wb-}cA_937R+|;N|9LP$}oKx#@PTWY9 z?OBG{Ie+UKc(iVxx3gE|^7G{@sQoL?txYvNx~L|U?#(_#c#a; zpFS@Yt^Q!Ka157Ag2>75L&etW?MNtF-8>u8ufABlq98+4^VaVK+<&(IVzexvRQifT zeh76_20dJ@SuEH$DcxO}>_4Kj`iGPKM8Am3A8e-&{6$iKP7ALI9`feo*38ugTq5T# zSDy+*SD)Ey$(zNZzpe@cb?Fs-cNj%hgzgBV!3y|ufRdV3^^MV-V1NGD6SWo!7DTvl zjdcDHI)mFvh4x0MtO$^7U*R7*)Q14B*-GBL_vZkt$=!z00Sb<=Y*-TUV^MSy6;d^V$LdLN6WL~ ze`wn$^|tL>rZ}iTuwjoFN`%4a%s29WGL+XfJp?!I{Jg5_)%oI% zE3Jca6YH5$TkSW~Sv~dohC^sK$(`q5!0>n-$eg_lUM$2`b%bZ`tkKs0{eoUz@?kF7F~uQww(Rh6Wf?%)Mul6Figrhb=yq z6Svuag7d?%d+CvJl*%uH!qrPbU}%G9Un@AkAL1{OLS#!}5YdKS zRZst-{y6BCWeJOZ*PRN?blzhh0%4X8V`3Z!yOE5j;8HyT2%1=KXfLkB@?%2=*(_KG zEw|C3AkGpDE0}0?%@+`ojiu#wBG9fe1xu{>JYJGByf@n;$apEnT2efGA1$^AfAf|E zBaSlM^~6w(x?i-mGF6vt)9W`3XY7=}i|3>*xM(y6Xs9*g{jt?NKr?wA<*I+W4+!A) zqbtK2fHZsg0?yLmU1jQs4%g+R)q$v?cg86)0uKD_Q3~<)d^>`~B)zS)ZCx>QG^5Xc zNU&un=%aa$)8Gw!HB$q-z#qc0Rx4ihiT_Z5TeKA4pV2noL*STq+)9UbfcwDA-Hy@X zz8pv%zChfEhNOQdBVGgyD0MO?1V)u2XU}?7Ww3@7T|j#Yx|BBB1ynL54xXk%t#|v?8DhCqW}K;vru#(BUWdhE)9KP-#)6EqUcE+3-=OCB zo~pxldJ&n0>U6nXfeMsgmdm)j0em7;Sy@>I(9x9EZ9|Vp6V#@Hs5j!bGhcDy+Bbi= zLvO#s0Dr8V+sXeinY!PKf;*5hfC!EW?BJgqt7CMCEKJ3)MomNJ$>4D%k=vU_Uqj@i zuXdaR5_v%uA%n~ni-75E&T325qwr@ z+RUK855f0e7$@^Fu;O)*pJ^i+h)+6I*J^}$#DTq;dit6z7KjS&62QQ05%iv6UKa7K{};wFJ8=2Gz-Lzg>N-M~H@U%zOwgZpR{?(J6Ur{!1il_) zJJJvCufGgKwyUg!YuEp<^Uql;=i+WlQ)4pj&lKO{cWLR+K&U&xL>XWU!gu zNT;Wah4C@eZ$`5w&r$7De~oX;jZ@$q9ERR5hnceyn5!J<`65z44S8&PZo3YgrcTU| z*Iy{;I1EPBIp2jlaTv|Ey-jvE5aO?Nb^aqRD!>?X!03Xl zjC=Cl$MFh;Z_g3%%uBk@Soi>`Weya-RsueWyJD1tsYA?d{`bd8wWdO&|AL_P7L~kh zN!E#05~jQRTW=V@uz$RN)qYMhx=iYTd`a2yfId6>Q$9XEH4$P_@8AuYHecUaebdi8 zi5mrr_mbSb<0&xJ_=gu(`ki-~o+3&tq)cczxDdRk+l*Os9Y0u_Iy-06kS?Qn= zb(}Aw&&piNm876MUFp#i@-{D~PTY09Ay2gl@7}U8GB7ZFJ%qMJ!?mozBu?*lk%aRkCehLM2f!zwD3q@*H%_#&f0SN#%&B0vPHzy zrE>%K-1sSp?i+U6zX7{1<0$WNhsA8k4FDDu4sUTV>PiC)YCe2Z zCJji|e*zXQ5C%9{v62juBl!(P?x^0Dx-$$@FS7P>(SLxQN}`=nNu^X+qh}|VLlx3H zm)q$XJK!!xgB91;_Ew}EMr&VeJ1KJ+qIAgStOgzH2p;eS4+vIR{j(i)HxLY-SJOnr z9|=yU`j^j)H3hBTc@rswB%3{`npkjkW_}Z)<#eCh+uPXLUGB>HEyGoB=@@$;!pqMA zTVO;!xY_BU8JG2k3mQb3ro_=<8GBN8CALpy?t`Vy_ZplC&DfLXz$z*B`Zn8en^0Go zO`>G}M5e(htzWE8Lq$kF@Rb4!U>>jg|on9v5BwKo?-BXQ{q7-(^5l z-(NsLuHDX1^UgmDSamGLioO8AfTy-tc~zk$1K7U)Al{|rhiC~98i*;jENhzCtQTR~ z<239jg+|sl2YZF3tnpyp>X`HB+T4G$B$$Zy78-w`#6g*P8@ZJ5LVHQ|#oBwl)2dQ{ z&1ImRTTaqrS9_|k>4wWA>{u-3k2$xV>61bya-EPc%|W5mr52845)%0L7jof_s)e@d z%FHz04-;%@V^>XRZ1ygFzcTRIeY(8D01dre{Ys@qi1*borGshH7C=NMQmhQ=iaM>8 z=Ck6TN#q<~&l$S&H7$)dsyp#;hAs~d&b_^LUTmhNbyk|$?D7RkG-{gw=43`ta$Yx3 z)-voI|H;zcgQX=7$=`8hu}BXSB?KqnqpAZ6`U>`afDT=L4l0#PD7w!BVvo>ch2 z#@6m*2^J*n6n=K`CIf$tONqH)-ucSYr=2{S32X7~p&FA(9x*8wZi$h$N@N75_35s$ zYu%ZG3tU}fahl`9b$5HGnulER-qT46D`Bu{9{MCsm&v`w!G2W_I4oQRIz)M=w*wSqXXZ41`BFL;DnK)*KXi%sxf%0Vu8;+nUYCidVigLy!++p_o=IC z?(@+TELY#}PxiBRIwMdj`!=M;be=Km5SqNc?b|Zlg}ebQ9P{K4M-X+~zMPA0;KDtr zKU3S3tSdKh*RMOmgvZIX-^$O)Ti=$We`nbuJ98FH4aF}=PjTb;smT7F)9N1p9-$c5 zJ-t0x@w#2vw|qI9FX{yqovxbr^jxpYy^4f9skdN3wqSm3C6H?t+;N^{d{ysJ0=%5~ zpV&4ycsWWZETNR`@tuT>gB*^_t@7? z7Vs&?>E#xZXsmM0N3QKwlHkjv7Ui*QuJ8p?9`BuwoW~cs6fV?m$ad|~J>9axK`RON*Gu=yO$I(s^o^O6`gmCYu(h4cUiXMZC_`k3O({b z!A^M?KO>b=gG~~*7m0y@l{F2$ZZ%~*Z*~tH$>mQkRJrrUEpwWq+Zu{mue>AkP0P8gTX&1n%OtY|IV=-=&-Ew7DkhBzVVWr@Vz9OEYRU0V<*INuG5=Ef4Of$;fz1 zLeO~A=sjo8@e8)fyotdl?xx+S+^J%Za^|X!JEj$@gMcOGPA*QWJH<+#XW1&Asx+zm z!XI@wmH&K{2CW$)pvpy$Z+jCs~fZ${(uIYQWzh9a5Xc_;Sih~{TBLnjxk39*dsi zvTir{=<(% zU?hF10s7>5{*f1I4V+hAo@y4_vY&Go*XtwGij%|KTu*9xTd;MF)i8{Kjk-w0;b_gT z*Aw3(swLwj49zmk$5I1Q|JZnC$BS4zxT}y%CX14$YyFIi?Bh1xdSiL@x9aDm>Tqy-rkl)h`1Hw2og;n`m}i=L#OxTMTYm^;%+oPTJV5p+d|%=#u^@o3X%(A?`%(NtvP&Ork)* zSli7?F2mP>b9Uz?(T;lCTD}MfUP^lB_jJDJGI>dDNcNhgEL;3?>K&dZI+8+(*Ekka zPpu`l?SEYo#B6?Lq1?;3cvhxP$y}2h;H;bRA(PS7KqS|#Fxk&eEBG>7&1QVo6>6<=`T&s|OF|OU9pg zO`eRJm?vCsb(xKEe|trzQbVT$hZ4VR5ez3)_{v^A(vYB7h)nd3k%v*fn%`sWL~U?5 zT%pajpMYCszxicB?I_S7UaI?dxKcw{EeT;J0IDohG&Z@fW|kPBL+jm*RNznbDdXg} z7dWG7*a}QQQeO+`)TRiGAgn9#gjDIvhSbFl15E4X(1#@qu?sO+`3*L_hdDpyWEeO0 zo#qsDU}8_188iUe&Y>4-y)ucJDAlr+b-Cpcq3t=|NgC~WbC_58R#MHv-bB@xJh{iS z$5dK$EJarvEp-EV5$wW9+r#Ry3eiNYT;Nc9hWR+0aHW6d z+L4%r((zjv?rFgv?Z2tH{XD}|;Ile`C)9{hxTqEu(x;eNx><5tOW=yx zRlO_EH4wZgp;F5S+~fjHY=RnQo<~xQP{}lW;c^r=_ z@y{$1n$B|`IO3jVZkKUUJXUL=3ANg;E4dUtO+H0gs^QN4U+sN&R8wo$XFw4J5fKrk zs$4}tK%|ItML^cs|=^cH$YYJkuQC1IX;-&=e?@~&Ak zYv!A^M*cZjA?KW@?7n~d*$EHh&DkLJlXICothh|uxIzsZY4Y)XVLoS!AZMAT3Z^5iM4`{J_m6%KKeb(-InwRR3o58SL zP`{s;&)8rh(`bXOFd7Y_t-;IRca(h3R9-WoHY>lFm3vHT&lbAPk-HgdaQG;|(P!#y&F5BqEzBpUTFJCh;lS-7L5O(oe-VM13I;RLoa-TBrm^H$mj;3Q+u&o z3Tx-S*Ot!dv*No83Btp$-!zn4;MN%A{u1 z{{08jaywMx)EpZyv?r=@{5`Q?Sv>Y?a%k#SR@yMv@|-~Y%Um=|ixNL3S53>-buqt~9>drF^i zuvnI;+W2<62xeX?gmlX4X}9YAGLLe|f1*=VQIQwY0+XyVo>eP(V?CE(2meN$ShQ68 z*=@bTeg9bA{K00#;Sm{9d@$yQgQN@y#_(yT1xXQEz`8swViS~D&doWb?5S2rlZa&!!v?vm}Kk?qJTKkBr+1$kx*)`kHT2tD!{| z3!A5qYM&mN()7>ZbP!gzQ+AIQz84t_4WKklkck{g`9#9SW`;V(sk2p8{GFn^2FIwH z(Gd(o^_Ws-7{#x5H}RX(xX%54X6@*;3S3W|r>=7B zLq~@(4+_Tv4>g+iyaSgdNo*2~cF~L68_3Wh8iUK4JL@xwI16uf-HcCbi_r-m_aejb|>EwO6{VVeI93Pas zX?NK-R2u*WrLANG%BfW*r!-*CCewCQFDO7|Jf;X4Z>ln)A-YQ4c7e?c#b&3;9jpsg zx-)H-X{SW{YKTQS;hBP{-mQ|5Y^~IKS#^`WZD6PEJ8pK{WkoM{6{6RYBoh#=yA zDjwO@*-eCpu;ciOsZ{-y-zZ`@oMAK-Ri84|xl$n|?Fr$pVhbFB6ylYiCShYfT?P|VEiJ5&JPmF&%Jisw(E~I&=$Ytb77^P_{`?7c< zeOSYoK~OKc!pW>1?GOE}OY8dFTDU<3im{r?BG80H$o_Y%dO#vI7quEca?8 z?=9F>tE?Fz>&ZtIC8pa6-9q*}cbYE5Czhyn#2|lHTUnUwn%0zBdUanEI`4ul-rRSr zKIMAm0`=j(^hw}|3JB`@1xphx=GDm217um@y^o}a{}}InL4kv~WNWN}0v1Znt!Gl) z_y{UhR1P86?C9wmcvp1XhEafyB(IkEmZdH}1^$fbP?G=gltqwJD{hR@%b^8V04uA) z2ZE(6itiE%T1nJA1`6gytz*9l@QcZZ3vGcRA^YBy@R;&sz?hhvor?6q)lEfxBM~@^ zwD|*MgeU$2AN)Dh_aq4ff3DkfHvk9-r_#(}hVmaib`2946Lfe0=?1PSIjzn>;IQe} zJ?9`i@n4(qYcqav#$jChi!*+4#{X%~SmN{wHQRhi(v_r#ywR^Gp#8?6wP$S#j^OCj zjA6=!OKi)Y%IT`JE>6*nCyljCG9!5;>-QgY%nCCQ{0H9x-i-p(as+E#F3EpQPh9}% zs>9P$tOoBjaq>G_v{^_cWL?+xih7O+ec}PC`~DTI5C!2VzL(bl(8zn%PSGMo0J^2{ z(tx~Q9m1@gQj*rzg+_&-n6`-ph3KSHQK5Ejk__5qfi>lBn4%$|u7 zaV{?f5)#t!g=fsf`9)?Ek5&0v8EuWQ@qB%CV-Ge^LzOjuSZ<%1K4HG9@mlJpl|#c2KT!IZ7+@}pNi}#|1AJji(nKHeD3{l}ror}*tY^7!GhM6D)Ixc^KLU-p zr3xywwPziq1j-<|D-Iy?%ML>duaJ5nEo3XlY@XMbj;0;0)Pgi-Gv>s-?6A9Cb&4XtK56sm{!W+=W)-Ob*4)far7ZPAbQZ z-gp7_cem6l#N71Ii&n{f$D9<4l22jM)hREeXt@fn2-k>hI@l7PHY*-I&1P9(46I0D zgQ>LjGGfiHkFRd;Iy6b^!EGw+P`{r-S7g6#YtOWtr2q2v%-C_=Kjh2Qj1ptsJ6#{V=)iP^HssHAfh&E-z?uK&Uh$2-)fSI!=tzwU)=CO< zd-%naN5Wc00uW9*66;wy#bystmm)O;H65)Gciy?7 z?df{phUe0R{+YnCDvd;maFUu^g+|^QwV!%g#8|0NCB~Hcyx!V<;3LVA&HZGuA9=Co zw!~Hh1^icly0GcpFCB6Qa^8cLT;7fxjHbkEMx&&Ztj{gxEKW0}P(lBirt|x@@cN9K z+K{-e5GndXgoUM#8n@k)D4SP71S!Eujsll&tNOOEn>3(SUU>GxA2`;bV!2~urE<5& ze6B6+J`08oIo>m#O!2C@nW>JbUQpu%Ijp`?u}$4<|H0|uc%P`Y``&6jl}7wa3=x=P zHmt!*YN|RPEW1CGE012LQO$k8qQ((BR3u3k=M@sD{JrVft|R(FJ$p&hX!l)C;&XGW z=3@{sXGK&vyr&_Fr#yo9KEI?+<{n)bMs8N6O4#(ZDnp%ZwL%U%}W|-&OtXPH4ws=xZtht`*kun(60$dN{qK z!n&P}{5=%W`$ihezgUmBwh~D!$Yoc43}@s|tRs@e%9Q=ay?r!z*K*VyYYg@0AX)jw zEN#~DvNm&Y)l^g)@ri6cJLKMeW>^8O={!0?gKT_mOswa1r=Npyqk1_)eez_N5A_~R zzI(M;=(V)!WnPBk>RGID9Uj{sH1fUbJi^Tz(tU(Rcyx{8j&H3G-xebvuE#yVI-sKp zl8gamh)y+S>f;m0X9_KcO3B8@g~+m$FuN)}KN9O#82i@x43N<9L9@k zRFjqXF!pZapxu}HJzaH)+mD2UWBQezJ0s-tnS;DV;k(zfQi;%2$-7c|fqEgx&le<-dx49f;2=nyav{T+s}R}mSsufQ zOYRL?&ZQE+%@Ie6n!iSMFi@~vI5D4>?dyLsjjjiWLEGFY_(sTAR8yKZ)#_mVf4KaN8>8st6UF-_j3NKudNdJZ&K{ zW8w)}xm`>aglj;dVDIHu?2)E?@nGe~6_4Ga(p59Hwkk-qo;bx{c^cKPmhCU)n6tX$ zu?rikH~2ZKWebEVGg4Y}#fLJiNf&%5*}*Q-rh#t?vF+zS z?4#8AAx@pAOI%AtM5UABuG_adE~i+oM$y*L{1E6F=rO##lZzxrd!+Z$bZchaW5%Xg ziVo1^5_76x_^gT8gA+6>P*nz}zl^I;`*vrYrzoWz`ms8me%rg1JT$TnuZx*iw zj~b=|z#QpE-b0g6US7-~qqcYFJ_C;=P+1oYCodZSlWz<8G+Rgmq?!tL9Zk5aJTNc{ z&siy?%^uVGeB5Za*Ge$i1wkdxEP9W1V!_M|-;nuKMDj4Rvud;SsjkwgR(_{Pq+t{` z;tGz8AF;k}?QL0BEMpy#)4D~rAc5>5sA&xgZ{MV^nJt+~#$Sgxg!0WvB}HY;t#;|n3X5~~6G&t!)9;28xn-DMm{wg_uVdCq@s||qi2X#Fp|)P0sjVwiZRJ06 z9iw%O-~QO2Sb!mU4JVqKt}@GlvtsTaCsD;6EdJ)R{+;l+>b^=T^P+>h5m}HAhR!X$ zuRPm22iOzLx)zC$T<;`1Wt_~{*Q9o5zQ!zwmS!z{5CJKoU8DBH^S>7#2LkrsT(npq z0#cGP{!{Wckdjr#mhJKvxV>mR9}0hf+MrmGz zZvUNK_hJQCL$u0PO=c!zuWl=fl*3v;jL5RR;4A!am+~wM4lhPf`GP9}eY~M&18@Zb^tLNpM7$DZ9D0{2-a85?ncYmVYm3IeQ#&pZHE=fYpE&i}s%zh9g14uPLaRoeNC)`S$2l3+gPm@rXEIEsa>PN2D(ye$ zFG3%UAY7yz*UFz7vhY=HpC{SayRR_(F)PC&!6bNl6oEmTS?r9!Vc7>gEbyUl@7B=+)b)>t;c?AeK@?Ktl z79+DXgZXM*eM%%uQmF@Nw1`cah>Po}J=jj93mZA4q{SP6TmMzkBHKB{XWajY(X3Zb zG;$1HMLnbf8QM9We~ZvdA;fQi5p?n|BWU8^a|9^Pvo)?GqZh3bZ@Q)|0jPwB8(|Wx z2?r*T2OCA(+ds=nmxw|2x>0XPUvsTMhKtE7D}`N;v2IXxQRQIGt9HT?5BPVqMMBLE zo;(P~X1{3C?|c9|;sPB~KxV1GyjsPljC#ngzGUb67A{y|nE_K{^g)_rJBiX~Brjz$ z5CnHXh-UH8a&CJSRuC@c*Yazb##h07cGPBa?Uma~S3iJy_mpSR31sK^;d2D-oy}Fw z8MPos@Os}Kp}b)o*|V-f!z?6kDa+978#d(FWf^9~an&?LJHyyS6iESEe$Siuz5E(+ zxN(jTy<)t8flm3dhUz*Vn)33E)Z&?y=S1$w@r4COswM~tU8D9Rg=_XS0 zP?@C5%Sdt3q6fR**NZ$cM+@~7DEAIM4haAFi#8w$5s~({Cnu%>VTEFYl8#+%s{jJ<2On(Ys$@Wwk7_Q>OvsyJ%>U$)MoImQaD3tH> zsi2#LU7O)2SkFS56 z6d;raBL4~LK|X}o-pdOg`DZ*|p1`64p{L7MX-LGE&A0dyzQGvWAc|^U7zL27tyq3x zSNv%VN7AqVhg<%8-XS0|KWC|p8DMApYM>V?iqyPfuP2TMWiNcj=8mFU%0^)=CmVgP zNpXp%f8ks%oA>yJ8nc+t=@;gmtxPco#dXkBSmhGc=1ER_Sq>XQsk(9e(IIJ9td=YB zrv{*2eFKS<(49I%3hdC+oObH$yjYK(P4BKI+t#l`ti^p^=r4SRpsKO;s7%YQDIG3h zV=>v-%FSSH_fGi~cZ%AL)=e~Wy;g@!kQxfbbx~^%=7u+D{3w%gg9$qk%E+7qUXZ}W zd(wX-epbxEm=Gb{*jj)Re7hEAo~?0gOZ~ooPsxZGk^A${5~AW6cgyQ-*LE*0++I^s zyT4v{r@TrVfLcB2xb=aLMi|s334{;DiMKp>ukK%`c*$;WfJo%`s!cT))Ug=zjkm}4 z4UW(>!#3Oa$j8Z*1~;3zcP;yrVsI)=jGEd=IzGj!OsRLH7v=Y}*R!qrOkJN60cOvP zkGzFbwM!+Nd1=C^zg^I4C7NkO%f%)Wdr>W0%OLn}6MKi_OhoHC-)353pT{Sm&9OB1 zFJ(Tl+@AM1JYRK;MttAQ^y5>j)&6FmyzhT|r8&&pjuxIx%AAo=RqJv@aAY=+{2#{Y zPb+x~tQQlh%2Agif0l_&e6ApSEGn)Uda&v-Neqijp+?_C-qRN{6Lg?j(&TnCHCR-(0g})_w(TOR`)@S<6`|Ne&a)wXR z)|>#vwYw@Fo9kj%-lt~|ksEjKuv8QYm%n1aWtB8LgjDoi>&DpnzRl^@qK(>p)vXR*It-2MAQnivX=lIxe zZVrwaC^Kr1x?A3X+U=aDh|1HT85GYscWGMf`pVlx%H{4spE%ReRiOp(?5NCH!Hgs1 zGMViyk0~Pd-!FgFQF-=-H$a-vk%uu(jvCzx*#n zB}HWTu}`q8TMo_<4%#m?ca#+Q}XBY4<=^>WK6~+``z0eJ88Q zI1Eek#&Q<(ya{T8ZvD{}sj=}Azi#&x1$ z*JWx4T)y*$bmLl66sK$Z%Y&R=(%h;vG`%teiaGJj_3+Th4SZfX{syBM89;Y3Lp+(m z$rfYOk7oBX$i^p?_a8_-f{G*4;z8*yRpeG*Nnz#m4Y>uov|$*#W`IuG35A#Dazhil zi$20PwIHPPA==MWSIVb)JJ)Nq*)-D%_t7Jp`XS4^4kpwzc8KM*C!C9$kz(wFlHI-{ z>6n(YH78;=zoma*w|geqmzIE(!Xqut-j-|MJWvV^!Q59+b&lIA{IHEq-EIPU2PgiL z(3af=oJr23)uaxtIy(a*S$MTcv$49D%jrcuW+hstWKhZbkesWh+uV9fx%#%h^_;J1 z-9A@l=8p=);vaGO%B@=-?+z^Wo4+e>NF(Z@Irr^8GbF~c=wwYg>iVdr0?8Ma6~Wml zb1<)?P^PRGUS6p7oNWAk;&zi;-`ScU<%bjtLd#=rrO|t-w1rl6_H_EMi2EDkY(o4F z*OX%TG>POBoA=j&!Z-F0jamYL-eO@QN_3nw(e-*%&+bP$VY~b`ezyml1)-g#SJ+5a zoLWu9H3K70_P$@{539wx@E}Yq{CEZjcyywlxEsprEqYp4phBgrY{QSea%-_n3Z^MFx~aJ}_yVdDjB z4@CD1NwLmuX9MhF;n@^s19ZYR2go1%FA$UIxf*}*Y^X9-93r;_Q4#-EiqfR-&HLZC zvSEyavewMi2DM|ZO8mps_3pcA+k6+@lkOgq?-^T|DJq48^nIT9K<-6d++^7CWnvHC zYkF)ejOZ1|;Zi<{Zo)@l*+GfnCy@nHi9L?PP>r#{VBvIY(rWkv;YedRBm^hN>;RRa z3dX@FM3>cx`ZVIX8F%%Qc0IC@31@434=A6A9L^be_=2Uok3M|DBTUp`0_~u*9)Dun zK8~KI#wzZ2oFOziIm>zum+$H;9g0!%^eyaQkwYsF{Jttw=J*1pS$t1t&DZqt!KqBu z`|!&G(h8KziN~g8QCo)IriRJ5;0bzYJ+pR#C*__dRQ8rq^EnFDf_w5(=%HkqW_6Q+ zgJspY&m(GxNAmUP*qmGXaY@bF;wi@3J<2?c8s8U~3#So&MQb%9p!SC*N3>hoyniw< zbA3+I%uRuWBz7o)e+-tkgJ9})?VE*rh&&@ifyXiU!_5@xYA#*J7coQLTv@~yHMfs) z2#+O00&RVG<`uJZXym|95>6~#fJ#8vXg^9Mr}L+5jv zcqzyGR#HzjU5i)a2-53Iw9ui^)!QVDmE#%95LyB$+^@un0ZI1WU&0L z=9Qry{v5dg=3!~&A$~R0bZb2#rL0dqSC6P?6AK-GQArWCUURbcWU2_SOf2sWzWuY1vrV6(=U!rwm;^RJEZ(mnQ3_Rx!T`dr>wCIZ_{X zYVF$}Cv{6p-Fpe?zj?j~obG#Pq#7Zz!D{QW{iw10V~e! zoddXs+3vV$On2%MRsC&Nk84+h-1(W@g|>Q>UVaO$M^C+vaB^yQT{_qn9yIV*+Y8$E zHqqa6&lWLM-mk6e^c)ztaM=05r!Sr+ejIp_2Ao{X9@A2IipVB4SVQ2j6R*MD*YGEr z-%OvNy9!!RoUft}zXV!8NOqn-{J|1lUXXse`%<9s$3s@$97#yD=~S4U*P$&ujy?pv zYr{{PmHL8nwdtkN4bMPtjAli?V+2M58p{+PQwAq`r*(aMggOl|9&~wjXeR?Ni1%A? zI`fqmbnqu&KYcqZY%hT8&9lLG2#f^0ILBKRoE)9uaI;$o^x6^7A0RNn_@`jmzQy~R z<4-t$vSFp`3$7=njQ%=l|KC3lKQ{lh)c;t_UrYV782Uxk|7^$cOMv{m8dO6{L4RTa zfE4{DOnz1+|2x7&q8;MW{DE^dxG^*&>HubZL6ZK(&rknblz+V+f7}bP?QC85#E_{#1G~E)OJb7y#nKwhDv0pAnmRe*$~0*qIip+nO)*f1$5)I_hm@+ ze6-^Tkqs4&%!~B$!k{!>4_-l6ryO?x4Pl%X(@ARjL~je>mZJ4|>@aZUhFix8sm9mU zH8V?cw(CZ6Jlje1W<)D_PioC3av_4)(KO8jh+sYZxw;A!F)h(bZ;s9se2keYje+;K zHlb=>UXtlEKQ%u2$1AWjn2{{W$&^0fsddkFCkDH(m%wm68|@jrr9np_`V90a7^?@V z%TTdpzL}(o$o@n7M?zea$(>JFZP>mXyY$y|fBs-fc2?NaVDxmpg=Jl%{M@T|GUxy* z7HJI5I&!Hkm7T~&AVFOLDIY(-(&g7Lfu8XfU{92dKkjL;(>>UqZ)D71H}~qi z(9>%S1oc=AjKs-lIVcBh5%{Fmx8Vd@T>iL4%x@qjBA*x>Fn30?1SXk1wxZ79xyaKw z?5=tCz^;*C(BX7{oW$zY&X5q!)dln1#)wXthJK!;J5=X4@KLC-yCfTDU2r~Ow)?i| zz)l&)69mnYi#8I(^rP+^`g(h_n2x#=qz={Zj;rDWH`B`zIwQmiSoE5peV5GQevVEX z$zNLS=MNVRybW1bx|?Hz3l6q|+^JM!L2FsTkLv8nr(Gs9Qh25pzuh3b#EvJvo?n=> zv-1I(nZ_z41Iax;p^Ny)LGX^KmTYea5OJB`P`=^>(K+(-VE#0dCA=iWNi1%nSfiWS zSwSa1UD-z_7m1nLj&#~{{#U!;$2VU!BpO~@qgAqWA<^10yt$3Fx7SJH-3e@IhXTnASGDdxUDmhUrzT`H8=c|9{$S64k^vechpP+S7Q8C(>1vsqG^-WSW3Y z;|(MGdVcrB?58GRYjO0Qp{9G~<+m=ep)33M1phW`!0^{-Uh{k(+UsElUCVkqTTrVu zpxw*0!io4yZ=YM&khVKOF2tZWv@i0M|vMox;Ey3D<1({7_(8SPUpJ^X>_5ShUM za)r?OZgB=u*fi1D7k>g99q-_+mZe@#i@?4NQsj3tE;roNG~%R=RWA}sLz&M;ePHYx7V z9gUXIX)4>{jWV9?ca4lI>CFf00TBqk%OO?2&FFjDGGM|;-N{)A_(0y<_a3iK))%dm zJiKIsy-*9iYothg1jH>VBRU{zXVMQQhCu^O6ESC}mc8MZ%b(P77V5*FT&(x$FG1kS z?X8FRpg(#nO#*p$e3#ev^So8>Jm^T@jkZ;%={>MnrhJ-~bES+hP-L9N; zl^cd`QmodLe>mSqm!F#BLgj#llx~|Rvm`odw}_OWWfLn5hICO6SJ~&4R-3WQkY(W+ zj4AI_C6nZ`C+P}o=FFaJj-z_k-TcGXUQx~a^3hlxBk988Vu5|fj!ol}YHIws!+@2` za=q#na=|QFAY#uRK62gkcQKrbD4mP+43!Pcb8M|zZKY>=waIgdtMsvv$VSJY$C2^D zZExn#*$-U7#j#N@8|8yC(qcQObUs(S81ReLJ;R-iy30&WomS0_tNiYxiD>7D4@46m zu)~JTTX?9`8s4vO!&pnLA-cmxcdqO9m~(Y9}3xs_YJzD35K(hV9!$ zdCYsWef?^{3|@2(Wp{&~hiPL|+3eXrW)SP{s$0Foy815sa)bMRBxYM7G;qt$Iw1F8 zfBIFg>=Z|uC{qdN;sr=aqdht7yfc?sV90se+1BWDQ{+oq#zqrgXgZmU3@2yd0b2F) z4rwnz&fTv0axjy>D8ar|S== zONlEanWu^S;&@cwb|oJNnTyN!AL3cH9fD~pU9B@{KyJhR1?PEJvA5q%rZDT%I*Sca zaniQ<=Z5T?>h|$MMphC!Ts!s?BQ6;^>H9D^)dmGVNky(rt-gR^_?jrFY6 zqQYYQ)n$S_>fGfVRyv9=>-C6MLPT?;xqhE)Z;a+v$OstC(l($`!wwDhwL66H^g)dpqtKMB3RcT`nAz7x-9lGDfK zUP;J--oBT9yP|kd>pBL($k5^p+_6wfDd@WCs?UINLwCtpVKW`WCXJbf#v!Z0TM&I$ z=a%wk4;=2v>aGN%8-oyovIDC_I)=Rp8q#$SRzEVg__KJzq*@H6aVs(re zT-6)~`b8;PYlz5wS=P3@55~kTbI%_2Jwlf}AkfI8GH+I`lhtEpk7w41)596!oE>5? zyc>gY)Uk!F4$gk#!R0w0Fxe^xYn(h>)c$tKrjgOPj^fs^B9w6>r(~2)CH2v56Gvnm z4?|%_8I^ZA5N?jPx62mr!VOAN!|PYC*Ef1j!NMY>Tg=Ta+s#hOAt>^UK^bnH$EnkC z?^sRqY$MHjIBln;t{rx`6w}WnRE1l{>}?&bY1BVspNkL-L5VrKwjc~)J<@E%`iHbc7u_MrJD4_b0BnzH`+hkq`&+dwBF&CJP5m{MTg@C_T zDqNwi2BNHko&y{Z+>~gAGr5fYqZm={=kono-Pon^h|}TiQH-t5=o4O1X$_06yh(dK z!IaKuOb$uK>_I+MW@Xfx1f4Zn#OvZow6e@AY`EDin`GI%e4tZ>S#~MR=~t@U-utYE zPTD!NkGhvcEOGtv*kw%B$`^8@w&>foYu{Lz`Cb75{6c{L)@8+Tki+5PV%5;YGZ7ks z3DVrIp{PI{shmCUJRfY^DrID331se6nP`Pip!G6L03PY6AH)G4!028tU24

80v) zGabg{1YRz0WT2)NcUEf=DiJIYjn!GHEwxwDad7ZF;^HE*GLkhlI_kX?DKoV!15_nY zs1H^x$L99P=9cX*Hz-71m_=TtUR@J42#sQ5ufAEi=h(wcueQk*$$U6%eZQtyx#l`r z=}K|JlN=4^!%&et^BHdfoYcG7c;p;jLEVCcI8xS8XpGTUu#8uYZ7)$nXoW3lM`%ho zHK~?(u3nXoId2poTbvz|0vhi&rgt0e(mtLY?aaf~oX!pTd`V^vd}H zqDuwK^_MD_zYR^L9xU+B?9v*3BS*1li&Kr^`V^#AO~=KAy`aNJEp-_@`2rtbg&<{( zOgV!_p-V(Bgx(Nfe1@am(tZdje;~L?i5fVMZ-DmA!<2mCsv2NN)?visF1MF=2IW>2 zsd|@paA?1%B=o8A-xG`+uj}nvh`5e@8JV!^>vYp^sWdTrBxdi<*9R-vD{7Ht>cJZvjL<&XlphCiX%~(4Fne-cS7{M50^O)CE@$N9 zJ=|XWDi=>SVf{qkv*EQ)T92?M;M^A}Dl@JUKUmkD+j%hq`US~^5Y8?Vu3H*?KyNhJ zlR<6dd{T#D4`yGom9?C|6|?mR|CPh~7;@g}7R+lHoiCyGWh}7;Z2tE7#+9SHY@n|?u$MF0fC1QA z9YJ$A<(!`5R7_dXfLM5>{sz34j3~3!T>ESSzrA?l_|ft&V-Mb4t#7?G#=siqZdYq; z`A(}==P~gW!2Yto^F87}DiWR5Nm}qvYx$qMjlODgfZc9X)6k<~jdd|Rd&h=~SYzTf zk7@$>jN-qNsH)O6wPiPRZcrV*`WN#Iyh)keZ=AcXc^U{It!U_SS(wsW9@SKut2ZS; z^c6y+r_V`5Icv6AYw@>M`N@)(u=bXV5~v?6GUou&JJ$Xkk7iZ|$p5O$CkvSY&*B_0 zp*84W2Cjl&%1f$2eg*sl$m8ho z4H=1s4rcy7RVCmM*25!I5F{eedvddP2`uvKBCnuJs4Z5tN{C>F6MIAL03D${J-W+s z(P%C-(meATaLx=hS~AAK5@J*BFA-S8uiC&lbKHB!t`CV;6{cCQNQ?95l|N8C$t-Y^ zVBTM1-0NsDx}T~!&Q+{UXno^|(Aa~cnb*M^?VMY3th~e3ahF1b7QVWS@fe}1dkHzX zcrD-w^U$l@nbEOrdWmSGmOwrL#QV-H%}~I~T^P5qU~aq7X_S;QeO%a^^8|tAkr>w_ z35Y=~Em=3xTW1GuGkaPD(K#OFBz~a}yrwywbgx+A3a6!jP5RLwKxs0@v+!5fU<9M_ z5O3@WzWUdf!Kn(!_43itLRb6B^|s=<#l@rd2+~l0 zZq4gUl9L^hGIbLyGGv}PZ=M42^sP|&($BQ>Zx8s+brI6$L6T0u$^3(jynj6kPtm{D z3NHzM5yKC?_J5ri*j#PyKp;e?AKbg6`u_nxni1LDL|%LOPaERD3bK#n`{Fv!VyoQD Sl|Deg-vcT6d+@uDfBzo~w|Eo) literal 0 HcmV?d00001 diff --git a/SwaggerDocketAdvancedDetailsExample/mvnw b/SwaggerDocketAdvancedDetailsExample/mvnw new file mode 100644 index 0000000..8a8fb22 --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/mvnw @@ -0,0 +1,316 @@ +#!/bin/sh +# ---------------------------------------------------------------------------- +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. +# ---------------------------------------------------------------------------- + +# ---------------------------------------------------------------------------- +# Maven Start Up Batch script +# +# Required ENV vars: +# ------------------ +# JAVA_HOME - location of a JDK home dir +# +# Optional ENV vars +# ----------------- +# M2_HOME - location of maven2's installed home dir +# MAVEN_OPTS - parameters passed to the Java VM when running Maven +# e.g. to debug Maven itself, use +# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 +# MAVEN_SKIP_RC - flag to disable loading of mavenrc files +# ---------------------------------------------------------------------------- + +if [ -z "$MAVEN_SKIP_RC" ] ; then + + if [ -f /usr/local/etc/mavenrc ] ; then + . /usr/local/etc/mavenrc + fi + + if [ -f /etc/mavenrc ] ; then + . /etc/mavenrc + fi + + if [ -f "$HOME/.mavenrc" ] ; then + . "$HOME/.mavenrc" + fi + +fi + +# OS specific support. $var _must_ be set to either true or false. +cygwin=false; +darwin=false; +mingw=false +case "`uname`" in + CYGWIN*) cygwin=true ;; + MINGW*) mingw=true;; + Darwin*) darwin=true + # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home + # See https://developer.apple.com/library/mac/qa/qa1170/_index.html + if [ -z "$JAVA_HOME" ]; then + if [ -x "/usr/libexec/java_home" ]; then + export JAVA_HOME="`/usr/libexec/java_home`" + else + export JAVA_HOME="/Library/Java/Home" + fi + fi + ;; +esac + +if [ -z "$JAVA_HOME" ] ; then + if [ -r /etc/gentoo-release ] ; then + JAVA_HOME=`java-config --jre-home` + fi +fi + +if [ -z "$M2_HOME" ] ; then + ## resolve links - $0 may be a link to maven's home + PRG="$0" + + # need this for relative symlinks + while [ -h "$PRG" ] ; do + ls=`ls -ld "$PRG"` + link=`expr "$ls" : '.*-> \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG="`dirname "$PRG"`/$link" + fi + done + + saveddir=`pwd` + + M2_HOME=`dirname "$PRG"`/.. + + # make it fully qualified + M2_HOME=`cd "$M2_HOME" && pwd` + + cd "$saveddir" + # echo Using m2 at $M2_HOME +fi + +# For Cygwin, ensure paths are in UNIX format before anything is touched +if $cygwin ; then + [ -n "$M2_HOME" ] && + M2_HOME=`cygpath --unix "$M2_HOME"` + [ -n "$JAVA_HOME" ] && + JAVA_HOME=`cygpath --unix "$JAVA_HOME"` + [ -n "$CLASSPATH" ] && + CLASSPATH=`cygpath --path --unix "$CLASSPATH"` +fi + +# For Mingw, ensure paths are in UNIX format before anything is touched +if $mingw ; then + [ -n "$M2_HOME" ] && + M2_HOME="`(cd "$M2_HOME"; pwd)`" + [ -n "$JAVA_HOME" ] && + JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`" +fi + +if [ -z "$JAVA_HOME" ]; then + javaExecutable="`which javac`" + if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then + # readlink(1) is not available as standard on Solaris 10. + readLink=`which readlink` + if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then + if $darwin ; then + javaHome="`dirname \"$javaExecutable\"`" + javaExecutable="`cd \"$javaHome\" && pwd -P`/javac" + else + javaExecutable="`readlink -f \"$javaExecutable\"`" + fi + javaHome="`dirname \"$javaExecutable\"`" + javaHome=`expr "$javaHome" : '\(.*\)/bin'` + JAVA_HOME="$javaHome" + export JAVA_HOME + fi + fi +fi + +if [ -z "$JAVACMD" ] ; then + if [ -n "$JAVA_HOME" ] ; then + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then + # IBM's JDK on AIX uses strange locations for the executables + JAVACMD="$JAVA_HOME/jre/sh/java" + else + JAVACMD="$JAVA_HOME/bin/java" + fi + else + JAVACMD="`\\unset -f command; \\command -v java`" + fi +fi + +if [ ! -x "$JAVACMD" ] ; then + echo "Error: JAVA_HOME is not defined correctly." >&2 + echo " We cannot execute $JAVACMD" >&2 + exit 1 +fi + +if [ -z "$JAVA_HOME" ] ; then + echo "Warning: JAVA_HOME environment variable is not set." +fi + +CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher + +# traverses directory structure from process work directory to filesystem root +# first directory with .mvn subdirectory is considered project base directory +find_maven_basedir() { + + if [ -z "$1" ] + then + echo "Path not specified to find_maven_basedir" + return 1 + fi + + basedir="$1" + wdir="$1" + while [ "$wdir" != '/' ] ; do + if [ -d "$wdir"/.mvn ] ; then + basedir=$wdir + break + fi + # workaround for JBEAP-8937 (on Solaris 10/Sparc) + if [ -d "${wdir}" ]; then + wdir=`cd "$wdir/.."; pwd` + fi + # end of workaround + done + echo "${basedir}" +} + +# concatenates all lines of a file +concat_lines() { + if [ -f "$1" ]; then + echo "$(tr -s '\n' ' ' < "$1")" + fi +} + +BASE_DIR=`find_maven_basedir "$(pwd)"` +if [ -z "$BASE_DIR" ]; then + exit 1; +fi + +########################################################################################## +# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central +# This allows using the maven wrapper in projects that prohibit checking in binary data. +########################################################################################## +if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found .mvn/wrapper/maven-wrapper.jar" + fi +else + if [ "$MVNW_VERBOSE" = true ]; then + echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..." + fi + if [ -n "$MVNW_REPOURL" ]; then + jarUrl="$MVNW_REPOURL/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar" + else + jarUrl="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar" + fi + while IFS="=" read key value; do + case "$key" in (wrapperUrl) jarUrl="$value"; break ;; + esac + done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties" + if [ "$MVNW_VERBOSE" = true ]; then + echo "Downloading from: $jarUrl" + fi + wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" + if $cygwin; then + wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"` + fi + + if command -v wget > /dev/null; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found wget ... using wget" + fi + if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then + wget "$jarUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath" + else + wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath" + fi + elif command -v curl > /dev/null; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found curl ... using curl" + fi + if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then + curl -o "$wrapperJarPath" "$jarUrl" -f + else + curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f + fi + + else + if [ "$MVNW_VERBOSE" = true ]; then + echo "Falling back to using Java to download" + fi + javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java" + # For Cygwin, switch paths to Windows format before running javac + if $cygwin; then + javaClass=`cygpath --path --windows "$javaClass"` + fi + if [ -e "$javaClass" ]; then + if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then + if [ "$MVNW_VERBOSE" = true ]; then + echo " - Compiling MavenWrapperDownloader.java ..." + fi + # Compiling the Java class + ("$JAVA_HOME/bin/javac" "$javaClass") + fi + if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then + # Running the downloader + if [ "$MVNW_VERBOSE" = true ]; then + echo " - Running MavenWrapperDownloader.java ..." + fi + ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR") + fi + fi + fi +fi +########################################################################################## +# End of extension +########################################################################################## + +export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"} +if [ "$MVNW_VERBOSE" = true ]; then + echo $MAVEN_PROJECTBASEDIR +fi +MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS" + +# For Cygwin, switch paths to Windows format before running java +if $cygwin; then + [ -n "$M2_HOME" ] && + M2_HOME=`cygpath --path --windows "$M2_HOME"` + [ -n "$JAVA_HOME" ] && + JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"` + [ -n "$CLASSPATH" ] && + CLASSPATH=`cygpath --path --windows "$CLASSPATH"` + [ -n "$MAVEN_PROJECTBASEDIR" ] && + MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"` +fi + +# Provide a "standardized" way to retrieve the CLI args that will +# work with both Windows and non-Windows executions. +MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@" +export MAVEN_CMD_LINE_ARGS + +WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain + +exec "$JAVACMD" \ + $MAVEN_OPTS \ + $MAVEN_DEBUG_OPTS \ + -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \ + "-Dmaven.home=${M2_HOME}" \ + "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \ + ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@" diff --git a/SwaggerDocketAdvancedDetailsExample/mvnw.cmd b/SwaggerDocketAdvancedDetailsExample/mvnw.cmd new file mode 100644 index 0000000..1d8ab01 --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/mvnw.cmd @@ -0,0 +1,188 @@ +@REM ---------------------------------------------------------------------------- +@REM Licensed to the Apache Software Foundation (ASF) under one +@REM or more contributor license agreements. See the NOTICE file +@REM distributed with this work for additional information +@REM regarding copyright ownership. The ASF licenses this file +@REM to you under the Apache License, Version 2.0 (the +@REM "License"); you may not use this file except in compliance +@REM with the License. You may obtain a copy of the License at +@REM +@REM https://www.apache.org/licenses/LICENSE-2.0 +@REM +@REM Unless required by applicable law or agreed to in writing, +@REM software distributed under the License is distributed on an +@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +@REM KIND, either express or implied. See the License for the +@REM specific language governing permissions and limitations +@REM under the License. +@REM ---------------------------------------------------------------------------- + +@REM ---------------------------------------------------------------------------- +@REM Maven Start Up Batch script +@REM +@REM Required ENV vars: +@REM JAVA_HOME - location of a JDK home dir +@REM +@REM Optional ENV vars +@REM M2_HOME - location of maven2's installed home dir +@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands +@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending +@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven +@REM e.g. to debug Maven itself, use +@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 +@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files +@REM ---------------------------------------------------------------------------- + +@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on' +@echo off +@REM set title of command window +title %0 +@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on' +@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO% + +@REM set %HOME% to equivalent of $HOME +if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%") + +@REM Execute a user defined script before this one +if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre +@REM check for pre script, once with legacy .bat ending and once with .cmd ending +if exist "%USERPROFILE%\mavenrc_pre.bat" call "%USERPROFILE%\mavenrc_pre.bat" %* +if exist "%USERPROFILE%\mavenrc_pre.cmd" call "%USERPROFILE%\mavenrc_pre.cmd" %* +:skipRcPre + +@setlocal + +set ERROR_CODE=0 + +@REM To isolate internal variables from possible post scripts, we use another setlocal +@setlocal + +@REM ==== START VALIDATION ==== +if not "%JAVA_HOME%" == "" goto OkJHome + +echo. +echo Error: JAVA_HOME not found in your environment. >&2 +echo Please set the JAVA_HOME variable in your environment to match the >&2 +echo location of your Java installation. >&2 +echo. +goto error + +:OkJHome +if exist "%JAVA_HOME%\bin\java.exe" goto init + +echo. +echo Error: JAVA_HOME is set to an invalid directory. >&2 +echo JAVA_HOME = "%JAVA_HOME%" >&2 +echo Please set the JAVA_HOME variable in your environment to match the >&2 +echo location of your Java installation. >&2 +echo. +goto error + +@REM ==== END VALIDATION ==== + +:init + +@REM Find the project base dir, i.e. the directory that contains the folder ".mvn". +@REM Fallback to current working directory if not found. + +set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR% +IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir + +set EXEC_DIR=%CD% +set WDIR=%EXEC_DIR% +:findBaseDir +IF EXIST "%WDIR%"\.mvn goto baseDirFound +cd .. +IF "%WDIR%"=="%CD%" goto baseDirNotFound +set WDIR=%CD% +goto findBaseDir + +:baseDirFound +set MAVEN_PROJECTBASEDIR=%WDIR% +cd "%EXEC_DIR%" +goto endDetectBaseDir + +:baseDirNotFound +set MAVEN_PROJECTBASEDIR=%EXEC_DIR% +cd "%EXEC_DIR%" + +:endDetectBaseDir + +IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig + +@setlocal EnableExtensions EnableDelayedExpansion +for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a +@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS% + +:endReadAdditionalConfig + +SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe" +set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar" +set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain + +set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar" + +FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( + IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B +) + +@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central +@REM This allows using the maven wrapper in projects that prohibit checking in binary data. +if exist %WRAPPER_JAR% ( + if "%MVNW_VERBOSE%" == "true" ( + echo Found %WRAPPER_JAR% + ) +) else ( + if not "%MVNW_REPOURL%" == "" ( + SET DOWNLOAD_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar" + ) + if "%MVNW_VERBOSE%" == "true" ( + echo Couldn't find %WRAPPER_JAR%, downloading it ... + echo Downloading from: %DOWNLOAD_URL% + ) + + powershell -Command "&{"^ + "$webclient = new-object System.Net.WebClient;"^ + "if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^ + "$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^ + "}"^ + "[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^ + "}" + if "%MVNW_VERBOSE%" == "true" ( + echo Finished downloading %WRAPPER_JAR% + ) +) +@REM End of extension + +@REM Provide a "standardized" way to retrieve the CLI args that will +@REM work with both Windows and non-Windows executions. +set MAVEN_CMD_LINE_ARGS=%* + +%MAVEN_JAVA_EXE% ^ + %JVM_CONFIG_MAVEN_PROPS% ^ + %MAVEN_OPTS% ^ + %MAVEN_DEBUG_OPTS% ^ + -classpath %WRAPPER_JAR% ^ + "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" ^ + %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %* +if ERRORLEVEL 1 goto error +goto end + +:error +set ERROR_CODE=1 + +:end +@endlocal & set ERROR_CODE=%ERROR_CODE% + +if not "%MAVEN_SKIP_RC%"=="" goto skipRcPost +@REM check for post script, once with legacy .bat ending and once with .cmd ending +if exist "%USERPROFILE%\mavenrc_post.bat" call "%USERPROFILE%\mavenrc_post.bat" +if exist "%USERPROFILE%\mavenrc_post.cmd" call "%USERPROFILE%\mavenrc_post.cmd" +:skipRcPost + +@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on' +if "%MAVEN_BATCH_PAUSE%"=="on" pause + +if "%MAVEN_TERMINATE_CMD%"=="on" exit %ERROR_CODE% + +cmd /C exit /B %ERROR_CODE% diff --git a/SwaggerDocketAdvancedDetailsExample/pom.xml b/SwaggerDocketAdvancedDetailsExample/pom.xml new file mode 100644 index 0000000..08edeca --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/pom.xml @@ -0,0 +1,54 @@ + + + 4.0.0 + + org.springframework.boot + spring-boot-starter-parent + 2.7.0 + + + ro.stefan + swagger-docket-advanced-details-example + 0.0.1-SNAPSHOT + swagger-docket-advanced-details-example + Demo project for Spring Boot + + 1.8 + + + + org.springframework.boot + spring-boot-starter-web + + + + org.springframework.boot + spring-boot-devtools + runtime + true + + + org.springframework.boot + spring-boot-starter-test + test + + + + io.springfox + springfox-boot-starter + 3.0.0 + + + + + + + org.springframework.boot + spring-boot-maven-plugin + + + + + diff --git a/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/SwaggerDocketAdvancedDetailsExampleApp.java b/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/SwaggerDocketAdvancedDetailsExampleApp.java new file mode 100644 index 0000000..bda1c83 --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/SwaggerDocketAdvancedDetailsExampleApp.java @@ -0,0 +1,14 @@ +package ro.stefan; + +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; + +@SpringBootApplication +public class SwaggerDocketAdvancedDetailsExampleApp { + + public static void main(String[] args) { + SpringApplication.run(SwaggerDocketAdvancedDetailsExampleApp.class, args); + } + +} + \ No newline at end of file diff --git a/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/config/SpringFoxConfig.java b/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/config/SpringFoxConfig.java new file mode 100644 index 0000000..9ad23e7 --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/config/SpringFoxConfig.java @@ -0,0 +1,32 @@ +package ro.stefan.config; + +import java.util.HashSet; +import java.util.Set; + +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; +import org.springframework.http.MediaType; + +import springfox.documentation.builders.PathSelectors; +import springfox.documentation.builders.RequestHandlerSelectors; +import springfox.documentation.spi.DocumentationType; +import springfox.documentation.spring.web.plugins.Docket; + +@Configuration +public class SpringFoxConfig { + + @Bean + public Docket getDocketInstance() { + final Set produces = new HashSet(); + produces.add(MediaType.APPLICATION_JSON_VALUE); + produces.add(MediaType.APPLICATION_XML_VALUE); + produces.add("Stefan's custom mapping value"); + + return new Docket(DocumentationType.SWAGGER_2) + .produces(produces) + .select() + .apis(RequestHandlerSelectors.basePackage("ro.stefan.controller")) + .paths(PathSelectors.any()) + .build(); + } +} \ No newline at end of file diff --git a/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/controller/BookController.java b/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/controller/BookController.java new file mode 100644 index 0000000..b3d60c8 --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/controller/BookController.java @@ -0,0 +1,18 @@ +package ro.stefan.controller; + +import java.util.ArrayList; +import java.util.List; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +import ro.stefan.dto.Book; + +@RestController +public class BookController { + + @GetMapping("/books") + public List getBooks(){ + return new ArrayList(); + } +} diff --git a/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/dto/Book.java b/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/dto/Book.java new file mode 100644 index 0000000..35177e0 --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/src/main/java/ro/stefan/dto/Book.java @@ -0,0 +1,23 @@ +package ro.stefan.dto; + +public class Book { + private String title; + private String author; + + public String getTitle() { + return title; + } + + public void setTitle(String title) { + this.title = title; + } + + public String getAuthor() { + return author; + } + + public void setAuthor(String author) { + this.author = author; + } + +} diff --git a/SwaggerDocketAdvancedDetailsExample/src/main/resources/application.yaml b/SwaggerDocketAdvancedDetailsExample/src/main/resources/application.yaml new file mode 100644 index 0000000..27323dd --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/src/main/resources/application.yaml @@ -0,0 +1,6 @@ +spring: + mvc: + pathmatch: + matching-strategy: ant_path_matcher +server: + port: 8081 \ No newline at end of file diff --git a/SwaggerDocketAdvancedDetailsExample/src/test/java/ro/stefan/SwaggerDocketAdvancedDetailsExampleAppTests.java b/SwaggerDocketAdvancedDetailsExample/src/test/java/ro/stefan/SwaggerDocketAdvancedDetailsExampleAppTests.java new file mode 100644 index 0000000..6c3c8da --- /dev/null +++ b/SwaggerDocketAdvancedDetailsExample/src/test/java/ro/stefan/SwaggerDocketAdvancedDetailsExampleAppTests.java @@ -0,0 +1,13 @@ +package ro.stefan; + +import org.junit.jupiter.api.Test; +import org.springframework.boot.test.context.SpringBootTest; + +@SpringBootTest +class SwaggerDocketAdvancedDetailsExampleAppTests { + + @Test + void contextLoads() { + } + +}