From 133c8a0a5b6c5afba0370cb81674fae36609cbd9 Mon Sep 17 00:00:00 2001 From: Stefan Paladuta Date: Sat, 4 Jun 2022 23:19:25 +0300 Subject: [PATCH] Adding the first interation of the example projects --- SwaggerGroupingExample/.gitignore | 33 ++ .../.mvn/wrapper/maven-wrapper.jar | Bin 0 -> 58727 bytes .../.mvn/wrapper/maven-wrapper.properties | 2 + .../dev_resources/EXAMPLE_GROUPING1_orig.png | Bin 0 -> 63241 bytes .../dev_resources/EXAMPLE_GROUPING2_orig.png | Bin 0 -> 62849 bytes SwaggerGroupingExample/mvnw | 316 ++++++++++++++++++ SwaggerGroupingExample/mvnw.cmd | 188 +++++++++++ SwaggerGroupingExample/pom.xml | 54 +++ .../ro/stefan/SwaggerGroupingExampleApp.java | 14 + .../ro/stefan/config/SpringFoxConfig.java | 36 ++ .../ro/stefan/controller/BookController.java | 15 + .../controller/AccountingController.java | 15 + .../address/controller/AddressController.java | 15 + .../apis/loan/controller/LoanController.java | 16 + .../controller/SecurityController.java | 16 + .../src/main/resources/application.yaml | 6 + .../SwaggerGroupingExampleAppTests.java | 13 + SwaggerGroupingUsingTagsExample/.gitignore | 33 ++ .../.mvn/wrapper/maven-wrapper.jar | Bin 0 -> 58727 bytes .../.mvn/wrapper/maven-wrapper.properties | 2 + SwaggerGroupingUsingTagsExample/mvnw | 316 ++++++++++++++++++ SwaggerGroupingUsingTagsExample/mvnw.cmd | 188 +++++++++++ SwaggerGroupingUsingTagsExample/pom.xml | 54 +++ .../SwaggerGroupingUsingTagsExampleApp.java | 14 + .../ro/stefan/config/SpringFoxConfig.java | 68 ++++ .../ro/stefan/controller/BookController.java | 15 + .../controller/AccountingController.java | 15 + .../address/controller/AddressController.java | 15 + .../apis/loan/controller/LoanController.java | 16 + .../controller/SecurityController.java | 16 + .../src/main/resources/application.yaml | 4 + ...aggerGroupingUsingTagsExampleAppTests.java | 13 + 32 files changed, 1508 insertions(+) create mode 100644 SwaggerGroupingExample/.gitignore create mode 100644 SwaggerGroupingExample/.mvn/wrapper/maven-wrapper.jar create mode 100644 SwaggerGroupingExample/.mvn/wrapper/maven-wrapper.properties create mode 100644 SwaggerGroupingExample/dev_resources/EXAMPLE_GROUPING1_orig.png create mode 100644 SwaggerGroupingExample/dev_resources/EXAMPLE_GROUPING2_orig.png create mode 100644 SwaggerGroupingExample/mvnw create mode 100644 SwaggerGroupingExample/mvnw.cmd create mode 100644 SwaggerGroupingExample/pom.xml create mode 100644 SwaggerGroupingExample/src/main/java/ro/stefan/SwaggerGroupingExampleApp.java create mode 100644 SwaggerGroupingExample/src/main/java/ro/stefan/config/SpringFoxConfig.java create mode 100644 SwaggerGroupingExample/src/main/java/ro/stefan/controller/BookController.java create mode 100644 SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/accounting/controller/AccountingController.java create mode 100644 SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/address/controller/AddressController.java create mode 100644 SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/loan/controller/LoanController.java create mode 100644 SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/security/controller/SecurityController.java create mode 100644 SwaggerGroupingExample/src/main/resources/application.yaml create mode 100644 SwaggerGroupingExample/src/test/java/ro/stefan/SwaggerGroupingExampleAppTests.java create mode 100644 SwaggerGroupingUsingTagsExample/.gitignore create mode 100644 SwaggerGroupingUsingTagsExample/.mvn/wrapper/maven-wrapper.jar create mode 100644 SwaggerGroupingUsingTagsExample/.mvn/wrapper/maven-wrapper.properties create mode 100644 SwaggerGroupingUsingTagsExample/mvnw create mode 100644 SwaggerGroupingUsingTagsExample/mvnw.cmd create mode 100644 SwaggerGroupingUsingTagsExample/pom.xml create mode 100644 SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/SwaggerGroupingUsingTagsExampleApp.java create mode 100644 SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/config/SpringFoxConfig.java create mode 100644 SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/controller/BookController.java create mode 100644 SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/accounting/controller/AccountingController.java create mode 100644 SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/address/controller/AddressController.java create mode 100644 SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/loan/controller/LoanController.java create mode 100644 SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/security/controller/SecurityController.java create mode 100644 SwaggerGroupingUsingTagsExample/src/main/resources/application.yaml create mode 100644 SwaggerGroupingUsingTagsExample/src/test/java/ro/stefan/SwaggerGroupingUsingTagsExampleAppTests.java diff --git a/SwaggerGroupingExample/.gitignore b/SwaggerGroupingExample/.gitignore new file mode 100644 index 0000000..549e00a --- /dev/null +++ b/SwaggerGroupingExample/.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/SwaggerGroupingExample/.mvn/wrapper/maven-wrapper.jar b/SwaggerGroupingExample/.mvn/wrapper/maven-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..c1dd12f17644411d6e840bd5a10c6ecda0175f18 GIT binary patch literal 58727 zcmb5W18`>1vNjyPv28mO+cqb*Z6_1kwr$(?#I}=(ZGUs`Jr}3`|DLbDUA3!L?dtC8 zUiH*ktDo+@6r@4HP=SCTA%WmZqm^Ro`Ls)bfPkcdfq?#g1(Fq27W^S8Cq^$TC?_c< zs-#ROD;6C)1wFuk7<3)nGuR^#!H;n&3*IjzXg+s8Z_S!!E0jUq(`}Itt=YdYa5Z_s z&e>2={87knpF*PKNzU;lsbk#P(l^WBvb$yEz)z+nYH43pKodrDkMp@h?;n{;K}hl>Fb^ zqx}C0|D7kg|Cj~3f7hn_zkAE}|6t|cZT|S5Hvb#3nc~C14u5UI{6#F<|FkJ0svs&S zA}S{=DXLT*BM1$`2rK%`D@vEw9l9%*=92X_2g?Fwfi=6Zfpr7+<~sgP#Bav+Df2ts zwtu~70zhqV?mrzM)}r7mMS`Hk_)NrI5K%CTtQtDxqw5iv5F0!ksIon{qqpPVnU?ds zN$|Vm{MHKEReUy>1kVfT-$3))Js0p2W_LFy3cjjZ7za0R zPdBH>y&pb0vr1|ckDpt2p$IQhwnPs5G*^b-y}sg4W!ALn}a`pY0JIa$H0$eV2T8WjWD= zWaENacQhlTyK4O!+aOXBurVR2k$eb8HVTCxy-bcHlZ4Xr!`juLAL#?t6|Ba!g9G4I zSwIt2Lla>C?C4wAZ8cKsZl9-Yd3kqE`%!5HlGdJJaFw0mu#--&**L-i|BcIdc3B$;0FC;FbE-dunVZ; zdIQ=tPKH4iJQQ=$5BeEMLov_Hn>gXib|9nOr}>eZt@B4W^m~>Zp#xhn1dax+?hS!AchWJ4makWZs@dQUeXQ zsI2+425_{X@t2KN zIbqec#)Jg5==VY3^YBeJ2B+%~^Y8|;F!mE8d(`UgNl2B9o>Ir5)qbBr)a?f%nrP zQyW(>FYPZjCVKDOU;Bw#PqPF1CCvp)dGdA&57a5hD&*vIc)jA)Z-!y5pS{5W6%#prH16zgD8s zexvpF#a|=*acp>L^lZ(PT)GiA8BJL-9!r8S$ZvXRKMVtiGe`+!@O%j<1!@msc177U zTDy>WOZu)W5anPrweQyjIu3IJC|ngdjZofGbdW&oj^DJlC7$;|xafB45evT|WBgGf-b|9y0J`fe0W-vw6xh}` z=(Tnq(-K0O{;VUcKe2y63{HXc+`R_#HLwnZ0rzWO*b#VeSuC4NG!H_ApCypbt1qx( z6y7Q$5(JOpQ&pTkc^0f}A0Kq*?;g9lEfzeE?5e2MBNZB)^8W1)YgdjsVyN+I9EZlh z3l}*}*)cFl=dOq|DvF=!ui$V%XhGQ%bDn3PK9 zV%{Y|VkAdt^d9~y4laGDqSwLd@pOnS&^@sI7}YTIb@El1&^_sq+{yAGf0|rq5TMp# z6d~;uAZ(fY3(eH=+rcbItl2=u6mf|P{lD4kiRCv;>GtFaHR3gim?WU9RjHmFZLm+m z+j<}_exaOQ1a}=K#voc~En+Mk_<(L!?1e#Uay~|H5q)LjD*yE6xFYQ-Wx{^iH1@pP zC0De#D6I26&W{;J40sZB!=%{c?XdO?YQvnTMA3TwfhAm@bvkX*(x?JTs*dFDv^=2X z284}AK)1nRn+8(Q2P?f)e>0~;NUI9%p%fnv1wBVpoXL+9OE`Vv1Y7=+nub$o7AN>y zB?R(^G8PYcMk4bxe7XItq@48QqWKb8fa*i9-N)=wdU-Q^=}!nFgTr_uT=Z=9pq z`{7!$U|+fnXFcsJ4GNm3JQQCN+G85k$)ZLhF{NbIy{REj84}Zt;0fe#>MARW)AoSb zrBpwF37ZVBMd>wZn_hAadI*xu8)Y#`aMbwRIA2n^-OS~M58_@j?#P1|PXJ1XBC9{4 zT^8*|xu<@(JlSOT*ILrVGr+7$nZN`Z3GxJJO@nY&mHsv^^duAh*lCu5q+S6zWA+`- z%^*y#)O7ko_RwGJl;bcEpP03FOrhlLWs`V_OUCrR-g>NJz*pN|itmN6O@Hw05Zq;Xtif%+sp4Py0{<7<^c zeoHHhRq>2EtYy9~2dZywm&OSk`u2ECWh6dJY?;fT-3-$U`!c(o$&hhPC%$~fT&bw3 zyj+8aXD;G!p*>BC6rpvx#6!|Qaic;KEv5>`Y+R(6F^1eIeYG6d1q3D3OL{7%7iw3R zwO)W7gMh27ASSB>-=OfP(YrKqBTNFv4hL@Im~~ombbSu44p~VoH$H-6+L_JW>Amkl zhDU~|r77?raaxD!-c$Ta?WAAi{w3T}YV=+S?1HQGC0+{Bny_^b+4Jum}oW4c=$ z#?D<}Ds{#d5v`L`${Pee;W84X*osNQ96xsKp^EAzuUh9#&zDX=eqdAp$UY)EGrkU% z(6m35n=46B$TNnejNSlih_!<)Iu@K!PW5S@Ya^0OK+EMWM=1w=GUKW^(r59U%i?d zzbo?|V4tDWGHHsrAQ}}ma#<`9r=M8%XF#%a=@Hn(p3wFBlkZ2L@8=*@J-^zuyF0aN zzJ7f!Jf8I+^6Tt$e+IIh zb80@?7y#Iz3w-0VEjgbHurqI>$qj<@n916)&O340!_5W9DtwR)P5mk6v2ljyK*DG5 zYjzE~m`>tq8HYXl%1JJ%e-%BqV4kRdPUZB1Cm$BQZr(fzp_@rn_W+;GwI$?L2Y4;b z)}c5D$#LT}2W8Si<`EHKIa_X+>+2PF(C*u~F=8E!jL(=IdQxY40%|( zoNg2Z&Aob@LEui-lJ#@)Ts)tE0_!*3{Uk)r{;-IZpX`N4mZX`#E|A;viQWImB6flI z?M_|xHCXV$5LOY-!U1_O1k;OWa=EchwlDCK4xHwBW2jE-6&%}og+9NILu${v10Z^Z#* zap|)B9a-AMU~>$r)3&|dQuP#MA$jnw54w*Ax~*_$iikp+j^OR8I5Fo<_UR#B-c>$? zeg)=;w^sGeAMi<3RGDRj$jA30Qq$e|zf2z;JyQ}tkU)ZI_k6tY%(`#AvL)p)iYXUy z5W9Su3NJ8mVyy)WqzFSk&vZM!;kUh8dVeA-myqcV%;xUne`PbHCPpvH?br`U2Y&dM zV!nJ!^n%`!H&!QSlpzLWnZpgi;#P0OAleH+<CfLa?&o|kyw1}W%6Pij zp$Vv5=;Z0LFN|j9i&9>zqX>*VnV3h#>n!2L?5gO6HJS3~kpy5G zYAVPMaB-FJOk3@OrxL(*-O~OB9^d{!G0K>wlzXuBm*$&%p1O#6SQ*?Q0CETLQ->XpfkW7< zj&Nep(}eAH1u$wWFvLV*lA{JOltP_%xKXC*a8DB&;{fD&2bATy>rC^kFY+$hFS7us;Y) zy_H?cv9XTHYz<4C<0b`WKC#{nJ15{F=oaq3x5}sYApT?Po+(Cmmo#dHZFO^{M#d~d znRT=TFATGVO%z_FNG-@G;9az|udZ>t@5l+A-K)BUWFn_|T#K3=d3EXRNqHyi#>;hX z*JQ`pT3#&tH>25laFlL6Rllu(seA*OboEd%rxMtz3@5v-+{qDP9&BcoS$2fgjgvp$ zc8!3=p0p@Ee1$u{Gg}Kkxg@M*qgZfYLlnD88{uwG1T?zxCbBR+x(RK$JB(eWJH#~; zZoY6L+esVRV?-*QmRCG}h`rB*Lv=uE%URF@+#l-g!Artx>Y9D;&G=jY2n2`J z{6-J%WX~Glx*QBmOOJ(RDRIzhfk&ibsm1t&&7aU{1P3U0uM%F2zJb4~50uby_ng+# zN)O9lK=dkJpxsUo7u8|e`Y~mmbxOTDn0i!i;d;ml#orN(Lc=j+n422NoSnlH6?0<0?th-qB7u}`5My%#?ES}>@RldOQz}WILz<$+cN~&ET zwUI01HCB((TyU$Ej8bxsE8oLmT-c7gA1Js?Iq`QMzIHV|)v)n2 zT_L(9x5%8*wU(C`VapaHoicWcm|0X@9TiNtbc|<4N6_H1F6&qgEEj=vjegFt;hC7- zLG7_=vedRFZ6Chbw!{#EpAlM?-sc#pc<~j#537n)M%RT)|L}y(ggi_-SLpsE3qi3V z=EEASxc>a{Su)jXcRS41Z@Mxk&0B7B<(?Izt5wpyyIBO|-M}ex8BhbIgi*X4 zDZ+Yk1<6&=PoZ=U-!9`!?sBVpYF#Y!JK<`fx}bXN651o0VVaW;t6ASVF@gq-mIDV_)?F^>rq1XX0NYy~(G=I6x%Fi5C2rMtvs z%P`g2>0{xLUy~#ye)%QAz^NkD5GUyPYl}K#;e-~UQ96`I$U0D!sMdQ>;%+c0h>k*Y z)sD1mi_@|rZnQ+zbWq~QxFlBQXj8WEY7NKaOYjUxAkGB8S#;l@b^C?;twRKl=mt0< zazifrBs`(q7_r14u1ZS`66VmsLpV>b5U!ktX>g4Nq~VPq6`%`3iCdr(>nS~uxxylU z>h(2p$XPJVh9BDpRLLzTDlNdp+oq8sOUlJ#{6boG`k)bwnsw5iy@#d{f_De-I|}vx6evw;ch97=;kLvM)-DBGwl6%fA%JItoMeyqjCR*_5Q70yd!KN zh=>ek8>f#~^6CJR0DXp0;7ifZjjSGBn}Cl{HeX!$iXMbtAU$F+;`%A<3TqbN#PCM& z&ueq$cB%pu2oMm_-@*aYzgn9`OiT@2ter*d+-$Aw42(@2Ng4mKG%M-IqX?q%3R|_( zN|&n$e1L#Ev=YMX5F53!O%))qDG3D(0rsOHblk;9ghWyqEOpg)mC$OduqpHAuIxr_>*|zy+|=EmOFn zFM+Ni%@CymLS-3vRWn=rVk?oZEz0V#y356IE6HR5#>7EigxZ05=cA|4<_tC8jyBJ| zgg!^kNwP7S^ooIj6riI9x`jFeQfRr4JCPumr<82M zto$j^Qb~MPmJ-|*2u{o7?yI8BI``zDaOCg2tG_5X;w<|uj5%oDthnLx-l4l)fmUGx z6N^jR|DC);yLi4q-ztTkf>*U$@2^w5(lhxu=OC|=WuTTp^!?2Nn27R`2FY_ zLHY-zFS}r+4|XyZw9b0D3)DmS!Gr+-LSdI}m{@-gL%^8CFSIYL?UZaCVd)2VI3|ay zwue39zshVrB+s2lp*};!gm<79@0HkjhgF^>`UhoR9Mi`aI#V#fI@x&1K3f&^8kaq% zkHVg$CTBoaGqEjrL)k*Y!rtiD2iQLYZ%|B}oBl8GHvR%n>HiIQN*+$mCN>I=c7H2N z&K4$4e@E^ff-cVHCbrHNMh4Dy|2Q;M{{xu|DYjeaRh2FK5QK!bG_K`kbBk$l$S4UF zq?F-%7UrX_Q?9M)a#WvcZ^R-fzJB5IFP>3uEoeCAAhN5W-ELRB&zsCnWY6#E?!)E56Pe+bxHjGF6;R9Hps)+t092-bf4 z_Wieg+0u5JL++k)#i0r?l`9*k)3ZlHOeMJ1DTdx9E1J2@BtdD3qX;&S_wMExOGv$T zl^T%oxb+)vq6vJvR`8{+YOsc@8}wSXpoK%v0k@8X*04Se3<8f)rE|fRXAoT!$6MdrKSuzeK@L*yug?MQs8oTbofqW)Df# zC2J3irHAaX_e~SGlBoRhEW`W6Z}&YX|5IMfzskAt{B*m z*w=3i!;x5Gfgc~>y9fPXFAPMhO@Si}SQESjh`P|dlV5HPRo7j(hV=$o8UMIT7~7+k z*@Sd>f%#{ARweJYhQs~ECpHie!~YXL|FJA;KS4m|CKFnT{fN`Ws>N?CcV@(>7WMPYN} z1}Wg+XU2(Yjpq7PJ|aSn;THEZ{4s8*@N!dz&bjys_Zk7%HiD+56;cF26`-a zEIo!B(T|L*uMXUvqJs&54`^@sUMtH-i~rOM9%$xGXTpmow$DxI>E5!csP zAHe|);0w%`I<==_Zw9t$e}?R+lIu%|`coRum(1p~*+20mBc?Z=$+z<0n&qS0-}|L4 zrgq|(U*eB%l3nfC=U1Y?(Tf@0x8bhdtsU2w&Y-WvyzkiyJ>GZqUP6c+<_p0`ZOnIK z#a~ynuzRWxO6c;S@*}B1pTjLJQHi(+EuE2;gG*p^Fq%6UoE1x95(^BY$H$$soSf=vpJ)_3E zp&$l=SiNaeoNLAK8x%XaHp3-So@F7 z3NMRRa@%k+Z$a%yb25ud&>Cdcb<+}n>=jZ`91)a z{wcA(j$%z#RoyB|&Z+B4%7Pe*No`pAX0Y;Ju4$wvJE{VF*Qej8C}uVF=xFpG^rY6Y+9mcz$T9^x(VP3uY>G3Zt&eU{pF*Bu<4j9MPbi4NMC=Z$kS6DMW9yN#vhM&1gd1t}8m(*YY9 zh2@s)$1p4yYT`~lYmU>>wKu+DhlnI1#Xn4(Rnv_qidPQHW=w3ZU!w3(@jO*f;4;h? zMH0!08(4=lT}#QA=eR(ZtW1=~llQij7)L6n#?5iY_p>|_mLalXYRH!x#Y?KHyzPB^ z6P3YRD}{ou%9T%|nOpP_??P;Rmra7$Q*Jz-f?42PF_y>d)+0Q^)o5h8@7S=je}xG# z2_?AdFP^t{IZHWK)9+EE_aPtTBahhUcWIQ7Awz?NK)ck2n-a$gplnd4OKbJ;;tvIu zH4vAexlK2f22gTALq5PZ&vfFqqERVT{G_d`X)eGI%+?5k6lRiHoo*Vc?ie6dx75_t z6hmd#0?OB9*OKD7A~P$e-TTv3^aCdZys6@`vq%Vi_D8>=`t&q9`Jn1=M#ktSC>SO3 z1V?vuIlQs6+{aHDHL?BB&3baSv;y#07}(xll9vs9K_vs2f9gC9Biy+9DxS77=)c z6dMbuokO-L*Te5JUSO$MmhIuFJRGR&9cDf)@y5OQu&Q$h@SW-yU&XQd9;_x;l z<`{S&Hnl!5U@%I~5p)BZspK894y7kVQE7&?t7Z|OOlnrCkvEf7$J5dR?0;Jt6oANc zMnb_Xjky|2ID#fhIB2hs-48Er>*M?56YFnjC)ixiCes%fgT?C|1tQupZ0Jon>yr|j z6M66rC(=;vw^orAMk!I1z|k}1Ox9qOILGJFxU*ZrMSfCe?)wByP=U73z+@Pfbcndc=VzYvSUnUy z+-B+_n`=f>kS8QBPwk+aD()=#IqkdxHPQMJ93{JGhP=48oRkmJyQ@i$pk(L&(p6<0 zC9ZEdO*i+t`;%(Ctae(SjV<@i%r5aune9)T4{hdzv33Uo9*K=V18S$6VVm^wgEteF za0zCLO(9~!U9_z@Qrh&rS|L0xG}RWoE1jXiEsrTgIF4qf#{0rl zE}|NGrvYLMtoORV&FWaFadDNCjMt|U8ba8|z&3tvd)s7KQ!Od*Kqe(48&C7=V;?`SQV)Qc?6L^k_vNUPbJ>>!5J?sDYm5kR&h_RZk)MfZ1 znOpQ|T;Me(%mdBJR$sbEmp3!HKDDSmMDnVpeo{S13l#9e6OImR$UPzjd-eCwmMwyT zm5~g6DIbY<_!8;xEUHdT(r_OQ<6QCE9Jy|QLoS>d(B zW6GRzX)~&Mx}})ITysFzl5_6JM*~ciBfVP(WF_r zY>z4gw&AxB%UV3Y{Y6z*t*o!p@~#u3X_t{Q9Us8ar8_9?N% zN&M~6y%2R(mAZ~@Tg1Oapt?vDr&fHuJ=V$wXstq|)eIG_4lB#@eU>fniJh zwJY<8yH5(+SSQ=$Y=-$2f$@^Ak#~kaR^NYFsi{XGlFCvK(eu{S$J(owIv17|p-%0O zL-@NyUg!rx0$Uh~JIeMX6JJE>*t<7vS9ev#^{AGyc;uio_-Je1?u#mA8+JVczhA2( zhD!koe;9$`Qgaxlcly4rdQ1VlmEHUhHe9TwduB+hm3wH2o27edh?|vrY{=;1Doy4& zIhP)IDd91@{`QQqVya(ASth4}6OY z-9BQj2d-%+-N7jO8!$QPq%o$9Fy8ja{4WT$gRP+b=Q1I48g-g|iLNjbhYtoNiR*d- z{sB}~8j*6*C3eM8JQj5Jn?mD#Gd*CrVEIDicLJ-4gBqUwLA-bp58UXko;M|ql+i5` zym-&U5BIS9@iPg#fFbuXCHrprSQKRU0#@yd%qrX1hhs*85R}~hahfFDq=e@bX))mf zWH%mXxMx|h5YhrTy;P_Xi_IDH*m6TYv>|hPX*_-XTW0G9iu!PqonQneKKaCVvvF^% zgBMDpN7!N?|G5t`v{neLaCFB{OyIl>qJQ_^0MJXQ zY2%-si~ej?F^%ytIIHU(pqT+3d+|IQ{ss#!c91R{2l*00e3ry!ha|XIsR%!q=E^Fal`6Oxu`K0fmPM?P6ZgzH7|TVQhl;l2 z)2w0L9CsN-(adU5YsuUw19OY_X69-!=7MIJ^(rUNr@#9l6aB8isAL^M{n2oD0FAHk97;X* z-INjZ5li`a|NYNt9gL2WbKT!`?%?lB^)J)9|025nBcBtEmWBRXQwi21EGg8>!tU>6Wf}S3p!>7vHNFSQR zgC>pb^&OHhRQD~7Q|gh5lV)F6i++k4Hp_F2L2WrcxH&@wK}QgVDg+y~o0gZ=$j&^W zz1aP8*cvnEJ#ffCK!Kz{K>yYW`@fc8ByF9X4XmyIv+h!?4&$YKl*~`ToalM{=Z_#^ zUs<1Do+PA*XaH;&0GW^tDjrctWKPmCF-qo7jGL)MK=XP*vt@O4wN1Y!8o`{DN|Rh) znK?nvyU&`ATc@U*l}=@+D*@l^gYOj&6SE|$n{UvyPwaiRQ_ua2?{Vfa|E~uqV$BhH z^QNqA*9F@*1dA`FLbnq;=+9KC@9Mel*>6i_@oVab95LHpTE)*t@BS>}tZ#9A^X7nP z3mIo+6TpvS$peMe@&=g5EQF9Mi9*W@Q`sYs=% z`J{3llzn$q;2G1{N!-#oTfQDY`8>C|n=Fu=iTk443Ld>>^fIr4-!R3U5_^ftd>VU> zij_ix{`V$I#k6!Oy2-z#QFSZkEPrXWsYyFURAo`Kl$LkN>@A?_);LE0rZIkmjb6T$ zvhc#L-Cv^4Ex*AIo=KQn!)A4;7K`pu-E+atrm@Cpmpl3e>)t(yo4gGOX18pL#xceU zbVB`#5_@(k{4LAygT1m#@(7*7f5zqB)HWH#TCrVLd9}j6Q>?p7HX{avFSb?Msb>Jg z9Q9DChze~0Psl!h0E6mcWh?ky! z$p#@LxUe(TR5sW2tMb#pS1ng@>w3o|r~-o4m&00p$wiWQ5Sh-vx2cv5nemM~Fl1Pn z@3ALEM#_3h4-XQ&z$#6X&r~U-&ge+HK6$)-`hqPj0tb|+kaKy*LS5@a9aSk!=WAEB z7cI`gaUSauMkEbg?nl0$44TYIwTngwzvUu0v0_OhpV;%$5Qgg&)WZm^FN=PNstTzW z5<}$*L;zrw>a$bG5r`q?DRc%V$RwwnGIe?m&(9mClc}9i#aHUKPLdt96(pMxt5u`F zsVoku+IC|TC;_C5rEU!}Gu*`2zKnDQ`WtOc3i#v}_9p>fW{L4(`pY;?uq z$`&LvOMMbLsPDYP*x|AVrmCRaI$UB?QoO(7mlBcHC};gA=!meK)IsI~PL0y1&{Dfm6! zxIajDc1$a0s>QG%WID%>A#`iA+J8HaAGsH z+1JH=+eX5F(AjmZGk|`7}Gpl#jvD6_Z!&{*kn@WkECV-~Ja@tmSR|e_L@9?N9 z3hyyry*D0!XyQh_V=8-SnJco#P{XBd1+7<5S3FA)2dFlkJY!1OO&M7z9uO?$#hp8K z><}uQS-^-B;u7Z^QD!7#V;QFmx0m%{^xtl3ZvPyZdi;^O&c;sNC4CHxzvvOB8&uHl zBN;-lu+P=jNn`2k$=vE0JzL{v67psMe_cb$LsmVfxA?yG z^q7lR00E@Ud3)mBPnT0KM~pwzZiBREupva^PE3~e zBgQ9oh@kcTk2)px3Hv^VzTtMzCG?*X(TDZ1MJ6zx{v- z;$oo46L#QNjk*1przHSQn~Ba#>3BG8`L)xla=P{Ql8aZ!A^Z6rPv%&@SnTI7FhdzT z-x7FR0{9HZg8Bd(puRlmXB(tB?&pxM&<=cA-;RT5}8rI%~CSUsR^{Dr%I2WAQghoqE5 zeQ874(T`vBC+r2Mi(w`h|d zA4x%EfH35I?h933@ic#u`b+%b+T?h=<}m@x_~!>o35p|cvIkkw07W=Ny7YcgssA_^ z|KJQrnu||Nu9@b|xC#C5?8Pin=q|UB?`CTw&AW0b)lKxZVYrBw+whPwZJCl}G&w9r zr7qsqm>f2u_6F@FhZU0%1Ioc3X7bMP%by_Z?hds`Q+&3P9-_AX+3CZ=@n!y7udAV2 zp{GT6;VL4-#t0l_h~?J^;trk1kxNAn8jdoaqgM2+mL&?tVy{I)e`HT9#Tr}HKnAfO zAJZ82j0+49)E0+=x%#1_D;sKu#W>~5HZV6AnZfC`v#unnm=hLTtGWz+21|p)uV+0= zDOyrLYI2^g8m3wtm-=pf^6N4ebLJbV%x`J8yd1!3Avqgg6|ar z=EM0KdG6a2L4YK~_kgr6w5OA;dvw0WPFhMF7`I5vD}#giMbMzRotEs&-q z^ji&t1A?l%UJezWv?>ijh|$1^UCJYXJwLX#IH}_1K@sAR!*q@j(({4#DfT|nj}p7M zFBU=FwOSI=xng>2lYo5*J9K3yZPwv(=7kbl8Xv0biOba>vik>6!sfwnH(pglq1mD-GrQi8H*AmfY*J7&;hny2F zupR}4@kzq+K*BE%5$iX5nQzayWTCLJ^xTam-EEIH-L2;huPSy;32KLb>>4 z#l$W^Sx7Q5j+Sy*E;1eSQQuHHWOT;1#LjoYpL!-{7W3SP4*MXf z<~>V7^&sY|9XSw`B<^9fTGQLPEtj=;<#x^=;O9f2{oR+{Ef^oZ z@N>P$>mypv%_#=lBSIr_5sn zBF-F_WgYS81vyW6$M;D_PoE&%OkNV1&-q+qgg~`A7s}>S`}cn#E$2m z%aeUXwNA(^3tP=;y5%pk#5Yz&H#AD`Jph-xjvZm_3KZ|J>_NR@croB^RUT~K;Exu5%wC}1D4nov3+@b8 zKyU5jYuQ*ZpTK23xXzpN51kB+r*ktnQJ7kee-gP+Ij0J_#rFTS4Gux;pkVB;n(c=6 zMks#)ZuXUcnN>UKDJ-IP-u2de1-AKdHxRZDUGkp)0Q#U$EPKlSLQSlnq)OsCour)+ zIXh@3d!ImInH7VrmR>p8p4%n;Tf6l2jx1qjJu>e3kf5aTzU)&910nXa-g0xn$tFa& z2qZ7UAl*@5o=PAh`6L${6S-0?pe3thPB4pahffb$#nL8ncN(Nyos`}r{%{g64Ji^= zK8BIywT0-g4VrhTt}n~Y;3?FGL74h?EG*QfQy0A8u>BtXuI{C-BYu*$o^}U1)z;8d zVN(ssw?oCbebREPD~I$-t7}`_5{{<0d10So7Pc2%EREdpMWIJI&$|rq<0!LL+BQM4 zn7)cq=qy|8YzdO(?NOsVRk{rW)@e7g^S~r^SCawzq3kj#u(5@C!PKCK0cCy zT@Tey2IeDYafA2~1{gyvaIT^a-Yo9kx!W#P-k6DfasKEgFji`hkzrmJ#JU^Yb%Nc~ zc)+cIfTBA#N0moyxZ~K!`^<>*Nzv-cjOKR(kUa4AkAG#vtWpaD=!Ku&;(D#(>$&~B zI?V}e8@p%s(G|8L+B)&xE<({g^M`#TwqdB=+oP|5pF3Z8u>VA!=w6k)zc6w2=?Q2` zYCjX|)fRKI1gNj{-8ymwDOI5Mx8oNp2JJHG3dGJGg!vK>$ji?n>5qG)`6lEfc&0uV z)te%G&Q1rN;+7EPr-n8LpNz6C6N0*v{_iIbta7OTukSY zt5r@sO!)rjh0aAmShx zd3=DJ3c(pJXGXzIh?#RR_*krI1q)H$FJ#dwIvz);mn;w6Rlw+>LEq4CN6pP4AI;!Y zk-sQ?O=i1Mp5lZX3yka>p+XCraM+a!1)`F`h^cG>0)f0OApGe(^cz-WoOno-Y(EeB zVBy3=Yj}ak7OBj~V259{&B`~tbJCxeVy@OEE|ke4O2=TwIvf-=;Xt_l)y`wuQ-9#D z(xD-!k+2KQzr`l$7dLvWf*$c8=#(`40h6d$m6%!SB1JzK+tYQihGQEwR*-!cM>#LD>x_J*w(LZbcvHW@LTjM?RSN z0@Z*4$Bw~Ki3W|JRI-r3aMSepJNv;mo|5yDfqNLHQ55&A>H5>_V9<_R!Ip`7^ylX=D<5 zr40z>BKiC@4{wSUswebDlvprK4SK2!)w4KkfX~jY9!W|xUKGTVn}g@0fG94sSJGV- z9@a~d2gf5s>8XT@`If?Oway5SNZS!L5=jpB8mceuf2Nd%aK2Zt|2FVcg8~7O{VPgI z#?H*_Kl!9!B}MrK1=O!Aw&faUBluA0v#gWVlAmZt;QN7KC<$;;%p`lmn@d(yu9scs zVjomrund9+p!|LWCOoZ`ur5QXPFJtfr_b5%&Ajig2dI6}s&Fy~t^j}()~4WEpAPL= zTj^d;OoZTUf?weuf2m?|R-7 z*C4M6ZhWF(F@2}nsp85rOqt+!+uZz3$ReX#{MP5-r6b`ztXDWl$_mcjFn*{sEx7f*O(ck+ou8_?~a_2Ztsq6qB|SPw26k!tLk{Q~Rz z$(8F1B;zK-#>AmmDC7;;_!;g&CU7a?qiIT=6Ts0cbUNMT6yPRH9~g zS%x{(kxYd=D&GKCkx;N21sU;OI8@4vLg2}L>Lb{Qv`B*O0*j>yJd#`R5ypf^lp<7V zCc|+>fYgvG`ROo>HK+FAqlDm81MS>&?n2E-(;N7}oF>3T9}4^PhY=Gm`9i(DPpuS- zq)>2qz!TmZ6q8;&M?@B;p1uG6RM_Y8zyId{-~XQD_}bXL{Jp7w`)~IR{l5a2?7!Vg zp!OfP4E$Ty_-K3VY!wdGj%2RL%QPHTL)uKfO5Am5<$`5 zHCBtvI~7q-ochU`=NJF*pPx@^IhAk&ZEA>w$%oPGc-}6~ywV~3-0{>*sb=|ruD{y$ ze%@-m`u28vKDaf*_rmN`tzQT>&2ltg-lofR8~c;p;E@`zK!1lkgi?JR0 z+<61+rEupp7F=mB=Ch?HwEjuQm}1KOh=o@ zMbI}0J>5}!koi&v9?!B?4FJR88jvyXR_v{YDm}C)lp@2G2{a{~6V5CwSrp6vHQsfb-U<{SSrQ zhjRbS;qlDTA&TQ2#?M(4xsRXFZ^;3A+_yLw>o-9GJ5sgsauB`LnB-hGo9sJ~tJ`Q>=X7sVmg<=Fcv=JDe*DjP-SK-0mJ7)>I zaLDLOU*I}4@cro&?@C`hH3tiXmN`!(&>@S2bFyAvI&axlSgd=!4IOi#+W;sS>lQ28 zd}q&dew9=x;5l0kK@1y9JgKWMv9!I`*C;((P>8C@JJRGwP5EL;JAPHi5fI|4MqlLU z^4D!~w+OIklt7dx3^!m6Be{Lp55j{5gSGgJz=hlNd@tt_I>UG(GP5s^O{jFU;m~l0 zfd`QdE~0Ym=6+XN*P`i0ogbgAJVjD9#%eBYJGIbDZ4s(f-KRE_>8D1Dv*kgO1~NSn zigx8f+VcA_xS)V-O^qrs&N9(}L!_3HAcegFfzVAntKxmhgOtsb4k6qHOpGWq6Q0RS zZO=EomYL%;nKgmFqxD<68tSGFOEM^u0M(;;2m1#4GvSsz2$jawEJDNWrrCrbO<}g~ zkM6516erswSi_yWuyR}}+h!VY?-F!&Y5Z!Z`tkJz&`8AyQ=-mEXxkQ%abc`V1s>DE zLXd7!Q6C)`7#dmZ4Lm?>CTlyTOslb(wZbi|6|Pl5fFq3y^VIzE4DALm=q$pK>-WM> z@ETsJj5=7=*4 z#Q8(b#+V=~6Gxl?$xq|?@_yQJ2+hAYmuTj0F76c(B8K%;DPhGGWr)cY>SQS>s7%O- zr6Ml8h`}klA=1&wvbFMqk}6fml`4A%G=o@K@8LHifs$)}wD?ix~Id@9-`;?+I7 zOhQN(D)j=^%EHN16(Z3@mMRM5=V)_z(6y^1b?@Bn6m>LUW7}?nupv*6MUVPSjf!Ym zMPo5YoD~t(`-c9w)tV%RX*mYjAn;5MIsD?0L&NQ#IY`9k5}Fr#5{CeTr)O|C2fRhY z4zq(ltHY2X)P*f?yM#RY75m8c<%{Y?5feq6xvdMWrNuqnR%(o(uo8i|36NaN<#FnT ze-_O*q0DXqR>^*1sAnsz$Ueqe5*AD@Htx?pWR*RP=0#!NjnaE-Gq3oUM~Kc9MO+o6 z7qc6wsBxp7GXx+hwEunnebz!|CX&`z{>loyCFSF-zg za}zec;B1H7rhGMDfn+t9n*wt|C_0-MM~XO*wx7-`@9~-%t?IegrHM(6oVSG^u?q`T zO<+YuVbO2fonR-MCa6@aND4dBy^~awRZcp!&=v+#kH@4jYvxt=)zsHV0;47XjlvDC8M1hSV zm!GB(KGLwSd{F-?dmMAe%W0oxkgDv8ivbs__S{*1U}yQ=tsqHJYI9)jduSKr<63$> zp;a-B^6Hg3OLUPi1UwHnptVSH=_Km$SXrCM2w8P z%F#Boi&CcZ5vAGjR1axw&YNh~Q%)VDYUDZ6f^0;>W7_sZr&QvRWc2v~p^PqkA%m=S zCwFUg2bNM(DaY>=TLmOLaDW&uH;Za?8BAwQo4+Xy4KXX;Z}@D5+}m)U#o?3UF}+(@jr$M4ja*`Y9gy~Y`0 z6Aex1*3ng@2er)@{%E9a3A;cts9cAor=RWt7ege)z=$O3$d5CX&hORZ3htL>jj5qT zW#KGQ;AZ|YbS0fvG~Y)CvVwXnBLJkSps7d~v;cj$D3w=rB9Tx>a&4>(x00yz!o*SOd*M!yIwx;NgqW?(ysFv8XLxs6Lrh8-F`3FO$}V{Avztc4qmZ zoz&YQR`*wWy_^&k-ifJ&N8Qh=E-fH6e}-}0C{h~hYS6L^lP>=pLOmjN-z4eQL27!6 zIe2E}knE;dxIJ_!>Mt|vXj%uGY=I^8(q<4zJy~Q@_^p@JUNiGPr!oUHfL~dw9t7C4I9$7RnG5p9wBpdw^)PtGwLmaQM=KYe z;Dfw@%nquH^nOI6gjP+K@B~0g1+WROmv1sk1tV@SUr>YvK7mxV3$HR4WeQ2&Y-{q~ z4PAR&mPOEsTbo~mRwg&EJE2Dj?TOZPO_@Z|HZX9-6NA!%Pb3h;G3F5J+30BoT8-PU z_kbx`I>&nWEMtfv(-m>LzC}s6q%VdBUVI_GUv3@^6SMkEBeVjWplD5y58LyJhikp4VLHhyf?n%gk0PBr(PZ3 z+V`qF971_d@rCO8p#7*#L0^v$DH>-qB!gy@ut`3 zy3cQ8*t@@{V7F*ti(u{G4i55*xY9Erw3{JZ8T4QPjo5b{n=&z4P^}wxA;x85^fwmD z6mEq9o;kx<5VneT_c-VUqa|zLe+BFgskp_;A)b>&EDmmP7Gx#nU-T@;O+(&&n7ljK zqK7&yV!`FIJAI+SaA6y=-H=tT`zWvBlaed!3X^_Lucc%Q=kuiG%65@@6IeG}e@`ieesOL} zKHBJBso6u&7gzlrpB%_yy<>TFwDI>}Ec|Gieb4=0fGwY|3YGW2Dq46=a1 zVo`Vi%yz+L9)9hbb%FLTC@-G(lODgJ(f&WmSCK9zV3-IV7XI<{2j}ms_Vmb!os)06 zhVIZPZF)hW--kWTCyDVRd2T&t|P&aDrtO5kzXy<*A+5$k7$>4+y%;% znYN-t#1^#}Z6d+ahj*Gzor+@kBD7@f|IGNR$4U=Y0J2#D2)YSxUCtiC1weJg zLp0Q&JFrt|In8!~1?fY0?=fPyaqPy$iQXJDhHP>N%B42Yck`Qz-OM_~GMuWow)>=Q z0pCCC7d0Z^Ipx29`}P3;?b{dO?7z0e{L|O*Z}nxi>X|RL8XAw$1eOLKd5j@f{RQ~Y zG?7$`hy@s7IoRF2@KA%2ZM6{ru9T5Gj)iDCz};VvlG$WuT+>_wCTS~J6`I9D{nsrU z2;X#OyopBgo778Q>D%_E>rMN~Po~d5H<`8|Zcv}F`xL5~NCVLX4Wkg007HhMgj9Pa z94$km3A+F&LzOJlpeFR*j+Y%M!Qm42ziH~cKM&3b;15s)ycD@3_tL-dk{+xP@J7#o z-)bYa-gd2esfy<&-nrj>1{1^_L>j&(MA1#WNPg3UD?reL*}V{ag{b!uT755x>mfbZ z0PzwF+kx91`qqOn`1>xw@801XAJlH>{`~|pyi6J;3s=cTOfelA&K5HX#gBp6s<|r5 zjSSj+CU*-TulqlnlP`}?)JkJ_7fg){;bRlXf+&^e8CWwFqGY@SZ=%NmLCXpYb+}7* z$4k}%iFUi^kBdeJg^kHt)f~<;Ovlz!9frq20cIj>2eIcG(dh57ry;^E^2T)E_8#;_9iJT>4sdCB_db|zO?Z^*lBN zNCs~f+Jkx%EUgkN2-xFF?B%TMr4#)%wq?-~+Nh;g9=n3tM>i5ZcH&nkVcPXgYRjG@ zf(Y7WN@hGV7o0bjx_2@bthJ`hjXXpfaes_(lWIw!(QK_nkyqj?{j#uFKpNVpV@h?7_WC3~&%)xHR1kKo`Cypj15#%0m z-o0GXem63g^|IltM?eZV=b+Z2e8&Z1%{0;*zmFc62mNqLTy$Y_c|9HiH0l>K z+mAx7DVYoHhXfdCE8Bs@j=t0f*uM++Idd25BgIm`Ad;I_{$mO?W%=JF82blr8rl>yMk6?pM z^tMluJ-ckG_}OkxP91t2o>CQ_O8^VZn$s$M_APWIXBGBq0Lt^YrTD5(Vwe2ta4y#DEYa(W~=eLOy7rD^%Vd$kL27M)MSpwgoP3P{ z!yS$zc|uP{yzaIqCwE!AfYNS;KW|OdP1Q%!LZviA0e^WDsIS5#= z!B{TW)VB)VHg{LoS#W7i6W>*sFz!qr^YS0t2kh90y=Je5{p>8)~D@dLS@QM(F# zIp{6M*#(@?tsu1Rq-Mdq+eV}ibRSpv#976C_5xlI`$#1tN`sK1?)5M+sj=OXG6dNu zV1K{y>!i0&9w8O{a>`IA#mo(3a zf*+Q=&HW7&(nX8~C1tiHZj%>;asBEp$p_Q!@Y0T8R~OuPEy3Lq@^t$8=~(FhPVmJJ z#VF8`(fNzK-b%Iin7|cxWP0xr*M&zoz|fCx@=Y!-0j_~cuxsDHHpmSo)qOalZ$bRl z2F$j0k3llJ$>28HH3l_W(KjF^!@LwtLej_b9;i;{ku2x+&WA@jKTO0ad71@_Yta!{ z2oqhO4zaU433LK371>E{bZ?+3kLZ9WQ2+3PTZAP90%P13Yy3lr3mhmy|>eN6(SHs1C%Q39p)YsUr7(kuaoIJGJhXV-PyG zjnxhcAC;fqY@6;MWWBnRK6ocG`%T&0&*k95#yK7DFtZV?;cy;!RD_*YJjsb6Q`$;K zy)&X{P`*5xEgjTQ9r=oh0|>Z_yeFm?ev!p z7q;JA4mtu@qa39v%6i)Z4%qwdxcHuOMO;a1wFMP_290FqH1OsmCG{ zq^afYrz2BQyQ0*JGE}1h!W9fKgk$b!)|!%q(1x?5=}PpmZQ$e;2EB*k4%+&+u;(E* z2n@=9HsqMv;4>Nn^2v&@4T-YTkd`TdWU^U*;sA5|r7TjZGnLY*xC=_K-GmDfkWEGC z;oN&!c1xB-<4J7=9 zJ(BedZwZhG4|64<=wvCn4)}w%Zx_TEs6ehmjVG&p5pi46r zg=3-3Q~;v55KR&8CfG;`Lv6NsXB}RqPVyNeKAfj9=Ol>fQlEUl2cH7=mPV!68+;jgtKvo5F#8&9m? z``w+#S5UR=QHFGM~noocC zVFa#v2%oo{%;wi~_~R2ci}`=B|0@ zinDfNxV3%iHIS(7{h_WEXqu!v~`CMH+7^SkvLe_3i}=pyDRah zN#L)F-`JLj6BiG}sj*WBmrdZuVVEo86Z<6VB}s)T$ZcWvG?i0cqI}WhUq2Y#{f~x# zi1LjxSZCwiKX}*ETGVzZ157=jydo*xC^}mJ<+)!DDCd4sx?VM%Y;&CTpw5;M*ihZ| zJ!FBJj0&j&-oJs?9a_I$;jzd%7|pdsQ3m`bPBe$nLoV1!YV8?Pw~0D zmSD-5Ue60>L$Rw;yk{_2d~v@CnvZa%!7{{7lb$kxWx!pzyh;6G~RbN5+|mFTbxcxf!XyfbLI^zMQSb6P~xzESXmV{9 zCMp)baZSz%)j&JWkc|Gq;_*$K@zQ%tH^91X2|Byv>=SmWR$7-shf|_^>Ll;*9+c(e z{N%43;&e8}_QGW+zE0m0myb-@QU%=Qo>``5UzB(lH0sK=E``{ZBl2Ni^-QtDp0ME1 zK88E-db_XBZQaU}cuvkCgH7crju~9eE-Y`os~0P-J=s;aS#wil$HGdK;Ut?dSO71ssyrdm{QRpMAV2nXslvlIE#+Oh>l7y_~?;}F!;ENCR zO+IG#NWIRI`FLntsz^FldCkky2f!d-%Pij9iLKr>IfCK);=}}?(NL%#4PfE(4kPQN zSC%BpZJ*P+PO5mHw0Wd%!zJsn&4g<$n#_?(=)JnoR2DK(mCPHp6e6VdV>?E5KCUF@ zf7W9wm%G#Wfm*NxTWIcJX-qtR=~NFxz4PSmDVAU8(B2wIm#IdHae-F{3jKQFiX?8NlKEhXR2Z|JCUd@HMnNVwqF~V9YJtD+T zQlOroDX-mg2% zBKV^Q5m5ECK{nWjJ7FHOSUi*a-C_?S_yo~G5HuRZH6R``^dS3Bh6u!nD`kFbxYThD zw~2%zL4tHA26rcdln4^=A(C+f9hLlcuMCv{8`u;?uoEVbU=YVNkBP#s3KnM@Oi)fQ zt_F3VjY)zASub%Q{Y?XgzlD3M5#gUBUuhW;$>uBSJH9UBfBtug*S|-;h?|L#^Z&uE zB&)spqM89dWg9ZrXi#F{KtL@r9g^xeR8J+$EhL~2u@cf`dS{8GUC76JP0hHtCKRg0 zt*rVyl&jaJAez;!fb!yX^+So4-8XMNpP@d3H*eF%t_?I|zN^1Iu5aGBXSm+}eCqn3 z^+vzcM*J>wV-FJRrx@^5;l>h0{OYT)lg{dr8!{s7(i{5T|3bivDoTonV1yo1@nVPR zXxEgGg^x5KHgp?=$xBwm_cKHeDurCgO>$B$GSO`Cd<~J8@>ni>Z-Ef!3+ck(MHVy@ z@#<*kCOb5S$V+Fvc@{Qv$oLfnOAG&YO5z_E2j6E z7a+c(>-`H)>g+6DeY1Y*ag-B6>Cl@@VhkZY@Uihe!{LlRpuTsmIsN4;+UDsHd954n9WZV6qq*{qZ5j<W)`UorOmXtVnLo3T{t#h3q^fooqQ~A+EY<$TDG4RKP*cK0liX95STt= zToC<2M2*(H1tZ)0s|v~iSAa^F-9jMwCy4cK0HM*3$@1Q`Pz}FFYm`PGP0wuamWrt*ehz3(|Fn%;0;K4}!Q~cx{0U0L=cs6lcrY^Y%Vf_rXpQIw~DfxB-72tZU6gdK8C~ea6(2P@kGH}!2N?>r(Ca{ zsI!6B!alPl%j1CHq97PTVRng$!~?s2{+6ffC#;X2z(Xb#9GsSYYe@9zY~7Dc7Hfgh z5Tq!})o30pA3ywg<9W3NpvUs;E%Cehz=s?EfLzcV0H?b{=q?vJCih2y%dhls6w3j$ zk9LB0L&(15mtul3T^QSK7KIZVTod#Sc)?1gzY~M=?ay87V}6G?F>~AIv()-N zD3rHX`;r;L{9N|Z8REN}OZB&SZ|5a80B%dQd-CNESP7HnuNn43T~Agcl1YOF@#W03 z1b*t!>t5G@XwVygHYczDIC|RdMB+ z$s5_5_W-EXN-u_5Pb{((!+8xa+?@_#dwtYHeJ_49Dql%3Fv0yXeV?!cC&Iqx@s~P%$X6%1 zYzS9pqaUv&aBQqO zBQs7d63FZIL1B&<8^oni%CZOdf6&;^oNqQ-9j-NBuQ^|9baQuZ^Jtyt&?cHq$Q9JE z5D>QY1?MU7%VVbvjysl~-a&ImiE(uFwHo{!kp;Jd`OLE!^4k8ID{`e-&>2uB7XB~= z+nIQGZ8-Sbfa}OrVPL}!mdieCrs3Nq8Ic_lpTKMIJ{h>XS$C3`h~ z?p2AbK~%t$t(NcOq5ZB3V|`a0io8A))v_PMt)Hg3x+07RL>i zGUq@t&+VV`kj55_snp?)Y@0rKZr`riC`9Q(B1P^nxffV9AvBLPrE<8D>ZP{HCDY@JIvYcYNRz8 z0Rf+Q0riSU@KaVpK)0M{2}Wuh!o~t*6>)EZSCQD{=}N4Oxjo1KO-MNpPYuPABh}E|rM!=TSl^F%NV^dg+>WNGi@Q5C z%JGsP#em`4LxDdIzA@VF&`2bLDv%J)(7vedDiXDqx{y6$Y0o~j*nVY73pINPCY?9y z$Rd&^64MN)Pkxr-CuZ+WqAJx6vuIAwmjkN{aPkrJ0I4F5-Bl}$hRzhRhZ^xN&Oe5$ za4Wrh6PyFfDG+Nzd8NTp2})j>pGtyejb&;NkU3C5-_H;{?>xK1QQ9S`xaHoMgee=2 zEbEh+*I!ggW@{T{qENlruZT)ODp~ZXHBc_Ngqu{jyC#qjyYGAQsO8VT^lts$z0HP+ z2xs^QjUwWuiEh863(PqO4BAosmhaK`pEI{-geBD9UuIn8ugOt-|6S(xkBLeGhW~)< z8aWBs0)bzOnY4wC$yW{M@&(iTe{8zhDnKP<1yr9J8akUK)1svAuxC)}x-<>S!9(?F zcA?{_C?@ZV2Aei`n#l(9zu`WS-hJsAXWt(SGp4(xg7~3*c5@odW;kXXbGuLOFMj{d z{gx81mQREmRAUHhfp#zoWh>z}GuS|raw1R#en%9R3hSR`qGglQhaq>#K!M%tooG;? zzjo}>sL7a3M5jW*s8R;#Y8b(l;%*I$@YH9)YzWR!T6WLI{$8ScBvw+5&()>NhPzd! z{>P(yk8{(G&2ovV^|#1HbcVMvXU&;0pk&6CxBTvBAB>#tK~qALsH`Ad1P0tAKWHv+BR8Fv4!`+>Obu1UX^Ov zmOpuS@Ui|NK4k-)TbG?+9T$)rkvq+?=0RDa=xdmY#JHLastjqPXdDbShqW>7NrHZ7 z7(9(HjM1-Ef(^`%3TlhySDJ27vQ?H`xr9VOM%0ANsA|A3-jj|r`KAo%oTajX3>^E` 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 YM{}PByk10KD_nuQ4E7Du?}+~TKh4V)`~Uy| literal 0 HcmV?d00001 diff --git a/SwaggerGroupingExample/.mvn/wrapper/maven-wrapper.properties b/SwaggerGroupingExample/.mvn/wrapper/maven-wrapper.properties new file mode 100644 index 0000000..b7cb93e --- /dev/null +++ b/SwaggerGroupingExample/.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/SwaggerGroupingExample/dev_resources/EXAMPLE_GROUPING1_orig.png b/SwaggerGroupingExample/dev_resources/EXAMPLE_GROUPING1_orig.png new file mode 100644 index 0000000000000000000000000000000000000000..9780c4102cd799b0c6a3d23f4ed7d5639c997775 GIT binary patch literal 63241 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

jrPm2J!^}(F;?Vn%mq#0cb@L2Vp|EU}013y2A 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 literal 0 HcmV?d00001 diff --git a/SwaggerGroupingExample/dev_resources/EXAMPLE_GROUPING2_orig.png b/SwaggerGroupingExample/dev_resources/EXAMPLE_GROUPING2_orig.png new file mode 100644 index 0000000000000000000000000000000000000000..06e0a33172266a735a60b8d03df978b8acd71e6b GIT binary patch literal 62849 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 S`v?g5cjc1y#rz8vcmFR*4`L4h literal 0 HcmV?d00001 diff --git a/SwaggerGroupingExample/mvnw b/SwaggerGroupingExample/mvnw new file mode 100644 index 0000000..8a8fb22 --- /dev/null +++ b/SwaggerGroupingExample/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/SwaggerGroupingExample/mvnw.cmd b/SwaggerGroupingExample/mvnw.cmd new file mode 100644 index 0000000..1d8ab01 --- /dev/null +++ b/SwaggerGroupingExample/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/SwaggerGroupingExample/pom.xml b/SwaggerGroupingExample/pom.xml new file mode 100644 index 0000000..8daaee9 --- /dev/null +++ b/SwaggerGroupingExample/pom.xml @@ -0,0 +1,54 @@ + + + 4.0.0 + + org.springframework.boot + spring-boot-starter-parent + 2.7.0 + + + ro.stefan + swagger-grouping-example + 0.0.1-SNAPSHOT + swagger-grouping-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/SwaggerGroupingExample/src/main/java/ro/stefan/SwaggerGroupingExampleApp.java b/SwaggerGroupingExample/src/main/java/ro/stefan/SwaggerGroupingExampleApp.java new file mode 100644 index 0000000..59443ec --- /dev/null +++ b/SwaggerGroupingExample/src/main/java/ro/stefan/SwaggerGroupingExampleApp.java @@ -0,0 +1,14 @@ +package ro.stefan; + +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; + +@SpringBootApplication +public class SwaggerGroupingExampleApp { + + public static void main(String[] args) { + SpringApplication.run(SwaggerGroupingExampleApp.class, args); + } + +} + \ No newline at end of file diff --git a/SwaggerGroupingExample/src/main/java/ro/stefan/config/SpringFoxConfig.java b/SwaggerGroupingExample/src/main/java/ro/stefan/config/SpringFoxConfig.java new file mode 100644 index 0000000..eafd2ea --- /dev/null +++ b/SwaggerGroupingExample/src/main/java/ro/stefan/config/SpringFoxConfig.java @@ -0,0 +1,36 @@ +package ro.stefan.config; + +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; + +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 api1() { + return new Docket(DocumentationType.SWAGGER_2) + .groupName("address") + .select() + .apis(RequestHandlerSelectors.basePackage("ro.stefan.external.apis.address")) + .paths(PathSelectors.any()) + .build(); + } + + + @Bean + public Docket api2() { + return new Docket(DocumentationType.SWAGGER_2) + .groupName("accouting") + .select() + .apis(RequestHandlerSelectors.basePackage("ro.stefan.external.apis.accounting")) + .paths(PathSelectors.any()) + .build(); + } + + +} \ No newline at end of file diff --git a/SwaggerGroupingExample/src/main/java/ro/stefan/controller/BookController.java b/SwaggerGroupingExample/src/main/java/ro/stefan/controller/BookController.java new file mode 100644 index 0000000..45e1b52 --- /dev/null +++ b/SwaggerGroupingExample/src/main/java/ro/stefan/controller/BookController.java @@ -0,0 +1,15 @@ +package ro.stefan.controller; + +import java.util.List; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +@RestController +public class BookController { + + @GetMapping("/books") + public List getBooks(){ + return null; + } +} diff --git a/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/accounting/controller/AccountingController.java b/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/accounting/controller/AccountingController.java new file mode 100644 index 0000000..3fb8aec --- /dev/null +++ b/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/accounting/controller/AccountingController.java @@ -0,0 +1,15 @@ +package ro.stefan.external.apis.accounting.controller; + +import java.util.List; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +@RestController +public class AccountingController { + + @GetMapping("/accounts") + public List getAccounts(){ + return null; + } +} diff --git a/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/address/controller/AddressController.java b/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/address/controller/AddressController.java new file mode 100644 index 0000000..ecfcd27 --- /dev/null +++ b/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/address/controller/AddressController.java @@ -0,0 +1,15 @@ +package ro.stefan.external.apis.address.controller; + +import java.util.List; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +@RestController +public class AddressController { + + @GetMapping("/addresses") + public List getAddresses(){ + return null; + } +} diff --git a/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/loan/controller/LoanController.java b/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/loan/controller/LoanController.java new file mode 100644 index 0000000..20186b2 --- /dev/null +++ b/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/loan/controller/LoanController.java @@ -0,0 +1,16 @@ +package ro.stefan.external.apis.loan.controller; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +import io.swagger.annotations.Api; + +@RestController +@Api(tags = "loan") +public class LoanController { + + @GetMapping("/loan") + public String getLoanDetails() { + return null; + } +} diff --git a/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/security/controller/SecurityController.java b/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/security/controller/SecurityController.java new file mode 100644 index 0000000..cf091b4 --- /dev/null +++ b/SwaggerGroupingExample/src/main/java/ro/stefan/external/apis/security/controller/SecurityController.java @@ -0,0 +1,16 @@ +package ro.stefan.external.apis.security.controller; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +import io.swagger.annotations.Api; + +@RestController +@Api(tags = "security") +public class SecurityController { + @GetMapping("/user") + public String getUser() { + return null; + } + +} diff --git a/SwaggerGroupingExample/src/main/resources/application.yaml b/SwaggerGroupingExample/src/main/resources/application.yaml new file mode 100644 index 0000000..27323dd --- /dev/null +++ b/SwaggerGroupingExample/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/SwaggerGroupingExample/src/test/java/ro/stefan/SwaggerGroupingExampleAppTests.java b/SwaggerGroupingExample/src/test/java/ro/stefan/SwaggerGroupingExampleAppTests.java new file mode 100644 index 0000000..1277e7f --- /dev/null +++ b/SwaggerGroupingExample/src/test/java/ro/stefan/SwaggerGroupingExampleAppTests.java @@ -0,0 +1,13 @@ +package ro.stefan; + +import org.junit.jupiter.api.Test; +import org.springframework.boot.test.context.SpringBootTest; + +@SpringBootTest +class SwaggerGroupingExampleAppTests { + + @Test + void contextLoads() { + } + +} diff --git a/SwaggerGroupingUsingTagsExample/.gitignore b/SwaggerGroupingUsingTagsExample/.gitignore new file mode 100644 index 0000000..549e00a --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/.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/SwaggerGroupingUsingTagsExample/.mvn/wrapper/maven-wrapper.jar b/SwaggerGroupingUsingTagsExample/.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` 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 YM{}PByk10KD_nuQ4E7Du?}+~TKh4V)`~Uy| literal 0 HcmV?d00001 diff --git a/SwaggerGroupingUsingTagsExample/.mvn/wrapper/maven-wrapper.properties b/SwaggerGroupingUsingTagsExample/.mvn/wrapper/maven-wrapper.properties new file mode 100644 index 0000000..b7cb93e --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/.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/SwaggerGroupingUsingTagsExample/mvnw b/SwaggerGroupingUsingTagsExample/mvnw new file mode 100644 index 0000000..8a8fb22 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/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/SwaggerGroupingUsingTagsExample/mvnw.cmd b/SwaggerGroupingUsingTagsExample/mvnw.cmd new file mode 100644 index 0000000..1d8ab01 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/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/SwaggerGroupingUsingTagsExample/pom.xml b/SwaggerGroupingUsingTagsExample/pom.xml new file mode 100644 index 0000000..fb178a2 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/pom.xml @@ -0,0 +1,54 @@ + + + 4.0.0 + + org.springframework.boot + spring-boot-starter-parent + 2.7.0 + + + ro.stefan + swagger-grouping-with-tags-example + 0.0.1-SNAPSHOT + swagger-grouping-with-tags-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/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/SwaggerGroupingUsingTagsExampleApp.java b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/SwaggerGroupingUsingTagsExampleApp.java new file mode 100644 index 0000000..95ebee2 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/SwaggerGroupingUsingTagsExampleApp.java @@ -0,0 +1,14 @@ +package ro.stefan; + +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; + +@SpringBootApplication +public class SwaggerGroupingUsingTagsExampleApp { + + public static void main(String[] args) { + SpringApplication.run(SwaggerGroupingUsingTagsExampleApp.class, args); + } + +} + \ No newline at end of file diff --git a/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/config/SpringFoxConfig.java b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/config/SpringFoxConfig.java new file mode 100644 index 0000000..c461fe8 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/config/SpringFoxConfig.java @@ -0,0 +1,68 @@ +package ro.stefan.config; + +import java.util.Collections; + +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; + +import springfox.documentation.builders.ApiInfoBuilder; +import springfox.documentation.builders.PathSelectors; +import springfox.documentation.builders.RequestHandlerSelectors; +import springfox.documentation.service.ApiInfo; +import springfox.documentation.service.Contact; +import springfox.documentation.service.Server; +import springfox.documentation.service.Tag; +import springfox.documentation.spi.DocumentationType; +import springfox.documentation.spring.web.plugins.Docket; + +@Configuration +public class SpringFoxConfig { + +// @Bean +// public Docket api1() { +// return new Docket(DocumentationType.SWAGGER_2) +// .groupName("address") +// .select() +// .apis(RequestHandlerSelectors.basePackage("ro.stefan.external.apis.address")) +// .paths(PathSelectors.any()) +// .build(); +// } +// +// +// @Bean +// public Docket api2() { +// return new Docket(DocumentationType.SWAGGER_2) +// .groupName("accouting") +// .select() +// .apis(RequestHandlerSelectors.basePackage("ro.stefan.external.apis.accounting")) +// .paths(PathSelectors.any()) +// .build(); +// } + + + @Bean + public Docket api3() { + // here tags is optional, it just adds a description in the UI + // by default description is class name, so if you use same tag using + // `@Api` on different classes it will pick one of the class name as + // description, so better define your own description for them + return new Docket(DocumentationType.SWAGGER_2) + .apiInfo(apiInfo()) + .tags(new Tag("security", "security related"), + new Tag("loan", "loan related")) + .select() + .apis(RequestHandlerSelectors.basePackage("ro.stefan.external.apis")) + .paths(PathSelectors.any()) + .build(); + } + + private ApiInfo apiInfo() { + return new ApiInfoBuilder() + .title("Openapi OAS3 with springfox ") + .description("Code first approach") + .version("1.0.0") + .contact(new Contact("Marone", "https://wstutorial.com", "test@wstutorial.com")) + .build(); + } + +} \ No newline at end of file diff --git a/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/controller/BookController.java b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/controller/BookController.java new file mode 100644 index 0000000..45e1b52 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/controller/BookController.java @@ -0,0 +1,15 @@ +package ro.stefan.controller; + +import java.util.List; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +@RestController +public class BookController { + + @GetMapping("/books") + public List getBooks(){ + return null; + } +} diff --git a/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/accounting/controller/AccountingController.java b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/accounting/controller/AccountingController.java new file mode 100644 index 0000000..3fb8aec --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/accounting/controller/AccountingController.java @@ -0,0 +1,15 @@ +package ro.stefan.external.apis.accounting.controller; + +import java.util.List; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +@RestController +public class AccountingController { + + @GetMapping("/accounts") + public List getAccounts(){ + return null; + } +} diff --git a/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/address/controller/AddressController.java b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/address/controller/AddressController.java new file mode 100644 index 0000000..ecfcd27 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/address/controller/AddressController.java @@ -0,0 +1,15 @@ +package ro.stefan.external.apis.address.controller; + +import java.util.List; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +@RestController +public class AddressController { + + @GetMapping("/addresses") + public List getAddresses(){ + return null; + } +} diff --git a/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/loan/controller/LoanController.java b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/loan/controller/LoanController.java new file mode 100644 index 0000000..20186b2 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/loan/controller/LoanController.java @@ -0,0 +1,16 @@ +package ro.stefan.external.apis.loan.controller; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +import io.swagger.annotations.Api; + +@RestController +@Api(tags = "loan") +public class LoanController { + + @GetMapping("/loan") + public String getLoanDetails() { + return null; + } +} diff --git a/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/security/controller/SecurityController.java b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/security/controller/SecurityController.java new file mode 100644 index 0000000..cf091b4 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/main/java/ro/stefan/external/apis/security/controller/SecurityController.java @@ -0,0 +1,16 @@ +package ro.stefan.external.apis.security.controller; + +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.RestController; + +import io.swagger.annotations.Api; + +@RestController +@Api(tags = "security") +public class SecurityController { + @GetMapping("/user") + public String getUser() { + return null; + } + +} diff --git a/SwaggerGroupingUsingTagsExample/src/main/resources/application.yaml b/SwaggerGroupingUsingTagsExample/src/main/resources/application.yaml new file mode 100644 index 0000000..f070ea2 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/main/resources/application.yaml @@ -0,0 +1,4 @@ +spring: + mvc: + pathmatch: + matching-strategy: ant_path_matcher \ No newline at end of file diff --git a/SwaggerGroupingUsingTagsExample/src/test/java/ro/stefan/SwaggerGroupingUsingTagsExampleAppTests.java b/SwaggerGroupingUsingTagsExample/src/test/java/ro/stefan/SwaggerGroupingUsingTagsExampleAppTests.java new file mode 100644 index 0000000..b0b6065 --- /dev/null +++ b/SwaggerGroupingUsingTagsExample/src/test/java/ro/stefan/SwaggerGroupingUsingTagsExampleAppTests.java @@ -0,0 +1,13 @@ +package ro.stefan; + +import org.junit.jupiter.api.Test; +import org.springframework.boot.test.context.SpringBootTest; + +@SpringBootTest +class SwaggerGroupingUsingTagsExampleAppTests { + + @Test + void contextLoads() { + } + +}