From 8a2ea2af9d5574e77a2dc67292f96f86aaac284b Mon Sep 17 00:00:00 2001 From: Joseph Cook <33655003+jmcook1186@users.noreply.github.com> Date: Wed, 27 Jul 2022 13:33:00 +0100 Subject: [PATCH 001/432] Create README.md --- README.md | 4 ++++ 1 file changed, 4 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000000..f16547e5f1 --- /dev/null +++ b/README.md @@ -0,0 +1,4 @@ +## Geth website + +This repo will act as a shared workspace for the geth website team in developing new content, designs etc + From 69389283fc3f99442a4673e95ef4a0bea1643bcf Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 27 Jul 2022 13:38:03 +0100 Subject: [PATCH 002/432] import draft content --- assets/node_architecture.png | Bin 0 -> 495430 bytes assets/node_basic.png | Bin 0 -> 101267 bytes content/about-geth/about_geth.md | 86 ++ content/about-geth/about_us.md | 0 content/about-geth/contributing.md | 34 + content/about-geth/ethereum.md | 56 ++ content/about-geth/faq.md | 74 ++ .../dapp-developer/custom-tracer.md | 458 +++++++++ .../dapp-developer/mobile/mobile-accounts.md | 323 ++++++ .../dapp-developer/mobile/mobile.md | 180 ++++ .../dapp-developer/native-accounts.md | 223 +++++ .../dapp-developer/native-bindings.md | 617 ++++++++++++ .../docs/developers/dapp-developer/native.md | 249 +++++ .../docs/developers/dapp-developer/tracing.md | 232 +++++ .../geth-developer/Code-Review-Guidelines.md | 103 ++ .../geth-developer/Private-Network.md | 481 +++++++++ .../developers/geth-developer/dev-mode.md | 353 +++++++ .../developers/geth-developer/devguide.md | 122 +++ .../geth-developer/dns-discovery-setup.md | 125 +++ .../geth-developer/issue-handling-workflow.md | 57 ++ .../geth-developer/vulnerabilities.md | 113 +++ content/docs/fundamentals/Backup--restore.md | 65 ++ .../docs/fundamentals/Command-Line-Options.md | 238 +++++ content/docs/fundamentals/Installing-Geth.md | 356 +++++++ .../fundamentals/Managing-your-accounts.md | 352 +++++++ content/docs/fundamentals/cross-compile.md | 167 +++ content/docs/fundamentals/les.md | 61 ++ content/docs/fundamentals/peer-to-peer.md | 165 +++ .../docs/getting_started/consensus-clients.md | 140 +++ content/docs/getting_started/index.md | 474 +++++++++ content/docs/install_build/Backup--restore.md | 65 ++ content/docs/install_build/Installing-Geth.md | 356 +++++++ content/docs/install_build/cross-compile.md | 167 +++ .../JavaScript-Console.md | 147 +++ .../docs/interacting_with_geth/RPC/batch.md | 38 + .../docs/interacting_with_geth/RPC/graphql.md | 65 ++ .../interacting_with_geth/RPC/ns-admin.md | 296 ++++++ .../interacting_with_geth/RPC/ns-clique.md | 148 +++ .../interacting_with_geth/RPC/ns-debug.md | 947 ++++++++++++++++++ .../docs/interacting_with_geth/RPC/ns-eth.md | 207 ++++ .../docs/interacting_with_geth/RPC/ns-les.md | 318 ++++++ .../interacting_with_geth/RPC/ns-miner.md | 91 ++ .../docs/interacting_with_geth/RPC/ns-net.md | 36 + .../interacting_with_geth/RPC/ns-personal.md | 255 +++++ .../interacting_with_geth/RPC/ns-txpool.md | 226 +++++ .../docs/interacting_with_geth/RPC/objects.md | 72 ++ .../docs/interacting_with_geth/RPC/pubsub.md | 168 ++++ .../docs/interacting_with_geth/RPC/server.md | 182 ++++ content/docs/monitoring/dashboards.md | 173 ++++ content/docs/monitoring/ethstats-mainnet.png | Bin 0 -> 299699 bytes content/docs/monitoring/ethstats.md | 46 + content/docs/monitoring/grafana1.png | Bin 0 -> 122043 bytes content/docs/monitoring/grafana2.png | Bin 0 -> 338418 bytes content/docs/monitoring/grafana3.png | Bin 0 -> 43904 bytes content/docs/monitoring/grafana4.png | Bin 0 -> 157130 bytes content/docs/monitoring/grafana5.png | Bin 0 -> 123280 bytes content/docs/monitoring/grafana6.png | Bin 0 -> 39780 bytes content/docs/monitoring/grafana7.png | Bin 0 -> 97692 bytes content/docs/monitoring/grafana8.png | Bin 0 -> 316703 bytes content/docs/monitoring/metrics.md | 116 +++ content/docs/tools/Clef/CliqueSigning.md | 393 ++++++++ content/docs/tools/Clef/Introduction.md | 208 ++++ content/docs/tools/Clef/Rules.md | 237 +++++ content/docs/tools/Clef/Setup.md | 202 ++++ content/docs/tools/Clef/Tutorial.md | 685 +++++++++++++ content/docs/tools/Clef/apis.md | 851 ++++++++++++++++ content/docs/tools/Clef/datatypes.md | 229 +++++ content/homepage.md | 27 + misc/page-tracker.xlsx | Bin 0 -> 6742 bytes 69 files changed, 12855 insertions(+) create mode 100644 assets/node_architecture.png create mode 100644 assets/node_basic.png create mode 100644 content/about-geth/about_geth.md create mode 100644 content/about-geth/about_us.md create mode 100644 content/about-geth/contributing.md create mode 100644 content/about-geth/ethereum.md create mode 100644 content/about-geth/faq.md create mode 100644 content/docs/developers/dapp-developer/custom-tracer.md create mode 100644 content/docs/developers/dapp-developer/mobile/mobile-accounts.md create mode 100644 content/docs/developers/dapp-developer/mobile/mobile.md create mode 100644 content/docs/developers/dapp-developer/native-accounts.md create mode 100644 content/docs/developers/dapp-developer/native-bindings.md create mode 100644 content/docs/developers/dapp-developer/native.md create mode 100644 content/docs/developers/dapp-developer/tracing.md create mode 100644 content/docs/developers/geth-developer/Code-Review-Guidelines.md create mode 100644 content/docs/developers/geth-developer/Private-Network.md create mode 100644 content/docs/developers/geth-developer/dev-mode.md create mode 100644 content/docs/developers/geth-developer/devguide.md create mode 100644 content/docs/developers/geth-developer/dns-discovery-setup.md create mode 100644 content/docs/developers/geth-developer/issue-handling-workflow.md create mode 100644 content/docs/developers/geth-developer/vulnerabilities.md create mode 100644 content/docs/fundamentals/Backup--restore.md create mode 100644 content/docs/fundamentals/Command-Line-Options.md create mode 100644 content/docs/fundamentals/Installing-Geth.md create mode 100644 content/docs/fundamentals/Managing-your-accounts.md create mode 100644 content/docs/fundamentals/cross-compile.md create mode 100644 content/docs/fundamentals/les.md create mode 100644 content/docs/fundamentals/peer-to-peer.md create mode 100644 content/docs/getting_started/consensus-clients.md create mode 100644 content/docs/getting_started/index.md create mode 100644 content/docs/install_build/Backup--restore.md create mode 100644 content/docs/install_build/Installing-Geth.md create mode 100644 content/docs/install_build/cross-compile.md create mode 100644 content/docs/interacting_with_geth/JavaScript-Console.md create mode 100644 content/docs/interacting_with_geth/RPC/batch.md create mode 100644 content/docs/interacting_with_geth/RPC/graphql.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-admin.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-clique.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-debug.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-eth.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-les.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-miner.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-net.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-personal.md create mode 100644 content/docs/interacting_with_geth/RPC/ns-txpool.md create mode 100644 content/docs/interacting_with_geth/RPC/objects.md create mode 100644 content/docs/interacting_with_geth/RPC/pubsub.md create mode 100644 content/docs/interacting_with_geth/RPC/server.md create mode 100644 content/docs/monitoring/dashboards.md create mode 100644 content/docs/monitoring/ethstats-mainnet.png create mode 100644 content/docs/monitoring/ethstats.md create mode 100644 content/docs/monitoring/grafana1.png create mode 100644 content/docs/monitoring/grafana2.png create mode 100644 content/docs/monitoring/grafana3.png create mode 100644 content/docs/monitoring/grafana4.png create mode 100644 content/docs/monitoring/grafana5.png create mode 100644 content/docs/monitoring/grafana6.png create mode 100644 content/docs/monitoring/grafana7.png create mode 100644 content/docs/monitoring/grafana8.png create mode 100644 content/docs/monitoring/metrics.md create mode 100644 content/docs/tools/Clef/CliqueSigning.md create mode 100644 content/docs/tools/Clef/Introduction.md create mode 100644 content/docs/tools/Clef/Rules.md create mode 100644 content/docs/tools/Clef/Setup.md create mode 100644 content/docs/tools/Clef/Tutorial.md create mode 100644 content/docs/tools/Clef/apis.md create mode 100644 content/docs/tools/Clef/datatypes.md create mode 100644 content/homepage.md create mode 100644 misc/page-tracker.xlsx diff --git a/assets/node_architecture.png b/assets/node_architecture.png new file mode 100644 index 0000000000000000000000000000000000000000..5b0bd1baadb80ecea142420a7144e1bc4a37fa18 GIT binary patch literal 495430 zcmeFYWl)^mx;98~cMGlog1fuB1$PMU!686!w-DUj-RYpg5?mW^+})v(>Fj;Z?DsoW zGc`3eRZ}%J&(G!odaZTKCHIO_Q;|hOCPIdSfKl~2l=vrao(HeWJ?$UOB(Kf zvekogcy7NRD5!~bTu*MLdm2Zy4n(F#DsIEU!s5kE zg!=$+32Y*AR^EY6ZoPrpO5eV0~a|I`1y~yso%>k1@Eo*X1nZE30af6E#+)HPU_q z+V4<)71C7v!`5%l{<`KD+}X@HOG&kN7m@sC@BGlM5!l2!F_jF^2}UHuMFo`sW&3VT3*x%86T-X z*JpL%zaBSka`0k-(kG?7VD2ewSAg@Hf#2gj4g^lBJ731!aPzEf;jrV4zQxa1qr9DQ z?wQQIN;%_7LQ_%MsYu9C#L_3OtNeS}G$kDFSIrC!?^~=FMb9@LOY9?;wL--`%?y6n zVdU~E%HS0AdmiLirc24AKrNN|- zY(c1P1Wz_oSnF-IMmX$EmW3RodX7g?{#OccYZDa7!wiob#^nI>0>iu50(%0@S-RhI z3g>sF?ur(_m<(F`58soU;&}_#J)vt%rU~DILyy5{s}Zfrh|5O;_6p$c%D~oz$Hhhe zX%tzd&&FNxk1Htow(OjGx@F?ac?WUk|Kne#x`;j7yDeqxf>o%>w%}(bfTY!R!T=G2 zfUNt*nuFr)pK8nZTK%>SNrvkp^9J@^V zEPgrr$ibo|atjDmN9_+D*KX1lS08qb4TjFNY=%`YVyB^?D%=}L{PyqTB~tzXj`@DJ z)3>Z0)V6O$)_-PjUtjfvez*Pzmo;IGkCE$~`bM(fhN`e!JDuRywIF_j(M^)qemS?h z&q86Sqh|@U7kQpJYHoJMnTLm6M&}S-*+3wUH^G%mXb{EhVRLT-w*gE?(+-1y9@2$FIZeb{X$=N6Nvh00iu8e|L1#JuZfJtt$@(w4Y zIq;&Vr=?kfgaNDFjNs`jZ;OIstfKOm)e$$0I0&|)2 z%!Kk~#j+G#n-8&5S+{8?rI`Q)Ff0mV^oR z_K+mw7`q?v9YYE$Jh@9NHS?#)Kzw{j-83=2Z>*s({iQS(&qL0nE&c{(^>hIf{!7sFQ;i8%qo4k24429 zxF%s?&Zq(yUosdSS9DKXKEJWuMPf@rgSh$CIPY7uY@P~7%)#-U=w!Y)A!IaUfN%a@ zXTUN2JcM0mI>%#&of7&}u^T}D-xSNl`5WSYA79N-xHtfj56hR#HY9-add-r)FIrJ4 zQ}~QnT1r9|*CABk@%lP>mN!!k8q!wd<#;{AnZABwX{-`vpb7Y0d^e;h{mlDPiwdYb zUx0O7MN2UgIXt~JT2@@fd3j~~U$c6hM%pL~1F{5zt@kP6)s1#Lh5)1{c{g%~Lq1v| zrh@ZQu}xXMYY?n3j%jJC62@e)0^<>P5+|~b|I~ee-1o0-&!qsG4)GR2`AGwf`6Gh zO0FBGgLfRm!uST0bh^w=1$B zeNeQM=jUKCk{mmuY9=)el=F_A8JdJi&JSELs&$Wb(6l1H{CpY=!xQrw?VFJNzZ7Ne z@Orro>yLM*B4=jnrzTxPA6tNp&uYtis(rm1=Wnk=XV-yuBrChgPDO$(>b&5#W+X^3 zai1u{u%@)aoOWr2kFw3UiTGyt3Lg}1bI45gZ@=Jo1t?vqjtsSqYF$-^KK`J!DG|Ah zczOXG`S@1og^G=TeR@P+zQb=EM%XYo{;4l_QPEj)1;zMw^+3I!sObuG&51IlKFrW_ z?GjNt)9OL-o2zVwg0t$)&_6EE{pUX~o=7-=!48(rU!jljqa# zyoNr2mo0r1_QiqE6-(4v7|QLOw#}e?CH7Sl7Op0u<#GAzAMw21LtUQ>E=aqlKD?o2 z8WD+|o-HDyKjKrdP=nxy8}oj>`y6<{=axfj11B5ea5#CvM2~91vMOhah6|d~I)&lD zxzqiHmh*+l1^2mT`jZY10y74LivSG8{Z7X}@J{lrucPW}o@nZVS4oC0(6yV#Q>~zZ z5F>bgR<6wc^zY6Ttdr|>gc6dby;UDe&Yk?Ne(G-jNah55a%b&&Fs zu;3|Ft5HR;%ih{T%OPq&_qj5O z>W02YTDgp>y#2zNapEiic7h>|8yYtZTI0<_LlVHqy`kWK#SqNPr&W-uUC$&oU$Wz|vNeuK4$t{0H1O zbb)3pfwphJ4?U{VqzHgX?m$%gy4|g-d18Hp%`O&D%Zyic2&AeO8-2a=L4GIi{YS(m z{@SP}-{}JxECnPt$~<`7-DU}oBN#CP247=z64ku1*})0sk3mI|k)&HGSt{_hvNTa zr8n^G<4Fduv0@;thRAAlz!5JP^&AlvYX?qm5d_&k0Oo7OO+-6bl%#L030>uTME@4< za{hneK7z-YMf*lCC8EYZReAg_ET5iA>~$Nj5#d*4Xx+J z0ZaCqJuJj5Za9~5k4o;mE(H4=PAbB;bcebTwZA4RS0H%$(kE4$VsjDhKzF?J;#|by zmG)E>f}fC)g=5#cPX&iC{3eX0{zREeoipNMoB+dNr4iQ}QH*X3y*|G8_QYN8p{F_E zTI3(HlEJ;I)28@n!CGyOjg<+&aC5^j4Y&)4#fT3ZB7A=b0^@btXVTGNmMZvKC7HKj zo@;uFuN{H3^MZo=KxjkYIu1fkBjrxz4}n7cxY9sU$$moYDdN8WbYWktl!D|k<*4y; z;a{&l2$QTvl5@3GsEsHqg`fN`e(Fg;(~=I;Yu2sxMVe!q+5W*rlY)E{(X$3rz~|{{jl(yo{=2Kqd8OMBVQ9D~bwO zO>ZN~iDHEBFq2Xvy73#gYY>+FX`2a3i5s&!puy+sY0jg=0HYo+OedWgPZp!}A0h3( z=-2}7$xzFfzZrZ*u7*ydJ{yszwE0#bNsnw|-$^MiXNv#k*`euD#%Pt4C)5Ff?}`}~ z-;CF8%gTw`B6U-{pXTOGFgrLbLxXn&)mkJYJxkoa>AkE(X5#&)j~_^P5-Jn%Iqlh< z{Cs`pJPCUQzu>rCj;9~KJ8fZlqda~4C~_>={RUOld+amsmFU}jQURhf1bOX?G&@R6 zX#@2%A&lgusbyk#=q$#V&z$P|$YTs-45b{C@w;CD4MOLnq>A$?NXpO4Pn!cmj}1TP ziX@~wwrIl6&;P9UXZwQef1@WF(I)|}4IvFrxY3JEUz2vp%!^Gu;&JQD>iF1lVsDV7 z;f*|sPBvJ0^1^nn7n!(2;vl36ea(PUP`qteaE|$^k3yg*2`wIGKLxZz-}Fpdvu>>l z1amIOYiF~I+Rn~j8DK6xu&kBln_dR2SEa(HxHA8jp6j=z?$1?k+HO}Z-XS(8=EGx!Kll$$7e;)^^@ z0!54Ez}?WUblopdg22t(>-ybQEeMSIdgO&vL>LN}Rby2XTo}Ji2=_Z)6ao{3FSWgl ztd%WsoX3>MB(9>&nW}g*#o8U%-QF+Xx2ZbUm=VlgWnF@`WR-$aQ$*)vl!tXBKWKTp zExdRWD+3T#Cg$U%FiRQq4cv(sQR27vZ`Lr+09oC`-qgS_Rf%9{8D&=;Hcmf-C(~jg zWF*+Z)+WHGMOoc4LMa8He&x%vGk0N~m-q8)W!Ak5_~bGZK%fW-7Z@^1#@tX?4^xiA zym==|QSFZK<&De2VX5(d@Q@n`h*0yxoepE675S$y?=_|;s58Q7-mCt8f_2gTuF?DA zYt!>SUyr5QjAvZH>TwHtVc^B?!$4dai>TMT&CWj`0mj#xY1(Ba{#oTb6jPpwhfDCH zi!RTFguaj_Ebg?+eCc!6?TV2VQ`h@}i_GNf@%xgC!@x;wn!kYKP|y2k9oLlWuH5~j zoRG^&#WZXcifXTiIMpYmE;dJXj#hHvnAl%s_44a1wkB9SC&JOy$+YzsnXIif? zS>-l7{BE?k-+x}wlXKAW55{e*(4D-h2h?i7nk!h^O2ZRqq83J3%Mq$6tzu6B&j(ZItY2{gs0E!(jVQ z|Ao%@!^SH;(Vp~|%O=2UJx%U+F%>_rN9(-RzC!C@ob<)VRXp5|1i1bwsP$#>nGrFp zPhY41Pp4L={#jCKcdY}*yd;dP|C z=_+nsrLy~%thP{6I7M(GdrMsHD^khm*cgE9!Dq!_6!$1hXCULZNBJWpCP zOZO9mgIhAe^&tHrc-ICt6!%__OYi@yk-RD{Ei%??nHW^BXhvGz21A>D5)+g7u(wa* zeRS8UujN95WednPB zAF6XR5<`A`uNnckB2ahX&(ouQiA!m96l!WSs9M3RWo8PmX9;qFGC@QL&Fk+UBvvsN zBSwo*u&pb#Dce4%eX-c6>qkU1^AAg38=ev$b?x~cWG!oJKm}ohoh(D>q>vp$j{5*> zW_A};CIde}CU7_BVLK1{V0ag$EbhI`;<{;G_0963e*^)v3@?mqm=xU9=Cpk>Zb1LB z4)<7B8jq<|s-UTRMdQ$X=-mG?Cz=rZ$3i&lGIg0W=m)bMB`oai%1heP3Tg9cO-&h# zwDd08##eSSJkp`@=a9t?OX9-4YUp_KcN5tIPq8ltTqAvYz8F9w3FRt73FD0d*c`&WJ!a}Ie zju)?+|K6B5WRrXwc#ewv813R)j;1EJhVO_{agG(*Ys($C=PS=cQ3O?f^jZW2w_ntA zq1q^oPp&8MXZSTdT_CyQ_IGYu7g+LZqQa|uGM4Sz{eo*;A@*9rv6I~unM0eF=yAft zC94{^*qx`Wwq{|!;?=C2C4%3*3{vem@1nsfDrN3%r>xa_r50|RB;LNBZN^HbbDzd0 zdn-q3nY5UL9SmYwUzoK})7D1%VLb4dZL~-NzrqWQpdccK~k=v!jSN=;-SK#1z195)V`qWw1&+Gy-TPbE+`u%B#0MKgifX5 z)yLohr{Dw<-`xG;Am~pfFKvz4b&goL+d~I7Wa!s+9@Hr{z8YqKtr(tHup|^YvkFc9 z^TB4;k4EIw0^Oo3ifz74nr_@xb=h;?EqMNijbXcC5Va57VvjG1N}b}M257KcK`!D@ z_x;S?03|ig`};dm*nlpS@dnPz0E}bRlDhdUv%52Z@NlzF55Q9K5dTT^AClr6$tMrG zz^T@r7ml_;hDEnyr}5OSs``sK@qKX?H;5=w)s=ceK18N&F1G>rfMB=R-HNO%3Zv=( zQU~@)I-5_03|J7K$L_Kc5ym=EVKPEg^-}sDQG8$z}|$IFTnM3v&rsqqORH z7~#gSQD!BjSG}HbVybm71mzeQ(x-TF9cqGd<>-)1FQK`g3x62N{QVciXX)N4l+LnS z20(k_rA5c!C}Ov#}u3}39gW&|HKS!O7sJ=w5;70 zI7w*xQ5qM{SQtCSKy8kjmt-?~*6m*0@})5u9e>`{pRUAwTCphh8ZNH8R?nH)Q4v|K zMf6tGhCBCh%uBk&?WoefSAw?7*zDzJidywslaG5$`-u=z&cs7l1jCMXI^jJdppC&V zwq<5*yC~F?T>=YD==a3D)IGl_+SU}7Rqzvdd+uIl$zdfSLGy2ws=Nacg~*Hh%5aCv z83*E)7*LNr3flcKr$=+wdu*3a_B1rOzk6LAu&{NM!%T~F4p(+fn_yjqy1Z{8-#8F- zSsep2?EitN;7-a@Lu+d9_mbC*K_y+q!dO_-=lc776X8&eKbubawRCrL=0^VW|3 z+gTKG)aJ3Z1i_T0hiQ)9Coa7W=akFAWmlhj;)D;;VWfBMw&iv-+%fVZBVlZWPe|zx zu5(Pz`>>;GVLtV*NaVMz!uoHw*!Yay4=<`UX1sN~F+dTUpYb7vs^hxJQ9GPzNot>{ zw1;+&32pd~ovcZLB{O$7bVL8)QFbcPojm03WIL?`oFCEjEayi$JaMd&_e3;iTot@m zi>JkdxM&W9zg8MR#Luuh7*c=k;iomc1@e*hPf`4bj|XNP3dUDRC+)tvse5)R z_d_z-S=S2+L|=)re}_bCxbAjL*3EYJ6Qn%Z_i4F~--CqhRmW^OH^@woox%m6tDhhV zeVRyuiaZ$>?gf402%Y5fz-4}&AnXR!!~gNKBFhj0OQ0FVNn%=b-xHEi&W#ble@EDJ zL_ajRBg!y(5Tc9OiiH$#smp86tPM-k?QJ<(L9Jh(%!MkugS7SUbUM@dypp<|#tTw9Pje%Gtf{Ww zKb^mI3*JwI{+z2r!Ud!Vp3eI(ck5qdJfo|mn*XWD6Xs<5d8;YOw*b|L_uQ;~Wi>)U zU!`GYi1oUYQe4mxAt3++ULR$tl2MRqJEn%$;`k!UW$o`*0R?MQ>s=kAXyn04q?yKZUaLE+s0) z^cXIPdmq#QR2jIgD^K8 zT5as+SN)k2A%^=SURiHcrz=Z~1@_jbdHSRG<#`T%afur>@xHY@0t-Ps#i>82w`aHq zPFN&X-rYqI`FWBn1t0BsYM1}-A~CdCC)Au@HiXeSFZX~KD>K?=05{!t ztmCGk)56*IZEs54@rQ@t?KxR_EJlR(Nc=JuEG0i7JuK|iOw1w@Ge}vDjGZ*eo-{M5!%p>VeYwt;o>P^6r#m8d&fHkDAO^PVR&<$JV3g=>*&oGM zO=o@Rn=-myxpqedp_|aFC`lbsg#0U>c(8MCCc|_)W1xy+DYN)VEd3mf)h6)4vAtCQ zEn<&$OT!&mrT8Rx_s5{k8fabByX(*CXXZM<1d-Yu#Wywh#By*L{Phq{=0Pnb#Y-f7yor_B4ErOo+TInn`WWYd8$UlX9=8 zN9T^k2}sk}eeuc8+YW9mz6VP1v>MfZ*P$INV-jb)jS`(Z2Wd^tDvndZ+U?CwdQG*q zB?^l`f%Nz1C4yDwnNtvSAJc}(`6D14JUvhETfBhEV@`yidrE5!%x}4%kKl{*zjO>S zjq$J0dx}+tFAXt3$Mn!OcBQ zQO$vFHf17L2<$ZV$RXN`EI0RS!S6U*#pv7-ZUWZP(14a|WQQn@F^3~UU*LZaPYAh9 zbu-Y$V(Plx;A)cw@WAT+)#2oq(n)fd;y)%j)tNx}xA>qt$0ykb)5RTn!j7>zW*{7) z6Tv$=MH6rRM~k11e6cxuk|5h$T>%`4q%;r2$d#CEdB!AMOcc^b|JBHq=ry-(EY=ut z*9RFI)fj23F`jhQ-1`F@yeftnU`_wfTT_+FtFXdJaHo75_rh>xs&Th##(gLbYw@|C zkt0AO>{a_++WNWElE!l0Yv?~AuEL`MujF75`expJp03>y7eW)zD!=?EvPz$;&B`Q$ zoJ~>X?s{R%Q0PuCTF0Wt3(uYvSs!4H+3@I0@^|k`46AaPsrprX=DZ$4fisTbtW*9k zjS{ojmGVlKr>ZE~Psx(O7y_9U@wai^S;oF-RadIwj|O$rXmJ#nrSHmHkdMQ zeRtDGcv2<`YPWWg3QT?o!r$Y_U?5VX)&jypg%9bHyJksHu&}YPy2i@v?)<|$Wm261 z&)<_^uQ*)u+$zGte*tG+$2ThyDfoyhQ_a-ebTx=Ey{jb%NM*kkoTCHuM%BMw<6|SM zM%%;4VJ!20szT4h{1r6f=x54KjjX9tYTEM5LrGW;QfVLe^d#w@_59N&>?i6$>u_z5 z7F4$b;)T{!p%A(zk(ix~#>)=Co+iei=4pU(OHMG?{$o3~`UN@Q>Wlt&G`)>4rpM|O zpBZ_SjpMbK(HDjM;i5y5>&GqN>M2kFsn%kF5){j}0dM&p$Lr)Mby~5I$|fOi@=Ir4 zV;3PrU6h$c)n8nWCYI{=PmQoi@QO*wU5O~eKS-`7lJ%Mw(aHDu(mcnG0!Ko8np3fb z2J`IN?x2DG3q;KkNc?Q6415txn_1VJu{RN}Y5|Uo9FjLNPD+6&m?a~vgtoRbQ z)ai)qmp-KS@H)wr02~a@_d7p(M{J!S2Zm2N{%KfA&)4sG&>m4`87^gW-L2R$cRyS+ zeN%aOBftY#wI7_ zxGi~@2$nSJRwR3D#98l`O!+iCn@F z?hBJIngjy^vg!xj;8F!x`Ul_3KhV-^p(3`jEJ0J>hduNUz?^aqiD-P{wl}!0nh#~3+LRn(vYxJxK+Y?bQmw@ZQFE4IiuW@7ieA*6kPQpn zJ|^GpD5}2QJ^N<>OayBhb=?kj>S^FzzW)n0`bC|{SB-1|Im>k3C*85&qw@D^r2Kd$ znZDa7)EMqljUltE4`nhR5Z_68AE~sn8YdhGN91*w9G+hoCC9JtabhNZg-z0?_`P6DRGWpB{{J34nUTRU#%2GLe{ZWn_c9x3;G6lmF;$xM%hd z+@(gwgLKNxOx9XSfQ?v$8`gPx0&41~wNZKjHZthjF6t8VOH;hcH9Q2MoL}EnX>Ea7 zVl&4eFcn?2P7(tqE#@z#_$Q>ToCtSvBC>dK+3l-a47`ly%MlyfhJosT?(56?a%o#f zo;-&zIuLRitv>;ZzxLyyIWXH1sg6jZQ#c0=e|PlT%t?&biij6p%D_+>35~Ac_58Fx z5Zl6EM~HnA;3Ky|CRF){d9nWNNo$y*D*! z%y-&Y*HaQQt|q~C;b5_ODk!1_GqomUiF5V!!p!B7UNT{qsDO@%`7O~?-huf~|GVP<%sivq*oRzmAHm?T)FBqLv3tYV5TW8kFdk*zBLMA%~xMC?YUWZbz6R0$zDcVF;a zdu<=pv}c;mBm4&otneiS_^;@6Uw7}HNEc_*%eZ&t1a4M$PcZ|gq$fSf{wi4oFEJ9q zDj_)*4pvf>Z+38n9C!U6KVTJffZ2HOq4uoLhaWa{ZDNzm-nvXS0i`|?&}Nmz*7yvb zD3>C)-v?pQa8X~K*wzD6`qB^WW*j*lx3Nm;JI@HQ{}o&TC^Zl_)*c9Q8m0TV{Y6B* z<&Pt8FH2=g<~Ywvq&GXwNV|K@5T`;q^ax`;WW3CNJm#$=DD4ly(;2Wc@VKL*Ylx75 zl17beFKk^>sNVMp*`duSN_=QtjVA;4d}lWO=PRMim@YyKma*KpXpk^Lt*Ot8Z7@0+ z9sv=$(nQec_s{f)9YvE5E;ayG@xT>1n^=sn=nmE&%KlSctEe|^cWFQ-n?H)<=0pNE z{HA^JFkA9S{V#)fxxIWnHd5#Q0hsDNp@&h11T?1k9&G)yDyGINNPAXqy!4nd_=uXA zVU~07aD4`o{mh=M_~UD^11J6O>iAaky3l+^ISU-{f*YnI*z6A9=~nY0`r-`9P~6@G_Ld9G+OS*k{2<7{)lh0uVYLb1P$#-U5)zDRZQ^6k`h6ROX>vLdFDY)*NxTYiF zXVytMn!#BAcIN-s`t|3^tslasC#~cDOqe`>q~KTR>$bf* zgaV<37cHg4-$P-oE}hc^;k-J{@gILDuRsRWe(=K|%o_zpSGvYTS{_!Z8oj_JF>1=t z%Rz_RMPQyP>_as@wLy%Y7uM$E^Y$4YDlCYbF^7mk0$^Q>b_$`BrvJIMwA*j(WG(63 zCQ?+IKS@vSPQ=Atk+bZT@Z&aTgsjiavwg1_61%4_*9+UoQV%$=6MC;nwM7B;VJ0bD zu+YC_f!#U%l^qhn?&l>kguonOv_r%+E=aSU##U+S=}RV*=H%dF1Z@Tm&W4$)Pe;$& z?YJ7p2J7l{a!aaCN4?drsN#jqK8Iz05_7d zZxJu7z9mtZdrfVA05MJh5Q)`)6FLKIdAH>^U)nQnLtVzN+wjKcsRgRY$kY0!A`maF zKvcU{LVED_PrY9g2?0&OPOyf2Q-C0&Y|>(PyXo;rfpEfk2lwfqDF8hr?9K>55S9F} ziI5!-v%w__*%!w>cV0IwyCq;NRmlZzDydMk^b*+YtO=9yH~*q{DeRsmzJ&a6hXjc7 zxdopkH5@h=8JJ%;O45JI0+@8rdAqZ2CavMK2$(6Y+HIq#zclJp7Vq2otrw)$tBGJV z&=En$Eu;lG*6FMn$NJHeD6Hd#!;{@i$F$mcZ|0ToR+#KG#TD*;1K}sWz-6Gr%wq%D zIw85;yIo2rwK+nAB6AKTdBp|O0xzyFjye_qEnIh0x`H}ssBXe7G+KXEb{a(8ES6d= z8ev`Xz-QF#J=**>ONzPb-~uyt6rO^r0yA!yuDG@OkNi5%tIBe}2QO?<8lErMtABtJ z)cQw)=C3jV{-9(v)12qmYAfbne}*;jyQ>#SgyD{REvMSzdcPYHG_c)6YAu=Sfjit0a^ zI?d=^1*mN*ZH(gG`(Q=+D0Qicf`pvLY{eo8e!V-a;XX0f58w>wVXLeEf7JC90$dyW zZS>4XcCT+PY72P0e;%+y4*6}w zr1Quxba7&xLP_{jvTrx)td8TaGJm=c^2FUF>l#P@@9u_bgxctAm+DwlkpeU(4T7a@C_72Mr{v z29o<2M-^f0^ng*Qc|)BK#B@i_%V5WqcZ>48Q7stLvtFy%)7k>1E`>NWD7e zatlpdU@tuM+w@7OmdU7%HYbq+Z|O(6Id>f>H(J{*7WbrTcpvO~9K?36EK0 zlH@?0J<252wE|w@RXozMFm9__%MtCV*xT?wJO#B3t=#^F^Xb2RSu{ieG}1jR zLciC&9B^++Q+qux#-QK*#zn*R6p^r_Qr8{wCC3uzFN012gfkj7qJRw_gm3@e9e81N zCp>5#Iop>i{_%qn;@Xcv^v_iPQ(|)55m9nHgiap=pUHu{Z2t7tb&^f+O@8rdy!y6v zp@6F}egcMAt0Rd(M&<|_`Ujp1&gHjk-9tQmto8ZmlFa1cgNT0qdg(*eRFQ?_~+fwWpEH` zq>rA5m$iYP64u+?WCQBqp{b8%9%w)Ksymp|oA&ENK~d?Tq?g6Mb1|!>Ma!qWgNquA zfnTA8Zi~JR(Dvwg(!^-TO?mgEAW4Wg`>z3se+^9CRQ_;ZLufk_+*CRE!&P10cFml9 z%Iov^VW9XN3j_6YUWb~X{zm>+S!2Es)%6em_Kkgxl*G)$#S;dJFG>zSl@t0LB2xw( z?%0sPZFIZ9_@aXkjp>Z;vq(LRoNfp?c6ABj?3FqZz@Fk2@Q8;It-5g(B)r(bj@LuB#F{(5s5MEex*UOmj|0)?)dkT2%qni! ziJk={1`|eobBm5PWv4%N3$W~Q(=#%WYeIlmCBsQcHqbh;hJUBRn?1}<#pbiD&g=+DH1b|U>Obkb38JSyn}Co+k-Mk zy4sfh9!;`LEuB>tg_=>6&|q8)@QO1yX-G*kvfP2OkO2Jno$REJkE z$bQO2&gbDl#{LnR@=O((gG~1ys~wCY#*`Z)LcaK<2m<}K0YpOxH6fr*cijFp)bVDA^sthX=YQ%+$hQO`Y2%bKcX(Y-uzI`P(U6fa_I9l1L>e{X^ZDVnYr+}4 z@zD$IZy-Q9RpkobuItQBajKnLQ?PtcmXZoYJ$ku)LVg2iX|?Ff zwFzqr`YY!}WyHH-4`9I=u%-f)q7?{aj^X~!>qaz7`ddNJTUFeJgq<%yho1qNxFE8p36!fm{`u65Umyj*=B7c7dBRlk`TRq99&0@J!1;WQXI$$JO)%VdiA zWY{R5nlE04^+e1u3S!<{KN7SFQHP}S9PUAE26CL4@dbK}A2znb=><%Ad*-^$p%xzO!y;BQFfsp>qe^9<1+0e~c@9yHQ`ykDfhwZj@UxO@ z;049jppXu7zUri#C_xu*`L#!Z{Fp32&=9GpFV^1=Rwbvi5VKUgpf=0 z9@Fn&Q4?6A6`19+M8^ZSX$u$#i>ZN5-9(`#|7uTsL+>JuJh9%%d^Se#+iNFGKwBLy zhC%(H`n>g1XZod|NkAE-xkCnMg6>9ar+F=7^by~Qzj(e`-gzQ8`q>{>D5|Ub!0?&G z%1TGLa=uY`IxU5l^H+V_mi@*_*C1jcDuDLIC3XFmN1EE~$F!*t`w6okt-BzQeA`>@ z92|_De)#+Td#Hl;1bL~OVJZ^xYA|^%CN!XZmD zB40w^amZ~ApT7OV;NbA6-=YYySz(;g??#m02W@<&hTSDHvnr*uaso!AlrVlL39g^B zV`$ZvHcR%Q;mHU$ubueRu3{W&bJ^5&$7#&xO5qE_Vp`Lo4~MUUm`d-1+LZzT=b7#{ zdJksR!;p5#DyyuFW(W2B<^IDSvk6Akl$P$SnB3Hye&;=#C&Z!eXT&oXs|P<@I`H}G zfBmX>M>5oRWly-tLF_N1EdJcU$>y4crnhAl>L^GT@6L7$LL{c7(N!nLE|0yC@QZ6m zfM~jl8c+J&N`A}+n*M;L$R(pthzezKSWDGB-zYjeI?z!D8P3-v#C}e&vF$2?Tn03} zf2y*7Z&(YKWimdm1M1jNpUTW(Zc6?SZRLRhkEoPn^2 z62YywipM1|JDnS=Hn|8TnUb#8GgC8@b#z~E)Su%m^q=+Ad4UzE{8u?o|L@HzYy`?b zPcXc7>xmL>cu7+giq<|+iof`(m{J6gc}#ogn-XM%G7sw5L2gUUc{8m=^ANQr)qt0u z=CuH?cL8g0bmIpO8;9VOC}5*=xGKEUXky+pLEo`5W}*=>_Cx9MFSkdR*rtm<=oo2p zxkO75f-_$c#GK^Fi|iNHoI6>8ezo*hIu2%xOMZj~7FrDJ7)6(&O6b08ZL?5Wn$$hK zpEt!JIyKx^=S&rJ6J{~bg2R>17UqfSZH|ZQ64hhEu+$N1t~cA5K)DBJq2S2sUUX*owdL>-y%v+0nsylX5blV!6^j&!_b|#MB^-G{UA6m%G08GfB{?xYx!JCYKBb<$6QiyV74YVlQ7fINBlK28EO>AKk1XZ%xY9Z>RaxKTM42;7oJIm?{D(q zhcYr9#uT%M_AD&@k6HQ3=SdIE3H-6QANoIm@N>9^g>6@~CXuu?3tczAz{T(2nZ6w{ z^L4S{Df$x>eWWBUwXl@S!ik7o{Jgs2h52yH!ZkcG02ZzmP3hKl4qpPC-;vDjy_}^g z3vjBd5uhT1XiGq>CAWUyS~)2x*89T5`~Z2F5U237K65pfGX>@4$Hq+lLj-oO70QM^ zOMFx9EtT@PE9tCv@oICf!3%^s8=J7W`?um^*+^DakTE4r4peq-E%MUWy+}e{1n>~+ zFGPP<*qTYHlT94e1ri$tB!sQ~&!@j`+PSJ%J)p!JvNqWK(E8iXuvIA%Tb<*v`;j*V zrPs{=%tS94Kn7e%BUf7yWK^2462Ia$H7P)7M0+5I!*=vQVz1|#Ejx|P$_h!)v6t!k z-7i&RVA_0ktmGE1|c05hfS|BuD=T&$WyzTx>TtmZ-_dOr1w>C>p z>7$nr2_F3|6nPflStQl3JU1Q~#`M46l-H!5?mV%k*AI!8_)X=Hs%$=`)CR3xdPhe9 zDVg{l!;P310Du=WmrylUcw?<1cFJ?t6~nz6ZD%>Z{v=z&Bt3Q0^R07GGOs4Ey9K)YZSBmu8VB=RG(*DJR z=V1@I0I;~O%xD`kia{Hyhqb8meb00CmNI2vV$r zi5qQ{U#C-Far~D)Nz8NzhlOe{%c!-<>8^q4fAH~^Kl7MnHFt@%8`+rXsG{#79n%P* ze>^%X>x1!60BU>B$S!6if@CcwIO_aPJlytCtb;{wy=g*Mjz!Np_vxN-$=iPRxQO<* zh6lVQi+mq`DFiA#0rKt%iDzY|=0IzhhltRwnUw^g3R{@2zbA4pbdOsVz4neo5e`A) zF#)n`pronNGiMD4Rwd_~Y!9B?4v_CG1%%eqX7_!_psG0I4&38TG^qphJe?l4QNFBD zQWd^+O+2Yc`eiElw%^~e$_bl%$UUX|;o>t{jxix zI`FOc)ZA7W9jRIJ3md%<0ns|rR2!1i-sY_HiBeA@a|a=L`*Rp&5L=_^Y{oSqw-3vc zF0AQuWf37k@>?-e5r(<=q72Q$pv78si!N3oA^@&~&EyLdK4ZL?3G)>mWNz!)49+ppWUstXUV=l{|;Pq{nOb#K}BBh@?xg)fXTK%Xr zJVkv#$31V5Yv;0oj6Jez%{2kOYo?HH)}yn)dbn->@34I1nCbq%5s&{B$^Ro*Kh3=U zBL&jGuggLrIZvnmwdtl+hvD{Jc!~)ITij6rzk>~A=4rHtDe{+)- zO^E&xS(KHtFSgm28i_0d);R0Nv`H7EwW%mi&wgW4t>IDnf#09^ldO_V?~nx3qAQsr z_Xl$+F%FUivf)szFc-OM$o;VLIRClUy!prln3H+YS(g)Fx?PEFQH3P~IO4|n+re9t z7nzGzw(W{)>rYG2{YxX*>57*9Luxvqax8mwbZ~Sdc4&EZVJJPLR4@rN9fgLDz(>;J z$Zr%BUH9vL>b`htOy#D)A1@m1-9GRbWaQ||>{$c*Jw5h8ZhILSoDg`m3UmYA7e_+- z+#JVdNdLq|p8h{63VlLE43iL^f+7O|?=06wepMVQzH( z9^4=L`z}W)f6C$jC6zv3DS^}|A~X{m8bziX87VG#-d5}w(<3@>NoKu*BLRJd1N%Zt z`O$~l{DZ?4Hpbm7n2zkAq=)x=_pi?xQ5w^<{vz_ncyF(>*t|f9J|w@jV*bpPxILlt zzw!0fQEj!|wVs9j-%`8rR>6$1CKJ^KM&!Abd z9F;DkQb$Aqm$aP_393si6nHQf>pXgJ4;vO_yPvw$e@D~b)tC*o@S3q-UnnL-y164=x$ zhY!>jLkAKPld*irU9scCd?5IH-Y%?uIVnc54EPt?-R-WQ($nc=?E3oa+r1kgo zs`EMFtngRDO4i-Cc@Zl|vh-DoFSO{ercp^jA8n}M3&Cecm|qhI-ts(VRcGH(Fd}c3 z*kXt7TM%-}ND~Sb%o$@XBTHzoprt-~rx{m&AHrm3)4O2~5G9VUfZ;|CgaK@5S(?Kreel*i(!$AeEb1EjD*kx$E!5b$nI50?f_DPmh!@Sd-9{t^{_hYug zT)&94Py zpK7!Rg!MGyoyAD>$o1C4xO$%Il-j~xuJ~&hblvGFp;VN9&1BPwwCXtkj)jLrea&<{ z@fkFpwdA&U8w*YK5Ked4dnk(4%5Nz`SwdEAkPGJW`E5*w7tQ(^l-MEae8b{SAum1A zi{;-RP)>D5m0yQB701$(@RjWSBb_M~0M$S@V@8-LdU+{uS3Ge!x$rkja{@+9 zyTwkK@NMfjA|JZF<@~UF)iX#EUGl8h7}b12F@v-e z9MNmcK_q7M_r@0jUyx5mbK{zbr*jzC&pE(y;%7S^EAY~#CFVR`XGW3X>ZH3L%cCWw zFqL59+~LV4QidH>;K`80kPN^&0}b+1&v`Zxd<{2Wg8Pc*UZPrLYv5mY0IXZ~XqTZB z9n|fZw#uhiLrK|ieFstWz5bQtPSKR=2>X@2ilG%rWjjor6Yj-fRiEFeYBY6}nxqhY zW9U)tVu3LA=H#g`4Yy*qd+R$2)G?u58!Bz!KH6SaWbSRLNMuf_lK?_Y%Xw&*l>1_? zQN?6qcVV@@D0_YT9GNcgfykIQHlOQB9GwG{q6IO?LCntVHe~CcHw{;M|<;B=&dng0hs&XM$0No%F)DhTVlX zG>@H?*H%nQZtW+1PW6wJnK`AJ&VLA&Y{`l5YrJ@jN`~u)2GJ10K=$Ipg!E}6L_|(F zrO{G(@d_3T4l{1Y6je`beRB^`k17f!027EjIj9&)CZ%&cD*0!|lIR{`&s%qX#G@nd z{Ett$lsvkxxpv>R27PE%E`2_b12=Z(LaM`-#G6)po)h8b08Z77f)n|+be&4kgdTd| z2#OoIP}JQyBihhXaK<7KFezLSR<|c%Bljc;mMIRa-ditLLXo302L|BCa%ew?N*K8V zem{9%Dr`7`j0KUU)rX}!G;kaYug=Qv^3Jz4?(#5PRhrNooReSje>E|LZk3nq3y_}# zKWiw#Jc`JPydNS`FpW;ixD^=67jk_bC{BV!ReiHFISz)TOQ2x~>&xI+H?a>U{-+$O zwBUIHv!W0}i`%ykkZJ+>+@IvBzMNv%ycA=H?T7;i#z>8SmU7-=MD1>LKFM029#O8G zM*SMaTiqDUgWZDXnW@E$)C3Zgwk)6Mh8*yOXulVBWo`ivRm%XbDQwv8L&hZdEj)TZ zUkPtqKYF(wc+djA5Le*j?c^;*_Uno`PY9zTD)$xRtO!Oxw>kvdvCU2PaoB~4a@qH} zOwr-PBlbbRnQBBHO1c!`9*w-dJS`jQgRES?E8DKUB4P)iQD$jp1~kdNP=-jZ?q>r5 zab;J(-gR`{#o68JkaTq~;-SOd#g9UQzMJ*r*j6sLij!)pJ(eDWz2^D3y_`kTy33b5 zB&X5&k4Eodu0?J9M`9l2?{#>!<2HO~FZ=r3v342mN{5AZ6l>NM6gBy9EvBQfr_MP>QkI)!JzqmNQJ;87Y~@* zSK3Zj$n{WmO0zBnp9JlkTAb*DZ@ooPP4X$A_7w5LGaKT)D`|a;q6dbtPmJsC1Luz- zt-I-d!=eZLOgG1wkq*A+G9P-{cl4tvuQQrADZP=T3<8-6WxNz;VZTkqbSpb$QJrqY zbgR_lQB2?4{O6Vjc63Q!+WKDhw9re~PFp;mO8!>%-B9GT#j*A?{vnBBlxQ{T$udGY z+D~%`n>>Hh&t*Xi(BLfzI3XaZK?5bcoJ9Qs0WF^go4`H4H0U!OxTDS~5dDiy6TvMW zY4n2(m52dz4cfwJ8I4pQxEyqk30G6 zs1^B!WK$HJD6IRrwZnTvs@q9UWOFGtIElCj&@JXgu|a}XHwY4rs`TjzNoJr-*ld>i zCm9e`54u58_vVZjsN3w|d7ylfg+;9SDK7>LPUVt|mQZzhVzCw~=sUARf0IZmKuR&8 zVnWS1kt^~c`kVUmAH=ldZuy6T`7eX)nZ=wo3Bj;)V>7(oxPM^7RvgF^tKz?4Jzj=O zhTzz{;{ALnhSExDO*715z-iqY=JhCf-NRpSmOrQl---kSQbu9R;IN8fR@M?k5~-0Y z9f<2U6q#e!Gu0<;SknnjIla0+D8hUmK%|#o=0+xZgUOb=x=q2OD$mNnxNQTxO1`5` zW@qk{MD(NkLsmRIzm4rX)YanMAKV@+4AHNl-LZU`aT30O^R_A~StUtXZ|nSzpn3X> z#En=hOebbSu0a&Vz;*g@1wl((i9DKHwCB?gMMc9r$mKL3kNHbEK}54m?657-|0D4O zJ3cqO?PE6Oe*Sf_oCFsm$G!d>LOLQCgnq{%*Q~zQBwpN9+}m8cho1wPnrG5%Nx`X~jUJO_;oJrA1AlAq<%(Hw zIuHILf8%_Xe{PRZoFe9Q`G=|ykvG{IJQ&d01 z{2f-KVS8ffRva!^VDEzGs2blG*=yPuJGa*gfFk_);e3E|e5!clCBn-CwrL&SG$obO z$Z>?D5*1-XWcGF8Mr9u0{VD(f+_I-|&##;0O>feH$3|uxkT9C(_!#UaI1{oKvm~|r zN(le^#3SD8m0>Nh>=il{m=#g7T@*XS!}k?OPB<-_bU-zSQAcd6tpX>!9Gt|9OyRYT zE8&#(+A$v?TA|K^eBz>>(lSf)+Ex}h5BInd)6JK0(|>yzFY<-#!5)^{2iozoYcGFMaRTn7bs~ zO06yG9V9+Zen(=Mtj60b6f4c4a2BF0&XnoEBcbXGuZQU5jQJq>3@i4cs^p&PCsJDn zoroN9Z`@8-_C8TudYybuZ%XIqIJ8<7;!ogUJRkDb$Bm>nmM`#G@myU@)Wj+iQ3r)L zs*S=!Sp>z)D&sXR7^GnGkPsE#=W%wBbch$ohYUXl9)5uJB+Sl{J>QN0@UB-7^nOod z4|-c|042=j*qOe|b6mo}T2zbV-lSax-ZP@vY?K#Q6sgwy!RqF%2m&uw))I4ALHrZ? z70tT3CkZFz6bG0aKvu7*x7)5EZ97ka4KI17m#uT)k(ZOh`}@b==+aV{krT4P;^st( z$Ay`Haq64z2)E!vv)}BR%C@h~YlTz5S6h=-<$mgbFS$R~6%@d1d7ZYyZ*yklV?y#z z?P4pok#XCBVVU2SKl-{r^_kh|RL}-bIGSCM7*PLAn$eJ|gJ+&HqToRsF^4T33Xy2Q z+&UO1nll5^OvdgD`eNzK22V;GIv-vTo}1nj+O|@sj0EOc5t?-6LoXO`8K-;SRp!Cf zXP$M6YHNLEe5nkWu}zR1y;&w@>~7O?!VV^G#Wa2nHKFfSfh7lKyvHqwOuwY&TXDZJ z0R6e@RYR_?M!t0|jSq_n?cAH$KLsN{OPRmOXyH!I5WanPFV2dm+wP5dUnnPzxQpz* zG~`{BuzlH>*I`X7^@)2mO+0_rjJLO`g3S0!7pA|~2>&*s%Se~pBgWkJd}S`2J0{vS zMF53O45X2<_!^Ks3emq(1e{m+KNCT25C){6?;nq|k{5_g=zhz3n5z@{!Y*f%F|Auc zD6F7YA-+RAoCo&+%NMB>Du+zvR?+I3tD->|bV`3?5r?1P)baFF?(tKOLF52Hr*4vr zrHMj3U5P&y4tu3#6-J>cyN~7vqNN#ln_}kCvQTO z9tn>!q|>?#OBx?mtF?ok)9I*FZW%?#oT<|}OkvlE=^}`xt2{@tl+93q`BpdY&jel9 zb&|<;?vkx10IgOyG9m_j)@ZPkG7sN97kHm3{2oQt5}HZkpis;dujSy*?U=Bs+bE2$*zM=IhQHUgl-AvrM_8BV{_N-8Y23#jYZbn zgwb0>YU&JPg|b)4?T|tElIQLs{#w@7Ht4W#mGZ*is_p#v!fE8Ze#Z)n>!02j{AO6Y z{{^%8jn*;m)Fm6iiu!9QI))3KYP~=NPdnzZXtVL8!fkeCt@k|ia_iZx>atjHQ!gpx zq$Cd0r98^vl!H`;F)F0p3;a64CvQn{a~wRd0Z?w64$oEWro}-@wB=3(u)ZQZf}C$c zoC*ClH=lINy2rqv@!na?YKcGE_B>qDh3@Fb;=WSoi`*vGP-8#;Z{ae}sSdeX@37tS z#rE?@_(C~nrJBef7u<$K;D>^C_NO8*vDx&z-a^@UBPu`(uc2xpr`wFg0?1M!=|k>S zEPRTbxIP{$q0zK=FTY^1!uu`1{em~pP!i&*7>;*&LU4>_ejFb`A)0SD9sKU8#n6-e z-WB)rs69j5a+uC3g&@+q%I}yjtAO8>3D)bkoM{cOpklCJ-EW*58+V}%FGYX-TdV9U zIgX=yRboII=a%mvwo#<)vxx6g>T90yvwN*u&tKpveDs|s8q1rWW`ASRWNv5W9>_)z zVE*f2!)%HzE3N)zb6uX`NxO=2K;A>419D`UN8&Am7~4m@zL5dk-KCPR*uZ|>P4YOr z1Y@#!B=lu>R!z=+mN`NG9Nn0OyDb@tGC4g_A916mc@h+@kE%@xeZKp~vUaVet!=Pd ztM-v$g|oFHB&d*KRwqkiPgaxMf9iezw>D_Mg8t%T@-SS@gy%L{tq^TPd`0ClMZLG| z4iy*#E)w2aG?wGQ?w;`^TuxN~*e6O${DZWip=0B`wGgve{1ea!6wG+aUO}vGY~;#$ zGD~Z_fQmZ>>D8T&o{_+CJSEM1F3~?bJF}w~AI|Xt8SXN*MbJ2v%=@ka~kMf?=%slGje*bwwOlHp)@+m_mF9 z^oKa7EpKsQiy!;&MI}pIjFD_MUi#&(DVhW8(`@{;dVswFt_fb_%u#I$jNuh?#sSQB z@ir2fF7iwvDki_PK`Jy|2dam}6Z$MWN-+Cn^|bU7za-OkBIxRZN|TQFIh@9`E^E}9 z+uiEQaTmc|&|clcMaQWnLjJ^k2E4uZ{iz~GGy6o-SQCJIn;qDbg$Wl?exa%FPHjhG zPRznOnHUH1C@4ukG;3B^eVs~;YxwuZv0}PqL@{-f%2rQqA7g+Bhz^;uD3NJB0+hyO ziRhh%a%Pa}VVYjAxr~0?ecz-Mv_)!mEjw~mJUxEGnRnF0AUUTacN{?l@?*?IQ4VS@ zx5bGj#e5bV>~f+378$8+!~4ELYBugW$vn9IfWRRYSOLTdz+Vt#L=h*-bvyS*@q_Pn z#%^c`Y5!3PytmnAmdUNF`pyGbEAZj^7kN3MCuMDqAs;&HY8&N^g(oKax@qh}F%ela zl0+*Nij-b&vNqSCZ33-M$07_Wo|1Rk4iZ>gh2r8g>a=Cb5a|V{_QO2#oE}^9EI%4~ zGvkQ$s@dStOSB>jB6W!0%C=(wnaL!1^v;qbkPESt|AAmJAr}U;@z{V7b^Qh5#9@|( zC$_QRLkZ&*Q1y_GjJ+G_tu7AfJDIrgB7PTIiWs>4>+?*?cgJjmW14rZWW%5Ki+3|3 z_zrJtSJ{yL`f_W9?$H)h8YLCxp$UW(1HCWAwgZ*ip=yYPrgF;VdPw2eYZiDlc&~uw z{krMf9hlpF(y5iRS990XV#SCYe~Tvd6y??i?H60@0mS$i3LDQL8>GQyN4Mn(BnW?- zck@gB_t#3>%-gMzRj#L00v7V%5`DnbR%={jh=hhgM`(PaD8PC7D0@h`D}_BrmvVh0 zVxftmD+|g-^i$x)T((`E?0~H7<%!hzBJ~y^`gjN@tf%HHfvaAkPPJu(7hXL51POpR zvWnpKit+1E?+F=PCZBMslsHhHT35<^*V>S0dpX*0I4#;gQlKtfj%o~${CYdQTm~+m zOkIj8OFGlwi4#Ly!>*CF^YXP^zJ7_WV@DJ94HOt`%I_DPq+Ki{!+zN`7N+G$+o=e{ zFpmwbJn+CVC$E9Sc+l^-O(-kopiHKh@KAn!{OS=sy;8)u!h+F>K6?h>XMYtWzdeH8 zHC-n(5_=#^ia*RG-2@|=4Q>-+4nc;Kwab`H?4lnkl#nxjP67cV?7eVQXS8QK(|O@@ z5_|iniXo#-??$0=kOW(%Yr>w`Qf`zJW6JE|Y1Yn*m$^05g2k=gCr@+OBF*G*Zd~qJ zLU$T{X2CZrwK#ceI+-54x1l}`&VlY4j_afr8sZ!-#>Z6gO-ljCJZNPhteC?1+{^kLbA|yi9I7~2{Dxa*e zo;b7T8}5R6W6n!`Dkn}+I7nGO8upr!ZYs+}N?X|mZ&i&Uu?d1p_tH0unG4(k+#lsR z86V>!ueUsNA_RLcL2;rt81$vA1USyE_50sJH~$_Sd)m#Mjm6c3Mf%Z>AabeLHITBP ztZ&baIs~d>;n&;1yiwPjaYu_#krP=sr`<{S!f>Z#y_SCHRhyLFh4I??U|xBw?DIx5Y0(HUJ`qAzPJGT!YO-+qxQ-81eb zVB8cB^(bRD98XKL{Bp1rIPzOyAnQG#CL(^mBAN*K4&>u3%eYhhg1gPGsD1Ei+7!>` zghPgv19y5%{lzk5m1SWkN0*1})2iT6i?WPFKFoOTaK5_B7qCG{m-fV_Sm4*639r5! zh1if0373WeEF>4QHVXWUJvp+B64Mh?u)deWmZ!n{NzI%Q2T1lEQw7~1M1^m`-A=fy znN!j1pLnEB(-bOkWV{qw6U)_~j6MNx&u*KLQ}6UYncW$&&WLR_4Rc4FIH*95ol%rZ zZITSCDYt-7b~V89*_v5s^Tz-X7^v8Q=1>>kOtxPkF(+UNDHKEOQ9fr8(7rObDT`v! z-*1+UDb=I3wSqW3KKCr$@!c$6HqX>K13y+`eotH2`B)JQPa0p+wT$hBlZMp-Mv{k{ z9a$0#vFD+*X3qV5IONdqseK9&V+svzZ{pC-x(%`mQ;6DOLdAtDOB|YBc;l^NNZDF& zJmYzWk^U~g2clP;i~586lb|9~)ITBfv>OjJg5!Ot2xBG?+{YP@Z)+<-z*xuMkxc;{ zT2-rkwC(6|=?OnIw_!6x2val`}dT!SoFj20CKTnvZg=>Zp^~elvrero>sBzNr^8%YEX|mu|oO zv*@?|Im_ao8Y(R>e+-^0T3e$~{w_Y-xNZhBvNzTx{+|C`ibs_$g7K=B`WBpZyC>|a z!SVgMD888!tJ+3VGcOAD4@U?WB>SqTGJTX)mR-*F8d&lb3`5g$#*ch7ZBQ`{X4Y$4 zBqJ!XiMG8U;Z9_XY0pYtbr{Yf$Q=Vht9d39VGNIx40XH#P{igzGXU9(5RNWbL}{ha zf@qs_iHpNCv&7R|p1V(TTuKt>7$io^NOB3mI?>>ZIY21r<=b=4i%e z>X#T$?_!IW>0T+s!U9nwY+|_gM!&mO<);E>C59@`!RF(Nc!~sBW&6rC`kw|MCmmNb zD|L$%0v!C975@lH0H??U{E=_(PqX2|EB%`x%AqguV?bZ{xM~i{KHKoU9M!PF960Xp z6xmI7G;(5r5`c4$I5csiZQ@Y{<;Lqze7}L`i+8^AbH7q+<%krG1d^KT z$c&ha;!p_WbfePqIZglCMLacTOXs*z$+zY0t0x7t#J(ocj@B*6BrC9TMur)6FKoR+ z5f$Ky`srpGMBl45Y<`|#-CLN3K9hLShqyi|?Tgd#4jcp)y8+UA7@9N10&h7Bs+G08;sq-9*+M1XQ+Z-r0=}4nO=EDz$q%}+&tGqr&08sAjUNk%H zsSwxNRn{2QPCZJChcW>G0PP2wp0@fR%$P!ZTCZZ!UD1YSlp2#esFKN0qtdW#UNp#! zFmhSyDpyMNGQW1Gv8$l%vQ1g147$uX@#|eaqhwH*xGlhw+c3@@`$-p{ZoD`3dBp`M zKy$y+yKBpDo6zreO6pnEdgK9kmi9pMH^(2H|i3tkr;B zRAMgND0B7I_8wBe1+?(jF8mOl$!Az^(=*-lqV9=hfM~!23CgHqFJf=#Nv0#KCU0cu zqr}K%UFZa_n@)>NQZ5|)7tI+#ch?VT!O=wU04#}a(dw4Nr;AOQ%g&k^UiUOU&Z$on zWUIp=5^!Z1drCgA=S`@?F~8`)68ZIsR>D`qAN!<<4|2k$sKjg4r&=Gr*tF_>^Jkzkon?LqV z0%-Uy^_#xxW)M72R`qo!N;EOYk>0a-N6O5?VBWngB5W;03^_M-d*BMatpob^6txel zHlqZq%Y$ff;ebcbqpVbrbJe6gY6UX}v-lUlNy9@g6#U6rQ1ct6D|i|^Iv%vo0x1r0 z^qj(p14=L-RbW!&IJEW1>$PkTCk+4ia0Lige97>`H8KSGw7bc}k2!7~bE8s-bW29t zpAV8u_Ve6Wbm!l_Anj{I^lu_=c*+$@hWlqX=~QZvI;duYHw@HZOb-pYAkQRFPIwa; zoU)u(a`YBakvD8cl)S=)Vc_%$%(ObVTO@2Q{if&XHj${=^+32o-704}^+>l?E;7`N z9i1|ycS^Knzl8R~myi!^;b{#fNl%#_uQHlLQ*@y|+#?>PAX=rqQmQS-;(EO6uo2HC zi4^nxO3xGW+w_{MVmEjb(ci?I5v{+!p9tY<+UcT~ofTQnF(o=@0FYg+yukbU`z6jc zRSFT@B4IUE>yN1I?&4g_eBw4}O-c6e8e-8ciH7#8m+3g{}-6k?tU-pAKzulq)uriod=Zi~yoJM8%w*C>KLgat7A0~A*x(#eO90#9T{LPQv zY_!Tr!60w#(FKF$cLea-j@O;YDAijZW_KK3oub0!{qLKD4(9gDQM`Nt4Q(r6&sECy zo*|OkZgs%`6w+7Q&>d^ErksZli+ep*?$LKNKT*)DfazqdRgotg-3m3 zzFodimO5(v*8c#z9EF)bLYDy5X{7(o8OvsBjh$?3)86*&jvluivne}@ZQBvS-y$yZ zdC^&JEtHmymOjLwkVdhu$t)?7?wJS1JFQq}l5hwm)A>d&T*l@l+#=}27#f+%`&fgz z`W9`kzG}v+n$pY3AS%uXpn>VV57eA*u|O#Vaw-*!TnHvjOo;+{-LIr0PdafM-$gSz zh1YeFijlf}OX0)#($H7$4M;OyFVQ%Uvkmj~#=RRXAm>Cb^Lpd=`*XZi^JBK2P^=n< z?%Ub@FO-5HMigNzt@V(q_H8su7RRCXy!c$B$MG$TTRHQ;V8^VggX-zDh`7UG$;#nD>R!cOrci(#0O}E0b0vqAusqAE zCsJSf>x$8q1~Y1zt9BAXK;|j>eU*4ovEOzK4Z$Pfk(II=fE_=aXe%6H%ko`s*86WI z`L`8K6^)xX#>AO%lE@Y-7NkSuSyazY9pw54_6`sRE{K>L36lAcxaLgbNc%@u4q#Q| z^4v`bz0rJrL`w}OTbT% zm<@OLAYVJC6+TAI<9z{=*xXY6%ADITP>EI1f_OKa6Cx7|BRc3&8#5&VJhb62l8@@r zMiX{r8FtXRFQbt_H${uiWttb%U58n2;PNJ15Z674ptW(hV!k+53jG~5M-}aOtOO(B zkLiTd@$&<^vYf>gi!FsnHSQ=wcM3Zv@Ru~AX2WjhB>g*fd7A*)BEEkhMfrH#-@?RV z*FeCo=TzL`n)L@{!E71&7O3Jdi&{6P^8T}d^3(7nAbLS^V5cz0l0!z zO)c3RwZ$Uc-$jex`~izTI{YXHIVk}j0+9W#zS4V$gnKX6lDPI z!OsmWRpCLJ{nkDMqkyfJ6`c;3pT8#Z;KBve1Z%qJ8IoUB7yHy6aqW@_#TGJsEha^^ z%9DHlNh{+C*8ea!3{K2M=?BOCVN`U!N6 z(A8Ufav78{a)-%4X!5z5C7*k3M}2NOi&RY{A3;J<$el)yN|uTq+D7qf>_T7&OGH`@Odm7S~_?-R3@U3xun#q9Y+hU_W^UB0i_L`=eHFBEo%R_8VExK9xD zYimIfX6>lfqI|Dw5@qBogFCaA(y?Uhd9O=htEG%oX+wO|^K6I3 z)YR>xzdKGF`?Qffzmo8Xs_p!^haaByUHIpOu$rJXkTwl!K(W7yS5?6v%qo|lL-n^OeutSv}iN~C(M1$f!p+NrQUC-P(&Bn6C z`KRE}L+mGio3QP!A6`e7veUyiE(ANEuTRENYO~lQm;EUL_iIS^@f3N>gY9k+v|tDdmUl$_DbJPNOl71e+2ps#^eW=SvWA}SbC|8<*@#~$ z?@xw3O^wV^Z*gT5Lw)AjgZ#}BGJn~fb?MLr+B3|t>XPdUD6PL0tKj^Dki^srvr@SO zK@L*=3Qi7Kfz4X|*kisIGfe`}c5eWFX>*t5anpOer5zm?@@M{5tBii8FK|(5vC@YF z@Ah*IQKs|d@9`FPyjO`u!;-UaQpzTFa(KNhwLh#2kO>(mC%z}k#2R40$v|>ttPZt0 zv;p#X&@?n}XXn@IS;d-mmW`~^dei;VZ=-%0u1wU~$QU%P%ebb+cp?L7wZep6} zc*X>&0w(>vMpdS3evrv2s!9qeG0R|pjM(7ZT|P|W69e4G9~`p3AOcpdiRDIgb;VsM2*g1KiRlPvwZ0vzh>; z?N2%%cVMIf_!ynVmXY&|tzGe|JVR8y&_Xg5_|g3LO>nZ&()LF=ZsVd#OBfb5KA32K zHmbEzlp#q7zJ4MapVW`>WDl>A;w-PwnYw!gdRH7FLdh zuVaid64m5zI^YluG?@f3j{}UKQU8T^9F{o$gxXO3aH+$P+tDbh&_nsU;Dm~kaEl~hFhsP`0wARe@P!~msX zqKPzI@kyTnz)YND7)QiERA{faXHNSw?xX-$k$<<|4*Fux{0jb3B>E5osBS`(@lq_d zAd$LOkyTvHNzCag&FF^!~0(pdsD~M8}z+7>w)&(>MnlXUg%yFO}gwoRt-4XJ~&+Z*&Lf%ee-^+WlR)0`+ zxS>VQlTm`XcRK!_Wp<)84XuD6e^MlGYslKZ_W-mJ!AGf>5eVC z-t)3fd)ZE5a<%wo*F5({`-SdC%kJ51s!An@iatb778lPR2V|vdVBS{L7x7i`R_IIV zASZHcZsJBKkgZgo!jio3pn5xV0N{-k&X5D!A)$K3QS6kW4pSfB_c5m&-?&B_0F$ba zJUjbTOnrS1rdCn2v=&Z@9HBV;)A3Op_((ZJA9C_)+%-|LJ)QDuKmWb^!a$m`+hwpI zto6GU_P)#im4y>D?>^U_zJT#x;{sofhn^_&#-{bbgD=4iTn*@3z?U8>PyMLR%w|mC zuR^=3#c+9KQubnu!J6h5;h2YMF>nZ`d2OmeAQW4Ex+eFVn%VK$Slf#|1*nvq(6WwM zieap-RqD?FvN`>{hTZ~j;J`xoZH~ii>O)BEFiz_Kj=^l*k?wE6Iam1ym0k{S!@r2{@}l;IkBPisJFWW^zP$f~McSF4 zL)c8f85_haN8Qqby_Q+d;i-PejeOt{!Jn^j2eb$bJ=0V512Gr<5U(SM)~hj)`FJ@f zGY202+J)}6j8Y4HfMWf?jWzE{05fe3B0@I;WBz`Fc}VBd^7Kts0=xdCzp{*xwi z*;h=taMNN|c2A^C1;N{CHwyo_g8ohy2tEoD+b$IrRC9hc#RrcD>B?oKU{&WsdYrYV z6xTZ(jL34c!gxU~+tv^AlL!~DhAnQZDCmtXw#pL-=r<+a5YmPB=d6TvF-{8wMSg9K)apLg6`yv)*Usn)%_<1P%vK5Ia zFl5FP^rIcg-VDRdVJK=G51KgVz~b|KBu$3{?#Wn?hjx;)GLmv4e=U?!+j!|c$FGw8 z-4+djslycGE*f0!Swc-&KXqpB=j_hhm*$V-dWi`CyI@YR(xi!h8sMM;gVfYq+2_Vp zGB6L&-tOm~Rkj}?0NJ%5Qu0xrN545M^TL4FZ!z)hOI88%CFAeQSL1KQY=KYcdew$9 zr-RT)NncC~5}~--6LwQSa?S;b_rX4B04@J$=64I*V!Rhq-S44VLv*5%_>KnsPHmjO z`ZHn(KKhFN!5|-9L)@fa)nO!%=E3v@v_n_OeP$lgkFID~XaUtFF%&5SO#2zv zA=AMZew@shBT_!>bx#89NrPzHQ3*xGRsGRWj;2J@`)J(P=R z$PxrbtdjX>A!75Z77-xfmetoRf+Rn6Y)5-R_{dv6RmB7sq9B!C-)Tql&%-ilju&c| zc^sbH3>nLY|J#VN<+A1e`Xabd9k6Ef8V!H?Eaoab&U2!@`t>GeiEg|mwK$Xyn~>y3 z6vy)N4`hf>9^oyWi{?LVgz~V@nw9tMLDZ<@>Ul|nH>foPr{daUm{h+h$;D^>L_n7C zM+6Dk0G9u67YeWNV=}v3(@&pdT>gG8R@m1s6%W1xrC{Zy#w+^1(Y72Oj8YOvW&AWc zjR&CbeJyiD+Fvut_oPr0vf2XZbo4sU|1$7=ftd!hlxz2Qw;=1u(3CjhCcgQAag_wL zzGeSK`AL{gyzDDiU(#|9kp~(JCI56fMg86%<4}-Jep#~(>9^ww?XUT{ewmgS)5hM>(Uz`OwZwjdN%_--^Rt+z(%Z=*l_?HONlte&bG710v@~k`^~Zd>>+x zk@>hDz9;n=8h&_uT6RXrvt)Lqso$TMwmfC|Ug!yhC;uAfA7$$BgsS*eP4#Pn2k?Gd zTz;5bxfy$%14#`>?gShCX@qR$k-m?P3f)%bgRws|E@(5LLl;X=%oJw@FaDNq<~k{2 zt8yU8=uETqiTywc=4AzA3oxT_eyH>h?9cC%AI>7{ zmPxDtxD5L*RRt`~wc8`YD&#pou3tu~XnCc^#}+OxA?r#*o4NiQ0`WQj#sp{mOnDD5 zH`b)qHflCV-l6%H?^;FbH6xFaq$A-uB#*JfH!dBS$WyLn(5UI{^L6X7=W`~75bIEGjXTLJ2cRUSmWHllnW}8Fh8bZ(dA|<|=D!KSi>iiBGwW&X6A%wk7@_{*QkO zKz@pS1H7vdTxBk~jOj4E>ks0lSk@tZQuKLCr~4;62qWsmL`urK9*E`A%0uNpZIi8T zFb#k1b|oR@M@MD~C;MCT_=5C3mGiQcObjy{p?ySsAv)Q@W=WNGA{Z}$>S`ib*IEGP z8zPpf3o-N|p-bsCPUtr_+H^jY>MLmp^A}BEL09An_j2-zE3T_vl*>*qUzPvfM=uT( zE7s2`_IUBEdDcWi;l0A5n4<*&S5;q+$DxRU7CRz`u&N$tp;F46WZ%w=wLik<%`xlX zYsd4-5&RJ$`W=*Pgz&A@HLx{o!}Tb_!kMuu)JYT8pZ`ItVD}PrM5k^;SXTrRE^)tm zx<&|281CZDNyg4!UAFvKjLMS^fgNm4wU&*Mn@Vq`2n#_so6ZM06dgZ|y=`{sZ_qIb zOo$`UM*n4+h`5mkZlv;HvlV!LBP>YxPn{(HAS30!}m=$ zq{!YcwF=geR=WcC>7Rm~T*MMH415~N<2EXo zMnTm!Gx{<=7JAx$!)>Zhpxu0hRo&N#&&esF9^r*oXbY2>2cPao6xfz6Ip zm1{3>&G_3N7wafMAL}7^KW)8Ew5-3Tye!m1PDy%q$l1|H!tY2pDiA@f^T(Q z*?t^yqibSTNMNmF6sS*P0rCS%UBlh@h-Js0H(%+QM1YUPWrgHD_Bqp01Mx5jX8%%T z{|*;J^++}VmNrEBj3_9mU?@4DghoXvY@?#07-9@s82*`+B^`+`7WKi zaW|zAD=vh<_w)lUlLgVGzo6sd%xUq!hQQ^ScYwyiLn9$AwP`*W!>;iVzbkz4H|z6k z7hu`3xT}-c!5!I$6L1W4y#HetXaOLETD}I_)xOxkBpR}Fe5rC{1 zCKJzGwkmpIj%I&v#t*Z^Gk3fJrrPg569V|!zT5aGeuEn?`%xt8Cqd(X`P$y>=vG%> zhBwRe7qhzv>cG+vuPx#Uy-NN2J2+xEnypQfCnq)AyBX)ia5-;^cxCgR9UU&u)d=H? z8C-B6)U%s1^;HAedxOQRkXS6IQBrZ`b$Cx3a{hE5f++zJ=kecRey;-F_yu7Q9@3chF}?A9yG-jddm)UMY{e}q)q124(#PawO`GABLA*z!r~5!@y3$s^xSlZtLzx>pXZ}_s z3=ljAs@z~6DO#=j4fK6QW@+HgS~!?*4~)2u`Q-!FJcffQ&On+X%*`+_GE)7UEn~B5 z)@H)jNQ#TC3xt|gmPRMm4d=fY?f3#x0iCdPc$e0({W{`D&)HNrSS7Kkw7X5K>fwPDzD_@|e)8`CgiPr7&T3diXES= z(OBMqjsfIIRknNeM6k@H4`^}@QEB($gJd7A5PsU{(FuRPxtGHjV59;QC2bMLKcjuO z9U!fPf%KaMTL{&*>76QfWlj%mlKB0~31T-vqi-lWo+i#=yvpo&JzVDV|CwnB@#z1< zmU39);e?w)_V#illrOv{sEi+5&r(F;|1!5;^{q`(*3hS79Q59bK$t~{7XeFaIc8=p z(T1s`3)R=q1>za=X@mU{#&?e}G$=xdweFdz??hQMFl9L479_*xK^^Khl9+OJ#fo!k zBu>$B#%{1bjyCALPw=n7;KF3PkPnT9WSAF7e->x`E4;Le6lQEX-lxbgGg|nBlw2je z%ZU}H3Xp~1{ptVTT|je4eb+j;@v!e#^pfz(knm5dKo;&+?cFJ^l7jL=?;ZhjU9;Ht zpk7{97F3uEONH%Fql)2Ne5zZtSKYh-G;EfdIJ08I)Oerx4j4~k%Y4nQG+XsFOQw*) z5I8n2SVC^UW#hMW-&fVb%y;$OO?+xtowTg5fEYERS8g%)9OioEdFZQtUytxRo5T}n%;QYoeSV4lx5~c+mZPe zOAPR!(fqh!>!@F^RhvY(Swb#$AcpD=es6tB8PS+Ym}tu{VYm|!ekZiSDLB3v<_%dB zP0M; zJ!3&+e^ASe#9O6xDZ&st>niOR(><|#4-;oa6_{(U-NyBqTJ%9uyIT~?nmOg1YJw5e zo6K(%KqwnS|9#$HY=%#B?1p5masmX3KLn$*2Mq?@bA<6Mh;KiJ;X;{cuN}n!{j= zUr|3l&7(t9&IpG)0W!tYa3wv$^Ld#%WDMNTR9QsuW#_7t+eJIpv#r>li`~m^lPSUN zRTe}|$Rax=sR)G1e(zpNOm{-Rd+HB(R#Cllkl61v8t;}QT=?>YKV9~z!LwMmGteAO z@ND5l9|8jjwf%3Zpqb|2RC9`b245Obs znM=&}V8+6*TkDX85j0bBku)W1@=DCTQfcT*@8ZK#JKIG}F8k<0 zuGso#$m3Raf`SNnsG0UYM8cRfEh@ZP6xi%ZTmHgYG`W+Zk6fZc=APfbo2`YGcEb9d zuVof)*E?~-ciffO#GpWBcf!^tz`v2nYt)k-Yny}>FZygs#CIS?>dddln}m0&+DjIvn8_wHFGrOXvx1xYQCHXG6N7v6G`|pSD{RR1-cc=ALGeYs6era zX{;n>A^bgS`M2M%@2_NC(y%T*HK5<5VSn{%keUa|g0(If=li@vgcj;FKUsmWC9YnP zVBM&ERSktO4()ngciyy{@8Q>!XM*aIflRBMn}n69d{$PeFew)_5IKL9oM8Ntplrv^ z0<&#UodpKO#^^B!RrS=X%~9zGU)2jeKWUQ0*Yf0lY~)xVn&rYugQj#X(CsCBjhR2Q z>%dZ)37lQ`=J5oJ2jqauXT)#V!DXyS z21JYj^7Q`;N&zMvZT)?LW}92w`YpA`@KL?#hQXOmqQGcAqQ48C(r?1vPe(Z5amhwisGcKor07 zpf)k@^aR5)pgk2KFXjEy5FjJ#HmZZ|!Pz%^-dWDqNSy`sbD~~~6~4<)|BLf$XUn+y zMx%G_50BW!(0(i5iwA+=^|e#}MrhSo4$Ik8VFg-oT}h2Dj+J&?-`0qG65ukBj$}5w z{}O_yF*yq{|KXtOb@hs9rAYTYFSgiD$N*tN&deM9IpeEt(jTbnLT6w`4}WC@tH1ye zjE0FFbp$8-SrDTQcII{zCTcl|{fXTQ=Bf zfThK_jJ$dorpqo&z4IA8|Hs*u`XS6i(p`T^3)z~)XS|KUS4URfkbZ(JwuoOL`O|n2 ziIE@d?jI#TYW5AG8uHsOdY$VDx`ka03i8I&y9HKI7;HrUX4#;x&&Tjt+*YwD3)YxV zx9k1|)s1UaM<$PHV#n|Ku_%cW)D zyEn+J`L>_L^&=9=?jtKU$1*+hdVxIHfkPk^9h~K=yqsu>kY5?7`mfI4APE98xnTE4YCLfFN(j z)(N*4W>q6^J={B|uu$mI$5I(#W9UhD%#qZXF}kpk<(k zp9+zu!(Jj$stKpp+)CC3g&wQzr^4Kxr~eDV%?eF|3z?$B_>*3uM6vI|xsn2HIctCO z22(NvVw~z9-=)d=(o^$cw)^g#_*wN*)5wjdJmmo2o39r;65|kc)rBSgDhg;T5iEMI zK%O<~1S1 zxvT0%=#Z!$!)<`+nZ)BK0kWQq<5bb$7vu#!6xSy*QsAaC(h$34HzpOPuLqK8 z*&0DliRLb6eD6&mq_>v(;E_fI#DR32n@i$iTx`WnOP_0sNE4P87>8uZHAm0`@vU{1iJijbH&LHfTN8+6}gK! zIgUHg?rQdTSaYL8cx|;CTCk@>`LCdelS&{vT~@?Z{A?^n?X<2PW8FPkc-^g#_V3^2 zg4ePy)$2hTwy?O21nULE?B0X_7d#6Q9OYlW36dCW(0|aGn{m1X^IN7+_@Y)zyKP}g zShYo6y%_sKr2_U&(ImWmz7@WIVnyh^lOA9e|AJViNjj`hf({he(A9fP6#-TTnC$(ILggaQz5sa&LqE_ zbc71anQ3|M+vs$B1#bi(O@}^H66Dv%q;pf#>vUqrtpEii+hB|*@JmJdQ|n_3j?keq z3Q4dd%EUmHoM?lkt9_@Us(!%+OoiW=^A3q&yxy_lp=NT=v8FPh3t4Ait$cV5EeB8j z@{`kuf~8xTrELT6$dojnl(_&ftL0doD*I zx^6J&{W#6hcZ4|MQH^dRZ&XKw;JDgN!98N2mLJzNyjf4x#_V(`cs~1ErBgVyc@OE7 z%cr?L#lh^vjdoAzapHM;JNj>C<5TpF`cO6Y|5Rlkds;O7!1IZr7D3j}CNEpd;lU|u zOXM%smBCbrw<~#84v_P2vbK>UePFfEzwDIDcaw9$jbAM@-RH^g#tEwpe@iXCg|{Tj zB%)(LY$8G^=VQVkKwv{c;z5Xhi*3wRuOX+qLv*gF)ssfYsl8v5JNX>8xbu~=+hx+P z6*WW@LX>_AG_}1V;4qn{5-e~J?B?5Fj46vBEHR=uYe$aM&Z?^CrJs1XO_N#ZfRkOm z*Bh!5Pfc;i941lsJYm9v$K*csTVH@V09bo#_vqo!0y*5mau>2Z;%fHElZk}_b~3R% zVS8o@OaR;*aN^A-hciiYu-0o~4_ePU_`VwSm^YeUsCi|Nl%jl7)a3B~$OOFE1$9VNU3Uf77WI> z^n1RJCpXpKuf=N%^E|$u2#s4`HH;gdb@fX6?TDkr+V5Z#8?B1`v&Tj1p*u5KE)#3H zh1xVejiX&%`_Jo;WozJ{3|0#3XD$h*albqo^klz;&H5eWm3`vC=M$)lAFhZ)ySxd$ z%EJ}+DZpC#``M~Bdd@R9v0g1;L9U-u&a%FCez+JVgeW?+a&oMU$TvJ0YVuILg6gox z_F9#l>33eKNuD|A^ZDkR39BVOM4HYmy`uzQDO3#8Lu|hVx8qF#eNr@*lTs46;SB`a z*e32JUS8Bx=#B+k-Xzx>Ec$PCBJ`LGv?qSzFD$$Y<6?n-_2~4AJv&(!0RU)%cCY8 zurZlA&+2Mjv73N)&1+^-ev#!c)R^edqUc5lVbBszeiD%WbiiB9cDI8xpVx7AQ^b|{ zm}|3}^l3g*Q=HHQ7gF8jznU^aUVd<7+Rj^o|3qgFCB90>B|1PuH5*^xLoLCq=YbMG z+Y)f#X@w|+EVn#{E+zU=9JXI4qv$V_XoM~$hxIPkv$=zS+C!23v>U>D7=6W65-&rm z7g2J(HANW!t9^*b^%^Aa%ZNg<%XNy|IT++c)u%=1amwZsiJwDVg324Zy}ZbEG8^31 zPt7{-mhy&A%8M-Njb5k(nUC(;Dc&ae4LJ%x}!zp?tZX0 z?b4irh3Z??M9rYS9tQHM3MkiXRV`Rtmg;Y~d2EdaQ?s0LN4-l1WR3XNv-NJo{(^oR zpWMe+(C&Az_~UZ5`MiWn4UVt~v+54%krbGt+bu0=L@iP%cq~kRzSHl~{v!Y1E%8*@ zeK%kK^5lYaYS=Q)4ykl7fo`fSd*3jp#zHv1 z$#@3=V!7UR9AdG>!F!k`ka-opTKT%QU)XcfT!Li*-s&F){-6P>OK_0YWL$ibXA<=M z!tfs1AT%*%a-Q%R=|>xcLH*seLumASJRwq|p#8q~_#~eyxo*7zHGVs(Uil=Y>!NI6 zb!P<@f;pFkwBjKK*o6kSz_O^1Ta-~lv?%-*KbD+~K{8;eGha|*YKrA7I2Daeya_Z5F+8-*$wZC$O%Pwy?{KByN`u2$ zT^K2tk-vbrmo{Ko!qOemV6=DE;4ZW8qDKQ_6kQT_a>?e+%@B>HMQ@Rx z@>_nvVsj?_HU0I(`cQpEX! z69=6fI0*hi0^9FztZ?o7k;?_wO#L0#ql<^Iijd~}l(zA0H#|3Y&Bar-_Oi{JE~Vdc zM}aMV6Czh7WG%p(qKbJjwA{|Z&U43{*F8q!rjA+N{Uvj<75LtRAi)twzK$?ujB4wr z`|J?%mODWZx>6%<0tK=PvDwle|C!*2Qo_0iC&BVy*gd0dl$Mtt2_uo6>g0vS(__2 zqwSa#kFsC(JZ-fEbj-=_Cpj9gog_XP|1(K^M(TiOw=aMMxnkj+{a8r6yVp)W^@2;f zz1MxvG6{*7vr(+|4?9vKlZbNkPi~IKjx_-CJ<}IU8`|O*W`C(LNj4I7H<_EG>{k!k$}u^6QP7qCNa~; zV_#kog4ODy$&-87Ny$j8vT((;>m*4#}Sb*rs_2w@m>#O=&8}I2iciu(dCL`Xn;sdu z5A!R6s|cdnST{AH5Qi|>F62?Qs)`xJI zduEfEzrod-2h<^7SoEi-HWNrB#CT6zF?wKZQ^u&fW==bQh^$8DtXAuep8gf3G z*fC`(?=S~h+`{G{!^0@__4_=&7ltvX#C8dRd6*6RsC$U@N?EI;|eL*_2s*sm%6qQ*6!5tn*ezz56nk`E2tH} z7$N;rU-PzgKhp9JrBl)*<8eXNhGB$vGN@1pR>Z>Dxux_Jwd^n zxeeLui~f?@LWm|^vYB$3Vf)z_hce%o5-1cRu%Hq7iCd+|=Il$V$IwM?z)%*I-i#Bv zd{%+p5;Nfh@pE2~3UsD{F{S<~cOc7hXw4ra+m~J{CL#OcST=GZBz8fn=TOJ!juyBz zm1Ihqh%i)!=r^^7-es5FFlf7Dj5hx;Xj=5PJxqBm*u1VZr1|X5Xe~4!hLsda^`TC( z!miG+y=V*`VAG`yYcw9XFuQa&Tdp#wIfzuNj|ZyL?Xg-I_>0O}fWAxJZSv(fMF4dv z(|Yk<>uxLkpZC=AR-hq+MKf$VkeP)3EC4?x2dIg2xD%bw8uja40eNY5b7vD@ZPVR9 zWtEVKfDS`81h3KCCisz4G^97!rR!RyH@VO8SN7$SJ(08NX*UKfH)UNN1YmLoOIjaU zesgpenNSNLy&IWe#HO40#haz%cvv$|3a?**9?zYY9pDq0$dfd*2`V}|>OPMNr=Zmj zmTYt$V7trSe%$|S8NSKm@uNv&jka;VNEQTwnkenyq0`q~o6SpySJkzs!8ZmpLiKx% zl{tXrxrvS>3Fjk&dAFaIs{&QI((p_FF8`YZjQ_u3V29}B*fF}U1bbnf^_iWLl#z9T zZ?~z=Atl5hQo?_9;{W6(`C(cI=*_(jHAgq!Sw6`xb&#nvktLnTP{=Jg46Su)^TwS9>)1FAKSc@EcwaCHMlDAQOIh_T zoY{r`Y>#4P-r=CaQ3#0FJ>mS+WuQjMx9?HGdkJ4QOsYG086q>;75&D+(@*b;Neo5X zH*dm}E^ybMni$1 zAd(lv5Gc=ltXCe6y*KY%yQF2n1gB_;Me=o1Irsi*%aMA#1w6z{bq!HU(cNPH7ZP;n z0B`~z?D1(KTD*&Lh{z7urDX|#;UTW|#5>Y3=kc=4i+Wx7N8rgIqDPs(9+9}r1gk?y z2MaQx3M$TRhxqL62HRoYu*abX+YyB@(8wc1?-s@eS!*+(tlUFy5tCK0b<4k!sH29< z6yptaE`ODP0dR(bEUT zmBE`U#q7|rI?WI2Ss{V7>^4%~tE^A|Dj-;{T#vH$2eiX}sqH4es_xB7pF{QbbNCnx#{y5Mf{IU=37Ehf8fGfkrx zms4a=;F5q-VsKy52M$^}i9F7?bctM%eEKHs6q66CTtP?tF6JG~A#kN7Tn?!$w^_b6 z0EEaJl!T%uoCVZ+jse-cQ<&81Uh%3Z$hi^P6;DM^*qP_G9f#w$wWo*Rwj6_ztgX+( zYeoCfk4e$+hUpq?kwdukpePgS*%+U3!5w{Ang$49GKDg}>Vft9C*4Cf5=;cz%20fO zOU=zRNd^BKI$_SAgLNPFJDSR#w_Z70I(Pc{z$wY4nxfFqucC9|mFf zm==9;6<#;l?YUvC*23bzk0p8D1Chs8A}9o0j{T{}?9d!9(V9;CVsDtTt!oll%!gS9 ziq8iVJ452A7s0=5Zc`N5DMcJLh+CARN=Ig0RdyG@kbY86H{W;~Pv?Insb$rXfNGC* z#?|g8Q&1F+gnEBwcDc+$dWaEUh@v4Wu)I!~zWM}i6LyiGCnl4R|L|=t{&)}X>DdiR zXH!nB-SyWH>3Lp@%tVuk~aj_jP2`fx3fh6Qh8l+IWn1Sr~b`GeDFMNE@(6F>6 zdAli4xLgeR7uyNlgeu`4BG>vs#uZ(-uqUGPpXw?to94# zS!!095fN7}`Si1;+8i^$TC$|=LSjvgpXg)BdfO9Yi8B#Km^e^w#DlNU%6~uHvCnqD zPOlv(m-YPhw-Epy%sMMjHOi|Me|U1Q3?K|8NW}M96mDr8Lw}H%^5wS1XoDU$SUEYj zJ@}0!uM-!&Ed1tAe~d?N)=s3FbJ(6ikV!oCj_33fpsH82eUQyEW*GSd1DFk2$E z;jE76A6NxpPe-raDE*Q^WWmK%D1%*|1WzR5t|Q5$`j^P_+1)`;$(`r)f#A3W zpHGaDbz5yguY1{%|J$3CD@Xi$vBooci8d9U?z-Z;xaX4SOF>XGvD#*krzLl(amt&6 ztsowL7Za56YRJv3sXpRkr-V6|J=ZP1;QnDU5gK~89+`X_nk?olxJBdVB=qr+Ch%6Z|ywKE;b=ZdN; zry@r27G;Ln(cAc}?mGHoRwVR}HG8kZ%AY<(4#fkMevYKIXD6PcZDnDUl=cLp-b{zQ z^v_!I)yTL^$*gZEj8lyFl`CrIl>gZ2>aZkkk2alju1w{J_C!bYMf_L~&G#2nk?^iA z7m4x*K_Ecm;Mr9m zdp5<^R2y8*09dAl@C!a7bapEg!Qd(Jm}%&j2RJsbYq4?uQonmwo(6kVNrQHD)0ZK= zhqhV##!JB=>n>jeO%@98Wh3fhouQp9HMY;&gvF?lW3Y@(<21%+D&mt(AELQ2K{NY z>K<1VunOzYP+!^hEEfWb;1qP{v-?+Qtd>LmSj=Fw>kClsS4vVXqc@zakj;XOw|XiC z)F}r9(5-s&R7!0KLeC23#oAA>Us7di{3obG85(7JO5Y_@i=&1w;N(zsdge3GTK?K> z-{*!|`CuY~@#0Z}T^pOb3@t%z?a(gR$Ctm#_)7YvhtEdU3ow><28WXVMMXFWb+Xjt z3_NwSiYtm8+6y7B5YhoNc1*l`NoI?{T@;bW8(t6QbJmRkylff}Uq4Q?=j!Z|KYq{T z=M+`}vm{il%QA1HSWP3LT`zs1Bvg-G@2rBKrR|>9MfIJ9lzu;@xd0+(M3)`rBfCeL z1^;MF4d)-&{WGsZT9Ohbw&lIMUQ;FXQ^{>DWc0Y0_mn<7|4B{5r6?e^Gx=FrL(wQ> z!5a{>pt{@m&9oRnIZqe7O%>e!e#DnwoOMVf%U(U4mMxw{8P)6k6M;f zw8h_P_olv{Jh%OD8>X;4qY0c`^qoFjr!YNYco<|2G8i$9{Fx`&&6jO@hK;yA2?ek} z#)*_~4_!dnXS3gSi(GWX*lzkc5LlVQX1DyA`b-HC2IM3Lq2o^X47+#U9>k}i2Jisk zFbR3$5uV4T*6Jd9cL`wPp*rTJ(s~*PgT+UvYpg8=mZAbq4<6lh*s4*Uol` z8x>fjS$n zsxAPUK8GHhO-Nn8lNHftF+XtBkcW0vus@9Kf7Z+WK=cL}MJPoFMZEnp1=?X!>!YF) zPJETt0wqeg#UBfsTNEq7=3X3^WjP_1+!RE7zL!0>LKSw{~`dwy;Ek(`7V}8zGauuqvqXZip^#jWneVZGg zFsvENO;h)}Drm z%4~`Ce$P_sNhV2WwlYZG>*4bxJb4|aau>xV{P9F#xWaamQxv39ikrdXu_e(YK&oTk z+jHT!KvajH)s7}vtt?mj^dQb8Y|pxWrvJFvuI{o2C%@*1X|)pE+arb4eUO&Q??B?| zPpem|NJ-;1*sG8cnpBc4LMFKttd$z)_6g}OXQLjCrfNOtyXJlW zgb=P&G=?qdBgqS1PT-V(!G)rb8ZIS-4(Ttyud(fmAn|h+0e1{AN~XJ5J7&5oc(Emo z+eM8HhSCzTY`#$IcK6ES(;|%YzB~IL*PpaHPR&(;iv&D3gH$0DMqZplZ;R=a5@Z6)zc}Qtu z(lH~>v~RW7-c5m_pqF;cWIQf*_TIIZzXCRP#Se>Dz8d+Z%j8zHFFEDUb2lD;lVVcz z2JeH|%`LS^CI3YT_Q~&2?+f=NN0?k#Wy7r3iZ7Mn7iQZHJuzD2 zH}$~<&^&FfK=3f7p7|xCif`a`BaWf2Zsv>pGCXOVQ6={1F(Bp*QIyPmSKk?6?r9Bd zZRs?m>}UY8odO_{iX5-+ykaD!Ny&NXQKBhSHcP(-f^y9+;*RtVaiADWAk!~-y{oR-h5K37)b@K$pbLrT9TlSw zBLM276+Y^qkMmUm!-M{=FyQ_IKXIV8++nm_kbY9h;i63AQ1h1i#4&dGJMy^aC_`l#!D#?pMtWftkiiV)QSE= z+vqNsj)84%l48D~LKzET?nw31Ap1Xqhh#=NbTGtR5dNjEiTk(USt#XZ@VL@NeS8~lWmnACGy;vy0DxLp zd9ya;f}HM*7?_~QmQU+y@bZs~>B|c`A5TC8w5MwS+Bv{tidlZa5mr=%yPty_2WVHm z!9@*os+F&Mw175|`BY$WLioVKk9xjCb)n_l1lEU-*yi<=YT3daYg6TnkMo8HbiX7E z_^cD)`w-Y2Vu5kT|Cq}heCcYzIgDHz0uzA&mVdZ=G~tc1uD+wxP6g=1dd?WNo!OsV zXM*Y|8LNA_GJ3nG@hF*gMQ__m%q6`QkvTlBH$^=2WjJ!7>YwIDsqCJsx{W?bil#%! zQ{7M}c;i(?~FI>n5g-)m0O_HzR@rcOXNOZxY-* zf>FxSin+(WhpH(K0ETDl)FRKgEtHIg#g+>jT-e!uvy23qdr|uRMh6*gUYk zV}IVkFEUo2g1R#vKlhk@LCvHw>37?sNVO>GZMpu0yl4xdT&{Sz2rUlE+8sl+%OeLj z!G*OVLwEpiqnOgF)Zh>>i@?#yrWoc@04c81b9AhoP5@tl*uk2Dbya6Mh;WqI3 zVJ7$`bH_rtE;L+;JNL+fr)KI+{|ePrNI;UHoc1#<-$uUbInUdjcwGrs@Veo+&xJIZYPEyO**IX7XL25Vg0vHp;l{v)w=M&K*KAW zDOp`56AWaq_A==@dt7d#4kZ8QQ}L34)dT)h@^Pp%88-9)kdDaQuY^!-2gCqSc5ltC z37hAt2I+|Fw&%7lG!c+j&xXJEOx6byPxt@K0I-jp$)qOJ zu1EMh5L;)uxd`C?3;-Y<&{k#DY@SbGTm{=r|EHp!Bu80xs^cC(KMP zIzR>Bodze}n_8|pL7P;qi*gLx;+y(U3)$oD?X3*%fGe>TI|8iF2K6NBuj*REmTe;j zjFGGEFj-C;eqaF?3 z+#_!Iuiwx@Gut611SDVR_CAAKq|i~=|1qpxY*vq@pkWESODvLtTQ;{3nH;0Qw(F8J zNx-gsqC#7IC^Ss=5^iSgD0yAoc6V+-i$VTB=yd3gs+&70_ho#TlKYntnWuHz>U;?z zZVFnDGk~Ik^t7MB*4+LNf&7~0^xZjw-bw}2d=`Raw9crtEaqMnNLLlVk#fiHYCXS5 zC)Si`fVL*{7Q1QTD?bE9Xt`mgXxqL8`beDko#3%QR+<5SAxpOya%n>(doRLc^q z^3efBgQPl!;Q!Mhr%l%*EGEP@@uY-7)`{dcd^f2oC@!12E!Mexj7e=~a%I6B=(qbP zTV~qqO1puq4OZ$jV1wf`2{=^mBfylWDa8sGh}7PogH5cDJz&)qYNyGfFZNaeSshmf zM&E<)7e2#hzmbTUREgWpAhKYZVx{!W+wkl2I7)gU`LJM)uQ@hNFK0P!Z^SumD@F2zrV1?9?z6Fw( zRo_$uNQb*2d_X7c;5#7N0ZEPdjX045I`#LY#UlML&zVKTpmK6B{T+GUZGe%$Fk?)46`Z;@ z%Fqt{k@0{GKZyK^)KtT@n$91IcyxQzneJIcp?Y2o*+{@G1A8~rOvllxR5?*5_e8q& zY|Ep__uIEs0&@_xbnO84AZ=+&&8715GEL~Op@=haXyv%l)xPey?^6ryX=vW#Mhbd= zl$nITThChDB>6PLo0IRcA|+D#iEnB1%8!p`d}Vw66qyAlC;SVJ%G4V*A5^;lT>{<> zPJpcKf+`NmksJ@c25bBrT4L55F~AlySeYNg?~dZztJXitUWU&}LVfO$Sb&KR@)#Fv zLCZnvzLWzKT>ze7Du!K(QmRMfK)gW=AR+>S2cWq$x#l6~{<^YrUw_Zm{(F`^qxBgU z4<;T>NMtllIyKn|N;VDTdg3Q5P)#XX7bdX4F0SUsVyrS6dUNYSR_CuG)NPpOQFY5?5 z9oY8u>yX64b2rCxTJUvUa4lDCzKbIc;J^7n|UMEMz@oOrE{s$Nln zhDY@+8Brhn7@IQiH*2$2W#tQ8G=5DgUuzMW(4d!oXDK%hmx8%L?}nJDx7JlfKe~3e z=cW`r6ZT)Vt6E4gEF!tP!0u@^);8`rx-Zll7imy1)da05TW&hv?(?f;ga47y+omF= zT@y6_!0d58$}Xk@4Opk^D9wjLI$A(IN{UUv{leh=aVne(#&rtJm$)9F9vbnMORt?i zF8|kf?U0V7zYusXk9Ma*j= zbSLN?9yk$l;mj8Sea-{MFA2HtP3~$2f6am}$l5Q;rAXj7F=sI(ihL#f5hKH?x@5k@ zH(}exXv@>f{@qNf>qnUSw8>U|f3Y^_Px~Oo_k2 z#4!J|$@1%z+O5t}v-^#Ompos!s}6{ht+tbvFNnF%tvjcnP6l6${FpFPABOr_^mtBa z4fhaW5HxJlJMd5oczOj*X(BoOOpnkJ4NBgQ<~6)Y{E|-^4K2sMF4-Ir59;t(R|olh z7s=LuyAZ5wLuUG^UB)D)XFi-=Vn+Elpm7*z4p=ERx#op-gY1R4No^%N`%UXeDcWg| ziExzq6ev|<=|1YO60yxflp#C4WHd5CNC@%?e`5z}*}&4p259f0;vjMkQ2HZBQ&%v17`oI7d&%0L6O z^5zFYfdTbu_B|+hMwz8vWoXj#juXgu{~a3HUr8+bzjTw2w9+2;y3N{ZX-4ozbo|ap z$UQumTMuu*(~mLhx#z{-aH`_Znw+E=vJt z_mm}l5%%>_tJ>=T9-yP4XLx*_mbc5(&Er7odl$B7Dh#H)D#gYIDLm?nrWAG_@P8(n zRJqSvZtyzz;C;-c8D#M-q!ncGtqARrZcV!2Lbrfk1g~ZJMkicEvmcoShbDaf*k!@6 z0DHf-7aHQyY53+7w^|xsxpgMQ931r>4IT|2{XWj@9ze%~H$IVeDYH6@nC$QABZ;!| z^uc7>^km4i_m%_EXM2oLnM(-M&O=to$J@Yxqq?8P3 zU}u+r5vRbWi-PRKNP@A)M*j-~?rOe3=LFlB;-%kymzb$Obji`(Eh~@L5`9`Fo37NE zVGT}?Wind2%8iRU$AXeWQ%BK6nt0HvA<6k21WAKA!hz^0*1IF*uT+D^!eQUy&^bKr znMdy9<->waHvqX;dasw<$E3qVC&s2bMEnjBkrM$2v9j=n6*Mzy^uV4ldZR}Z4t0G! z0KtMjQV)j+4_!gRcfispJ}XQRJij*0b3cmyTwVcqqI?lEo%v$f`H0S_pgs6Y1r+PN zOS8CaYVd(v|kZG%VJun9pGKDXGLI|bw z_oPqta<+J`Aw=2u)u`_7ZW6P`TdQX(GZ5xnvSeEB7g{-9d5-j`owkXpOS7AFQ4_IL zN+9xr6s!35o%eL}#lxc$ANv3BZK`Ecyrn0I1<%5xUqD8dt#Y;2;GhYuEdOwiBXqp+ zrrnRHzZ#@D(sEDD3wpX5dXQXsxk#CS-TIGk?Fz>c=z{CvxkFzbSJ-K3O21&1>xf4xc1Y32#WeEw{ zoZv!noPJA%`MN((;|e>T7BucFc_0tQyhiJ5G-^;YP>wJ7Y7Tjb(!Cv88qbB%nxIlA zLag3fYZBI$WvkQpkmZvjt*)8>aVJabn*f+Y5X0?iVteFNEPTODd(XDga9`ZO$%^XLf=uqwCVWB@?qhfy4uDZm5gig$ZjDwj$a0e1#OpeFtI4ul0vk!l9~)aLqT!+RetgL?fmIwiUoM}=Az zuyZ6K+z||S!Hr%*4{l4O^<`Z&3g4$4;s^-4Y$pjUct2A}F-`T+Dky_xp~o63<4Qk) zP4KBUXF$jj2;|gGQYoE4C?6F-r74Q#v$}vOtzQ3N27FE%ERELl@S(g)&9#VWBbiziLF!~qJcHjhKY;zVnkSEWFKB0;Np*{^4 z$=eJav5*$1tc-8z{f&gJ>F&tc*N$URaG~opXf&%K)L~}7sKHQL1S3B7{o0f<4&Al# z39~;r0|zx`2k~?DrifJ!r4oU%=Cp7h%V9k(RqR+ zOmgCYvIu$-!3Xv?q4z%%*UI&o2){yhp1` z$hvk*PW_EQ)uE$CrL($SJZ^0SKHt@(HbdLy6N$P3aOpO~ zKM(P--!sN?9}jT(h)5uZwE=Z#F~*c(>hPi+xZtS>;fPMd*s&b<^9<|y!+-$}%;VnA z_~S>X=CY3AvV4`*WgRWLvI1~D%($~d`R^aXL88I0QHR}n%g_C=&@V)4%tRc3Pt~%v z#Wp(I=3OGmaLw%=)XvKbBm4QgZ;>?X<)@yRxeEnOFd zxaRJ>I9s>hD%HVV#CNS9G|%#bM)2_9w;I8u#lN|20yzX9fo;(DU*@_3i@&P_*dto= z{*U8CnGirW-RIM%a2EFdF`_ZW^g3w}snJPPxtd?{*YxM4_Ftft z^}*JEs41!1EqPdUtu3h?ogF% zJ#)B#!WVTCr+s?Z3QsLkNwU%H!uhrMCfP1-LlujJ$W+w{S*8+Y(uDiVr_tl(FCdm? z_BQTN5YoTurp%wvmwRAa*^B4ofJF~D3nuts(ACkh&3@wfc$VT%tHVLW`{PY(?!K)a z3cVDjTWvp*wbm+?r4$!=>QJ;^Ct}m4?p|+@@L(5OQ*~pnZ{B+?9y~eUD4E2^uNge& zjeHBZ^|-)**|*ZD@uroI7_NQmo_Uk;N}tBO&mo~8@PZEI~g1Ta2C}|d=kS&KQdabwTjRp7{n(F=2Ny}vhyV%ckv>&ZUW46_V4q4 z@L4kH%+V<0Z~4b?2J8PYuE^XfHhNA{@NT?gtk!C@e|VIkEB#hur}8X75&8?3uN53w z{~K*Fz(;1u_G-V8Tl%P3bG?=z7VThcNsztRu9zRd?fsP?9J(VCoSF;My@XCeQj0X- z*TGZ~d+FlhcjH5h=Y}}119PLcx?H;wc#n64@|x$kCwa)GhM8X+Al>`Z(qpg#SCfF} zbSx(b7DWY#eD-M$>dsR2CB3^1U!-ANo|?|tsHfbP^+H)X`!L2chrX0>E7FpvB^PwC zgkvHkPP*>$IXz?Ve@mWN>YZiJqg)4!A6+v{>h4bPRRg1k)yZ&6(F8&u8@a>0V%4Pc zkR^p4`F4QD`-#K!-CCpG-@qe=;a1*yc=gB8wgY4T8c;ak`<}8z!h+5y_iuklxv`!oisZzNcYz(>N}ZHA(xF{O5ezY_kCw<mI>=k8RJL(ObeR&2^UlGr*>OY|4q#o=@XfSd-Jd5;`@vAoZFud z=kuM?$6jX^lr&683-;n!VhQ2c;_3oeJY<1JQ-6LxrGu3_j|llcDdKXs^7mqQpK%n7 z9?g7;3d9^6#uR?;T0$-!PE1m;$Q3w>jYR{w;zU{%9pOiB<8t`bikWxdQ;rw~0tX2& zKa09K;6BSg26kS(=w~E)F*b!EF)|oXg0uun>L#vKUh@+=3LzoH4-;A0<}J%e2NNEy z&LF*5$MKacu$KQ9WnaNnXV+wjT-+sSa1ZY8?i$?P9fG?CclV%yAi>?;?c$K&?rw8= zzwVjU{q>qP^AnzW>QwEs_pUlrrP$R-i^z-6W;(m|)~^EuZ>K!aW4D;A)oZ2dVa{>` z$C+i#Wib@OYU2Od!ax{MOg!KfwD$=zjh}m@QnM5$(VdF~h zLrhsg*en7mXo><%m$o$KRdO|4kX3r&_w>}tUz}g5L{>Xw_Yl^r%L4?%Kn_&ijehdvu|cI?-Hy_dKG1R ztmen&2Rs>QvCwdRGuu(#T=Ugbn189#^!|f|{CM+u>$FhXHXnaLXxvk3H41PCLK+4%p<%iN2?Lb_&4IvGIrl^DM&i-3zI|I*^DLXQj z{il_K=7_dL0|PvHcwZ@tgrwxFs1}SCG4-j2-P4rTP`Or#b;(3jH_;YBAWh|8p3w_R}6(Bv8dXAv)=V{_hl|>Gpr4 zApf~bTED3^ea-K*ic5#XI%Bpx&jZk&bJf3^KkPl7HgM!M55CBcD`|P&o3v%-xfAfs z_WBN2ReatCs<qvCb{BLP|QO zWT#KbgK1Uh{Sc|@xS~R7>aDTK#(~=J6{o7CX_>qwv?RnbeQrXhD$S)|3)K%Ag^#Tp{nZp z`_Gx>_nZ%!(s`R1_M+4QLUi2gG28)rPDB0S9tEb_fB1BV8P?eNjjn_&0tk}cJ|z`? zZW6yFmHe3*Y~W`wuX<8wqE&^cR~h_woP5|nGlx4-ON)_(*}=&(qfZ}L!jdjcEa+Cf z$jB&isFWyPlbrxw(@d$Y2KmeH4aS zzFx!atyy?0PP68OGzo8AisBMBkeN2EbPq8tXRJc;%!bYXE6=OJUN=bD*;mpzlA!Od z(WFuaprVNb%;F8$OD&bR$)gxYGvKTr7vkrB#x$sSpgwm}qivay2BGV{YH59uMWIn1 zltf(x+5XD(BuBe~|K6co?iE~;{xj;?e_R|WpJ#cVfY8j<9rQx+V>ka-D2L8<;yJmD zzBswzd=osP+w|ajJ!p`e(3I)Fl5U`rAL0BX%^<`|akB>LuOEoyfc@xzS1OEuSFUBk zU!$_CjlFicX!A}qO3cc*%@@QV8oY*wC#@SAo)@yieXQ_l;xdU2b8X-jDiw&1{`6TfusfN5()gCMiy%>n z;xP_LNrxG=5k*#*n61$JX5G`Yuu|<>7kSEvnpK43E2@T=3?vd(GyACD!0XL5O--M)2->`j`b8D8x~niz^UMJE(lB zYR8Yl{a3xi_wj|4Z};h2jC>x01n!Q#&n|Di6O1wFZJZ`LoUpI%AK_g$rQ;+YJi`d9 z!Gn-xGj+~}ZFIV7D!06u>Onl#!Yfo)f2~tT@*tr-`b3mv;4e^eH0Nqk-cvdrw7Mosu@#F6BAJj5-u*QDPCs zHhbr;(>41?oeX+&i%|a7ORZ|7GDk6Sel$ICQ)CqQ_t!e=LQIHc@Q7upz4JY?i6b<^cz16rgP*;T3?kgH z?Mb#blGc`XwV3Kpvr?NRoJRhisIU(;Vz-C0BUsz>4q1=>%>OIc3k_3^|EW8HUY7sH zLiPPh|d8O>VIaozu9%ZMO&qJBp6Rx4&IgcAe9WwJr~>zRzblCnv3q zE|&;aKq}Hnujz*jyO$yi0R+P2c{UHn#K3P#a(c3|W8Vg@(ZoVSK{62HH$p*!I&rJ< zj4!;V|Ei!M`YxwG$V7`{uTq^SBMKd^SyY#znZCMcYiSoENXBt>|1c_-xnRuzvreje zvcR3NQ8C*nU;PbXmHakM6MFmWko59mAp|0=GA|Kt8jhycUa=kelfG7LCe7*(P?Ao} zhme9)`6+#+7Qz9WgtCW-Z3Wb?pFqf}PeWW>Kdw1{<3tJbzyalcjC6guG5cxswf>%>p##9^Mjn zOV1o5gm8k%^f#&A?V5rl#XABPW<6fVd6jB`V9EOv*8VA4OQojip39u4LHRm7RMv(R zjxRma3k$b)wF-bsi4U;Xmxu1KX$1R@K9PH);i4jI@M~GKf_u+ZvG=DBxWy!}-Gl&R z_v*2ZyLXns8Mi_Km8Pl=ad&Rt8q+c^IlM!|1>!f0DNHm77%aN$@h;Eup78lBXU9fb zzxH}qWntc$o*T?FFtqNxZ_!L})!wu|VVYPG=y?~rT)9|X{S_KUre*e(UhN-Ed{zRM zymWq=J2H=_9!<3y(BFE2Z)+AM8YeGnF&bxv z&!^!ywR{M9T;lYPOO+P#AlmbBiPW&O}^CLGcNgz68pKW;XFUm z1OhtR72#yFt5H)j$b)PcnH$uq)BroBV*{@X1bcEC80tH?U@3HJUV0-@%1HRKxP{9Pr{<~ z{0-10j$b=63(qtiPf8#TGUZgjlWKLEjB&eu0c|Ijfp=MRPr z^YR=MX0QbN5QZEcr9tiG5#BSw31K9PjwayB0`V+s^%SRlg3Ym5JV^VU2yi(HLdR-q z>15fy&0l~wRPYSvMcD*}x|5NDfda{7GN_}v49F*mX-?}w3uGJ)W(m>05+8$(u&_kje0zTW`Enr0 z&$T!N!+u=oz8+?2X-Iwwl;r0pYxa2Pn;k@k4wIiAUjoo;XYTDggp>@HIJ(}2d{bh3 zAsg)O+N8E58|tAl#aZ(Kt$0DU_(q>+hstNk2SF;qk4(sBR3|yiZj@(0%KT*b`IBzKVTRUi!Ue_l*!xKHv^(60Wlb+D^eU=Aqje94> za+fv?J9SKO(HG(WBwW(3np!-vsd?AdUNUcQ;PQYUz5jA4>Y=VQPlxumdueoLqe#b7 zm=CnDZ}4E5o+1j-;;-;~fiem$c^}Q+4AwH|HVfrbO((A~M2myG=YGT;)lnrAF-FGL z(7_V&o=;CtVY7FT^FY=Rr=N>V9L%B0NqZ`fG1p?S!IVtw!0rK6g!hXCUFr)sg4k|w zr;CfYkhV=Q2F#mT2{Knlh@iqjk{bWD!Jon}j9ge@03{OnsyZb$rZ3Yng2! zd?es2%7?-N0isC?lmGwdS6vp1fZ=C)uV4DE4*#4Z-pQ^fDZVDf0rvNSOxLtXW zbVH1N_r1+HUV1$!U3-Y(p7!D0lNri?*wlrdkZc-WK0xKV`<~$I!GbE` ziHgaMC9J&thlu%!)9#%ars0o?cjPHag!9LSjxvav49FDAy8v`bYmlV~XD7X^{i85o z508kW7L)8vxvkpReTJZ1%dOkS0d0c_$jFx?iVAZ3+hQ-ZsX9WW5_Ck2!w4Gp1pWpQ z{~XS_Z=)fQbiD4k;20{Pm0P4ObSoOT|C>i`7s$@;WIp+`;O)HG@y4Jk5yaA%gCj^^7!#<9;K2_ZFiSI(+E zfAR@ZOjzzS8A+oNNbpL$IK8_zXZf|Ie#!rk=^P~+oO z(<^J}lqGh}T!y{opXyULWQXMBCT2urhC;w|J7b{Yl=B^y0AA4Y9__(Aw}{=Te9i}J zkOH8{;R~Q|^oVW^rIH>AN~~b_S$yK+^6q7{<*J9={&70IwpI4v?F&6H@ZF9)g5^UW z`_K^og=LbWh-DP6ks((+V>Khzc2Lwy;5UX)sbjD(o=qFdbwo`-wk@Bd7- z;kC~XDvVgzV47gYSn?UPY7=}X|2evoQ@MiP5g;QwLg59(Z`#KvqdeUh(unCx%X)7`Zb z{deeM8ULx-{qG}9G4x}#n`8!|k>vGk`-4l?ap3P><1gJpWpmP_A7eOQq%JBw!Cwyh z^=3XiZt?8*6p8?OqASNV?D_P*#qJ}3=Z}_3vgi3p;FzUbIjaUw3$zVoUcy|*eq$)p zh12kub#Jk2MXie>{Qtxe8$WBZivLCAeu%OJG5+3nrnW6I)GmC3!`&d3qp2~^-ul<$ zK>s*Az5Mvhcr*LaB5=sy{oL;5vD)De<7_HDcYjDAip}CA2ISH4WpPkCaW@1Cr@c8M zWRbb9(lo1OGzS)k4;%@ri!1|b&2DJAW4AmOyc`9qi7cAdl@@fEg#1i%xl?C=Avk0o zWmz>4w(7?{H0Xk0FDlyk5}y=>jbeIIOn^AmZArMa#OVrvc#aG8wLszWw)8v+>V7Nw zgUtcaqkP!~Eio9QdL_3)qD}<}{c_^>Lm(-D zzN#Mdn9`Cj?-5TV;GZ6|3%U&gr>OEQqdQOb8kT343CvRoavK`!r(V})&rmR2kU*bo zWs)=2_|lM(l01mDr+#NSQ^AhMY1abym$b_UlA9ZKAE&5tj z$=a=d8*(CWTXS2pahtEu+j!@{m#vW?NGoS;T-&_P-haM2g|l-$_dVx!_}@v&cnZGE zPo3M}#;_ezyWY7Wen;(g&L-#YExC-Suz;W>ND}mynXUQ^+UmIMwv+D-6zl}w8mBVv zB{t^2pBHXVAfpizt_GAQ3?~`+4x5vkhEvEQMwr`q zad8!z)rKt*>pld_^2L1h_2rWiKqdohM_35*?uAR3e^dgCn{d-RuMXEXJa=Wp^W>;ls8zWh9v z^z%e8Ml@IBxOD+H^19Ylt1COxeeu+~4)Oph$`L=TgThD*`Zg+b5_H%wcoA|`SaRC| zx7Na|FrDyMc+l$r(5_nRalba6IZxgXT*3>g)!r=5pJ5!we!h!&y^aQ-C5Zp|Rhlao zKP9AgHh%jG>hiRxKgGPGA5yfk;SUgdUwZWh7&>-;RcoZvmdZ;yhM_`zF%OaYh;tA|Bq|(06bck=0D8+@1zAbz z!Y0!RFal7Cah%6OuO{gBcI^w?h~wROgPr;;FpA`-v3||QV5#Y*nW3a(#&(DNjsMbg z`y^jP%T{>Ggh1!Km%h3)ytIoK{z@$0S%#b77|qx|or*Ixf({~Z%fElv2|G5fxyG)b z!F`z)o1=;+ak>6VRMhER;oHJMB4rCOWYTXNiZT+ky{l0 z!(8cd(Ia`?hND6f`ZVZr>VEAq7|8OP07g#CGWc!TE3$kFZ1CpC8f5VA#C~?IM0RQI za6jA*aa}i~pcM*;!}t(gb$=-R_U0M@jH*RMun;HZl8t=V6eaB?HEvd}<6yz!XzXaU z6R6PMFDfws`)Y@vw9E$cmHs+GRTrU%Lg$O18gMAM4!NX>-lMF-ujRY%x15_(s-Ab$ zkEnx!B1S3((W4~%QAx!7l+8RYDQZogbl zSSW9Xi(J{`#}8w?HN7 zuqHDLIsEwM1*e4+mZc?e>L@N+I$$OnO2?1J_*Ocx43*mKQ~Wa1l$4_frXvx!9^E}N zaYBz4M}!5Mn9N@x00NJ>5?#dfB?Z(JgCTHBB#_J`upbH?|SThS(oPYcmv(w!Yc_(MF&xFQN}Mv z&u^a6UxzS(D2l`n3;#oLf-h0eG0;@^M$&ne58mL>8_4LhbR13R4THHS?nas2-Jdcz zPDoV2WTQC@INYZQETZxq@$vQQRN>sU)(QJk&#${Zg-e zol$~RjV_dlxugr64QH_31VuWD@7w*szI8mqo%!sO>A#(v`TKpx*Y|?KMH=fOBuEzQ zxm`t9*st~%c5YbR}GB=j6 zAHcLZ`<;-4o)^c0BRD$3xD$M>RuXQ$^~@_50h#>e0Se%JZKM@|Uc!ctjcf`I|M2i6 z3{w9)X1?Ei=C$>7we8IeGf55t{|EK;*3?`Z!%;!5r0O>R8Ns>D*yEgRRx&WR;$$ zf{R17#(w)4|9-XJ@yvA1cupM>SVS~rPaGO4sJElSDv*O35#pzhk|~9WwP<;|i==`4 z97EbOB@FoxX@xz|kFSbAC9k0G_SQcV7aB6;hl`GjkfII)b$l`wEV5OtBs$1*SDy?M zCR9F4$|VNVkm@$==5>%XYeZWn=DAKc@6Pbl>an~w)KT31^TVsgr+b_fdgjzK~~^N&aAwOkPQOI`W8hHW;*E9jR;9#6Oa z%7r-KtC3_7ef$W~lb5jM@sm8~1hTSQX0?@~aFUnQ ziLkNeLBGA4f~#-{+d_=vKGv*U2?I&cgh4hzGfbsv;x1N%fPUzeK~`weq8270eJJKy z=*}P8&4ydUeEGKEJh5UBJb98_W;kM(&q@;DW`a_&}m35TugYNWQ7%x;8Xyr~gd8{5M7 z(2N^Iq67#RE|_&r64d^pHI%Dz4Y`13tEXMjpiJiq0$(0gMn`O_JpPwA3TofzMD&0x z^KOiiZqKA@Y!kv(dMGm17QT85ofq`zXh%F)cGagimcPpKOs0=-P4x0qiBYrHLQ22Y zf3sf?_9Y^Cnd#;p&^z}Hia`+wPsSayznrz0{?-l03P5UT9FH776u-T)VZLvDwbb;5 zEWFw$W^3^5zFm4xzNWV;0cFXb9!P_?1OBV~$Frg4w}B?3FFE&j%gmwnzxELT{#ec~ zE|Nd?Qgl_;r`@cEDjyNhlNgt5*tFtPlH$OM@p1*;baC=4Au>pD^gCIay}kO@`?4Bf zNDCCDBz`d9fy0k7U5Mk@U@JZI(@r7lxC?L!q_V&brxAyE6DUa&pCI)?pmz*XJ~ri;^}w zZqeE8?49-W=5(PbG7@=sJk{K9LuGUYbupqa8esX^64Cp5?g99z%*3;)h~9U(JTF!) zo};~48G2sSvzc!vMkL1YG2v7hJop)CZeu)DSB@7e|8myBmv(3=Y2V-XUWI)IPU$fL z{)eN#lcr(weH5<|i4||C`RtipO-(I&k~TM&z%1R_&Qk0~coaTABLI^eIUW}Evq(c2 zjckD1uf8JBX*!;xgK)8ak!{#22IRdPpQS5V!^V||Xg&ryfVGF6v5f+pjE#9=p%vjM z{*$sgFueD>`_9sFyv9nzY^y%oxNhvqE8`mR_b2q<-mxHofBU36hWs$CtbRuJU9je7-_uycgZ|w|soi*d(M)Z-F}6 zDZ$`jz{s4j&gguB=5yRK5cG<}RC7NlN!t`xd2Ig{DnWWI3SYk>RBEe&88@n6k0Tdtr1UdqGw7Kb$vmr}qk0BcgB}Xn1 z(VtV1x1Za~mm+u2?HnR`cB-eIyk0B9M z{fZ+ZksqZ*G+wB3(V*dtCMN@RbDOttf!d{ac&K8tayeobu@r&PO(GQT6!(4mgUb}J z1L)P=*u0Z-BI^r{@*D7#1L@4`sW>F0n21?iMCcq6JyUep|HR2r{|6^SL47*vwL;4J zit96Y>dw2K^Y`861v_j-fq zU9l;69|nW^b&2&|3^zItUjr*osdejjIEr5=@5a*w%zY6s&i|G^@e5Xuzf1=R2W%qX zmX>l>zb{8ec7Qra!@U4xuD|QS;%T z$WZ~*^X-FOs^mDwdn2;QhlPJpad8JM{>0&&4vsxry46aJ4gbLfSF@KYo{@nbrlW=o zkbx5)7!;mp{Hdu!I%ycf%#3Ru_303oBRNgO=-v0;WQd&?w9r4A?PrWP+yRDML}bx; zkcT7<=@nT-3JdgSv+!(+h=bf@<$T213n0k~Y@;B$b1^*GvI{a1GrUDM2^>^kc-+?C zfa+=@i5S8@C{$}0I|wa}ikHMs(3f3|^hd^Qlw0`&v;2|k;9G^UAB zjU<6d$&8w^A;LbkHzgASeGe>9OWQdd!>?bA}&_cr^d?9$r|c^GP?Mqyzftg z*Y!tP(Z^He-sEbZ$PbKvpo;~Y53VH%X;5NnW+8@ZNrgy}K{5?{xHP8YJ-Kp#`J1xGHEsYobi5RkS2RAT4D|&sTA6Ph)Sk8f zrZXWhD+dT6q8!o9o$$7Xb@8Eo7i#GH%#=wa2?@m(9B++1H!jKo7$0Ypl%9}FUYL;3 z>a)%Ls-(-0;8`qR^XY3*emm5{DP)>EO6(^S%?j-}Kwe>74^W z!EW!AefzU>)i1UyByHXCn)dxg8q&z(ek$6`~*PIk4$}+h2B2SjvHib zes{iW6uyhYu7_uzoomtN*V}vLS`R7_2FrE6@gcv|V{t%`AcjPdQ*)1H4mv@OE-}y& zW-@^$4?)caEzdGc;%6|Q5;`n-pYfvm#l;`y#hew4WV^B*JHRM8af0DP#0;M*Gr4Z2 z*wziCBl4OHq_IGA_4aa9a*EV$xbgO15Yh-qSO;b%#2kKg<16YmZU8k7G6@GUO+X6v z_h9wXG#M->GLw<|rDd#wE0N?=sa30-R3o*pVKj2{=+E1exp@td?Pe+-kHVB1qUEt6 zaYUY29>$0c2rWG^l=3ye9UUP;D7x5K{BIit*AP1fG%4F%e1gt@jeLU+Yi5$&>2`xE z9qJfz-^@4v(xd3{IP`VmR{cJ&vOH=jZ}Zo~4Pez1^zK0w{f|ug4{q=ylZ~8mM+}t5>jRv7S#o?U}T8ziwaEEo=#q+dobY3`{qQqMY zLG)x)ng}{4C!3#BC7~={y5S-6OuYBj&qniWLqmrLP<%V3mwc#`5-O4TnZ zsm*-98uYU_)zt%#{-L!*tk%G<^>k4#dmA%%@QS=_vD{~1V5%8Ys!L0wj zbjx4C;rwvBbRM75)Q#VmS}*z~LnlGE0ll?y(uAGXgW%o7ds8qVC<8xVuA*(mY4IEj zUc%;-^W0V$IVXIYtAfU{79s^>bLh&&3wWyY&6)n=o6n8r%m~+Ms1b3YwY)d<26RBt+mA5 z0gJQeVN9Q`Y!D0(+Cqir^M%~nrAi_FVGFju^*mgAcA-)6xi~~K1T-IU&I*@J3f@3f zh6M6yBi$Vv|MjpUx*}#OHR}bfp(e#2Np64C`fOuoQ!knmT6>P!Pvtt%GTBA}0z`O(C-G z3qN0nX4VKc%OXc2Erb^JviIDDEwrx>y7wUB53`+untCi>1RzOi4FoRt0QHxjqUyr9 ziE}Q3w3U{vrGDUf7bG|p|CM1dj+Z5lpSEP%&s6#Syhq}{5%vc6%X(4_-LDXL4t6lhpwM2 zkXi4LQ55WBU}dV@R29k}qGr{)Vn>nIU(cx4nzjmmxk-K+Y+cn=e4~HpSE#npc9~22 z_9E9p@&#tT`7DeK{Bmx;IrmuyR;nyh7NX}Z4&`cAdWSo|vHnEElpO{Uf6=?uStf>q zsq?Ab=%&-f<^A-&0R&S>m?lrE6zfQCdkax^dsd#MiSz41mbszUV1!0RZgw*uK}Cc# zkkiJ*ZtB` z!;lf%K=$>p?}rOZ4K^tDn+^ElcPb2;I7wBN{OD7p;4@CrK8AVTsE*sl(x~|q>q%#d z!lY2xu)W1}5ZWr|e7-)X6fyjCVrB>`Vu0Q)8+-<$baZ zZXLd_6spE|nf<|NMH1ULbK%?db5q^JGewWK+%m7FlLBt-h)JMgf_DMNHm2TiLA2NSz-$t`}y)Ns4H61}TnNM5`{Hvbea6`!gX z^!JEC&LJnxD#j&Ft$v)BtH@;r*+jkIK@tr9BW$}syA=fY= zJ%{BZiHo{ZU2~g&UBI*`fR?<1ci>gI)eoAI-uqp4E?O{$+o5}ppaAG74G#-@@}dc5 zyi0}hJ(8dZF@@jR+3m|T3Z}9VjCQ}?d4sHvLjcqX<%(~OtbCeG6lF^YpoE#;>SDF& z)_MzHv_j2WL1kWZT(Z)x6wVd^A0%fTw@M@u7B*rwpFA2U5Dgbn`wAox>_YXVLrU1^=`JbGbQB+hVQ@NOVb=ufAFP0+pf22H2>5dO1 zdKiU9VjdNU1QKC9k(KTOk~z-%EQTLxgYpp*>%fBMwW))xm<%R)N3<80;|l2@u#%O9 zs>!5?9igYl9butnygK8cp~_xRQ%GiOPw^I|OTDKX7XB#5)3C#;g_CWViu+j+jN&~R z0tos=Ia@)0#hLDb28@4SZ(6l5;S4DCG9Gt{sykdw}~Vt77eC1`H-M z97k@i?c4KE_U6WYywA;}6@MA9+on4;AA?laul7wx?GKq2F!p|6ym{UP_b=C~YfndQ znvKs!0L5~Dy$r1)H~xKKVKz(A7qh{_zNU^lfwR{wR@>%x?gzzRo;++#%)_^uJ&~cE zec789#ax>^?kCXwlLv86L@Q-XU~lw*BTF9tuxy zpk)I?7MS%jZF|{72-wK4M83Fjiv86$7gV6I%tY)`8oUk@j`ckdQ2gI+Ym3|Rgr<|j z!p&$zh#wq?#e&}PiUzY!SGUh7wwEDHkH&sO`RUx& zn-RjT{F8*-3=?{XplB84&}=jV2iuu=_tZR~isM^T11n&}>< z;c_OuWfnK~DSuSF{g`kaHxlLD$)Fg<&69_ixOktfw5aD-gi)InWhEXHMSJ^S!<0DI z|JI|J>U*p@5WY!_>w7*{$eO!u%m}!g*+31Xgd3x)#LAF@xh0!CY<0+B^jMs7ixw3- z3pz!_7AY_tXV<-p&exXAg73%*6-V$r&^a)!R5IePY~2Xeb1qU?80jzgcTvIF_cnC zrpWW%A#A$hADQL#9aC9Z#YyqkCC5jkcH0DcS`;lU?%|qcL;0zY zfkfycW;7=!ubmz2!e1RkcUL?=Qj#B9-v|JuT>sXW5Sxh8LRkQ zmBN+On~)=3s6C;U^P!%X{YHMi>|uo()*xm{eI=^vwj7bL4Z`ioblfm1QQ&`snXVK> zhw_jJR5?14)dJK;e2)aJeLtO_*=K!?Jx)e}hf0=q%oYSsp(wPOH3YAkV|JZlT6}C; z`5tdRw*UKq?T_+>1yDUyj5Lzpz|V>d8+te^pdaFkxR^fF<8IZ-Bd9zs_J;;lq&}u^ z@V#rg9Tx&wuW7&N333H~R2bd(g4z|3o6LT~&SNL4I&S^(jEeeTBOt#&jFuq$r3C!V zX(lHZmp+R;!Ene=%*>4wKc=ILf;DhcF;{6dO_Ohbb=|=yA{^Pz*LG`95;bGNEp2U< z_#3zW1q>;u!XTRrJ(ZWc#;Xz&2OG1{-WB5BvOqBsNKy9PcoXJ3*0Tl;S8}B{P|WkW zbkkr>gLSxYbdh7mOQB9$yv!L2ntieE?QIzX&zX|Na~3R0?>P}eM;}&8rzHF=$Q>vK z@cVo(OBzT#=%i2AyPSvsMVB2E$TlN9CLWs3MaIcrVk?`;XEeq*c(Y>u#zzi&!6JI& zM<9Dentxvs6R|TmVC@F$fImQ$nPA!2YurE*++c-Oy%Ak()0kh-fdUoko}8RoSlRx$ z*ld@Yj!wkg9l3H5w8lB!P)U8EyYLgXd{u4^E#hQ2*1x3&Y^TLq^W~ornhZt*zS~4H zHr7pUL&k|Elzqszd9Ab&$VWs0X)f43tCuhGRz2dsb#^Z>P|=nvp((NI_th(=7lcQMK+N?U zZ8rDfSljZtYS_#_WL=-dW0KO=pIrn+2Lt`Ea2E8DreQ^iWhi03o$rSFCE*sB)8tU_ z;gn%zhtMW2J;W_;Yc!kdU}AeGcf9tpWu&=r&e=xKrjUSgWLYeku+YeBUY z5`~2@)~JUc`Y-x}&4>%g%7PfY9}+5AcRcM0*Zx9c#;h_@c<4qjJW9JG0NFX@iH7(c z04kBS_rp|j)X69OA(tm%KpPPkYA$vl7NX-X4?=P!#BMdy{%MpAUS@}nVq zRd{B9pE8k`TxR%A;`+16#$XCK?;znPP5*r~OG#xR&FY<1kngZn{V|RU z2*Krj`gS%%;NTw--o+JiQnDZ!6z#UEhw}FArIb`yNJV~Zr`$LE&ff#IZSw_HhtLl^ zP}MpQ$0Cz?<95lQry7eBAQ>l&#>gRP*lm0*`Wr>yc=0_1$P*0CsRu_0VBXArVD7jeC% zm%yg?UOv`xnOR&2zhiKhlSIi}G4C~1NP9^z-flqwj|8aQ)s)mm;Uju`sxAUjOm0#~ zkvtzkd&3QW8QM{Nf}mMdDG-a`_Vs7iek~WeO!3Bigy8{^$<~q-o9(D%5_J!T%o_U=;+~D0l{E!_&I)3%r^e0Bo#|F<`*i~`uVDBNg{>2uq{12r8cb(fv>`JfUj!16KV*WFFND_K6DQ4}3tOkU z^V4yYepEx&ufYl=4QI$dEm7)4{)SNIcZ`4iz*Y8yA#4QGn~8**6;SA-zE@D5F$(EJ zP9j1G3i^*k1=Nux3r~lL5o;Ek+f_K)m)WxD7)=a|xa*T}^65J*bJ%tqNmS~#p=EJ6 z^k69R1#Wx3zur4tPc%7R=2vwK)T1H{67^yvYMfnf`~qC|RwjHgG5p z)M0h$EYh;|dkf@~-&|!3s7?|RVh=9&s{z?Rjc=rVx^v90#$I;$iiCbfi5F5tP0cGd z?UInPxKGCkv3zz-hW@JsrX1V}T^}O`h7OR*j~|D;O|0F@HzYPgp7vCcCe6W24&0)S z6uT!b2pGkkaZ>XV!o>{J491nl!f#W=%qzelG!tU;_9Iw8ij7ROhWVWjRJP?c6Tdi( zT@JY6A?JIFB2KxR1Pk>NoqnjHr5q%;oubKf_f(j`@+3=<_jHI(poxX0W8ytbAw2e3xs4%)xU9esm8AI*KXn3F&rzT zX;amR{Q-nIPTLn~@q5h}B4T_n1KAdbSb7Y9Maa~EG^mi*Nj$VqY5gmxl#OzxUE69K zL$JPuP_0~Kq)X@a)4l#th>mg`h^m&E>tI;;z{8Kr1**>*r&gNe_oB{Yq?S3eeQ2YD)v;}LSh15+ z@Ba4Q=Zy0Y>ZvjBwI;56F0IYb2VD=7sgd7xKOe9sb-Th5ARCVvrBAB8to~g{e3L<$ zfsQn}rVyr!v*ew9la-woRkNmIk&>hyP8AY0PwVm@bUPuHLHn;2j_U~$kJ;5=HcHr@`g@%Tv z$>TefmDPDa)q<{q-WPT7H{AdKkT$p|UKwOR=HkWo=5B^%H}JHmigMPLFpkDs*4{= z^hp7JArRtC!F*X86)3`63+zanfNc;H;GlH(!}@h4xus*E4%z|~g2Cb7rei}6!T{({ zvQ~vo_yozGY*zHR`?MLQsrd_2TX|s-6qh>@EL9LHdG6kh8YC~zg%@zIgl4z96c?_% zryd5o8z&8s9OYejmQ7u3YiKv+O+5R_>N~QTF8%)lqcGQa9uz09({Q-_X4ez(2@(a4 z7IhcWDP?Il-giC!yIw!jG=6FJI0#EXE_B#K26dkZ3Qd2GSkyYdPUzxn-h&apUMN&= zzY$7@trO&~z{=Yr!?n7Ze*AeN>Ga>^2mNdR;NSWFQ0oZ%`EO;2fWs@n1Eb-AzL4*>LZ=TEVGQO4%PbCu=V>t#!oT!+ zvl?J%2X`CGr4*oN&M%3Sv!JF|f(v9KAp;n*BUic3oR*1=>_h)!%|9u~0*Act6*EFZ zB;{z0&M8;V*LKL0{}3cshmZ#ev&Erw(fnvIE^>!XgJYzP;HrSM)^RUANh7D|CFC1! zre$=Lmita4Pg_!GO>EPtSy=DEgzvLlSar?bG_?_VHN3%Q`)?_;`;4C%lX1NbL4kWK z9!vMS@74Bd_}KPpp!|}@_~2;8cq`o&6yg@lsFV4AqPf~6o( z2D|;aD8|)H6WfI>P##guCuALe5&4E9DNr7Xj!Fc;&KMuNNR}TP@h7VqDGkNPnGXL) zN1fF_o6Y(sG`-F{e!;hk#+p~Klad7Cfy>tGfe9>zxuvDBiGSa<+swH5Eto)0f|Y00 z1YrD6V(~@B$q^K6A*C9b9Uffp%0u?4k4OgMPH^c#{SwwiIHW0}q}=c99IcfuAPUF) z$#y#7<(yJtes6!?#erB*n?OkDrt zEL=7lOb~MsGG|8+1@}{#w3GTx5xG)=#ts&7v3z3j4D!i!CPw6B^NzaU;Mx&*cenEP z_WR!dtd7@f?1c@p2n|h5EoJ{eBgtE2WyS!+wRl=B`#H%E3a=ghN|^tZzT2RCHQIw? zIQkn#WE5$pCpQ20Rq#_O-tW9oTWYN}cnkZHlCM{M1$U9C#sT@Wytk$*rB;opZo(Pg zXE^SiFHQ%)<7+EDZ=!b^l>qrPy@0G{hX+vfcL7}8!nSgHy6*B+>VWAHs99U>6AzgM z`*$5w)*#1x?uD;kotHBVlbRYE{?d}^b4&Wmx1N0d2ur4JALELXpm3?>jMaIs_}vpU za!}FbU2Lqcs*M>eKBh~Xp0N*Ss$j#CNGqD<(-h0`!!zB`>}MAxeBDY@Tmu|!3~1J9 z2}e%i?F{hOks&%&}+!I&X)S_(ifq@lSI0vhBl{$!Gnn6Y6-ZMt_9HND3F z$-EkUMWt2jF^oK^?@EE~*hQqkb3G9Kr_*WeyHDNCFa6b)15JaolLjR%!34<(wv%bj9?ea~nYtde*<^#nu)z$hJE(_iL%Sl1!8APr`1oB?J49Va~ z9Kqbm&dgL?MvZoij%$XowEae*CoL`j6w^R~U5Gxj*ivpDkI)~w+?6^MvT5s1`c^;A z)!lv^4BuAT7_Ov1R&eS;CK50#(kpz+<8L+}d`=z78Li;lDQw}a)yyGa08ne?o_iWU6?lZtCk0;8?Pj; z-Vo*%%b}{R5gV7&vYW2!D515&sHzFEbW(PnWQ0mYAd;ygN)?$a9@Kb&x^>`L6nLfb z1V1MYJRva3H)&3fHSDco==0^ z5{6#E*4B(Kl4Z)}A2BC-K{7qh^|GwOWtTuAmEKU@e1EiVp3C88kZzDrKCrYz9tEil zR{e+6n_*}6o?;*s90D+t);Iz*DS1^}t?J@=ZG1L`tMt`xy{_jQUu+{-odm7y4v$M~ z%WDWh?6urguMIX;J2AzxHT7`LL8X!`o3)Eg+_`^$fOMpCFPAn!7%5T~GC`XtDmEH~ zk|!sq1qoZhF2M$;j@NhUY4Dm58-bC$kYq(BLWZzUL=OJMQFrX@NM@^igCYsg752hX zJXwSEDnp{Jx;iEoa~nlpbZ0u*7v0!YvifJ3@aUB@*JuZ0!PJf3{kLWy*p0{JU-?Ge zakN0a@u<+M_Y_gveztD?L=t z|2LuWM-T%cxA@;ob!2}m5Ue9G3suY6^AGG-@|WFI@;Bd9j;#A~F0K!>G!r4`tM{rT zE#h8!BlTB}dVc%XGckYvBeMB`^^M0#Qt69&wHM~!jub~sIYrU^HC5S-T5~(y^wOe& zlMUJbwwC;tF=YtzvwiI6EVxD&%rLhd_Kd9#36Rq$zotVUKw#QDf1@ocOcqEc3E~;) z@VNnMLEegafeaZXqux$?fzXSl_fgdggb>ZtdeNwKV>F^T6fcOCoW>xrK)+ib>w)_J z%ZLQg7iDc{XSTrEK@`)gE~v4I@e_`l{Wx_^@TK>qVcfPh(KYbY8`3nQ=>1|SILMzY z6Xc{Ukn(q0$us~2Z{@SX6j|2b;YzkEy-i$+{`@>a+_BWP6_&sZP4WV$X8zb5hQAP8 zjEfOwpV2hh5dr;tAfPLjz{8-mS5Fuf7q>~92)#qHOkJNo1&XRJK{NFkX<2D!qLdw%2cY$NzmcR zixDGDE}?!T%l3W1nplZ29l$igjJ2&M(xwp=yGVfAvZA8UBWB)q@-%}7zL;9vMTJfA zmgr_1zg1PYV+W$SQ5s@Fz+~XaO*ikXgc;_E3DYdd<`st!W8$r+ojdjX^8wEF=C$m&P)Y=|YW;p8xGullqe}!s!wJenxsl;&BB?A$V@h;MsX;466Z?F` z!@3p~YimA>$Em^jw2ZxFfk)#RA|K$AmSOuD1R*+zkvy}uTkA+`&O0utsR2LdwwJl? zI;yO;*8ca(gO)q+-xXnd!?W^_lTL}nhWV7YSiVZ+*WWAg7r^7N^Mk&2$GI_M&x6=c zyB?&Lgl%1xMaO{o^Q0>x-q_*9hH(2Tn#NQ}tuj%Bw!y zB_|UC^>!;1+CR@FPEABoU-B}a( z3Tf9bfEzB-q6}g*#B`yHnDW9tm^*SBU9lTF{63=eP~%%R(?8mVjH0fFY`0{D#LV1q zZ3%R8!VviNFO0`V7&61N&H8m_rDnpiQ?xWKvvhXG-AizrleF{^y9%IDzX~FYxGEK**w@jAEp4 zu}Y>3<(zLnS`638-}m`!tv753|2o%c^S594mjBUg-4@dgQ(>U9tP~X)R8VKu-IpWm z!@u2}+Flzy?HG=xj}{z3fIbumz`pi|rFT6D5v%$W^z(ft3bJ~pvDxI&Lhz%1bk+CC zly=J-0$T*gt0@AcT)qkbm?N}G7_P?9Ap1r1*eb`$ik2n&o2hR$Ro)^Ganvj3to#<=H!j*uc#EeZKS0Hx%K`6X15EUuv( zY4fts*KsJ*N6rj-HW)LN3$#$)9Ak*a64VESux%m2)3BkqCL5t&(+%VD%e0CEhPkwx_B63ujV{xkj0UGa z+HTV$oENrKj8?WsolZVS>wK;U+iv1voTu!cOc&zyakcB={O&Sbg9=TL1@n6_d=;akv&>%8h^J9A4S~|CJ86-PH7`pO(J6l>86P{=iYbPnb=? z52FS%VEmtgUUXr9_%@#xK1hHZE%3f5$c=AD=ExU-8H9Uq9F=6cxp!Wh_ztt`eoLA- zK!(oy4r>L>x43|z4K72Mw9{3r&dYGHew?@M!F94qPPmMG=|hE64U(mzQ-h;*je-hAk?PC>~?*SDoyD$yAiMkb=0NlVrN_ zRO{Gvx$wL)N5@apY{WGqdwu(h)E)^5GJHN)Iv4}r+8Ji>HkUViUL%_Crlwa!L^H0M z?KbqadT;xAw7rh5a*de*gZGrw@WvNU zx&8}WXiagCQW90j5#qz^SV3evmK?Wb(CjU#H|&u%&(6J+SWil~2#N10hhoOQBp)LT zYg|@^24eP@?tj2q5*|S(B&>!EY2+n>*<0xW`7=LLNLBa1Iy64LAue7B?V~`gW$)dH z8N=i>icY4W;2bi zUzHMC-&9Np=&vNQ{f2AYqHWxG)aSq=W$S~3&G;ic$6+TX$FT>`Fu-r@JISuE_b%8~ z$D4y*OS~Z5aZyJL^2(+sjm5N1e2l`cb^ZU-WAcalF0OA9+591Z4{V*;9)R(^7F5Q3 zZeM+xJ6XM*y_2OcNZ3tXF2T1wkMr*Uu&kUTC<|lCHUB$XEYH9i;s12pKhD_c-+n@Q zKivtmz4+J#a~J-Cp0~*$U)^+4OdF_4(k8g__Uj)94P5@mbsf$xmXtD+m74jIN7V?F zC_8(H+3X(iJGr`yKwRci;?!xw6~%*0mgTY=P#@4*D>zpJ%qH-0>GGoS-HIE4{QiXO2=?A&E5T!BpMjs9NL9w*l0 z{GH_5{}Id1=gg~m=L_<-bJ=+A&(q#aa&}bY4hDf!} zkB^ySzAs_ZjW3g6>w?ceR3vIwn5eon|!;7KLe(UynN-27^vt zX_qX#4eBGyxA}NBCbGi`cKdn?gtW5c_CVTj4GdCfZw&MaWmmqN_=}`N_ z^g^lW@rE(*I$9$61%bTn|3>s*1B=nH9)GLxRZV{(^4wi0T&J2z-C!;E=>H~X*Q%Mn zrb!&FJtJ)B)2BNLQT!iSF1*f1LwZH9Jn9avK7bs0H$w__%gho^@_*6d+SM}ia}URu z7LIHb{$558jhLn()DGC!c1H;8ygbVUdrPp~EtQBou(cqW39H)l zaz|5?^-5bAB zjI{_HBT)uQ|5hE5ksBwNh`_rRlu5#+qVa%9^ zFi{;pW+#B^Eq15CF7dGEvz^F}R;f7G%+eLjP~Zi}aODm8(>|`OY;wKLL6tI+{?vgu zJ;x{fe6a0SfgJqCd&y;Klp{UuT3MfO-aLa7c%6Z<(*E-V1Ez;Jl*Q2J-|EVBS5%tT zc3irY*88as6rQ~)3O7@>d!e&46k+)&pg(}1U2q^zGBBxR3p&KW)!3*yLV^&O912bk zbt(mMd-0@Q9;#P$yjNRj7exA)Q@vjVtD%q;B!5e+E`dil5Yhl`oeZY$I%MUs?Ouc) zdYB-&LA6s1YoMM)jmO(MXUiW?O)?7!utpE2AV>gNxo}Wk!emMbTb>o`!`lw2b6%MJy;Vx3EC4E!^Wv9<1RKxsGjP)w~xO6&J!b z7s_edaj2kb5S71nSNAZH2O3WZT&;DkfNqk@GRyoI0&d6c=%6r#*>zzIB&4mj$C^<# z%Ny$Z`)W*`SP3}Lw8B5Wa8bPV<~ZETMqz_ZcY)r(AQI*F6B^V)p4yz5*7bWz>Dt5O zEPD*OiCX%me@(^fRTzK)+7?FPMPyrl@K4M6$*17`)bUF}tSrL){oy;V!m+5I*h&(r ztLv|GKS&xD(1h=QJJQ<?vQ&D3Pg64L*6mf*t~@WcC6$jI+$QU z*gVKyPf9j7V2hc86GR_-h9}eLCiGKdFq8jwPx-*4YEXsarF3569`T1vRgtX0abyEj zTOTS7lsTB$$ws@A7{^EM8iZg-9~pWgD{85Fqvet)Ug`c3m@Mfm4Q0J$GbsfFiT&1{ zs=-3ImjX|nxxm}S{IfH^Od_4Du{GAOY)gt>&sQyTb2sCf00 z#pK|5J4|ARq4#mIGv~R61ggf3mS1(9ukUL2u6nzJH&&fn1wR1}-WOgMJ}*kEIwDc= zLI!$m|41AMG}yqDew<^7RW&>O`wy|&U4LVvt9?Q@b-V`3ff6>of)h`Fc}g&+^@@iW z0z)BXOwacAmA}I>qUf-}ER!}mbsv9NdS0Sb7I-xhc?yh+n2{>(?s-4R&!F|I5K)tYl{XXtswrU|Tq8b_9V;&jY}y^xv7&N7 zI~1`6?YR`H8U!pk?cNKK?*+xXrn8ogqxzDEmUJ1z>UzIHIRyo-izcgz z3d`W*qEB7Ca0;dbveTBLhikZxMPv{bw?NNm9zu`UNJ^feRwT$2k29KM9D@7?Wf(CT zhT&79@B`nFM0<+OO$WmLFY+jov4PzdGO$wCwwT*|!$?Eu(8x8?p!{ zg`f7=k=(*D&)L@;m}sg<0x{Eb;V{)sGK_M0v~uzRMP`-19+>`i(^v7eZ<2Vv^N|re?FH=1url!AAaCqo z-JbVEF{f?YR&jFqzpGThPrgPx^L?svPTCyh5OL3CZ=P<``Zu)D0iZ1EJ`FV1xinFk2p(Jc*4yigKL%m&+o8D>wtt zc+2+g>L#ynzP}bQGdzAH2ecy$>3rmd{R0k87*piU@Hgpp>^FS;*2C;Cz%!l()dc* z#nk!8@K_!W{!yg8-yEl4V5--(Kq~R>Zp7PascuMA%_CaSszL+O2#c#Bwk?ds#34Q& zQ)WfQbl|!^cE`d?56Z?-j6*K*ZFFaoC4-G@OzV7j2lIqPUQiQhz`gK!KalU?#`R`# z|87?tx*d|?;re)js>J?SK$Zw5Jd_4KI(#uIhNY1`DMs>?=BmQP+@dhTe?!ARe~=V1 zm`Arfc0ez>`w+c7UXGfdFPC(eAjB#Cv9h_6Eb0b;wwGeMW;l#WQ8mB021uo+>|%lz zh6NW;a(YOr%Dc9&uSZ?9EP1}4I|i7kzUu~`E!A#(aVA%=NUEw|A_SF7$DA{%$OqfV zsE>p(mOWh-p4UY_ zI3xM$4xl?Fq*wd7aehr!Z^x`rWiKPn^Z>o`2B)n2|0&QfsvEofKxK!}(bbVhD*vge z7mWU|ZiRmzf@vbM=#Zt;oLK;Q@*s|_0`+(6$ITl9Fl7}$)jjG9xFpIetg1|YjY{|k z=eLB%Bt!7a3Y`x#SVa@?EW8va(Idao2628F*%MV>%V)JLFgeP|U7~<&ecBg_&>J7s zV=!~HMA1U?6?WZ55NtibfjAZ+n!R;`q@qIdxSkOM{RvMMyvoIy&Fa7`tAlzIHO|P` zb)Upk0k+kMQ&ijm#jtE2(cOd&G7>xR${wYFDACL*Y)afX(Bh1-zpW)T_T14Ew!Pej zo<*(aJNsthz5(!`7gh@b*w4e?_c~+>hFcCo0Tb|<0Urj{-PhwJb{-?&XSzboeTeaW zl}!3O-U=jV;sw-%ouHapbTW<3XaC)vh}+ul8CPisVy$e2OnC@~J{Pa4R&a|{Ox7T{ z`;`}9z(vw9EEl|ZeGF8Qq)nmle-aMx)HF1?ERRSS`aU2b_dc>C_dX+Td+v(a?RYW) z*YEnYU{tw0V8TC!Bzf*1kt-OX=nW;$Yu=!OzW{?W`41VE{@O0GKSwcP zqTr@Yy>!S?TBc0vB+=|sT1ap}NHvV3p=wTu|B8_Bd;4g=wg(F{rRuCdd^RLV6j7*@ zth|OPo}wTn>^R+!st#|6f8L6=P?7+`Qujm^+LMV$#%OS235C)LNMxkXsUQwmCsZSM z?GwP39q%X4X;0$LfwsN~_@;VKhrh zn=rYW-K?ywC46LP5;{7hQ`59u*!m5A^rtVax(xa=YWHBZ6i>VwkYOV;fx_^ajx&W} zny6sj$yL!G<+Zju1LgLMh8&y()&J6OnY9D`^Y!28VtTpqich`NK+F9FhmgkrhcYVF(2|(~>OMc_pe)8HrNpE+(&J##=oxb+nS^1q&-# zjsmB+hA51E%U*V!w4m z&~sNOu+CNx&4&Q^Th4`pVZ9SYs~~gDx~%h#P>!ejUEt3P!8>8}<-zzfeg~hSdb$vK zqIi1RqT=O*0xPxM3EifZ{^j3ub6A3uNhF&DskzL(+0Da__pL z@J)Ze@TYCg$wGoP43E*k;(#euOF{ zo^#8Z;Wd_;y^9mW-NUqmOv5jr=}@}z-m5g9efV&!5ATQW2xJe6ZHphmiz;qx!sgQSSqkm}B8V%27H_3Kq-Lco!iwCkynMUCALiLsk~5BJ_BZ;y)vQ>X}k z@!O%HDlHOin+1u6(-s?T?G{}rSicShn*LlkZ4FxalwBCa6e1jR8y(VQFEi5EM{#d} zW_8qSKN3=_d%$?Z*PYH^thpsCgJzhG8sFDOGH|RG=Dc>~nj|dLH*@6{Hx;i!%VD^E zDp7zKN=&F2vsiG4&}*wOwN7_j{%Z@&3fYO}W>y_x4A6zlzshe)+^u!T z{2T6iGP;wxFi5c2b<-SwFBOPvg=JW$hAQl{hh_GjI16hNC|N@xiQK=59~bLdCP5KT zYP4m-qo%yLspwCEv$*HR3gk=SJDp^7(tC;S79X}?slGsw3DbovVHU0h>f557l7Z*U zSu$8aK&84zLc^ryZzG~U+XSPsv!c`Ch0#{o^gYudBqpUrOinU_Yz##m<=979X=9TU z$NV=@k&%%`g?%$BaiOK0rAMithg;+X7cY?;{XuTp01>Dy6!w5eks5AdHn`=P;m;X) zynfe~*)@)+8PWHU>dESct2UgBFs$Q>Hhzr&BuYu)5Q@#%gAQprCIg ze!&ztwY#fjD9)z?<`=wg#O}R*;2Q=a2nk;rn|0pI?P39r*jHb2+#WH1ZeJXSANI!; zP`?WkJCm)Epu~;s@N;(@9^C>5`c1I50v3%vT_urPZl>v#e`SXM%@6@>2cTSEtcEN# zrXS1>G{eUH9te&?xLGP1Z1Vzw34iS?WO|nqarsJz4?w(o$jpW?n3^6KBs^XCy|M(n zz1{Q*Zr`06ey*Q?cW6)1CHB0y*9OKCw@8U_FyJetGsMBAJW8|LT= zZ+FuW`*gwdUTi}oyuYaZd|RN{tev9hI4a;@Chl44<{JOE0p2rW`c zR!U3?LmWn$l$R3Icn=NsV4b|kIB7OqQj~}n)mhFfv&jkJ2hF66w&X4Q1B9SI)hUhq ze~P2LJ6RyI_nYs1jQ!J}eV3t48MsG!-JJ;?>fz^$v~|B#%v8Q(;y3|#-2r?V*>5sSWlp>lkauM4R86Zw43u9`v^ z6#ymbeVr`G{YzQ7QG&e;!JVVCzQxMb3cfZupMG@B)!JZM-tTLhBxF~)TELu#%4BUp z7`E`O$cS54`FLdD;s~Av+u-`@9}G%?sON8q-QReyO0twEw9nAtgE1Qw$kCFrl7iwC z7--mOp}V)TXR#8kE5#cKA_lkeoe>#)73+(6`?sGNDq z^rrVPD`xs~VPPr!%WxWFfTNu_d@4OxCrdP`Q~Ec2Fdk?)6O3;<^=1^N(YdFiivPkZ z2bGhc(wDgr(N|Z|A<^oQ1*VSg%+(-^BBSN{K&%PvZ-=2s=LJ=D_24858RLTyB~bql z_Oa&{9t1EY%+I@&mY0+BQ$vf1^+(3V$hfO9?I$9@jUJ#gGSHnTWikgw42 ze;{k-3WikG5|3(J@o&uZChWQL^zk)Cb|wtzUj0?XhNh^(E|2eL^@t0M(xnVuq=Q{5 z9hj!5Ina*c$AByQc5^k1;_Q2kMwr9lao-VHjyiniY-O(SYO5fg`)ec6^V^^nF{he7)@#m)O|>9SqQi4Xp`nU&d3lXA zwMw@b#Jh9{zbqtJ>{PW*PACjSQ&U*k7@B%J&czYEtXV!0_TSV=Qmrr-1un{tr^vjtI=7!;e?l0lsa&Snwb%HZ6)d$^*BfoM*ZBwJFNW6eES4d0 zC$&ohd-8*YvC#VwZ3HrNbO+LH8DuHduR4e~AHF;7t&2gz=N?@-xvMqIh>8|tpr6ho zKU@Ofwb#j9Gj+8atN_{CVi=T|)xtp}pw-zFbX+)V!xCt?m=k9tRa|7iZ!m)!Jdr*^ za4E-jVp4;crDo~Q_6dNnM4MBxR4_QmEjjL>fAQSg|1J%jxe!s`^<+hS*#o#cJ9$~3kg5WfJ(%~XGV4BAxefPY_;%=6L<&5<;9Cqo5T_VCT;saL z>0uxK382}K~{D5#5DoH6MmnhQ;=5YVA5Z`EL`iNQr0 zXVhvAg(X-)nIoyIb0<}F-(+kw$&ZFp06|jbIq;igC}g}cJNDys#ax5<=w1?=tn$>* zX%xpCw=0=+LP2a+qs77LTuF5x?LUwRJx}sH>dnU0Ik~yXSbD+a%V@m|bV zV32GIb(~Tux-vCP#5_J z4>I!A(nF@9+{NZHaeb{$r;J4LRB*8oG3GEr5$%sYFS1Pq?EVrnHpwC^TB255pXu(I zXbb}6&o4rifCt`vdK%M>97ofasDn>)_ zCnMRH+NvT%G+GW&+nxx6)U|EaMe!VeSKFLhGA%G*twtqCE!|Z%srvY!ld8OZSqfM-F%%*Suhux|TW zsjmVe#RsVqf%9CejtMn8Y1-iO)_G98HAF&0#h|nvGCmzwn<&6sak*FLpj;3hqRN@o zHD-uWx>jx2_M=Ol}a+*?P(3mapukpTA5hDr@N+b2s7QJI%G zUx;gP&qyoFafpBA@henmoPALvcxO_A@<)&4JZ>fWTczGJJgu1F+TJ@*wuzK^{dtH# zVd)t9hacrJ2x<_i)~omLwuoh3p7)rNlm=9Kfj5fn&gX9Wj7P;xwPDRc`dvbP7-JLc zN5Rai@>v1LH1PeYb5i3U`jw?g34IZ933pdC6UjRuad&r< z8A`POeh5keq%7&F@iGVTnOS?pmy&|6&)6odR05A)nr~)TNn`MardZXy=v9qLCt#1 z0RgZegB`yoBIR7(Ai8fACZ~1AW8>rfyQ!EONVX%1@3+?`rX-u3U;~BgBr^KF3ebN3 zkhu3xB+0^}y1<)Ax3{{Rfzj2UH>QY&jW{M>n<#H@7Tso^?<`EZM*%rj<=vc3sK1W& zfi|ln)i#^R-xrXdk$0f3i_VP+G=ilBkd3!;P8% z61kV}-)u=XyX`(2c7EmeLNUzf4eh5mayWK8g9hvoeoH$%om0SP7_ot!#vK(uC8mV} z&-pV3AxhRFSU`+2YheV$v8G9;?j2e@r>e>&a#?Ho+jLtC>{B=0_onHb;+=@<;01sby zbamIHbe%{L0CR|iSyEUDnWfVX3x{-aB{xt^e7a4Co`NNa?Q9Q212q)SjLOlrJH%wZ z*{uLltsyi#ZL(;AOXOq-AVpc#$YQz}*E$)nWSY#Oy^E}*%Il#rE;~UhE+&P*4*yF{ zn~zY*^n|q6SJKDDf^L93MHvPLw>8SS1_tk91Sci{xN8~J#%)QgH4At_A+mf6I15c<)hO6EMVMkJ}K-3@9v+K zXmi)waI5Uj(KY?SSkK<372vk~vtkx~k$E$kNK2&ivT^%29o4tvN~uI7MjBaF2Kcd4 zdry5al>Gmt)1?0{9OCI7 zc$V9IJCzh^C1(*Lavi3)S`;jNf{c+iW78&kq&oa?DLFkGK|NhqqzZ$Wi6)XdLIg#l zFJc432zjRq;jIl#ahoyzMEH#K5i9^oK~=<_cxmK5zU+e|>CuJp(2O<|uR z41Be{j$}{?hZJ2~180PK6F={C;|2uo9K|V4 z^8X~qGc;fNhXq@V1lr+~Y6$fQXD6*69KAS>T~1i8D0$M7bCB9TW%@05exLs7+)83?*RFqIte9W6qp1#68T)nes>x@ zzg&%9>-BHX^aOJ^LM8W^2woP{vUTMb!hHLmViZ&{6I;lA&X@*Y27YytHDnBml?Rq= z<{7%A({*_o?H&({Khh0|9#6=iqjDN?fR_8x0)in^!z0yE)qas*iUJ_&fe6tixZy$teAi*y-aowtnw+HaJdC9*;&C~NX<&7YMKkN!Sg?A4h(}%+bGj* z#aVd>n!Y+-kcVTg~pfrSS ztU@HvKnYIiA!n*4@?d3sO1=MIV!PEkG(+E;Ffs~JA0L5@Udtz9#av!Atnc5)CMSo0 zXr?zV_MmTXvRN zJTnTko8PCNjB6AH>^k+HR%FHK^nzeFnHM~Wk+FY1tP5Owk5iRNXOnfZ-=p?zw&Lh9Xo9*_ zXf;`>ZkDahd1)SYwT8OyqGwqsZ z4v8Xv>Du$Tmbz~ZQ_uWJx1NNQ1-^|hPPQaLPYaxrM|sN5ny)o0CvOYVI_-;r$I$MU z!0}&9NdWwB!TQ08QByU!SnpFxgCU@^g4mU}ROfq@{BQk|D~Vt1_B`cQ8}`lv$6N>Xs31f)bV2sAc2Pclx6BUgW8 z`9Vv@Q?mbRLcf9wzqwCDDI zGIh5{90xS>Rp95+hVVvrc3{+Mz?jlo;5*CI$NnW^t%rz0H6FU@L7u-(&RR5`PrT{E zaKWdm*uUrzJ7KVB&HB5)?~wve3*jpm_eRn9I{!(JRrY^LZ|!f|f+X^74tZ7X(KMB) zsFYusat&hxC|%E`ol0atL9n9J^5!7jJ;E8X!9XPi0?Roi$QZK&qtR^#O&mfXF&jwm zxp4RDtzi>rR8@yosK*>dy`2%*K?~YyEyz#g_+?oUj+k6k=hz9FO|gru=UrlRTd)r- z9VIuqkTQh>xXNer%AeF4$4in?>tjAxX3Ch(bu4`A|vIEIIdy6Pi@gv_e^+d zI8+*eX3X&ECY36Nrr5^;x|BgRutgyy7+9u(9p%tESvt6U7U%{w4n1tNY&Rs~JAXq;YXT(3 zInUq!RV<;{!IwpR_dtN_;OA#TDbcbYm{_>pninBeMa|}U4W4Vns|jCup)&guDc|7x zxU(~ku3KocJ}!gGc^Sw94wyb$-ctSkC)m^zN}6dkwEH?BPzPEnB7km2$Q_=FLyMx< zo=<_v?AiOo*^%6S$X7N59!;|sJLo8;@Q?OTdN%v?rn-I)Zg%wW?0nCBm}-i`vDkhN zvhPnMM@0Sb7f^!;>nV#mLuI7;jLyoi0cnSMGxoRZ$^meds*Tl+N%_xK$n(6M=fqtZ zzPEwaJiU_0IPvj=vvl|4#20>^$V4S8k8iohZ{e9Ci?kW-C-arm?(p(S2#2p4@7`M9 zSs^Jow?J^mDYcK8RY$%ND$(E_mGUo4BuiG&0)w$%w$Wrnl(Y7CXwZU!MjM+x)x+`C z+Rm1o;3$ZK+LU7C^fnPCrNuoE=)mRLJ76FTOdJu|-W#Y`g7~3{XfK_IjH#iCA|b90 zpCf5Z<`Ue_)DQ5%W;3$0iR$^7#AU3jOS-M=lSgDo651%Av5=p`ut?Y27|h;ucs&$B zc|Rce!kw!%?3K&4%*xJY=H}qouyJr`pP8S(a$Qe$X24z{TKN?hRZ=LI_oc%_9+n=WR3$ab}x7wqbs?+p^NEWb?WA#=!uQL zdbyWIfS|R|7Z42<>z=(oyFJ%!9{CVOKoXp0Yx823oU!y}T0U%mUJW5l(iL^A@*d-@ z513Z^KA;-AcE7F?PhA*1t;-S+4ScUpggkE4kl>!#(KS__{a~=shD#Kk9V7)A*}XHV zl6)qy1n5PRAeEW(tLun^002l|A^-|B+PwkCDTBSfhmXoh{fwch0LHZ&zp zRs=DWmH5r55~EBKAED;B+b!q^Ck`Wv!vbukHx`q6b@&{|Orxo53T*!C<^DLtZzb9Uob(=hIgD5cP>9@Vp@*sq-a*k!n8_#%|XlaquW*agmpRLcr=D5VdDqK>KaD zhcT_f$$aF|Nc!g?O{2dz9NI6hSsT!o*Ta}(tY1UAnXdQlu&j5xa*MUA@dH&1IvPQH z=lVi#W9Nxs*y6;~ANKUQ0Q+U$?X?3o)<0NTH{ZujUM-`lm|!OeVU&)wEq3~+Ry!|Q zSsg{(F(*f&J9L0Y(>H5fNS@}C;*8a~;jT=7>l=KrTNF29#|G+o3KFSO@r7GaQX+(3 z#Ew-XS{Lw3!)v$x#2(&AeZOn*?S8zxR@qQ^I1|J;V}7?6eNR}f>cqf3J=?K~joFgP z=r!$Ka)V;~7$52iAVA9X004*(3+;dWKTN%4RMcOzKgVefHj;*!zUS0I@IwAap}?C~qQA z(e6D53MsLry>u7`?K8X;ohez06j&Yf_P*h|Az)hIJpiEn_X(pmlazrw@t_@rW~aBl z3{F^mjI4nr-a0Xc>k+*`$#dRRg9XVJRGTy!*PpsxaW^ISat3p#Ap>{mced9$)>xvt1nbdEc{Xu9XLU_Y z4Gp(Rhq)V-^;>N4Br7r`ZUN%!5UpLO!r>5Ko#zFIB0;eyfq`DD1l|i<>Z5fBER(Ei zN8=q`2U<_}mVz`tNyErmXf0{s4{>P>mHwCZg~!FDomXjA>KZwmZ1IyB;~k6CVKdFN zmL<5y&(A1%rM~@ql7D6xns9JwzK}E$F#Z=oIH5*X#t=BJJUvQsXZ^m4^c&`*#<#wy zRyScZEFX>k7|Uv^EKN?5xnEB6%3CEBSv_NDm&1fgJnOq_WO@AS!*Mp(5}lRWoX{L^*GJ zhQ2xvO@t&@gWHW^Fx~oFRZ=`nkzHnVlZ(nIzb%^lYr}A?zjbEwpN;e@JZNd_oF2@e;VdI|3y z7}!ky7W4%pRr-#Dz0}0P9H&yhYaH(<>k_=4i|rj1jnrP4mZmNb#Jo?fFG?Vz!vD_0 z@9wBRECxXgK3s_Z=>Wpohi4{6+g7JkxXI+?ocZInr(mdsp?+A|@x7sBg9g9fX#u(8 zuBhmG+4JIEJ?Ic~p9WT*Gn!l8K0PyjN*U#VBV1l>o^|IaW)GnTw}=qlS#=mEM%S3~ zIUoP!s<@ubC=rCMAs*trhsU&W@nhy&2r8$vH3WS*wm;rs;<|~)UFOH7h9_S%H_kXp z#xI}0{ryeN8J|P$VP4y2?jy}_$`M{6M?Yfi6x!aB=L+0bTUfY;z7)0g%hGr|Lq8WZ z4J1)#oq;y^y!h+pa?W$wy`9i>7+lM98VZ2Tf{^41Z-*_FArhpIqXFRPeFVzrs(Z>QwQF?Q(?1bSDKZ zU0h;gN@$i&D1V6OzTeR%+38gLLGs}jyPxx)WAmf^FWVlr(6#!92Ul854Q{%Ia~VE4 zFoB|5_RdafR_|wGr|wCCN~85`*D++C%#d{)YwZn?=~DszZ9j`B?Hstct9+25A>5_! zL_eO>aD%N`3-CWIYM@rw9m@}3BzFu;UfsfACCJMg zdfp;~hnqvatJ{`nsUzH(l$ZtH*ezA|X)+Cc$|$XPmL~N40O!=bHh`I`F?ZG^<+V7i z8Q0j>x;rf5RZ8rqS1AKonIl@8DE7mGi#NrD^jqZHGv3j{3rd-Eb)Hrs_xQt{?AXv8 zoz4kEJX$qw723S%ur38^5SJ4ko3d)THd9dM2}_uj+e#CQUteM$WiV3@!_e zE*1oAp$H1qe@d#wJ3NPX^x_%6q_yFH`w1@wDlN?$r93#sYe$t_Iv){BDYSl2-p*qI zDseu;NNK#BzP%uS6=w&YWMJgOa3w46{v}W<1O$Hbr3~OA$kX|*P|O^(M)zKC<=2Wn z0DLdHlfQusr$^Sku;a}V(^B$g$5*!!f7e;N?Vq&vVIU=r(-MP`@iSq3_7JBfdBs|9 zjr`b9)r{C)-?)D=8<*>KlA)&XbkG+;o6esTEE%=vRTT_gJyS?R5)*&1u~_kpA9WQf z7mXn_(l?-1zKBkUyHt0D>Gye`@O?ez#+9-3L9(mOoF9H{#z?Ly@lLGuSj8Id{!Dgf zg}WFFi-8x&rFR2{>a_7A{f&O2B(cLY;xpq5Y`=+$I6yF7;tVw772vWHSy%Nf)+7+@ z?`FSOv%Q&_I`2Enwi3GkU}L_2+5SCnEB^NQHImm2Y`9CbSNxtG8t7xyx_IG#1w?PU ztta2$y>FIt7s8DvIzRY{9N#uPRQ04Q!2mdVV+Peg| z2bHnW;|p+`p=^oCJt#953{HE|GrahjPYU=7LqzsnhU|JCtXY(bCY{C0)_j#X9dl)s zYzOW6iz{wF-C)pC?LUlB;rs=gT5^&;pG9n~dY{_Nz{g3hrN}L()_&}3$F^%CO0gGo zh-~`T3%^!;XmR2*y9X!8X6pi=X+gn83a_9+!gNlRNesP%r{As;(OXXcgin9xKX!e$ z)!9#t-hMLmW7vpJ5yjX2@&z)dWizddW+NL!eI?{}Vi4o>@dlu?`Tk02#GK>GmHTcr zql8-^Uu!)O{n}ctzCzJPSs+6s%9k1g4HW?sIF+B&Mg;jj3u7s0Wgzv;01 zpHevxfeku6$#wPivN;-~k7Q;ct*7I0OKao7#W(wEUxY9JdUD^QcqcOK6=?~xRCb&E;)A9UF!9y& zbNJ6q4Ii&gy;3P>8}e`F>+rP9@Y@0+{RTI@WOjq7zdI{}7N7=~4fNqG@o?|IWQcrs zi1Og~goLzkv>(P&w!e!`9-UDEFQ;-R0~!)f@^t}tFDcrd?o?;^{hqFVp0=*+yx;hG z)$85tCyAXe3VS@+a}b95)-!W++x~SNJ^Z-OrP2P)=TSG+JCBRM<(?}CUy*PH92 z6qYPa{0_IjhysbW(fM~O4aofE@mrQ}x%p`=>~n^F+2#+JAXt>JS()PRki6Q>V0VYJ zmykPFcGJaw4-@-_`#Pt$VrDz&HZjedbQzomMfqmAc$u=C6(mD0g_bR*d|*aHX=c}d#&98)jOCleU|wJ$#(MATFr*Uf{d58jAEM~O^FVNn#v{+3A*u_|VX>?KSeXN4Q24i5po zjo9EcGHU{ACg-)}GF-41x_q|^CEf|#i)D&v_vHEz@X9)=daWAFv|IMC;`7Xrob$r1 zgxh@FnZL0NWWXDeah}HHFP)7=>mPQJ`1QC(3_)z2`@cwd6(BNM96Ru={mXBf!oWu# zjf#hEbslf)7c9t~Gn`c(>NWf=yAKS(Aczuz_FRza^oiB@{&s=eU8M`<>5vT>$nRxg z&~+h;8m5X>dmyOP-V0jMhC_!qao_DKb;jZfdjAnMjB_q*E_}HMcc8SPD*mk?)N=!JoAcQ-gTpO zdjai8L*KXocoU!Rn-8Mj*sf-y|K%v{t*FXT1ioZeG=21-zAJHf{^94eoYw5@oXq~} zkk!Qm;?aCj08@C>9_(v9t3=h9Pi&YXJZN&lv@>(W3WO~b>;hiAgdPsgg&L-uE$Dnn zC1LgmVyr*vh)b%ppL_N3#NFA9uqzlT>ybw&V!k9*)Wp##gfiBSdq8|8n`b0);BF~A9jqSwISr3kQuX%-y_0F$bP^pEuTzxU1 z$Y@26yz#N)H~B3ld)`@_?$fKxPRwYzF!hsc;0UpoK< zhW9)Ak_3btzLMb3tfn z+NXOJ0@qdE;>MY6SdP!kd7RH3Wk3X@&uX^X%I21EPu>Zz= z?JK~ctqd?*DKsw^Co}ph_wa{$g`}?ZW_p-wL&f*a;17Pj_c_?t9jDgYg$?$Ur9Vz; z*dojm?s+8 zA=dwhE`xB~G||NP>7b*Q#cUQs3S_4+Sh<15$}^)5s8ouM?3)W@sk2`7_McpUM-IQN zqS7;zT8?nw4V+g4Y8%dCmpG*0@;%t>8IuNDZ)YzXCWG%x;s}d>HsAlBdpR#&42wVC zKeQ-jzH2~J9pRXP65}SXo#HP<+^=!XV^gV5J>Kq(r?ng)V5> z?LB|BMt0LcSaTdnCzgW9Cie3?s#eyQLHpoyf$a(WN?@NKe^6)=K1A_|KC#(Np7;~) zKV`t5=)o~DGqE3P+)m5DuOhAmsD$s@1E`U1vi`~92_(-IJpRWn&uTNr_48=CdS2wNOZ=42#zTb&dTBVGL=l%vbv`vOjtTthv>gVBs*5P5~wYS2im%`~45s zXe8Y{4Jf^A>bcH)2bkr?AUQ9hX=+jA5PjpWm@?a7{4A5uuming==5e1VX^C4@+>fW z@#m@P)@^s>Z@8RpCr=IN*k$Tem15AFTuhkF?3Zb&a{qN^dF8i0w>Izo*YsspFAI*_ z`671hl-0k82k^8cQjAqSLi&!qD9!6UgMm@(2#9RA&=~^Z(rvIgG#?*nt_zsBT&?}) zjm)upm&3Eb{!h$3s^T$4bx5JYUywzP7*mB?Z0)0{=ck>18F^g!4--ZTr;AF0%Uo#a zR&jkLGp|kir$)H_pIF8A($AMCLc$_`XDdM-CN=`QIlhEMW8i-GJ1i_9xs`a*g~N_h z9zNjQ9tjjJWUCFyIuuYBhlv7U#ojM48>lIE0k43w{vaguh^wjf*!Zr5kVpZ=5QQzY*&(p^!w4T@h~1vrp|A) z!$!h)Z(^K!_P@UEK6qGOr +Aq=ci^{RXec!5wfqCs)c#G--U8Q-`>mNrygWdu+ zWIP+W$<|M7m#0Ye)cW@G6$k!6K!&e}lM3+T@|QLZuPzDhz#RQViHK$p$=scsRRLy` znS|x8D631C_uk ziK3b5w0{F#U2*gc7oZIE8mri$$B?Sl7%ByWITgGIx+KvxQnsu z;(S(xb)231t|{|E@9&Gm>m5+@9??pd0vHIji(k?n(dvKQAbo>fUj#;)HcBdV?(Yh6 znTh9aN>dFasPD9Pa_H@Z^U^2W>F> zH>&-r#!=njP|srs3pjlh{03D?gI?KiC+FiPFi+he>d%p{M*Y>B7zr;3qp`@Rp0H<% zlmfI4NaE8~QwOR2^-Wl*yH_{>j~;AzwxC;nKvT9lT%TSsrTLX+(z)y4Wuc)iYNChfO%VzAgav((6`ENgwJDs=YMUpoPj~sV_Dn)@ls$woVP|j#bX6^uX-m*lB_1 z$;(%tn_?`kAInH@U$wVqc@5rf1z0UU*_9oQ^6WY}b`#uF%91T&VJ~{b;B$^1oIgqM zGDqT_d%}XNI6Dxzx>70pvOdBlDA>xF_--hu^V_+Y=O;5^@*Q$g#kj@CFsft*h17-F z?xD9`$C1p8gdIry)lq%&ZSpqG~C#-C5Y-nHV zs1bp(a0w5`^2yf$fN0FMwsunx=C>av2Yj3Mk<8_(zH9<@MS!0H%!j~#iNtPiqmXqls6;SGQ<9vRX;cB?yi-FmSE-}G>3Hm{=To^pkh7+#sQg>n z)}0Rw1}7vWM7Fd5A*3X^hziWTX9kLjs`4NFz&jR>;>6md4!sr0bxtz57&sv)!N)jz z^Z-=UdU98z6q0(_Oi+cS|y^smHvN2e;mn82z7Va58!rh97_j&bfz?0mnd4z zOl>h^6728dVZsm`O!Y8u2I#70#bfnqSF*Wt)-kIFIhgy62aVWY+MLZJ2WCkC_~P2)<`%sN zAR^o;e^X1#J)l8yi#Omfwf@6yKetW-@5jh`xQ--s`lPPv@?RR}Lm#pY&$ehKUrv+p z?0_Q2qYReRDgax`QCCAjXasd7Y29~z&>IfqSU1Lqw2y?E)vp=o+t7PM z{y4cEEI+Y6pthtM+Iz>tVE`a;eIC1mJli&v4^FehEzrDK@+#CExH7K94WV@|o^g+-|@M0uJ-L+q=wzOS)NuC(Rjju zO;a71vs=@6_vBbt<{gUng%baMrBui{yVYX*t-g1@^nUi0PyL;Zd~0Zb;BC~DjJz@y zVb7Gw_4n3#)ZnXE0Dv4}M6EZMt5d7C5#TlrF(Mz(vnn7J==>jl$$%tlz>~kPxt4qb z6wpF{8ev>FUR*9P;>6rU0F64$7`0t>3t{NDH=O}5bye$3#?UOHM7eiF@8$an7SEDP z;MujUDhiu`DFFoFDUJn5jZ#rn*(@*)WeUwq#U@zjo{nQcJG{X}RaWmw`-a&h51E~f zdgjKxU1oc7h}|fSmKObr>Z_4H6Ch2CaqLh6h*mR+v`fw~(zJ7p5iDa0rXH|8bcF>YOGWnFv zN-)@yQ}p4>^bR`PxDwM%SybJkq<9{7T$h~Tf`&$3%Vl!=gO<)=k|KFskw!DJ zqKh@P;)+4u(U(%L`jVl|LsZ^L5;m|uSG3}VuS>&x*&t?cE2DdgY=VU>BfQma#{kvOo?aQ{;i5qdxei3K!_;t7L8^eOQ`z}rg zCKo*-BOCEpzQGoW@J0cc=c`Z*9JjmTOB4c(^D)$#-zP#FaXj_O9ZM>|AD*s0{TQbl z!wS*V(CS7&HRm*zv5beY`=Ut+xhI1&My!vbbDjF9gkP&Mr(|#}A!olm?ipqn) zp6$a!by>4~vgvV-&|E7e5JvmAAez>6zAf=x2q&4A`>=o#)C0ce9>B!|T}=`1GB&(^ z4hY^(@~uE(V4fh5G7!`zQ>G-)n7?$536u(U{7;6;j*Mv}^W!72Tzz#Ac(bq)|Fm_M zrSSA;#u%evYq(uZ{?~H0#HClcM-*F~}ai4J$(J2;gOHCC2yR^=pn3IaD4bhIi z0$pz2+J>nw=>wBr4_IDR;8(~VqZLOB9f(yI1^>fre-Kz7-{0C-+Mq?5?Dm$rszlj% zwP2hai=Xc1#^)?#(@51j`aCJ^D9k=8(E3A`nmrXxmRrY0dT`B(aX)%GQL|`N6#*5} zC`*nG$C{DMw!=%4AqH%HB6CLaE51-HDIni6X>xK!EpfNOHc&4VjGa#=_QvkhC%JzM zV+`a3F!68{oE2HR(B+*E5-_o1KM4v`Q8);LwW7FPI+^)n)BYOmBJyrNdXHu@+alvF zJfYTeyQd~WMZZZes;3MosxCO@S`ud|D)H;-dsQf$(?DwI86$r)u2|FZJq&4Y*Nm*a zcKfNNs$9~2Iq9vRG8*QdkV{m~+Ew`@dvz9rc6}FVn>_8Zr1E=0rD}9TGgNQyh6T}( zYK*OI6^?Xw3QBuB?85kuctpcE?Z!kl(m2pRa!s_*sZ+yV8`XGGKu z{QHNe%Q3s%y-b$py&BUS^&mrw=WnMoVP6j3hvn6qjO=+M8@Yw zY59ZL-WMa)6dwOv3XQybhmuRg)VT2vjki1|bTKaCV!S*gQ$gF<6bJ-M`yk2*Hl ztEStIAUYt}NLx9QP-^W~Ahf7et_^+f)3c8fWD4r^1!307JTqD%Aw1_7OQDlu`lqPT|L4mH zK4wSyQ>`D*KHdEAzZ1VG4S;8VL$P6|`bD|;{61THuXk8kam$$9&Dg0@^(T9huXNdY zi0ay}k4IWA5^3S2ua7B?1)LuBj~_sUHiDV8I>T1029cQ}uPR&GNbB$`HbrM@Uf&Hh zIxzCt>+%JWyt6v~RVcMTMk(%lWw{s3&QVGajx;zkf1#&-Orry5YawSrq=Ud1A|d4B zJ|3YUzj^xaYRKyNpWRI#N&6NF1}!GVvuNDd5z-{V@@o9@wvuIX@hp2|r_xOvpMhxG zO=SD>OuI_dSbk*0bUxz>OuE;qG^}69^+dzE?f!}M3^BW&n@w{WxITghtsKJgN8n0J z$Ll+RqX?-$4?lWq>y1z7hl@Pu0&I+9H3}hXV32 z9LR(-7P|po2R@?Vzi$}2!H#p5@JlfKDDl`CKI?ugJ~S=|7+nqcaHIpW5@h^%540h+ zBmAO)r!oQ|Rf57z7LN52bRwD2us-+wgh>C99`nCO}=ybtI-PC@BUCbl*`$P5~CIY^kTz!ZoUWT^WH{GLKBGg07*3;s08DYJfP9+BaJ zsr2`Cr?(0H`$Q9z_lc{>H7bKdk&}nyhaBehk9>#8Vco z@DHKvQ#WYOFIPjvv+RCw+MTCrDhe7tm$_v@eF#|6s(;-ZO+phO#^iiug@9q>u!%ho zW~BDnVH08QVq@841_g7D!nAP4Jgkhdf@K)j`f8tJf?34<*N&AmLHAm(k=!pT_yyVz zzK(iJOo(vhb16Vnp2ZPWF-~;JCOshAQE{*~?aT68FEQGdw>em~yne5dRAJITU|vYa zvpDckg`vGf9SZ_cGw9VKSVG6HqZyxKVR>w754;?@dwu~|72J&ka6t~AYam|R_T*(M zRL0ofe`vkO%CL08#MrGKvsYR1!q}*%{={359$KgTQ0?il;d=FSTy;8nnN$>BvkQ>g zh+3*g1xC^7x8NxsyQ5%Sk^naDupd|zUm=ft2wGws8w6{xnaiX1o4NhB> zrtSNDX+Iru{q2I_cg0~tOYwKK>!=EPPQp#z-M?k@5tQALo z>Ux3uv7Bz;OOUfpk?D#2rR5kp*oqdNIPW7#wRpW+zX;M#x+XfwP>jn^#`s#Li9p2= zD9t2T?9@|?C{pTi| zdQnkVXIYD7@lj~Nh(x2oSE>|G#^TU~$(oc=yd1j|H5WOcKK!(Zi79V0*K`P|!#~^u z|JLUu!>Cn&OO60D+hO{U_Y{`9sLXxl@!^SPnLS-jx(sHeM54w{6YrX^(4iU_XuA#)2O-(>X}ch@Ph#D6DlYSnx}ibU&`_OMQ!>0rk(g+{j-dv|eq!YQUbMRA(W1{gz3yXnrv& zWRa^loV})4P|IOiuvqlqRX<$XBGw?d*jL@;cx|FyDtODOE&6A39D{$4bQygHMkMpW z4`gyuTgnI6(n@hTZ>hlm-PMX#Y>? z<~hBhHUvhRxo)E>i{JRpP<7sZ3j(1J@T;ghQAQGPVmldq$Haqty>WL4w+;I$$WGB1 znp6TcL7GCq+JA{ivg1aJm_Yb3;ZDx{Izb5K8%!LZuiH~9T9hCVvr_o4f^oF0kK3r{ z=s;7?5j8Rpr4B88O@AP%CKS<;hr_}hUaE+z@Z#B5%QE<{rPc4JP!mNE!-f{Oa5c!= z^7jCHiInCWHVXL>yAcit+d!Vu>+N<1W3lx$BDWD#FC?nj07OO89gNv}mYbqEpW{&$ zKb|FEDozEA4*R+FQ-|y%P7595>Q5A97~hM73VR1(3O&2A3YF-2j-aBY?^4o!g1UJ^ z2#y>)N^pV6n@yGyY==Jb6Bb2tAeb<=GN(k0(SMDbTy3W=nhbPTLu{)YLqgyy2SZ}#8 z!t%xI>bs1V6Bc~q#;DU0BIoFry^Lw-lKbxf8=dRi_O4 ztmcl74p2n#TJ=4>L9v#MfGs2UQBvaU!%u;lBM~f|DHZE1ESf(xYn8#EhqwDzd0Wnj zg&*3+$hfCvf(>)An^1z{E;xzFaHoqM*1zq7K%9fG6`^-ux0D4>X-Oo>8|B`VD7qjA zOIsW919rZ|`04t>R-p<(WFm&sxPytqyc+LzjO_ckOI=6?@nOtb;4>nKSF7x zpm&EN7Wan6BQRVLFQ)VY5X z=zdvp2ZCtGOck{=+czOy>`GBDokzDBsw{wl@Ap+DWwUd=r)U%>4R%kmFJgNnuNq_% z`NDipByrWReIrnU285dDBoM3VJ69;cK}Lgm3k*!U2)}SY&aq8R0M%M{EP^)apJL?y zbu^yS#OnHxG%?$UEe;s017&8-%DDrD5N_LEo5`rMCj&?Na`tCzMn2 zoyc+u&yPiN=2>BI@TBI*5St9rKgEWrIy}TC=OKm022t!!(w)lvR)>`&lc6d8L3lqy z-puR3hM#~ovMS0>wwJkLvD-=)oceZ_M<2TPS#`+4^ygA8i8T%-R&~+*63Nr#L2 z_t?>DzI2!!F+4UV#&l9$Z)i3K18us_qr%fIEVr6!_@iC}YYPG&TfytlM7Fn(UQh%> zY45qBB1cEyQ;P4#`=@}j2zkC;gKldM#ZehLbnKoH>o|4FTA=-~k==^hTK8p39Uiw{ zL7dN^c&)sX%1DYGI*3H)ieRApBR*&PF>eK7gKnfu#^P85Ke_vYx1vU^X2|_BR3b9N z;Im5NXH2uCBIu3#VE%aH;ACoy0PZ7#DdycKwY@<3(v|4YSNLXQ^R2?Z#}0m%XW=$f zuQ1Lmv~5vPU?@tmQaWqixubPg1011INS}e^AN1)=(Rcx;uf1Po%K6|qfu#;lJVVRw zdZ!Rn z^n>~?0ICK;{Z(Ex6GAY0@pmje2)V@pT9L;{>^^GvZHz^HNr$n)#`rO+Kk ztnEXOB+PW8VbktoAYAZhK)yOMbEU8v90A11P2eyo01((>+swuS7jEvBD-Kg8#-931 z?;bXy07o?c6D>Ww-Zw4${d+Vdc-_{%B2EtCHwnP5GrED8*SGYA03FWskZMM&e~Ci) zg6L-JNAEs;^xd7c{|-b8=8z)Uhz8afT1GL_-%wAU;8K^*f?wlDHnPDAJZd;ETx!shj|67zw`SmyQ!_*98-voPVvh; z32M-N91RK{27W;z0iyOYxo{)>$no#;Uv&P!VDH{eb*NIi$)wCUZzq!os4a>b)T`HL zztf(H3EL(rvL}zb?*e}cQ|Oc`FcBagDn0TxG2t91kwJPPNCcP+d6D}WQ3?HTFJ;uf zYmQcv`Dj`M4g24ohbB~F-KOnBgVIDwN*qjIRECG-;>Pjn3BnOt7>xW3G;3oZoN*$W zBtLQPbIHHif4w`WPDOCQ=M_p6sS5+p&Ks4ZgO$cb37-wAm^r^x@55w9@;VD4qz9h+ zY7iFd#H=$m*Ad$(Tt9>7{x?{&IW!zJl>yYOdmS>GlVB4|8LLNJ$oNkCQ`nRBiCD+C zhH0T=HOJp-jY5?S;|ZLfTOkIY&@7DfSplC2pG&XCOPkE)%g9zT%9&4+3tTSyaN z&F1zkqp1x2R@->Cmxr8~ImSko$(Se7F;8oiCL3S8c37rYlrhxtOi})KBBjd;s!Q(Kk z-iIrP8y>&6E7=V}S?hB;pr=4o~#JzVN?fhQly`Kz71I&gV)%NjJB@Ir(@FU&YSp0PnRT z!hwDtVFg$)Nx=gFRx!~KQP0y#bVCmEzEp)c@#U&sV>shG{Od(qHoKXz7yU| z=+2DGb_x)&%oeFZcA=d(6GN%|Gyw~oELXmTs~^$>ib6p3qfULI`mQ0`;ZQszcVc~( zksZ#?w6s!nER7;{EW||5{S_tH@B#o(B81?;5YhXT3mu1m-{f>AKDht>vI?1+m(b^M80m`|Ja95#TOg<`m>CCB#>SSss(@$p6>vHaLz6J;9^jZ!K3@g~k@@JM%8j5Nn6+n(EWK`EyL(GekAp%EA(0$Ux z(&BvTrO$z3(-!ny17A2LYIp?OSE`c6`bat6`t^C6{YrMQswmptiFVoZC zW>-|$1eUaBc59K%ybhIk3_{C%K*f1z3d_62XrK8#_2yE4OENX}aiHppy?lPGf$|Pl zlIL-5)h*!S@gx8`INg$9XZM>`&HdCCKY6olnGi2|{a?n9?iAe#Nd zm`oyWaTQ9g;8EvL_X|AIdD{Lwu`yhS_d#5B)IFQxZ<;oCEdM;nq_iM-J5sjcz6|IxYMieL+clP>5M`M>@|dQ%9Y@yUUsTkYND=vq=B#xeALc z{%HnB{@o9Ji0ozQ@9ZY*AH9gxOaGXqq7)Vli`N2Is@x=jqpk@qg@Lo4zwWYK72^O* zbV@)V)}fc;>7pew&RvQ-%%=gLkiF~!IU)NZcDb?4HCRTB&Wj#QsM=2Ze=pGY*xrG< zqms7LY^tIVR6N5B=Fwo_9}5Xvt9LUQP#8!&XF42&7Yw8UYfwUi!FE~&MZ-P_6Ghgr zl(?Qz)8`u2+vBo9(HUf_rC(W?kT~et2bCPao~DTuB~Fv`j?y~p>kctG^I}_mCeGI- zi`~tqWy_t{M%s;rf3Jj=y*4rfAOB{T#>6Z;&U}-@`Qf>2Yd%wDsbW1$9TO8X?=l0Y zI0#NlO{IXxGPni>YGE-{^)oQ+xb7F-bFGrTiCEp#Iur@SEBtP+aqmrJSKbIn`O0mf zMUJf(ZubihEoX%S4O@3Gp}L25EVMVZrFqaK=po)jOVD;S7!TfuFZ=WR26^+vH+*p3 z&?_l=sll#l2sqV8mQnVCmBIDKcOIg!;}1}2ugRDOuu}I1zF;m`(JFmg>-xdg!bKYw zwBHFB3)oOXejVYahHfJmU_J|Up^U$G!9vJ>PFqxsg4)ynR-f)-W0@F5&ryX2?#uv3 zFtUosLWAm_VAR>nh*20nFLOu7Pinzo8pumUvHM+NC1!$W>FnrOsm3S| z6U>Ti&yYjZZ)VfAs)F_m}$3yNynwd#@Zu zc{RMwj#?ijAP3WcA-%#lNaV9*=7&-H)%ewC81d$lw?=T;ZL`_&moYzDFo|txW$_K; zCcR&b`RbBrk)6Ri7ISw-m@_vR7jFF)m7bO*2IY;FjH?>HwMRcGs;Z92{QufokrTld|N0A;Uh^x~eY(Eo{Sv@yvAHeLZ;qwy2423#_UOT0!C zgx&XHR)H7|0%74TlyK58VX_4>VfwVekqNB?$log{B|_i@)tFOCG9(Fu)0k+3YJ^HPx(yqYr`zXX7zEj;l)pBJ-fE*!I%#J zGUTl-ebBI(hKA>2ea;^lRHg5*aP%hGpv#6Qlg}@azIB^9Dc*Z9Fz|H!j=*4QbN=${b0>3t_8qMpp;(cbQXl~{cR)sh2 zcbe>4-h6wV}y5Kth!dc03@BFfd4RL}{kR3e7N*+w;cj!hRNOPMrZ1dFW zdwj-+sg=aY8_3&M)B@5*o*oI8!u)-rVwOL|HhM%;(PW$CPTRG4*rDetDRS@XTYW6M ziXngHCLAAZvqZ>L;r@A)DM;gW#251Me5{)CzdL?zTM?i50kzgL#lg4z$HtHRN~`ke zWUkp#G;wsc!J--+8Rv8rAKh~I0I$fL8oZoWPVx~18pw;Rm~ z1!zPNT;G%3+cT;2e`2rp!`yUZY^0nerS`8Aydanaxs6RbQHFsFu@&pX%3Eg(_Q|;i z7Q%rO$(ZymAU19ko)MQRH?BVxH!{P&RqO}}7KL`az^Pe9*kJ0Uv$K3zTVz_o+x7t8 zLb5r8r0Np~c9UVqgiu0lWZG@CvB@0bsX=hf;wxPcv-NmK_@|@Eyl}3s4_|lvuD7S> z{M>>p%hv9=Tr@$*hdyq(B^E$zwYEyCe(&6ghGPvfkc@9JP&gS~~xX<=uch^ZYIFP`T zof0)u1>8-DXhjeCkVYE^7RDMy3z8C~Q>INt{rd`|N0c*xnOx#MsHnV;NCE2FFFY({ zcLfv|rt3g`kneNMl9;@W48HvtEUMqpPJ=?grR6xFM*vo2WpVy|-7&XB#!2(&oG`ey zU-~JWojj{82Ywqa#Y_;cN|fUdXTV&3>~v0XHxfI)jnft%NXq~m_J!PzOP#hrg^>NbY_Hm}knuDsDCHa=b&HzOQ4;j88oN#U zm#Zy_LO`mjVRpzbmlvDR8#jGa5@6%-0n6;{Ti^k@gH&mtF)r~yUK*EB&kL+ScX&UX z02JhTIOkeusMiu`O`n2{tB|QSPnL*hj%!yE@;ye3rJKQYAtCT{e9xo9yA~4_`XGW2 zqJNM%9uuUvnj4c3?=U1nO?izprwnH%XEZm6M4ylm6HiPe8JTSB+NuVAZM;Hh9yXHh zJY|13%hj12DnYK9gMl^ua@46+k|7+#=r9EG)AS~5y26FhY$SK5~BgS!Vwi*J)xF zFz=>9l?cnp8PG0e} ze^Cgy@bQ(CM^}P0*b$@s;9BHHL902}IH`K;Yq>0w(Xo@r;-yI+6q)j8<*3;v>L~c* ziLW-aqSh2z5rGn%Q?dU!V1+pq04ykE{Fhxxk%8GWi7>XcH2Y(lQAhf;MRt3D0^{sj zq2s43Pdw;3g`T|CX1l&-%Ncx`7yab@5Qe-5Ana2FED!UXPAX(8Vt=R*XCD={&AQXs zV)IhL#)3e&$*W_rj`2tdSxgf!@)^z}mx7MdYzq!oR3+Nb2fYdfY02?387t4KSmdd8 z5X3#5E!!Tf?=!X;sH&=}>)}ToN|i1?orHJKIIay`ETmT05hyE!tqnSoL5A=qq=LJq zKAy82V_h_$rM5l&%-((BkIQ@_uKXY@j)y$GPfE@4bncVyaE%)hf>F-|)PGHgsEav6 z#FYy>Mfk})qEyqFG`PeCdMv#fG%W#IkA3;$VZEW$wGMY$p z&`tvya4c-q=9)E^h2=CMyxWilovR72u)l}b8{`+lK!k`XV1`RcuY#`90)mJRnmmq% zKS!&oGygjhjn-qrF9}j$G)E>)C^V=+0iXo=F#AIdvMFA(m(KIE>!6-`vLylz6J*8L zz^lg^Y#n)li3{kw{Z-H7=VD1sr(uD=zI@AdX3fJR9{KOe81&Eqh_$=zmdE+4 z8I8j}++4lLx9HF-`_!YROdk|liW9>@ZEE3&!KiJ|@8l2@*giqgw=KwByKV{y0_C|> zHpb$x9~s&1!zRJUtIT)vZRUl?>%RY9UAL(m!?^awk^YsK_r{UtLO&``_SMc0g{WWY ziOL9YVuuK#=RCbdW4L9`b)If|5r*2MeM#Nh(p^|_GA?kq-BPsA@2}>UIa?k7_1klp z6_uFOFUkuFv1f@_I?vu+@r!5Nm8~z`nRfqHKT0xyfNe-^={tFmU-wbiZfyEcLxr*W zEw5vdy>iKlD+~k8y?;~G^alp9a7OBaT_VWBCHo5|vV-9ull8?qy>mxEaWHEPGbv$c ze^wQ-F@n3ySm;*kdEnuHaGo9qS<=CD70?xa@s3Q!nSl@yS3|B9x`qaoy(@H(9QEg4 z-AwCuT|JXb|570E0PmpVko_~uCa%ufGzM*WRC4&&d#3GI)0?*h->(=w5xfH?T+1h<(Fhrz5u^tyC{^k{Qvs0r%CXcwiZn6XKW-{=qk zn+|IGDjXu3xsY{d0 zX<~XZn8u}M@r&Ab0LZ1twA}h%F&nwB&TBB1P2EKH@aFTEbFz=@ZL2O8xkGK48vI0s z_QxBewT7uWE|`&MA_MHvc}l=1iI=!W?{0n!-mA_VhKi?@P1FFDI0$K5T_`g~kRo}7 zpm6_wlkH607nY=d3d?#H&EL~|Z&D43ejGfVFSG&5NG!M$5}`6X|D8~M>!{dz4H@62 zR_LqxI|2sZ7aM4fv3<@v3#1QxUxl39V&)@nH#hx}Lg*0zhrRVO33^LzKj{!V(6-zV zA_jtfj+VEYuBdRAw{W9c2WuB^5KjJCUsW{z&L}xMIqQrx>e@bauJO!@0;y z;87x(LD|R0=_zwI(TLiuB|up;E#>xl;sxgOW294{Dy3tnfDzgM zntoX8d0@7`?a9f{1eHm2I$z<1D?ph(7`2#~D$oI(49Qr<9-55YZsI+IuO)bRS`YVG zw4Z*2_F_z*$ZwNf_u#)>qcPH%?h@(jZP31|@0}5RQz!NRQS}yVQAX|BFf$A>bVnbOaCBK}2uCt;PU{_IgYhDnlT($VebLQx! z(%-+n{Z6Ngx9B=m&1nC0fI(P#O;X6t&TF)IV+kA+p6dkz-j#1W30-Bf8X z<8%U`vOf*(#z1B9{Eeq$vXWk8vzBRs;U54lvShI17|jla+^j{1(8&4v5_d8qVGPUx+zJH%zV%1Ujij8hE&t|h`D;W2gE6c5w}G&* zFkvIiSUuusAYE-lJEDS=)}fp|tXE*ZGIWA2dWh)CVU5gOhNJN(*?H_$3lFb=!oO*a z{HbTx{9^~+)MEI`+r`JrSk0{h8TQr!xAa~!Gs0_JuQ=B2IABXhqXd>k=~sPcg#^}m z53=mCIXx;QaDiZvP#Eeqwk)aKajNQZW5Fw&@V(>h)s;}%5uC7kJ$!=FR&NX@MPP#< zN`T*uP_*Q8>2v`vV7BnYkrda6{Wa41_4-H8z>J@ zR0Z5tBt-lcV4N>dl93{8R`TT)f1|&Y0mK(7TtJy!PAelkPpj(x4xN~NYOjfn2&=?v z5!N45!swRz&N$cWN#kDkc8=Y1Wehj<@43CkU#Ml8FUa}~b2b{{9+AN-X{nQi`U;-w!@Hf`Jb>E&l!{$MKp@A9ua z%P1o99}fTBpZyHL;Y^{_I^BGEBxrBiQr8fBt$L#ja`C}BBSyph1-1=De8f$yj(3s< zws^n^5TLJQ)TDoid%wL~CojOd@)@f`_@h_%^42jK1&Gpb%Z;ICd3(^S+WTcfBOO+l zucEosXH!y8P@YkdrRch??<-yQT5q}rUh_!@mSu=8ukWIMRnlQR$ER3ZUY^zUE>B4@ zc2?-6%zZu;** zgVZP}d+kc+0i{i=Lt+w2n!XF=IDS^!gpYTJ@vhGu@kM7f=!9EzR28M|d&Km6sg;pQ zJ#F7Rjv}P<{MMF=j*12-Mt7dY+^_Ggy|hyAn=cj|a;+34xH)JIMeaMKk&D&c%lECn ztJg=OQF$&^ijXkp6D?7=_FD|-qSIf`r_M5`$TPf56ZHA?s$00L*cJByr~Jc^*^tuM zf!K}eFKd-%anjb9@SW*z4Y4~-Wl@8E9~_kE3ow*0;V^&1lCFG?G7<9BY+&r&Tu(~E z^Zm@UuIE$=Y-V~}1_~c!F7~64Jq8Z3$4sGTiny^pUzNV2p^8;ekQC)-QXpM7V2-!oWM8Lc zb~mk*1lGtV(e5AjtHtNKT4YwcSNPEw$8WF8UR71r^hM#>+U&0#>um;i>6|u+uLV=| z>+$wBjo(;mc8?AEJq_pmIhsxHslk&^ROqwktBx*uZA0yJrfCxYJhS~tMEl3+&_f!$ zrn2y8Ood#WqZfY6;_$`HhJC@nv>Rvc@(x7M5&XRFJXt8(HSn}L(%Y?S%d@CHEC~3f z*?}?TFuk0gA=J4Q_Dz71L?}M=<9i$ip62@hV(6H+5mU_AXNq`}sAxA#VV}mN&~p$X zmD3{3#O^G7AQl%NSy#u?yuv`w-z!= z>PLT;x{We?=-u)v{aQ;r0*s$B*YsD-KM8T=%F?%k51SzbkqbXV)2(qstUuD*Y^2Ev(lZZ!W<2dS?);Z zY$Kx0EsIckMgL^zUDWG6H^*s-yw-N&l)Gmsp5d?nB>ebld8?Kd+8-qvXAyp6tzj$k zh#vk-&kLSK-C%)VyXet2JbC`ulCh=fgPUD%+$8^;;iQ#HNvZWE-XQhEY-8pmK5i7t zCv|D>I0Oz9umc%^{t)FLP(b)t16B>vRbR48`||PO6VLI*h&97LE5DS9k-2%(+S#E9 z^t19HZy+#Me#$-vT7n6kre*Fnl#{nhaOE6)XmvMSYHj^lGg@%BY;bZlTKeiL{ZpSC(?`gtp6g&}``e7+EGCknHZL=&vR_2^G z#R_h>fn*w|@gPVoARJ(Z0Z?i1{DPClBfhBX`xuHl24v~@1ix2E@bC=(#K*+Mb7!LY zw&Y@^p&7f#etnbs5|_eHV~sOj=2w>}4uAW3*t^GT zx!HH_2f5?IzQyRp9}ZV!&c*Dqueekk#C?uHwo;;xJqiQj6YgJOaWB6JdqIosCXG%; z%eSqw?f=M8ftoJJA*NP*>T-k6-066Co>#2zqxE>=w)1n6r2M=MYj-*G!pmxFL)+th zzw%PaN9O5@g3=h|_n0^dkr@?V;ks6=W!;c*F zoUK`8E|p}y6``>0dKWn8RnZZbOMQGtiG~J}TtU_=)G&qq-0r~mjAVsSp@5s6q;+|6 ztl!rHVd`%kQwS59$(bh!WUeiabjX#QqUwWQa zX_-;GVh%M~9;RRXh`DRVK%i<RXQ!(2F+3CR zQaf}b@vS5`wqi8mQY@>{+?;paO%j>^RUBG!)jUi^q}@9fSq2`{^6JEaL9uKaU*~(N zn@(QuvFb3RfCoE@aWUUQSeh?%jAoZQ%ds0X4aUlJH3eH<6wYgS+xfm8H7wEGKs~Zd zDiDA`4+|2#wc`!M54iSpj+;pS4}W`BKTK8?I-d$!VCV^|Ims`%$!Z3&qK>KPaTEuHx)WG>iSyFYjJAu$=nxRL>9di z_04hEPN+De#b})LYVkGI-}#PWhvhz88*wkfX8@xeacv>~^;qQrXDHXBC%cgvU|RUx z=}uOkZP6b*_fI0dDP-<4qt8BLgSD+h^aY`B`9&4e3BSgGCS?SCXos5Zz$8gFXJTrZ@1k~TIqm`_bq1>haF`!OOLixxv`^IyaB|;2in8iVBila z+x99uRIgtg0k#{7&$VR29Y_ z*Fn+UoPmP=l#c%EW!@#^BR!ew?(N4DSv^Y;wwayQrMZ(s{=`enpmRQ|gEsB&WBk9Vt z36tWcoejpLl75rwX0+X%?~T>luAV!O;r+O=!%g{5sSGj=rjDF02~}}F@Z7upclu~8 zt<$3{w_TjN!*Gm42v7Y%At4tBu_C~Fa?ng~Y%yr3dFU50v$Nh8RU@j*E0rg`VUgka z%Ba0wR}c^gB#N`FPe+b4)zXh^!*-<+GcLpceTtJ3W&NT^j3knQP$Jc(3+Muhl|Zd+ z#}P-KHx*qx%*=Utd0Nzgr$nd4cJO-)9MYKZUa9j{4KiNaBL$@e=haG4pCz^e?-$up zftt6f%iDt@)d7xOsSzn|`|O9#!>_qtc#vY(uRRY{HQoe<0k3U{ehwLTDRKM*S^@uP zOTW61>N$+sbcW($M6p8NQx)i`P@UXl>QUz4gu^8A@ zGk!^65H6jAxygsPf86d{2GvD9_pXgu3=7U`{E2sPhqhUXdpTzvEV%J?7$>>m?e!Sv zjN=8sN7FVtrcXtPy5Ex)l`Y|V+!4$?Jsp)y9q-Z5di3o#$jvfYo!si4czs&AerB%! zHS>N+0GDWn-MM&%jejYgMS;0&G5kKce9i1!f4|-x_m)dvZe!=PhpHJRi}&7mrTC^C z5Ma*n+C75G%pCa+MLNTFOC*!@|T(@g9zTuM~BYk%FVF#@6cur+$G<)N6sB-l6Y{70$6^!G1pSMr;L` zpWc8JC>@xmWB2q$y&E21veIjOGDOyUToNtOF&8Ck+CM*!`(z$dqCYse&?yG(IVqxY zBh=%6!knogNa^bxHQ1${1Wqk3yLTgZNfYD0*hS7`PeYpdFuSblEBPSI$ws0f zOxvZ%&ZAMD5Q~B@U*%tb|J!ac;ul2;Z)6jf%RCrj7Kxbp8`Yzu74Se+w|1%@$`k$U z+D`pK{!U-HMjTGyNrZ`P8(>6#d3a(SC33$+baL;_(Zs^>VdKKDJCu7Nx^LJ1BmU{+ zy^p=|RPK*$YN3yH!CH;sS4+6S)KMb%J1P5fH~#r=z(#@$uf0Ql;Rd0h!4-`1IE7@o znRMliq>KVN-G%^M;+4!e!SE< zVwh()1P;>#FoZ$8H9aVRP|~;(Ge+T;*AYwPvR!+2=jEsHuL}RJE~^NBcx_Tw*K>%) zTVzP*ML;UP!Uz9}Telbv#PH8yD|Mr_(Pv*89jQXgPolCf3|j(R3^Ti{h%I@|_k1D6 zNgc1UaJNS0ec^FWA7~kF5z0lC{9n^TA;}*{d+wFxiK>szjP-7FGMv}z&U>gLG7Sxj z1fCXa?RV^>cE8v7*5{nO_1xuYb;? zqwHDP4zSe0X=h{mzttggjQn^4yJL5HR!o_fEK&ByOV~wQ?ElBbo%MTe(J;;dEN`@+ z5Z|p14usNK|8pAwITG3|5CAz`bm2kVb{a^31+Sbpp82;xaR}(JFY=Wm778Aa?pMG5 z42CA*F$_j1q#?9idsJrrMnyn*Dn2@e+RCX4EBvHCISYML^vNw589@VA|3|V^#{r|$ zCP9M6VzCWvW(RT+LRCIJ5}Mg_k`pX)eCU-edLoM6mJNR$#B_-b>qgWwIqYG|Z3U2+Ai%vUryb0BLK*Bi6?Ko30zq31dxb zqQzFt?8wM3=Dobq;vYQTX{1q$%8Dsi8RvEPK&#p+4JrRd65ACYTjz>>W4{m{h?~f& z-TLG@!+F|Pl6GsgtcmwSH|Rz$8$voE8K?;`9XS}#pC*2u{k{D;B>V9_T(G%WrmE$s zf=rf*z4W6G(6c|C_ddN#9@nWQVFT%Ew`q#=a;ukso`zdvW0|HS6v9KTN}fK~Hs2S^ z&0BCFXJp1~qcCoAp9NVLD^Pk(1LqN}3y%GYo3J8An4Qu8JjQN~m9+=)(T0vSkP&y; ze+EJV%q%kH*qhN%SPl|_f)3CfuUHv9W8v)!IbRHTS8v-pC(Qn_`26PPPp*V83X76~ z+x3Zv?9?O2dqWT|Npooaa1I-5_K#@6s2ASn%)zK~-xpp^p6gZDuBB-hj?YG$Aq0GH zL5)53E7_ppk^Nya<6ZRh@4^ssvlRF9?<)5;prkl>yD0*UVV;zBYb#K+*qhQ~jF0Eo zx>M408OvivdGE^?mgc+-d7CL3%DKg5`m#&B052Uc=1U7tvd>+RPhG~`{N-?s#^&Ar z8CWWiyH2zHWfn9v#}XZywxFJHl-2qhDn9vFK}q!=-}65h@~f3+Q}D^q zX4xR^pJaqh%WIr{g*6>YZe&K^B`>oiXVV+hbql zQ=7qPRP3YWCKy;k_Qggyyj$gSzdYDO-t5a<*EXm490N-@kEtksh{JQlpl9(AgGvb< z`9>Zr&FPyp z3}aDABG4V6%o6)-w{-?`TfG-(zF7cff}U$GX;v@#iTHCrfeZJ z^yk3jEhUfYgZYV1xVu*a+=7JOB_fvWbbF#4H~=?sfcH z9q7Ca`hTu3t8YFI-^xtYre281zAY^S&g?a<|F4BHokDWSvI~8`oB&e zkVqqOp?bTE?Ju*2c7+LYON!i?4tfIfTHbNv?3ZuMvkCio zcAwx{2OQ1GosInOg?NvuuTcpCcDe}u4-I}uTeKQIj3<4$S(jF4r`t;pBI2JZY3n3P zsvROB!rb`OX$98**481ncVh(}tC-=@R9h;TKsHSP(o$B7gJW`g?<7?;7tk=7K$7?LHkhfZawD*VcOd38lD{Ym_zAkqnaBGRN9P!bE?%= z5oL+p1Pz21@&+I82wCpv(I@XFd-OB{0;A?wsR@WsV@%_Kn-Y}nW;8z( z^pT76K@3-?)zPuYcWt$&7#|v@#H3(5+ZQLc7&X9s?B2Q*wt2+-O4sesmb)c7e8+0{ zeA>`nA)Q1hjhQDjyn!Q6pM zN`i>gPgz;Rl*eGAFIo(a0$!-8)lD)%&j6PSuu2zayB!7Ki&27%z)(*B83w?q#L1Sh znTxuKfR9C0Loh(c*A;6}K+*4scSHL~f`AAc39P6$V6X1_0d?Ab<#9e?pBrHH$ZA!hn%|`LWjqneKg{2r2UUB@2kG?QO$wys{$AbRCp>=IL zN<`alo&D40BiOX=aGYwNrjS|ny^@3j&MAKOuY$7MSRq$XM&OTz_H0TO`ajinn{>ED zZ>(Pm&-YUkji?QS0J~a9bwkNh?w{GOzv&WY{CVe{HEx(LfFyVSghToWEv-)%f2Uc- zMd$IXxpeQuqPy3UuQ}(xs7-l1oinm5ohsE&_7$EO9^flLzajPpn4bFjS1$LMtSG?N z1jlmlSOlWNH!sJx3V{Lvyp_x1)A&S(&a7~xyJON{JuQli1)r7G6@0R<;O~pC+;yCh`++dS z6mfR+v_7zY@;1N+>Us9m9b}YJuEcqG#ghJksI)5V9?UB2iMwQu7M8PY`E(R)9}LJ* z%SYTNTU=v*rA}iq#&EUItPycH(FMNw4IH@9k~(_t8aG}ogI# zFDmgUah21pwZkMzv9iU)phQKpNV;%vjQ^#)+us5DP^C&qycYm&rxkY?ufrqXF2oM& zZMjHk1L4y>FKBt?ejAEl#%CN1UC9sgPZp(Ce^hh732y617A8@b7y^uGn?t?z*4|HI zNl4uLNRHt-ZB2VMDvNy_7#J8AIjF?r_PGFppY0zHW%EoPb*j7NGU)KNqkWN?KCH|* z#hG@xVb@EoYBT2NuglNP&*O&61^||0w7kzO;~x=A%5ylRf4dIZ;h6Phc8^eHPtpX< zL*6@EhG|uzjG~PYzGR7XCu!g`Xw28ISn^pc6Nl%$$wM+%R0P*#Vk-l7yT-O(wTwy) zyf3YZ#l_lU#6H0TYQI*dM&S`5TOgk+vPf{$5J1z!9Az&pRH0RT%|HKxFg_!|w}`T{u&vN;t<%{sOK(<}I2Zr<03q}q<4yU(vzdFU_aD0=Gy#V5`hWSS~*QZPdRMM(9 zk-Bxa_!!WEG=baO!Ro4Gk=?4{5B!C6`$utSNmrB%p%#M=x&V`NuG{Aza?-%O`B2}EuApd=^W#atWz=3^GY)}_|V zb|Ka{DHMAT@}FNi*vOAZb(v#wrXj5PEB*R%h@emY&~h%f`=DQ~4z7n2Mo?vD=Az>7 z5(;LigLCW?$z}I%B;334Lih@)!|z*VS{);J-8Vnr=;;QGrn|14er_i3Z}2`BB;j5N z%mvzH-VNw$G@7u#{Jsz{O69f|(TAGyv-tB6n!-&cN?@$DE6nlgqfDaG3KgDEMVKl_ z0w(2~N@7O0eW2uvh1X^Hbs9>F^A$;m{X&p0Ro%{auXkIeWeAUrML9tuAmi~LVO|v* zngxWY!guQ4?g=Jg;AlXk;{2Cb*6`wB6;&lc5O~@9zElK=?_!xgNF2U=ONi+M6*Yfl zs~RW@csk&)=%e`X<89#=Suh?1D>u9iges4a3=ovf!AHmBA?N@RvTjq}JPh}R;VX7s z0>7rR3y`eG-+0M}v}Q7_y$FC*qGeAfQmpoW!4H6=SWGKr5*gCUz$W|6v0TfjjJ`(C_JS0Dd2>s`FK ziH)+ZqeCnpO08OlMW#_SzcdQCI+xqApOOS|E=BFmJ{7#kUUj~yTIJdh^doFlspb-% z{K@z9$KJu&*dmL>faPGMA=Cqt60u0sQ*(3z1KR3HGS^N=0e^d!U zs&voa%|l0y{kDrE4b~?VEZAFw00Zf;ibYjks|cI(ZH?BtN+q(;PAHyvVitX?y-@2p z{DjfCcQ834F_oO(1C0n>rD!ntNiUOHL6YQjFZ`7sE+SSsdGy#qxn|dI zBej3f><*KeELN5uUk?SHd7f>kAiONocx}J^plQSr!>^eXSXB;jB_R=RkoRCk4oCxj z8Ulpm$8z!cnScc9F+mQz4KG5>Wq)p=H_7n#BoNG7Pb0)*y|u%Hqlekg;wxI<$*cX( zljnpv^sxqef|@}L8hC@#9jC7;?AsLb3#@JsCh9V(=7iYy=pI6xc1eB2=?~JMj-)$i z`j*$ZBzp!&0xaHS_-zzfR6#Fmb~7yomwtEA53@lfa%J z%#?ILdvp)yICR7pL&Kb>HFMni?P#&~%a=kW{UM`F?72EJuy)7yNtvP8ibOp3?GwLy zK9E1Q1&|U=P`PbOd}%9&Leh!nggg31affJ~v}YARt`X2H8!4re5z8CN(MvH{8Dzv2 zD-*9XzQ)G#{9O#d^79;jL0JTyJOM1gcPU^Qy$^e*_O%NVVa@k)hxDNx{X{~7c$_#K zi24+>&GFQvN~`^TrzcCAk)T7)XU;SvaYuT~W!U|9&63wjH4#MczNetbwEavI(6lf_ z%(< zVWn>lF1^3NHjha0rQ($z`51c(=in3CRB6%27Ws%2N~xtUciW{-neEkblz9}Rt;)g0 zy~pj$=5%E_YEz~1q|@jC#**-_J0BMNWCoQBN<8FYN@Le7*AS{5e}AS0vK*8eiqwQt z<|7s#XrNSnwF5#EA8%WvNQ(}O)&` zQ$<1bRK0-4dr8O&bGl8uUIkHHQUxyVISx&Bb8G(#_dQdM5PVfx9#&%%qW`9@D#^#US{4ILcGU{xug}^xT3}CTtWKeg*utcw|>c}ulx5o40 z0iE!bxr?zQ0`5DB?+W?r?N3Ckp!)YAgTSUoZ?uUB6?&IL-uFp9WkHa^gBNv#OF}@- zCV$b&_8}Jt=Ocjanx6g$d1CEZtA5-+FFFSL!bOtW{%C;Yv?xk5=dG-Ar#>p>aXv3N zP)7Xb5F?%pQyeO^0)H6$nIgix5wb36>}^HQNsx03{1nA}=E>X$oC}>s=f|#kj z{aFgG`b1x$x!J)hEXVY~kjD}Tk)%+x+1RDimvVmX@mF-p$0f^`1%#H~u*AAzFs$1^ zi0ZnZi(1{uO-5h+D17!bHG00cpVx7Ve&G8HSqv`-0YTHJt=!eA<|QV$Hp|g?Ri0Pl z^tbwisa0o&=2t{$lV6z#rvh62+A8#Kp5>)hKR0!|I?JStB z)v=5$mA)N_xp=&-`6nUH9@9>y5#kk0#9qB9+G43P>LX1{XZDdtJhW;rtp-1akmjD3 z(_`OtHkux02s6Pl7zrdFn|dlA+$tR<#{qX9vBvnhYeem9&e=2rYrq3yjRb5}8Pg>q>d0sqN>|)(^rjYVkAQ#IxKm9U1`ga5b}k+xQ$l z=ySzQ6dIZ^OfUd#;+I*=;f}hugaTlsM$N zQ+z|`4q>q4!P@-Zk@2);fP>dVzSJK9K41`4z*9q1RN6^O_#Ke0f1fXK9{L+4fAx{{ zH}{{wM3$isR1DL8RfbEgMFVQ4%($^~Hgj^4Al@B6SO{dd5HL?8eUJ0McFP64)F*n^ zd0GD2*$?$u(xwFv@wu2|#&a1AtugZ7-=lr|MezyJ`r}53O@{kiV@`fCSjDcTBKfLq zwilN<>0%a$xerE!E5soYpbv4Z@-(f7>Yfo zJS-=NUY?*A7(O-rLy_pwBv8-;%E^-UbqOqLC+39xspDb0(2Tn*^Qm~eP47fr!wAx3Nbe*CC$21lX_1Re;ea(%byn=_mcOIMPq|&0|!)Ok%buI19$=p#3#^|O`F}*5z z)dL-=azyQ-67AT^VK<}HQ31YljpyxwP`bcaiT}=ZI7bSf{0Ki_xjlK#kVZ11cQtKz z#`5^M0K-|nKyzQFPsG?Yum|jqlsC7SUm+`$>Mio#xEenHZ)#X=`Fk;_SQ5>%CS=I9d9;#~Y`!zYs+EF^h zbdg3TK)^%r!HQVSsk3c8kn$$_^#6|z~F~FjpqeTO!?trci>asA-1ebEM@`*Eq@3V4%uz?XQ4NFkG~H9 z(`YUdQF9EBv!n}pg$-2_tAD&GOkm(QtzHqc>0ED_#W2^@>wkvY`7brTRq8j!8{`{^ zz=nRB22ye(`~hXyoB}dwWa)DsKSdO0NP*?Taa@V)XM{c4B1Po-aASdWuF(DEm3*Kr zB7@P3xm^er#!O<>Krbc_JEI#pm{!DlpBn&z69fe|`tY@=wOp=PoJffN@4&!W0?>BF zIi-aceWKdH?k)2fe(GjN43Qzj4JtCBTow@TS2T)LA<|90C)ADRWwlU+Izqo>pB(1# z&JtDJ07(DvyRM==ffKGJr-b!%~TDR$oJDspG3@c`JI`XQoADYEhh0&nR}2VW1~EXUS*=#N0Q) z8lU*O`5cABiWzQ$dS4PaLBZ|2rSHM3&PwM1{3ISX-Ql*4Djli@_@fC$LVk4Ul|=xA znLrpYuQ=cE=P-#jZ-gn!%T_(D%UZiN0}gazdg*0IHbbewnn~3;vTvCke@cL)^v7{Q zHYOhbIzgEWvF}5Q(qi*n0>3Qc6$RTbPls$OuR1-MePK7Z$G5BL9i5#M{5t&_7;;aP z+CKl7uGqNnvGGYb63scy5ANnR+R;iLb=$>CQ8ZnqHN;Z*=$8<4OLF<0WOX@9UglDz zBS@7j-*fwew^k$iRs<>iGkeiKp`%>v{Q@}@1uVFVE@n)YEK-J~jZK)0EB6}t=?Q|! z0O2+H{OL2oxBRrJ{elPqwd)3Aabu zq#nyZE=47Z!dVSKlYp!gEmgBl4UfI%agFG#(nwa*xsO_Dw&~QfTi7~0cmhy9+;!&) zf1f-yr=(;hQ&Uqvd}9}agV9Xh!{E5@8|dR0a*%BlG-4YSZs!{uLCrGgdSu+%A|7h~ zMmFt2T+GO}+0n!cSlC{C)R!6YYO**9p+h7)BZ87l1Azeflae4I0VvR(z*Z3X2r97I zP95@E6u$hMK{B>duk-N^h)u!)SvD)+VU;A|zS2jHG#FB45X56WZje#h61ven%-^s+ zau;tI%VR@nvq3q7_H}p`-P*g;&}>>@%@jL(eXf^r)8y}vY0A$v*57vG{#IV9za%Qj zqjQ5DFozWR-6C8CoujM|sFOJBG|UVb2>VB|1&w!N#~Uf5AO;-kzS$qnyx;%k{8hp9 z1dzPwXKhktq9h`eyw;4dyYTqf>kziSWmpC4cI$D-+oW%CnE)XITOC-=WIU%`<`?dm-n<)Sd}=es|ak; z++sZgf|KUf!M+%Qz24P7ow)TohxMB&#QKW!4ZHAy&>jpAqJSA)4;NbpAR9UV)evky zyJa0C&CXW<`t0A6aDQLl9GAm6w3Mc8-r;GP_azZI6z?2BwSml@i z2X78DnuM`YdbJ-5T&z@6pr>E@EmnaL@fTsYaISiZrytndhbqSbS@#o;pwTqvzgD6Q zp1*&9+G)SZ8L^_EL@gV)rthhWrHx-&&K0RczT7#6_0UEbofl&cUg2;N79>k@?I)&s zQIn)4s`L%8MK4roIR@2)mWdKozP~jd*h2rXy2NKSZLIW1LpC0DH7#~M#hc9bEp-Nd zv0d7mTfh;L>GueH35FpgK%T{N;!D4H$tVd1S?{W^CiUXj`Mv8=JrnL*IH{q5rU#IX zk$Auqtq)(Ls>|8jr@(^#=AOqIJ`7e|IvnZHzN3iA*OX){Q|K*-TG0F~upn{xW}9}B+}!qEy}U@1S%r<84Jujx^pXKH{xH5Qup{=+1!COkTA+O zj{Ck6Ov${Gs7SJcf!!Y9VbrHL(Tlj2YN|TTV`^=IcydKzq-O0 z9g`?9u8c7x@cFDtVTXw+ABWI-vHcpT-Xophra`m?zbW$fQxm=vtHg|slvvxK%OhAK z1HKz_pP5t2?#3eWv0FOt@(oR=gN{C643&S1<@Zq58(x>RE$o$^^Sq$Q`=OQHUL^kY z*?^gq19Y%`O1jwbG(Ggnsh9L@fHr6(!Fyog4_(A?XYNvf*J0sUbzg zIoq?7rO3iBud)Jo28-25BSUb7ilbKjFbOH=*;6VrArc}^C|A6pHR$(kI%C7SK#;-D@RIWOeo}D=hea1qosS2?vw+V4Cf_3hUW}a3VFLByer)rhY=4`Y)Ms zDoMqUGQQ(~QCWDkAka_h@+QIvr9QgYPaqG5PY7`6a)!piy||5a`M~`OJ{THi(46#q z=1fJmH`Hxh5q(}g8SOzTCh(>C%DM6F)I3b%VRVG5q?YC(HG!PLe|c+8%W>;U@=e)X zSd$z+Si&df+Yhbf$JZx8(+6H+uF~sRsr$qI9pm~!vPG_~=?34vDbVrmTYS*zTc~!j z1UALLJ5!7pQF8f!1t(AkDL0pAzCe2p@Fm!@F!4*p?EFVB%BQBCZwvv6g;y*qt&Z=Z zN>eW)RO;T)G0i`ThUgW3cpnb58%zRYR(*(Fo2uTdKr2093InL*$aw~M3HC^ds-Q_c z-^jDqK`Hfb?D%LTK>^81k}R9J?V#MVk+pWv{n`upWjYc`4amBSxy-(_`Bi9yh#Out z*?+!Bzag{)J>ps9skdmPne}1%_z!w|!X@A-(C)_X`FBcpc#>0n1N_NhEh(*bLO!fJ zaziy4mst&Ai$O0S!n*7}!{?WI1`yk3vE1J4~$BffoW@Yq)~ zGxrI}%qKIlU-~1g#)F~AA79b#N z@}Jh+=r&7H4|;BS6(&vJ6{T<9q+yn{df=H~Sy^y94NUh!)-i$ts(Znmu^wYH*o&im+3DR}8JU*z2 z?6px;Czo)~K{l_gxIIewYJli<)RrslC}j0j}NJ z*xBhlR4^9C_THTrs`S#*^jD4Px-OyrReyfOX&Qw@NUOap%;du;2zUI8{5s>dLMfQt zEVIY;nQWztIUMz`j9=J|29g%+8lXdF`y^FsuK(Fl+D(zK_5LKl!)PB7i=gCMZEUAL zK956JlF~i-_`c7AKHpn#p~$H_T$Y$HUW8P#S#g;p1NSIPHl_8F+#;S9itFtromH_$ zP%!WIr*9Ilpa0?&el{gfbeHDi@NhYl>qic7oqdUScW#H~IG2x`falg)L7_aH`-&;H zK#t1l$V#6$WU_SLsUqo&2Ijw9tf%$bYX>gKts7omYuj;IjF)$@;&XR&OGi*d8Ra%l zY?A(5_)hcA12?=a!sV#ANur0AR4bp0%Akym#zmxA$yubiK+k1U&FhE7psyxY;7;%P z7uokkH)DngERTL1wMfkOHlv0dV>a6IVEzerZ44CeCeqKXihk|s-rQDZ9KI6&1J}>o zKa3XXFTMRu>IMwSx>Tv#dUPb)OwejE=oOG?kvCErnseAHUD;j@nE6Bkx4u#T*C?cP zCa=cG|BWoOGrss12Nd8tZqf`7Sp4PZgMhu09y*yG;R6Ns!o^wRoFNH>&Bu$k;aWez zjfD|MP-0?@{Je;M(oBgg;w0Xpq%#;y;5d{6n64Wvf@7^;iJVZKZA@^oPYP5KoS+%P z8r+$s)caraIkMr+H-$Q43$EP+9r0LneT-Zr2X-!)^5*u@1!1i&(`Dj#Ey=iFQi9J5 z%E&8@F<;u&NH`CpFisWnT9JwX0f-j7bibQbsxHy zxb!jXOgJFpvE7nYT5^H@xOgWuwb*~ohvkG%sOCVUsAwliD@Yq;%DifPh_|owE}V>Q zE&z(=o{|>o+@WQvz5YgqV>S#}(`>X{bO1-C6&!HR%(C@Mafy+}Xr(7;diks)cU#;H zU1}2$9u{43mb{Rjoex3e&h?n#RCVnvrnDTWA$d!kUDd6iow{zHEGF*V!b4GcFCzCS zozRNHjqSQ+)?aTk)TO|4{vTos>u4`^TU5Zw^47ihjEBfE>4NO`Sq-gR_Un@*Qr6|J zy%@D1q`y*$B7s#0_z4^)$YX~ut$|%#7soeTGxR|op@{#r3QPVasIssVs-7y6v61x( zf#}DHD-tR`* zA;d)tQW)oPvsVbBK*ja2y0(JE^u88gj}EY^`*go)XWCkT%+VV=H4KE<>Wfp$S8O&N zPtAGCoz33+q{w?o;PzI<4oRFcFiJ>_l`k#T_xma|)-LG?98LHomJX+2P`Q$f|L*+q z795yt+3(Mun3C8)kl5s!d$Ip|;*EZ>{bgqXSKwF00W6<>U(SYG8~Nm$g5CM3zT+}V zp2P0+SPHR{ys^SM5~~o~biw<9s@M5-FDwm?fON6Dvz2t9;oo#fjski>BgZIv6-xcB zZBKPU?3){jd0UT3GJL4}iKmFqfY?{}J%n>#l4jSV@CJ7fQYXnPQ$mT<5FgOoF0tIr>A<$yIUx`mirg1Q2yE(#R8(Dy zXV9Jwk*@;#Q){8ghhnG^wuSml4&_j8gP#VR0sP)}F*Cga>wiAN@w2?1n4l z)TddWHoM37-!zK3{yoCxc=LVrJlOu~Nwx0GKh`w5hG`d#E&(Ds%BbXLqXaHqWm2)* z6@I!a+@2fhcFQ(geDkL%(UJ-m!{?cf01f!6T92y(2}VX%(T7pl-Lsb^tAqF=3No2E zDvE1TMj#9CQsLQ%xZlBunP)v5$zvnqsGR~3ummIY^T(!OJ_fLTRtnuL#bPibCo7D? zt`6l00J!~ZEwS&^sp)aLa$H%?cd@Ob2?sWAjmFv(L!x|}!^E}k8U2uU2!+Xw;_~{= zRP_$k$Bs9)S(pM*_9_%3H$u0F1@SH2gh2NFG!04!UI1tw|Qm~ack>;}$a{vUIUg-bg9pKS$e{Wy1I=a}^s{Z=KC0#^Yz3L^0jb^&h z@s+f6{Nl=rjYcoU;-MJ1Y^jy7(I)Qq;6H6pYz%3|CX#)A@4e^STmHSXX1ev)z>{=b zcyZaF79Wrce!6mo^0^1&Is_unBWlwSbYupyB?kkaDaTN3m5T2XurE|is-9jMB#8u-yu62QejI47V$0K)-V z?DyCSv4n?LG#uJ8fpBE>hMRx89w{gH^~7D1nnRKjA6uzdfJ#Te2=WGuh%cxv~oNgx(oOswN{Nod-|;=7u*_}putw)O)XgX=q7sUp$v%C|?;GA15s0$!-P);Io4I1781 z!5f5;w?-8{CokbzR3}Vhb|cdbeRi=wLHQ6r)=$>$+OP@LbQ2Q#Al@@J`=&yCOk6Y1 zFD!$N(wrlHaO;pg^Ens1(Di;o)CY_IJ`HmC6aGKuMBn8p>woYdB#}twHFuS4%5RmE zM!f$hl2oD@QGb^@bJYPP2;+LIK_`9SmZW@f3_?uosw|AWy_a>aVwKYDuD`XZ?ww)V zRKWRC>+P?MwlEPk`0FDGBcD{wj$gE@{p9G+@ncJG5eu-z5@Zkj5 z5oq~5S)uruR(r7pRiTbGqkYg~D`j`d`wU|tE#KEssP}2xZDL6WsN92wmDz<+vRJOA z*4x9GvR>9#Fus^cSrEOX?@D4nrZJ~5P#mVkRZrcDU&#FUZk?=B(l@S^jwTq&6xw`dR{LN8zms;-d0y9M2*k0aLqf`%KfO5_DKRo%^909c`uAxBM43^z z@3hVjFnz136!&sAT0E#UYaiqy;PHMZ!yn)L7CoC`I zx48aHU)h=Y&+xb-Sx$Gey(#5pli`(j_weCV-sk2|CIQ}BTLfw8*hOI>QKL<~t^L*yK{~Cu`aVY$0NJYzTp(@x(2f3WE`Y=EA73y)Qt#9+XU5jGD zU17hE*?H~ym1CyFVpAq<64HWDcF-)C8q4n=gzOb&INBi4!Cg9};2PC#mY!=a>QFW4)$F29)B^kZh z9H`sQ*4Mj4NEW7!Or6$3JMG6y5+~HQsgiXWV8lYt`=X4<=7N#^g?RTq)7}H)>dR=t zz2@K#iIR*Kb5iRQ@tA*+W43p_e{b7sl6*~XE~(LL#Yyst7GP#)uE1$-`R)>yO;kqM zZh_%yfRk&8`J0uG0spmw%$2 zW*~0T8gk@{)=cCvKDn$bSwJm0MQ)wdqog%x&t-Nkee)Q27xQZEwvH zZD_lvP>*g`8GvHBw_>v7eMo`5*3Fd-8NE!th#8l&*yGFM)$-aAx-)4}s0Zq%=k{$U zVF;qlY{UuB?fLC~cdxmmjYy0ZUKG=iHT9?<2qoS7d81h%V2qBwW^o@?>35VgJtPBg zj|ZM~z5?5wqz2ZWhk0#ZtXtTbd5#r-Wwi~6I~}LFG^?i{4AT#fl+q7>vDxNA%FApU zkhD7{@SkfiTFY60UuJ8^cg%jM@DXs4Qerk+N50r^EtUcbsv-x0A-0c=OW$!kDQ#Gw`!hV+73I4!E>xHee?T_mo*n+nZQtJ6eJcv8 zlLVF77c8a70C*j#mT3Iw2{8alQXy>#;7oZi3?W+?OozyC_U1f%tA_CgTT@{Z%_2!B z;Y%~7U@_WBeNksT?s@BNY}eSN@m@myZi+!nbQIn7rr z5ny~+_&J#e+E{R=KOn;KZKSmQ8y*i6CWQ(;Yr+^h7z7g$x%gzpU?m?i+vKjIRika- zXZwc#EL9v=f_NuU(uR7L>|Q+&XL>~7PbzNzEQV%<)Ol#Zcqp&SXEY6(yWXe6KwB2d zm;_h$+TsJ0aDXa#va2JvlwbCp$VE)v*O|cYA{l(NEG$+#4~3U#XqXWn&++wpDunlY z1UWcbW4}y@k1&+V&aX(cTbYM1&?mFJZ43FmX5SONCd5B25Bvx)@Zv&ZEQgjgiW z7$_{h3k^nTS`<2T-AWZ8CKNiYOb=O3P<~tLID;mqW{MGi5QV4A068LfT&ggd_$u^% zlR0)^J1C=t`NiS4C|)LVB)*Uny8B!vy8UKBgFxa49iT1grNOn{@&Zo9+w{e^@}`Ez zl*~wJXVabPf=olji0@5mRJ_=hA8FF=g2UDcKJ?#6wl^5%3WxuO%`g z{2As(mKfGEqwn+Y&Jp$}0fV4y9NQI!K>7FlWn2p^aaOga*ldc}3}3~hO?jCa-{I4# z3xBs=e79?k9S=a1>dGD-0LF)pkwXq|V?SiQ)1oD^I%`4L>=nI;$_nlr)+kEz z{pLIM^!n~r)j`CCC_q~QvissoCMlKa8+hA4f7<(noE#1Jl_#vYTAJ(B%q2Mlp~@YX zFqsB*A|bQsT#RI>s=x&^4(z6YH%s~`LqQNSa6(N)FjEl`u*hS7u4Co!1N=8-@`ARN zsF#f$pT~!Wsv`-)77vXwqH2pbj_tyXr(-Pz2Bd%JidO^Z5)pk7Q-q6ZsXT-B;@(sF z-W7VCK`}DCqa{`sL{<9MgGsCJInM*5UJuDH=Ax&&9jZp@VN8(%21qN*KnGF!(|>|e=eiCK zPo;J@vzl7F{{mwX2&*caRNc$_gnWN}y?r~iO@~;$srdF)AbA*@-!m#ec?>5JrRQ1E z%F^>EdIhUgY-?m{?@NSQ9k%r;n}W;&g_YArq`V?Kk0vq@jclvxRn=6>4Zvpa4Y}(| z@*8hZziWRQApeV-i@Zt4pV-(8B&YQ5XLo%w5Qo9UdZCnKbGD#3-{ilI>E7%!($5E( zT60P4>5eOwTJas|7p5bON=~zQN&-wQH{i10r9gH!iZarJ5Q_FHP(Sr?Bt#@ebZV}& zu~aPj_Je85%@EPcR)p+s?lE6RIm?NPsFlzQ+mYUH{5_3pa_oF{x-fY!Wzt@gT(`yh z%iaL2WfXm6Bz#$TC1RSA&Kdyk^h(ES{5@&ZprcuNP?Q|Vn9y?;;ocG>ee%AeZj@?rj0 zhiZcF@szo$;c5gov5}9kU=42eqJ$scLQb0uUxU3O*CsN9@0vovWcD4%rxUpO7kKRb zaQ1OH0o^6r4bLh0zTe#%zoP$J@0tWnsBn(L><_mrbsj4dCQdOqY3U8Nm`R4%m}yXM zNQgTTQG)f5wwGzh01G+h^_|79rv9b6SF*U=PBpXOH|1@iH^0POe?OQMPcFxXNA}nJ zZ6J)vvD^}Npu>J4Otv1z#9_~-sgH#Rc>H||EvCEDQQL3>+y(a6*4he2aNNlH<*{68 zels7dONBQvvGT(-kd>+EjJ9h4U$a?{)iyOLZz6ddyLcoo<(q_-1D-!$*?3%I!-v28 zLNj&2g1SfJceD_k`ZINLE5Xw8+*69LaT#c>c&AGq&!h&gc1TCuH$2^ajadRBm6~;P zWfw6Vg0hy2-MiD^$kOG*?SsFOTRyx?C|$!7F51#zzGw22VK|6Z0}1d&*0wUO@ZXbC zJ5oU`HC1q0`wh;}A0oOVXS0HXxQ`x!VTkVa=o$WKEY`M;ETK`ps0SFz%kuctN!JCz zU{KWpDaHAIpq*()V5*N&&+$EhJAa`weLOt%I1P;~o6jiq~aR|Fc zm($J3d;(75TzrU8e81L_g`4UB~#|xUXHGj1I zF18u(FB$7Ye0Q%Yxc6$`G9M`$h%hB=Caoz)5NcW60-h2{{F8= zd6*p=#-H&XCU46@(D_}8_ETc*;) z4|{B2sKH@M03n7htd;{!GImvWGhz1`-L687|y5$_Uze zv*$V?gXr}(@^bB2kEi5AAd_&`)=kdqO)A z7y#KA+>=H%8&eKKtd|^x%>NRGoGE`9`~i|^UBsL7efuz$PUWFQ!dP!?3z=AJZU~KP zWt!luF#q{3B#wYs%f&6UXf1he7>rJ!bV$#)IWtUmjh+pSdoW_8g2Tlwew`Q6`a^zyh#P6zVsnAJp={3yzH=Q^HWMdX|Zt7z@ zPWKpz0)H2~I;&TQ+I5VYGu~CcRWv?Xu~D0RaQwkM*a-Ga#lWM|MhxL&0+q2zDeSkS z#)G}Ax$;s;c9{5I2W#KAO+^>Umv#9eH#Rn2#AX9z_shiEW^H-zm#{xI-p8Mw%Y6)6 zi&v)g2?G039M<<>?UY;026a>^xp&e^WeHsTb`}a!yp%o=CiNZ957^0XKS?j{TtBYJ zRi2po z2b>$OzWwM@4IdZse{@j#zDgB*faW0WE(IP-1~}1e_&sx7Rc{P^i*Dv|-+w3Y*ffm@ z6<6t5e_8w*4osulq08@}y+Zfj;=RRlpttVpVIv3?%9DS(;$y7jDE%18%BuB|C}zz^ zCG#EJX~$OtDgvWp64hgv|70isS`qstvpp))G=Ah$IiBQ4WEmEYa1IB8z9IISlVVi4 zIJybRA#(jL9uvGA>R74lg@N_ARo;VN^I|*2~$~%N2o7J>^JW3w<_i1OE9tv}gq1QI_$T3BM12{jV$39$GJ& zoHVxd#-JuXfTQTHJEZ;mZd6Hii$DCZ=5d!^H%yInqk7)C<4d}t*HN&l%K4GYX__I* z+8}d?C*x(dABYxD#i-ioty+!e@!xdK7`3>Nt(G2cepL9o?=L^r^mxagcS7(F z_bhPZgWsMLy>@!W=v%Mfi_}462KC=A5_D0diA{4v;z$)$QzUi2W_{(G&k==|``=sM zr5I;P)H(iBnAfEmo>oMs(t-j2#BatjJLf^1{t|C}u)}-k+8(o0sM^Fp^3^Jd=Dz!- zHyYl3+73U67&xlK)p$h5C!ALs4sAjdLSA>B`j4B5;lxzH8~9HK$8)N=DTL2ADpD`9 zgg{zINR<_Uk3vv7_4Cr*h?rGrkdRFT34Do`r$?Bp807))wUVwhW&nIC(T@{6{%O;_ zsNg_XGz`^Z^%yn|$WQ=M|L?s+q}J?o-DC^e7C+X?Fl0k$5Etu~p$>n>an;%8W__(E z#c(GI9GUnr+Z?|pM(1qC2?cO~X70wms@gh`e;#ca)^u!H?ZW*8>J=GbVWWc{{|Rs* ztD~@pbOCBEM-=O@q`)A=h{!);0F|?{j77mWtV+usD4&d`K(eVicszD&9Gyw{DQ#%@ zbBkbJcWQdRbZsR(Ay-~1*>9GABF<(S4^aW=b$6!Ld5c_g<|I&rfk$*K(9Vy4hIxY` z{;z_?&LVL*lKpfZF#~^}v@;sd-&mh?s;JT?5-8b$6RHt`Mb{ea{_GB-sQJI6KOLHN z8=&Ixl#&H5E8^88fJ6RnViDk>i@g%f{)_yLD{NNv+DRzV@HoW~#=oet$z?(0Z3G8d z<;?^gPv_ujAPiKct!^i0c;^gW?$Gx)US^0&yZwoPKuk4*0yNf#VPlv!av4-n>7AL0 zss3&xA>Xi{eLtP_=<9pw$Nk@__kKsn5T(H%U3E&)?0Gb^G~auq{!~)+Yf)heA8Eqa z!s$Sz4=*(@I+V1^VxU40O+7cBZ51~V4+b$GMaME|AfNN1`raHPc=!o~sTx|qfsy@{ z{gVO$8`}*tWNYd64OREM@T79#cSBh5eAgqMN?CPSZzt4?qQv(M9?x9eyBr)XhdLuX zIoyumA0Hl^VRO(^tcEI0EeD@SDDt}7@b1xw#Nn%AKu*Y@RZhGt=`TFC1GO`?%ZsSR zrMWRm%2_8AMDr%Io$f^oLe!GNjg{TbaoJxuyFYDAHD*T{ImA^3EIAIt-ZhqE;{N`< zQ>p@XX~*Cmi{Fv|gl;z$SGecEl$V+Ub2&s|#LA8vX^BeshXaihpi&;yc75D3pQqy1 zmH{jbDhBUQ*S41tc)c)~FUj+EI+k{sxdz=)%)EY~6nsFnpS6Kb*bfM!J@x+wgXe#R z_rB4KtH;;Vp4i!kU#ET{0^!|Qqb@UICO1(w+c-9PX8Bqk9GhfU^i+Tb7w-~^fK_mQ zssTzk9dovb@f3Q4XO%Co<6yzT^LT0P{@?Az!Uy%RU2J+ZHk}c*eRly`}?gYySC|{FwnfO;d(YIL!JX%$uBp6{n3w3yM`Y6XyW&IG* zC(L^0I~VaK>?w0(S^C%nh`ajtdc1vvWM)YV%oMmDzHtS&MgkTBi)s!IBqj=ZwlL~4 z%on=KCt8M1JQhs1**#3QGyS==SrfE9D6dt{ELP6ON7j53?`Sd_o&n4}G~KBwkc7J-;2=TRpC&ge`pa@dr5%13bD-VO$|!vybnd9?xbjCnmne6lH%*&9))n@SKL%aHriOhIRn}S}l@YtNY@XlJ% z@RHXPmi6Abjgwp4%m&h0@DuHC(a5-8*`R<{GCN+KH+aSU*r}ZjSq!zAr({Ne% zwQ+nH{U0q0r=W(?lJ^h!-p7?~Eqxl19g_J&W?;V}c$8OQxf$z69e{Ccrdoo$(De^M z*=-`T+G8{nM^|&N8e;$YJK>%ZWpM^S0fkYP5j|u{=)%Prc zc7S3|#+j6hBFsn*>bp;ik^S1|8n!UON7+3&WI`P2aoTq-3XJLb5fbWC3;=RF>l8f5 ziQ0|D7kw+FBF^>(c^czbpjcbj&JwB7@DXATO+btE_|`s0g2%9iOQr_<8RW}EbtCds zl{5iEigB<#co0S==vWNJq7+fbv5hgRMJlpG^7Cav@M0}viVPba?}3wUT#n72kSis zD-}e~*H7VSxu#!g$c^xMEh*`(ogytrE^*{0H=txg=+}4jt{XHXeJs)hJS1tIN#^6? zVxm0LKDv^j=BHu==7fuuTTc@6qt#a-ZF46NNSOgFyC(|tJ7GB{N*VQpu5X5|&*iXo z4wl96QyW9`^cdaa{)mSTS4K{MDdF+L2=#P9K}HIE1K#34#{0Za{W?h}J?9K~5p(<0 zd)n9Ip)7?lyp>Y^D)5_<{Ms+bt`HkzX;#({4ChMMPD0wG{hVsLxdh6@Ooc;X zXF_8EpB9)vGMV4C?)5oDW^$0$6(9*?&!6E~kKTU|>3DwLcyD%AO-OTT^gdYYDj-$q zs$UiwyGaP0yw}|9o0iKB^08iHdJ2aY0j>fqYdvi6-#BgdL!%dK3LCB(q5p6v8IOAf z-NYHYWL++vh_lFhkdY`vTw(!GosXq8EyXg8@q8Q{Z-yfXZ9bicB(V!8CU@uGG4rI! z|H>L8)|6{{nWkt-v%}0heq-h25iZn)r}6}v<;!Hg9*yPcd`UVlU-f<|FxFb>78I8XP)A%ilw+zk9>9b@7C3nhl@G}k8^K? zsRKe)oTBKQtP!(Kz~62Mzo}?}>7b%&oTqSm*Bs9KEOm&3xgtMC*ihOGKaaKzK|%#m zt4%NkUIG?C5w6fOkx0cxLT7Y2uN0VM*2)9`D&1s_K`@DKQxYf&nFmus&w?-gJpfJ} zvHdV8rEPz}oos9W2Tyi(a>=+Ix?cP(-;F@4nOf0bWr(CSC_0B)G2bYR2Zbs zsYQJQbvZ-51}7iARv^WfMtkP{ckGp1>UeoEzNrkX@0tJ7@{~Q+X6UeFR$o+BZ%bDj z?v={AyS?2i(kKnT84Q0B#l7;)Np}0qA0Txq3j+cpfBNsy{oPCX4&OWJ47aNop|B_I zJNl_*X}foOFEA#Y^aMo+NuB;;Sr82-`<_ zIM%SQ7{$?wTU>9_s4+uEG&QqOYOMlWVFd&fiLOl#MKAjQ2c2}PsK+qAI(^y`Fl0p+ z;Yj)`LEv@uoQYE8_ylUW3-4LkkFA_u>fu6T=0dXbaO}t9 zne1%C4{SEb@tNxj6@5aNt-FMX%gF<$VMy85JaUD&7e?zK3%CbiS+^aXe|fs?il4RB z4Jne#Sl(kuCc$2g;vKo@UFqT(spFurCHrK{%Ab|;w4di-L87Gdkbf^6jz|!0>lUc zu}2(42nN@olfk15HhxNDqpNY8Kpg0x@5CtK0F)LC#=`gU&Jqo^l@#zW*wdL#iwxAb zI!kE1od*LvNuU@+H8a5v#0E&%A8~Cp>#y4$H|olW1#O>Vmv01X@44=MFqt0qUbxOYLizOeM z!vN7Hqy8(4O^BZgW#>N=@*-S&FVrvL$=_D$2xZyHBmWnJxh1Hvdl^12Nl2#25q4f& z8PnYBeI@i)eWTZh@`=ScGRWEl)#^;k@9RQ><*VBE>Cx$P2Hi5ZpeTwvM}E{m_`xLA zW^{%`HTuNUcmEU@aIQ4`RGZG>_Sra*Pe|<0CH!4P22p8SiA^X1-ANJ|Uask;7thzY&H?9}KIm7&~x^RDzf)%izq^Q@Sk z^z2_Y=BB>K@1?V>j!4MYeH=`2_3ddUv)uLJMV82{Q+cx(zGs@8 z=e0i5iV&X6GTVdSV3k0D$Fl*CRbHTyij`+{2O|UZd0>tJMKo6Zplz&mFUz0k`j1%F zRoty{?!&(&uCf3Xx=TP?8sCA~l4LFUtx?5Abdv#@xSp`jaTmK=#kS%qA*V}I@ zag6b+yLaG=hBg$`_?(`h9M7fPPK-zE%7Mg+)RsCQ2AYbg;eMTeK6T#^rWZ)Im)m4O z&MXi2n$Uo0D69EG^+ro9AdL9?^%f-`MSJ?*@7>=;KJPw!&BrA|ygx5$*cLze9LYDV zXH2ZGh~6TVPg^86u}McAZ5nV>@tOI^`)XXsJ=)Bcl`^5+c~?x)_LN_zTQ8Vo}%u2r@XF)fdsg|lQbOIu%<=L3Z9r^!IKt~g#~^ChxP>5^4B}tdFMZBaOLr@ zHaV(3Fu@=7sOnZR86l5_#%-L@{W0>F=Jl57t;B27BQaJ5m;cH|3?+ym>GSLC06z^5 z;e9_{fTD>OkGZh1PE8MkJ8hfhGVb(u)EV~`#G9NSNt_&9#ZoSIJ|_mHU9+PU~~+$_iQU7=zX#FU(S3UPQUb{O*C~jn_({ zM0p>#=AFUg03}7m;>8b&&e+rTHuH;dwbv5whp~JDX`ljO9JuK;*w%!E{`IX%Tb=vSpHY4HTXWw>%pqnN z)f)6(iKn}Tsz}$NWEpsUg*$TsMIx=Xko`x_!TE6P<_WzVhj}k6wA7MJ#`53B{1t(R6*C zIws4(sTGJ3vY`>P$EFeYli^3pGwX_TFUNFsII}Z0>cEfJ-QD>;#_7{xh>nt1MaR{n zZT+zC87|Tck@zDS3PV#J-d&6R>wBszZke`e(uG_;x5pqNKs-1h#EqN2y&pPQCh3ho zo%gEt$WP`KTa7QKI8M z<-N@VwcjvYUsH`I_WYsBhSE>ZmiF?%K0a*t)DP#g!vWQ`k{-bw7=+yoVT@iav^h;) zY3Q`~KMRy({Qu1X{+K4em7TC5p1O#r1U1agw~6m%=`qk5d79mV4N%zx;jFwG1g>qI zHw7@b+h-Uof$39wrT4x8fo_^3#)1aGipJhx0vuZd>Zg4xf`kBD8yxuRSs-xiV@&%$ z@q^jQd#c){Bh5_m5qP_>U^en9r}1@N!h%2Fx!sqReT`7G|Ti$Db(R)_m92 z9gcPKxWV$#z%jBaTp)myYR>z;78rz>{SJnLoP6&F?nU&O6j2I2?zH&M z2?id8M(yL5LwebR5qZ&{?x%nCgucvM1sZgEE(hE&S>KVXO@t%4r@FwmT?+Zba6q8^ z9grVyzAQyLQlbeSZ~;-QW$`#bb&ctvf!-bYs(P&#PV&{%J<$u9wS{VI;s(&C$zMts z`#gVpFxFeF`K0>1uA&9gGZKyl`%1~wk+<@|x>BJ5r%5td<|YuBM1CJ4Vlyh@;*WqY zF+UBhj28;S%aHEf;ca5}p*B1)WDH}P$ zvBX#%vYsKc6ubU|%5FJuLU)P(`c%6~CJVkG{KNLC3&g3dctSlR{G9b*`7ToPiO4}B zkc8#O8SG*n`43fK0N%4~Gb2RAkBu2J9L}!qTajdqlJM_Oz3bvL6QNekzdybwlD>$N zu9ugoh8X1gXDR*DgINPNe4LHtz>(-WZ{D>i$Gse(JE z{2!QwyJGxpsG*h?T$5HajhOvmIk7}|c)vd6_1C8wUD(P?=2eUh*Z%^d5&f8msh(}I z?)R!t&c`J*5ZH?y8*&HWE$vP`;HEkEeogU3(~0RHjTO^U2TQw>OT<~6e9rL43j40= z5wXN{m5RGK-gZY^eY{-#>L_p6_ndL_x4AHTA@YTg$3>t{PAT`+?LiALm8=J30+>od<&=YV@K;sdClmXxVa{l zKl%TOUN?UqlcQ;rZ4OPR^$w!_50E<6#{ZwEfJG1ueF^o(uLk__YKDu4CwyrDE_u3J zh!e<$Urr9Xi14x6$%ZLh?oDLT1k%*i8JsPwLu;TzME~m!3&sFw>Gy;nIEwU)Qk2=(>pDfy_}BHX|^{(n5~LH_znOxE2!LKeYyZ@W{& zbT?7am|l21&TvOzItg)X!Pmvl3F?vvzI)Ow8lu4F?~%VHPkGujxkL6R=x=g#u&NE1 zF0v*?+KD9H#kLFw>(; zr^orC-W_DxVc1}6zET{1fp+>1_J+H7lyN4sDzLvKf`VdyYHsSyjGBEN#=HUGwg+qi z2J>TvIXX2vIUbBl!2dK*J3u7?w%jbiG{nW*`hX*4B6v#jx+eC?a1xd?sbtoSnk+;s zWBp>Tw&sEG$^IS`xbU_mEWTXGh2mmj=2H(kVe`^=P7Y(q2g=V9t6pRdXp_bkq~=CP7;Ou=tZ$nex#$*$0gW>xk=tfEsmuEbT>oikrCX8Zu(of`rbrl?WO*83iY4uI7FYpyNg3rWms$=h5uEcdu-k3X?DvuV}>LZuXgG$4? zGU1~=Co!MZCf@I?;*{Bj_d}A)gA~)&-|FMaDpW*ux(y2X+~*F2gmBX&8Q_gCE-%}) z>tiniMMt->VN|*5l~!jPo@PTZSeCgYB4SuQBvYJ3j6WUb_1yG!JfF9#-GP6SRY`4R zAT=bQY{LvoJmBkEM?lRL1(0Dm*q(kBvDyLVIqR*T%q~^p-8Lun>z|X=*T>wM+D@96 zl#Ly8xgW!V@>x&jR)+ibzrQobO4d+LS?ki6WqZV~I4*tc;g5t<{t6si0~IEUwRIsK z>h74nq)zXh+k7yOr%dIipoB^$^^{$qb&xf|qws?3VC@j+&mpak&v^eA;47w#jGlsx z)F=(T3w`VBvmXLT`pONb=i#~+j*47}({3>oXb21DNET`7jS5D@KyIky5G+PPUU7aA z{-f7}*i?*1if220E<-1MPCRs4iM$rw6HUskKoB3K{Tf&}jr4H$!XTI1<*&SvCwxyH z5ofObllSx6Mx6mHeL}^l;8+W0#;*n{ijyHGA4pCLZTcmdF=sQD=W$%!x5zZbN#k6X zT`a!kX1H1y$lzG=eGpB|)W}if)Xc*D2Tn~M@rYYUa4odU!Ww<3SU$}#Uw_{3G4M1l z*`K*~1;tH9q-5l|lbmEuL&iTh-ARVp;=TFd<*u6H>oqskZ)Q9uu+f;PPqD& z+fu1hH7at;9z1Es?qjUt@r6Nyhx&g$HPc$+((~l^vU;@@4FvA5e++;F^>=AK6P!4` zmV4jp(E?-BQ*=Sy+Z@}&+!0m9QWI;0TW@{PLr7_=QPK6?>7YS(_`vCn__D+H1Rh7R zq;HOcJ>SD)n(5Or&!jAcpXzaXqJx2OSBbPV$tNpMgrtj4Gxg}w(<4|^qJe2LArh!# zHC|)y*GxO2Q2ymtIV@Q%hZ6t0z@t%vjR8YAHKSz2b{nsA~^ESyl39=9tmB^ z8SpU(Pz4v0GiJkOe0jRrNLKz9 z)FxuZX6f&|-kjKlFHGe6r3)N&B)lA=`u(DmfU@rlTG??N26Zeu5QC-XGQnmS(*fpKMM`Z<&^v zKUf(%dZs}MXn@wV3fni18N5z{Zo^!ISBa`MpKk~_EIX_w_&BIK0q)vqmLq>A4mHax^q~YddE_LSnn|ryLg}WinQ087O0!VW2eg zQx^v_szL*4=Wapc=Kd#~DCa`3MIh)o4>-{@P_?hI!_zLj@YRU_^IC!w@$-KB7iHsfp8C63Vxv$ z_(M<^b12Md%M2YrF~vMnVGlG32+h*%6VgToAinyK9>@P2#zD_&N)5C=qL9#qkX|nF zdtq=cOY@<&K%33@41(a&1pP-G=#uC|RTRfVdwi856#UQ)hzbePDo7b)9X4H zBzJ!q0B_;Gf>20g9pXH^sZcf5*bG~2#tx--q#G+gE4(@4bP$(T!KN-JrFyM@YuWFF zR$@-pSXi@B=Y9E9xTA0S9?FY(1!G4K|87K;V^ROp`(0}r9r2=_KKR={5gmuU)OP84 zU(a_j9)WtiewKYppKr5Pep-9Fa%!8{n+~%RD$6q}rziA2-}Z|_H^~n4BS9Y*DCY50 zF8+{@?Kux8Bw#sYcaZ(EZ`v8X0*L?O%dA?jA>@younM#(tf6N@<<@hotjAfLCQCjE z!#->s$*e(`&XbhC8Yr>dPYf2SJD78PE8o2Rvh;#}tC#G=Tjkg`w4VAGSMhFxkI1;w za&ms~ zHk8nKAoKYPesdpI(nvJ4x7jiO%USz!P;c_lr5Xut;+4e76p?E~j?0QiiqEq!-oSqv z=lF73ei3c=%N1f7-?A*Ci-~1cheYj<9hayQ*(tDlw6fSP5 zoxO!0>;EjsD%0)Csy`Xrrh8Fd8Yv0N3*dXo%W&~idIKF{uqH5n)hMV8lfdu*BjdTb z^L0|V>A7WpIC}B?M?5t_#z@f7&mm>kULgn(-@^G|8oM)X0t53ZlT~GCi5}mI2>aJT zu4k;4;RpWm*b-;L0!9e(r){}eM)^DGngg){-K^SD8ZsYZ5M&&)HaJ)&1l=DLH5Rc% zheeVXHKN~vTzW1w@E^BywKOUfAO&zt-T(p_6PuMu(z^2Do9;$@rq1X`9!q-Qaw(F| z$X@RiC%CmkUP}WVuurfUiENh~1K4hrN6T_2>#fJ76EQl3o%ExPNCIA$i@kgC|4!*j z1H8&8nxiw|!oN^_NpZ?W=S?I#yNl~IOMPNdOol?{A`W}(A9{}c$sZY)%;1+5{9Ng)O={X68kK$5&*efipn((@-HvrICb2bm_;mHkW}G7Udl{}blCaX!D8_It+DS(efJph`2;8h}m_fuf?{GsQxVOuuti zlQu@)-rKj5c?YU#@(%y7hrSP&U302ne_yN?t9C-CQ{M}oSdY|5Mj72BS-|_M4l7~_ zsRA3X8!qh`CX=-Fw=4#ea+}h|%grLL0~Du*Un08!1RQ~SN;UB1EpV!kCE%wq*>YXu zL8}*YaF^C{HhA^69#FqxTxKdc>d$$EKzT{Zum8-VSU{W z%+GXZ28W0}s>9`@|GPNT2!ej8ol|iN4zLLiOft`K$rd{rdMV|L`%ub)ghJtn0m>m~ z<%zlDG0+G#>D`P8`9-PoUwdJavl1avl&7RdI_QTz>3ZY=xcL(g92tzLt_9Q81a+-8 zl$p8lbG`g!Gx!*hOpNyLE0 zGaa?IJ}%b$IK9?AXr>1d18wLu#9>xa3AHk;)rR24Q5Ijwjw=ps{Dl*Q?|dHUk%6Mv zz`@svysl$3Ih;hY1{dwlkLPx?Xuc0q3@*`RxQPN(Boov5)5VTxMy?bEs_Z|5$Stjx zoDY>#M}3%N((v?HJN0+EqBTHayyPg0uA(9Cf<>QSf>%k5Q}>M^WeW9AHzL- zsmq(_n2$S*Yg1k6&h}0f)I9~;B0nYsf_S{5T0v_QuZq@m4-e8vSSO@yE}xzDDO(FU+y}@6q_&8i)My~N>V>Xi{TB0a^ zXHWray+W)#v34ptW^RK6X41nv$EeY#U3ijePB377AmM*L&R4+wIDEq;ZLrUHk=Eed z;>ZvpUq$}6q@nv@L-o6As_f>_^R_T@&j4f3CN+HVi-kn{-%5;Gdk67x1+dS*Mf$}F zBC`11kS_TQ@9B3-GgV(HCWg_>R+foUb=nulNq!yvQvRNSjtJ%gL@*mdBF{)&aEs67 z(?bvwyiqT>)veV^`+g(hnn;a)(fF<*O{TjfHXWkd8S28@&0zsGNCQ3q4F$Q?sPezm zl!&rf5G$EEKo_OFj3@7e+cnNrb&~EkdFL+V{DP!Vx-6}~^~SWdxAsV!n3L@dQofJL zS{^78G4OQ2?)xRy3cjX@ZMa$F7xJC02)XAS`5P1$qt8Y(0s-?S>G{*C=8BX9VL>cG zr4`Z(w6UWtJK(A^-1gnQzo*$XXjA4T8~ukzZYk+Ozfc?r$oWVPcuB@zy=*X`w$1B- zC=xNt*{~=kNU}Y;1w@Rt#kFD#Y;WW4bU71kWv=$Agx+|vZ{wtf*IQnkU7kC$nO;i` z;?y&AXi_&1wJ}yDUyrcg=RQB!m^OG$Des-(p@q@-h%;Wbx+b4}{~3qG>hTC_sQMCh z&_pd>MK)b9W>8)GKySJ^wzCqbM<+|z2jX{TaM2Jgx)I#AZa(VKGu@_vSJ`3#DbcJ1 zqnQ8I^*+&0st!c2?!UxGNgy_c@M7&JQmjW*<{?%MA~8@Jt}IXZ1kY%aHJKlvR^pwq zeHb01=Ym}dNKUGIra^f`0S~ zreH*|ZvFK?uEbtiSmqO{G5ti)Cc~?129#+wK8xWNF9`z`l>`F18={m4+%r8<)l_T` zsC47QU%#k4?c z{~>BenTmH1tYvY+4?u2IsY6WuEVVn#SKY4u{;sL#vY+!!yXdH{Xo@R_nd@ft;lT@% zYS?p3=Z2Gpmc>WOSi;Ta8W~hB5|{w?AdR&S2?tRWJ{CTa4d!H-(*#Csk_ovMV^!DE ztoLU(yTw%?Me+#H>TnZ1`S-5(RlRnrH>RNG;E-5pF##X(jus~V z-V%LF-cRqz-SSn-fuT#wwSbjj`tZyEPgz2r?yO(KwX;cN7L^y{tIVvnw-iNYD9`hQ zvrlCU1^LO&doAia?;?tq@f=GIubnH1`<|08ro@z8$lgZAA#{sZNdLE0;OYJR_47=R zFd{bXBoNcgH~>CBiMO#5Z$5eumf`IJh%H*%ztG@MRtrEa-1KlhWImWLy~1B@s2)8H zXpu|1ai7QwTpaoLUyA(ve^X>sTU%YLoYi?4AIJ0u*vy;d~f}z9b z6FlIR#i)Uemk8%&%9G;l{5SeQ1J_Gy^SQf_;^qTACZ@>J`ay(kU+Rim3NhW^PVWqf z4odd}$@Xi5 z#Y%!HS}7{*-x?vL?;~&7&P7M?hb?Zt0xB^V>WGyl|B3_kDw_87$RZk8&3`(eN?u#$ z;>{O_;3QL`Fui6avc*K1iB(Y;K`tP=okDvP9|>jx`H_psQ(2tzop^D{WNnK8Pq|h| zljkB}oC_rMV}`$y{f_!KQm1NJE6`0fJpViH##+*q8;=c<&2MW7V>`6<4qiKcbNT_Z zA~?cDX|3yJdF&yQuZ4nIpsydiAHQIi;0Gg^lZ!|R{+DFgrzpA2BosSIG_$K*0sHUB zPe=n8?F8?e8Jx&Ro5DYox6QkP-m@=UFM}no(>G3o2YyH<_H|lsh14u=JQJ*=HHyEV za(B%5ye#{+V0il8`~e$ZP%SVR6&o?NizA7ArSqgM=|#t*thL?umF@<#-`2|VAQ79T zBJNk}eSGMuiB8B@ru6G7d84qBid^%?gy?^oQi9%NRWfF=32=00#BhyX>!!+55%Q;R z1vabc*vRC8sHMo51MXM;&&0$9|EPAfzsTL=gGinb%TGBLM+W|jFT_r*|4MLF)}K4w z=q&eYSakBX4B)FWlCYA}8WOWB^!=blhdKKd@Mr45?ugBz=1uWB+-zn3s=UUr#rFHo zcu->)X{op_4KIYtk%n*ITMC|?@po;J6Sc?2|J3IEKahM1b)OqSY3MJ)E89UZ>R$R0r{NZozwEj5*noM<88D2 z4wTR0o+n5oQ}tK2u@^osH%&W`ygy@5g~V)W49O7uLLdr;12F?7xC7>g58C^RD;H0v zj{g?!M|b_x$@5FsvgZkVH|Xl-Xon0f5C=jM_CEcgVY)hK$-I*JV$rjhp9eyEK@nM_ z^~@p(_@VPi2_?T9N6`0NGa^+~$V>Z-{m z7=HQpPFG$NhR*x#^mbEyld~X?2i_#E?zr;Pr&B~8^ViGTN@Z)Or;_9*jBi(WF#ma`sM| zOj)8)H*K4R#lEODugI!a7ut&dez`s_F6dhsxscdw<8qYb^A+Uc&M0WnJZG-Xr zX3L2yT)gdi-JUAdM%)h(bCUogkPw{(#!Hf~`g|fFHB}LqoI7b$V8Ou`APFMjqDXkN zpu^9c2M3o$iQN^`f}Jn?_rRs_a?Z5Q3xvZ_22o_&rcw)peXffSWhKyVNGXK^1JEOL zs?Ow6w>Sw^Wxi)|V7#+`JE+fmP5o|v00$((lXlI-btWfso)&}vPtc3EC>6dPUj_Nd7OKxnR9jwJgP(43%bL`i~E>Y!sSD6Xg&IUf=LAx zj0r*zCMr6!Iohz)Cc*)@gtR$lSEm8ZMlE~q8QA?bb)Nd_+9uXxS_>|#ROsqnIxuG} z8uX1OBIdSUGfq3~tR(Q4am|?fpYPjas4^mWZ<4%~%%1Vt~YA7#NiRzMp@e zdWoD_ntD$thYD8{!!HMmew1CI-;-#)tgDFeYvqt^_)s$`#FnXr>KC0za1kBqiaI%2M%(9DPK?W`oFh%QYWr7wN1K(3-P_5)sFIZh()j6Q<8#@J=It6FLXO><^ZM>5&_>>IIb`1FklYgQuY>EKXBPgGBoijta1Or zhuwv8TX)*9;NBjHD-$2ijx5o`f^{^f%;x^~P#)_xk1LL@j0QEf7~gKIgIzadOsCV| zo8gd7d#HLI{4Nlx1T{l-aZXd=-1i%0u)2@~=qZF3#K zXdhh{*mbrY%rsHWgs;(njb_6PqKFFV+$mk3%ffaO`b~)UdFGS+DLpCP_%z*uAf87} zmdbX^OU|#2sMSROcVldm(s8R6kA#czI{xUUdK}b@#XTc36sNbd45mX`sQ%^Lm(-uQ z&-`N6grH*PTv1VCO1KAIvbl>QY1PaQ0 z0YQ9>Kdky`eKe4m`5{!Rwq%RK@7e zI^u6;HGqArg<>1q;z#*Bs}3tZ3dZ#jigY}nFjo*GCMc{`OxS?j{X5R{eoI~r2Va#_ zR$i7;C1#u&x}>D~hM{ja%(6Ky?vVKP>zBw@cK@^CGenMJuf&v64|=fWby9q1bH!l= z-Vztiu%=AuwPP|WQuup&;{5wiSN){lqx*L7=}s{=1#VQ3oytNkVf$V z?*;{cozj)GNflJ^Lu)QYUG!h&_KOY##qp)qH0@8Fbb;_Qw=lx5S;wcAlubUN3h*c0 zLm^*OMMOj`>e-esNy>K;{9ExQW@er4WGx2OWPboPGQEp@YpWL|2NF{LVd%xuv0apT za9;b816^_jynFc|^nTOT1ECmn33(rx?MD2}X7Fb7;)&Mt#hP9Xk&+#PY?|%V{gFOFKe};^qA14?ecjR^T_#OO<;#(%W6( z`mkw62K5ulORURl@M{E+bhHUj`q(fR05gIDXJzUVny_vrf~BL1WEF@-KWO`B?AWyV z)9-M*Un>B~Ud!`h6o6Ncr5L1+eJJ;1R?;C*iaYC8I#0Y6W1Sn@(4tw?a~W@ zY>WNUEJlomyc6iQ82+U3(^Vqp8#T`@fuF8aoqd_Q&{Qn|@C27ZN_78IfuB&aVe>&Sn^@4o8H8 z1lVl`pu4;CO^RIdZH7(4C#@@$t|MYtjylqkFXl(_fd)$z)uk=j zqwOzwFe|nxDw3dgVW!Bc_RI4(OB%1yMy3~0ZctbWEaeWb#|Beo_6!Zuz8SBRCHT!4 z&6f&MJ&gJ*eT! znXGIb%(@)&Bv3wH$RIH@@tHsPNRyU!&lY$kxid(Or~<7UxhxifCP1bX?;n_>ZX`@$ zu04+e5ANw08I>^!x*lZxr?TAUp7dTkJ5uRpMAGeot~hzt^&ezld&Je!`x&wUO zWcMVB0$M94rj2jm{aUk;538P+mVPS&O5bF<>8jr?U?a7$Jf5E@J}z)CJ;4H% zb-w*U6C~VisJ)~=sqbFB-5rhkx89SVaKGcU`{YK=>$@~28Q0gC%xXx~H5Qomt>Fr= z-q!ubMmEN8bdfSCQC-4*i6#@h+VJ%#PEyO2J`dAA{y)MVh zSsrgX47nPR!A~Qb9tSVx^0#SIvmQ6HreBV`#q}#8w{l;@(siubl@Z}#ycc}|G9+;N zI3*nRL~YEaPw-js;SVDTeR`7ie8=QC?)$tN*R9R5v4Cx@i( zBIkv!CQsoHoOjR^KWr8QY*82}A$(DN$a4>Yl=$b^V-=`Kie7&0Ah*On)D7e85hzf7I?3AK-2 zB_7_ohJYfn=?r}bJ&Ha@teuDrvrlr=#<2oeDxGE{J5{+KBE*C$-6MwQ)0^EQEE ztoPZ;D&DyA5(QD8pB_Z>>Eat(VwH~3KjPL=Bt?5Naq-?M*rix32m8kQ&|YTT)WRa2 zKZsA4VGXNQrrCuqe(zTlG#uJvwf5;1v7OXw4o`Dl;Qq%zy(l(Ppo89U8hOVUO~vK& z#a&fi0^nD*R(2WkupR$3{Wg)x!iM^A2j`r~l!9u)IXC?0mNwd6YGSfhcb^Sw>J&It zNuu&q?$>D3h`VeAVGu?0eQrdH1pwdgoT--T4~Tl)aGspiuSZre1VP4Vnz!P$an1+L zfTsqv2-`+9;K-a@Zr$C3;PSJ^gN(j>^ZA6b_*2RYH3;}V(a)#n_LlVqe)3tt_pgvI z)l{O5@j4vm_K>yJ?s?$otRg0}^!Y}ZB%Qf-;3i{R3~y0#Z<#1c@KUrG9IUZkI%vq1 zP6LxTZ8AheBEW%Wz_*YYV}MD?^a#aKrRe~=U%JxW zkO+ON=C~y=fR_gQen@#=RiCFcdz^lq-s5oM2etS@Xlmubk7==&^;b~E zbDh%qSZ8ur!p$78C&*RpL;C1I($OPMg~nk&O3M(CW?X-<)$vB3hl)Z<2Bt;`tiTS+ zvxXj(N=U;ZqyVphrgrJRVJ;>&v~h=Tkrgxe>bi!rw}R%2E`CZ@V0u*!rg#uZ8$HIU zC)HnJy+*Y*mHhijnmrj+4Rp$botq8*&0Ohc_8O7s;tD6qBH6m+R{Cc>&qdOwY1;kk zwuX>bclzTOMPq`QH}cna_|m~(GE~gJXKu@8y36)}^)OVB6$KC_LuB^%mrna_>LkFh zhmAZqpbwtHz5Mk3SL?&NtZTUfIAB9_8UD=+O7^qBp24nhVXC!r<#mLMr8|K_i} zqJZI5at+*1grF;<7cXW^TI>hDqy%{Z9{vY65efXHg<_qI8s)rJ$>l4UQ3tjna{cri zAO`047bGv2ewdhm7gM5)ew5mUti|ZbW+`QCd0L6DO(pvttYZ2jz-i^NXW&R4-6PE< zietlfHA0P|E--9r zA&{F>+xeW3Y62>5cdxZl+MA(Pdtsi9AT_9ALq#pT zL}5Qd>aSvL0~darCGvvw;I8_Feez;WZ-iv`&ZS_moX0`8}aVH&^hoZmQBvQZq_ z4Tx0j$T^721w)aQF6@2TRWrXm-Hfz4fvcxdER_j0x2*!A-Q*qjGHDkd!kq_ufTd(A z>)V!dG7{!iY>1(eZ`kuK^oqZ=V?HRzEB#z{v^-$k`x5z4*VG@hHvOZn@;{zw?)yPlqUPH z@zD7TuO02G2Yh%wXTWj+bpFM!^-Knr66p{_aLNGwSP>j61PYGU_9hW?k00GB(Q-ffXn6BRL{47{wQa=mHJ>NgPM3T- zV7SvZR{pbzmSh=Lq+;#*j=s-=1VaSPX~&YlL5b*k?~ zrG3z&8M_s6e+58&nZtS+-gUB^3Mxse^sjgh{5_9+$g{L6qx6N9YiMA^bL|H%=)3jq6$gFk*e_`Y2vRZ-98of1K=mJs7~XkO7JJC{ zr1_mf?Hx}oFC$qh_A}}W*#D0GUFJp@ECC#oDMMT}gk`~wrfp7Gb)&5>|D;(P>DhQO zlH6|SM0KD12zF6s$#d{igZ7oohAek_)uz_myl9{|{e*z~D8flGy?AL#-Z;klXe8Ah zfF{{cZmxK5%zg)f!oIY5)jjz*W_6Yd=jG8{ByuA{ump^WalVZtg@z%u-~XztjR|Kx z8>>jfKHBWHn!d#ofYUwOwX^sEI_C(CcAObKL>h-wX%UZxA%{Rm^S)YkxbTO-U)E@D ztW7iZq+cXmR4MNF7k1@#s+lm^#_N4Gz48zz4I8eF%3OcSB*=;-L~_EH3P4aIRWNXS z*_Ugweg@vAg<;^01=~Vj<*p_PwCPt7xC+Q}WaAku{6lQPfLS-|xks)+EjDM#5Hx^G zEo;_o<^~~sx0?Dhivx4iQ6Ao2M-0431ESz@EPm$hVn>w<=E{sQG}b{BIs9lq?k0Xb zfUZCXtz(oQS4(|C<&yG~zZ`ro^;)7^P&2*eEUiQur=7Uo%89I#PUdMysl|ZSh2mB}%iIFM3I*gnP z0h7ajzwFY=i9R}#8&dK$hC`x0Q$MRlUkSy_p!7bL9(q64T!bv2M)I-2Ezl6q0pf3{ z^p@pWh%^7JXG zEBCbR?v42*HK62wSAm@AeC=1o1cPXg*v^%RGD~bqEm*-5RPxCHPsD0?H%EVYBHlK? z^okpx`H%6d@MNr>Bxu5?@=Hg9FnKksWiyPP7dF=Qi(Kwl6_D@o)o4&MFtTj#BUzPo zvrWkFt{%Ai^qaKwd-cLwk^I};#D2U(m*HLObD;?{=4t@w$q?E-9%YCUw@jAdrkBzJ zJ*2<6M*>sc4UR_TdtMw|8&BswRoO~*bO^iU5qAoJL&bh8nYOKW?r4W1A7>!GUYd#7 zSYEAm&Dz^)HsqFQ&q2iR#|b#`H6rDf?-V`^Nl@CQ+w*FHs1V(D(AAS`)6*Mr@c@tY z`^%`_67V*g8~d*yL+ZayAWT$25)+Id|GMvnr0VdptzH5(pI7bJ6l=*}a7;$}Rk&|@ zxpqSObX5YLW^7yLl}N+8FJDa|*@CWC+f+vIxMTMhYiIfAUEDxrwa z-w(fRa4f^&l#uvFfY|&VVX$M<;orsYmZ0k2bT&~&SAgG|D}ag2aok(dwIS0us?v|5*iPTg<)XZKTn?N?-5v$E z2C+4L%G?1-9rtF`uNblNqh_r)r7D{mCQFbMTiq0Kns8GtdjUsK;E45s%cm z@nxbitq^TD?Ea)@1g$&_p*DUUqp|t>FQeDciL4s-zH`QDm|P=eIXT0;QO2B}U&X8hLg|wjnJ6>KHF~ zpTK2up7m@5qw489Wx~f~3n2gtZbfLFG+OIaG2G_rX}tZ{KU;cCwk9LOY7B+E7JT8} zOmHziql>EMs!p(y54OrWH_^Le@;?~Tqr_-Nr+pYg(j)mX;JU|G??~*+%LrO31>48P zBh84D>UxZ>5#vNI4>pyMS@&nG1S%0&edF_OztvU4TrZ>4OFKD zhsg?uc{v&$X5g8$ih#nIV!)r@6GnYN{sRflagZ1r~+iGiGA zDv7VVv0e2hKLQ>Mje(V|ww(zK3e%f<677Z)O2rw3%q^4(gd($G=O&}_RAep{!BY|l zr7N@$!7ITadGy9@N5ja;LQG)#sAuB0=NZ_BzYd2>(2#MzL-F*xHp6Q`?w_-bfX1>) zV^Wch^ST2u%#K+GyOeUO;Y!z9Ib@DBtm}5Zx?%_z<@o*6gRg^L+?uy*$L8%{pXB4; z)6+EPHb=E+EEq*nG%gat#}96xG>hF5?OQTVFYkXj3M(29?yrTTp`xgc^A zjBamS@s7XLrr60WDLAPwv78FI8ff5E;V7$Dp3yw{aJpN+c{4@&%yn+w0YS?7+xB1E z!(;E--Ze=7d;t9cS|DOgfJBAxHuw(FT;{)%P>p}@OIUI7S}h|w42cdR7rUvi3oYsQ#&!1}WIA7zr@0hOL4?~{C)WW!h|u?bAjQ>!nm9#r&ZBoksh_LU7B>4xP? zJa&Y0+5NnUr{LX|p%KX4dGA3yduyImbVghwetS0;w~tnU1$SXtkh$EkZ8PLTXr?FQ zQxK%zvXM3~hhqlHE1VvauOtoA5|rHP1D#cV1#(#&NF0o^;2gAlQcuN{Jn=20QzN<$ zA1_O>(_9dvEGe&K$X>0;HLF7q^Y?ep6Lusc9(mTJxaGn45m2W_uo)GmLjpov|$b~9&?=zz+#eVbiHHBbDS711F|&N z4B)~ms0HU7?}{9Si7f>r@x75(XwAerzECD&AaisiQU?~eF#&w)tIT0P12Ak>pcmHt!$;&*U8<3FR0AKO;Pj8pi*{lpl^1n(J_naeN-+xvDc?Sg+H zdD@Gy$s~i;Mati#`V}cw$i6eZzq)wn8Rju#IgR4r2^R3rRnNspN; zirJz%`uJD^9o(={*^Wy^BBQO(V-(Uh+OQ}k5SK9in}gdp%P=I&0|NXvQBUV`Rr*d@W=W)BL? zPyv%n>rHrzR0{%3t-9~M{g*%L_aNc{keEH3Qla9Q7c={pjZkujph>~cUpEqE1|ha} z?lg`y)Uc-Ll`+ous8J(|Ks5h$LlGLiPlQ#c%jh%(Uf1nASSixvk2#I&qrTT_qYU8@ z{f2rI!oHsc?nmsLB~Ml9kWzTDQeFdCsRJ!q)_!9|}_j1Qn4{%%K#GQVWt{?KQM=ib)~fpG^Fn6sad0olN?)P`5fsDrCI4OrPSuQBvB0-|0|IgzW> zpoz&0uJsg~Q1HL@FzI$0&5%Ql=|2^D!n~|^&QYAHPF~TH+zhduMwS;qaxGfbnu5;S z$NxlR@s#XvHjCpgqr!jv29R5z7Fcwc71IWOT)D3-f4_Fqtfy&(l)N)>dJ}<|s)@|) zQdwjX;aCZu|DC!@$%pz4LeF4Eu=taFO}nf%9uj3n?DlUiAbRoU!_uVxvcH$SM41Zt z2tn@OJHw*P+#`F?Ng@5#QtH*tp7bPykxhQx`O!Y=(t0NmlTI1-|xtxPR9fO+-# z(^LGyw!UvSlKDL=5c+(`%Yft>>>IQ3xIvRKz-j>;{zR7hQrTmOvJ2#{|63pgPH+_l zqUB(ZU9jH#K@h#j{+H8D-#f&X>?}46{bKfuyG@zfb%U&oE9>Moh9R`s;TkDjz8 z8+rYT0%GbsS1(%q+vupz0wbXnAsLm`2HO*_dpWcA$CduAcp^8qT)+AKZ9p1dSWXxnJ4ySF+7q;b(KUAT`@9Es=5eT=YWoVlMxu}hUP8oy&7C*?H~3e_r86B z7E7)8rNokAJ^w4KyMs@Z5`JJ9j$a|_9y7kf`|ihwlh?o&Zv_Z!oQt#|*}1#8?8YA4jH5)#$s&2koy&cGGk*r)BRWJcVK!cP5a}MY_y7gxX~~-Xg?as$cfpCDd8QI z0|qX{NH9X>!b`@f%uH4zObR|XI!u+VM3HO|@gg5LEA7hOr?SHy>BY~t zs8eDNsPmxj;!lN4gxzA#!(2VkEN|C?)R9jZU? zWUvuPV;X+9CnleqJB%Bn6jk#L#Yt9X+zN3&Q1`fr!=xwgBB@254l9KhJGa8{i6#z= zSnO*(h!<@IFKW0r9ncF3p8IQ8OK;6h-j(sSjl9%98S9`qO@#FJ9*8}~%Ll%Cjn4jrIvE1Gm6w!1 zQV>V2ra%Arjo0%=gL}i}5$Q#a#``k)=Xqvn-ghtVL(*oWZ9I0R_Yk}|ird!5D+CUi zkyvhfJI!vx@kGdMWGe*QR}|Fo{s?Zy8@&GY z10H>1@+`pl?xeK$Vd2*Nx#IdCzsE8|qjF}(pBKsBMx2~9AVh8+3owjXt-nj%xASFn zmK^0yQN=g#`z<>x_yS7|hA(K&y8Zl#{3+dHHTbmHHWWGvI@fbmT3Fr4B`ZDdQ^64J zG$K8OWevB049Olt1Jy@W8Kh?NV|X}AM$0aPVgfK~IEc;+FEl1!a|Wb?fjV#!enq(O zNIlePD4>laMn~`!Sb>Xp(t#Wj3KbZgl})*l?;)AP>^!>y;Q!c z?>#crs!ux8nLP2yR-PxGiK!vU<_S1hJP)EzGq$~P z?4D7r%}Bg1hn+>g!jmc;#j&m_yDo=3qZ^D-kn`E!OScya?66R5J~43o*(wPFZ3QV; zX)TjUmJAgYKddGTN171<$te8$vcnMxI^ZX=mX<^%mgxY#d1zE)y3A4yE4TvcE2res6va#wz?PnvU7~|)r3)4#h&DV*!ZiV&aydky&>(pu_@icrk-{(FSYC`Rf(9T89Q zk-v_cv@Cr^hiuWOm|ZLsWlG^SExX2ia}_@F@b~a&#o(*MiZVaWW(p6Q@VftT#`kY~ zK-R~Bw)K|iy!i5nnJpUycEnPAjY8aVuF=7bJxJ4WPQNyB(v>;2Kf zJvUvdsjCL*jd-z`bHG4QG6kMdrt|Lh^2)7+ckXeX^zzP1{jJ(c>B=CVp4oqR`zv$pgPE#?c12`J&W9~PGzf_Sf202AZ{9h|L~+lNd*(#!+QhZ% zu##_-LvOTCi~~E6-i-uy-`2gUb2*^S)opbqjm=M#a#aH?UXXxIo^U@bO#98fCHMVe zNPHq12B&(6)~l}`;_->P>U&`N9e+D0%-VOC%T^jxA_W*)F2hR?%+{OXcAP*Z=M^x> z%r^A+tO4Vz%w+hxO6gEXlD8< z_YL0i;O?psKWdk!YP6J=ENUF64DZso^I@1CbqHWcL$JYQW(CRVeiD zq0k?H3M~yjX-s%1JYYtBK$>^cL{%g2`|1D8a@&+~o}+*MGvA}1wfMFwGCL@3@uB(l z;Sh1Z+{4oMs#@!;%(h75@;JX}#9-KvYnj{cMr_>qVZcszoUpM?SLkQxszgP~)A&eu zNZOt0R)}Jiy#4;qqg`{h`2zEur^f8F$Xkn1*Fgn}k2TRK73GJs0p_ADkIE>%3#5KO z;bKzF^ub^H)CDi~hz^hp&z0_L)&!*}G>PxQf7n%L{fc~l&2 zE^v4hKk(fOEdV?5tC4OJ$b@JyO7kna2_8*>Rtz;NT>+?3s{gbxpS;5mXphmmSmfT8 zu2;aWjpdyVDL98pT-9koUDDyv*TzsSG>KkXEU8~a5;Zea6rou*%%hGG`M-VS=E&5s z37TR;%XZti<;^7C`Y*MTIvM(S(k~KjOJppRW_@7W4IhAu1oNd^{7{X?;_XXU~ zlGJiXmuFiq$BQi&iEMe7Wo0v9Ymrv@j4aK2U{NEd){Zrq))>srG;H+Vk|7PA-$C#A zIy;f-2lLI7Dy`Dr@a9wo*uo-O-I)v$X-U8X!r=Ij94m#NCoC&@2tuODIXT~|3Kxz8 z*b*WH3^=1aKoUSG+y_o-b{GHG{HgBXwA18jjfh2_$oRQsng4&u8t2pf-?+b)K4+l~ zJ%-Rf-xSF41_i)2KU=U^#J!gdzAD?g$1ff)J){g)fBv`|xjUt(ztHyqx}PIrDCA3q zkZ5OuA9QSa4TxaMJyU<2AL>WWYs)V3WoO+k#0JQfC(zm!56pAr&t6H+I;ek7#Jlr! zQxzjWtaqB)`(Ds6tAQ(L(mCWgB6i=g!G{RTA3x#GD`79oJ>sciZFOhUD8wgXf&BTU z#ygRb!9r~vPv)z!s<_q9ftd1D$7%Gk^L7CO+aRQ$N%D@1J4MNG%Dw83~H+P(KbC z1V%b9Vdu>Vio^;?ZubgvVAW80+|P}^sGZh&Yu)>9>u1gN7$1HH`Oo6ay$z5nsPNZILRb3--xE%mCQ4VhC+J$wFJ3scx-cus z(12&bgQt@LN->$^*1`ilX6~mdD>r*^7E6e_!?Klq21JuQgnr z_SUR>0eM%X1Jf?h>oZtg6wx}(Z7d~pwO$9-_ZS6Ra{*NAEt>4A-B(+WC*6a;)wE6f z^86@4nC?0z<$H??H^>k=b^;S0IuV3o+bef;-@Hfp{(@|
/`, for example `area: plugins/foobuzzer`. + +Use the following labels. Areas and statuses depend on the application and workflow. +- area + - `area: android` + - `area: clef` + - `area: network` + - `area: swarm` + - `area: whisper` +- type + - `type: bug` + - `type: feature` + - `type: documentation` + - `type: discussion` +- status + - `status: PR review` + - `status: community working on it` +- need + - `need: more info` + - `need: steps to reproduce` + - `need: investigation` + - `need: decision` + +Use these milestones +- [Future](https://github.com/ethereum/go-ethereum/milestone/80) - Maybe implement one day +- [Coming soon](https://github.com/ethereum/go-ethereum/milestone/81) - Not assigned to a specific release, but to be delivered in one of the upcoming releases +- \ - Next release with a version number +- \ - The version after the next release with a version number +- \ - Optional. + +It's ok to not set a due date for a milestone, but once you release it, close it. If you have a few issues dangling, consider moving them to the next milestone, and close this one. + +Optionally, use a project board to collect issues of a larger effort that has an end state and overarches multiple releases. + +## Workflow +We have a weekly or bi-weekly triage meeting. Issues are preselected by [labelling them "status:triage" and sorted the oldest ones first](https://github.com/ethereum/go-ethereum/issues?q=is%3Aopen+is%3Aissue+label%3Astatus%3Atriage+sort%3Acreated-asc). This is when we go through the new issues and do one of the following +1. Close it. +1. Assign it to "Coming soon" milestone which doesn't have an end date. +1. Move it to the "Future" milestone. +1. Change its status to "Need:\". + +Optional further activities: +* Label the issue with the appropriate area/component. +* Add a section to the FAQ or add a wiki page. Link to it from the issue. diff --git a/content/docs/developers/geth-developer/vulnerabilities.md b/content/docs/developers/geth-developer/vulnerabilities.md new file mode 100644 index 0000000000..07d7baf86d --- /dev/null +++ b/content/docs/developers/geth-developer/vulnerabilities.md @@ -0,0 +1,113 @@ +--- +title: Vulnerability disclosure +sort_key: A +--- + +## About disclosures + +In the software world, it is expected for security vulnerabilities to be immediately +announced, thus giving operators an opportunity to take protective measure against +attackers. + +Vulnerabilies typically take two forms: + +1. Vulnerabilies that, if exploited, would harm the software operator. In the case of + go-ethereum, examples would be: + - A bug that would allow remote reading or writing of OS files, or + - Remote command execution, or + - Bugs that would leak cryptographic keys +2. Vulnerabilies that, if exploited, would harm the Ethereum mainnet. In the case of + go-ethereum, examples would be: + - Consensus vulnerabilities, which would cause a chain split, + - Denial-of-service during block processing, whereby a malicious transaction could cause the geth-portion of the network to crash. + - Denial-of-service via p2p networking, whereby portions of the network could be made + inaccessible due to crashes or resource consumption. + +In most cases so far, vulnerabilities in `geth` have been of the second type, where the +health of the network is a concern, rather than individual node operators. For such +issues, we reserve the right to silently patch and ship fixes in new releases. + +### Why silent patches + +In the case of Ethereum, it takes a lot of time (weeks, months) to get node operators to +update even to a scheduled hard fork. If we were to highlight that a release contains +important consensus or DoS fixes, there is always a risk of someone trying to beat node +operators to the punch, and exploit the vulnerability. Delaying a potential attack +sufficiently to make the majority of node operators immune may be worth the temporary loss +of transparency. + +The primary goal for the Geth team is the health of the Ethereum network as a whole, and +the decision whether or not to publish details about a serious vulnerability boils down to +minimizing the risk and/or impact of discovery and exploitation. + +At certain times, it's better to remain silent. This practice is also followed by other +projects such as +[Monero](https://www.getmonero.org/2017/05/17/disclosure-of-a-major-bug-in-cryptonote-based-currencies.html), +[ZCash](https://electriccoin.co/blog/zcash-counterfeiting-vulnerability-successfully-remediated/) +and +[Bitcoin](https://www.coindesk.com/the-latest-bitcoin-bug-was-so-bad-developers-kept-its-full-details-a-secret). + +### Public transparency + +As of November 2020, our policy going forward is: + +- If we silently fix a vulnerability and include the fix in release `X`, then, +- After 4-8 weeks, we will disclose that `X` contained a security-fix. +- After an additional 4-8 weeks, we will publish the details about the vulnerability. + +We hope that this provides sufficient balance between transparency versus the need for +secrecy, and aids node operators and downstream projects in keeping up to date with what +versions to run on their infrastructure. + +In keeping with this policy, we have taken inspiration from [Solidity bug disclosure](https://solidity.readthedocs.io/en/develop/bugs.html) - see below. + +## Disclosed vulnerabilities + +In this folder, you can find a JSON-formatted list +([`vulnerabilities.json`](vulnerabilities.json)) of some of the known security-relevant +vulnerabilities concerning `geth`. + +As of `geth` version `1.9.25`, geth has a built-in command to check whether it is affected +by any publically disclosed vulnerability, using the command `geth version-check`. This +command will fetch the latest json file (and the accompanying +[signature-file](vulnerabilities.json.minisig), and cross-check the data against it's own +version number. + +The file itself is hosted in the Github repository, on the `gh-pages`-branch. The list was +started in November 2020, and covers mainly `v1.9.7` and forward. + +The JSON file of known vulnerabilities below is a list of objects, one for each +vulnerability, with the following keys: + +- `name` + - Unique name given to the vulnerability. +- `uid` + - Unique identifier of the vulnerability. Format `GETH--` +- `summary` + - Short description of the vulnerability. +- `description` + - Detailed description of the vulnerability. +- `links` + - List of relevant URLs with more detailed information (optional). +- `introduced` + - The first published Geth version that contained the vulnerability (optional). +- `fixed` + - The first published Geth version that did not contain the vulnerability anymore. +- `published` + - The date at which the vulnerability became known publicly (optional). +- `severity` + - Severity of the vulnerability: `low`, `medium`, `high`, `critical`. + - Takes into account the severity of impact and likelihood of exploitation. +- `check` + - This field contains a regular expression, which can be used against the reported `web3_clientVersion` of a node. If the check + matches, the node is with a high likelyhood affected by the vulnerability. +- `CVE` + - The assigned `CVE` identifier, if available (optional) + +### What about Github security advisories + +We prefer to not rely on Github as the only/primary publishing protocol for security +advisories, but we plan to use the Github-advisory process as a second channel for +disseminating vulnerability-information. + +Advisories published via Github can be accessed [here](https://github.com/ethereum/go-ethereum/security/advisories?state=published). diff --git a/content/docs/fundamentals/Backup--restore.md b/content/docs/fundamentals/Backup--restore.md new file mode 100644 index 0000000000..6d038572d1 --- /dev/null +++ b/content/docs/fundamentals/Backup--restore.md @@ -0,0 +1,65 @@ +--- +title: Backup & Restore +sort_key: C +--- + +Most important info first: **REMEMBER YOUR PASSWORD** and **BACKUP YOUR KEYSTORE**. + +## Data Directory + +Everything `geth` persists gets written inside its data directory. The default data +directory locations are platform specific: + +* Mac: `~/Library/Ethereum` +* Linux: `~/.ethereum` +* Windows: `%LOCALAPPDATA%\Ethereum` + +Accounts are stored in the `keystore` subdirectory. The contents of this directories +should be transportable between nodes, platforms, implementations (C++, Go, Python). + +To configure the location of the data directory, the `--datadir` parameter can be +specified. See [CLI Options](../interface/command-line-options) for more details. + +Note the [ethash dag](../interface/mining) is stored at `~/.ethash` (Mac/Linux) or +`%APPDATA%\Ethash` (Windows) so that it can be reused by all clients. You can store this +in a different location by using a symbolic link. + +## Cleanup + +Geth's blockchain and state databases can be removed with: + +``` +geth removedb +``` + +This is useful for deleting an old chain and sync'ing to a new one. It only affects data +directories that can be re-created on synchronisation and does not touch the keystore. + +## Blockchain Import/Export + +Export the blockchain in binary format with: + +``` +geth export +``` + +Or if you want to back up portions of the chain over time, a first and last block can be +specified. For example, to back up the first epoch: + +``` +geth export 0 29999 +``` + +Note that when backing up a partial chain, the file will be appended rather than +truncated. + +Import binary-format blockchain exports with: + +``` +geth import +``` + +_See https://eth.wiki/en/howto/blockchain-import-and-export-instructions for more info_ + + +And finally: **REMEMBER YOUR PASSWORD** and **BACKUP YOUR KEYSTORE** diff --git a/content/docs/fundamentals/Command-Line-Options.md b/content/docs/fundamentals/Command-Line-Options.md new file mode 100644 index 0000000000..46a29354c7 --- /dev/null +++ b/content/docs/fundamentals/Command-Line-Options.md @@ -0,0 +1,238 @@ +--- +title: Command-line Options +sort_key: A +--- + +``` +$ geth --help +NAME: + geth - the go-ethereum command line interface + + Copyright 2013-2022 The go-ethereum Authors + +USAGE: + geth [options] [command] [command options] [arguments...] + +VERSION: + 1.10.19-stable-23bee162 + +COMMANDS: + account Manage accounts + attach Start an interactive JavaScript environment (connect to node) + console Start an interactive JavaScript environment + db Low level database operations + dump Dump a specific block from storage + dumpconfig Show configuration values + dumpgenesis Dumps genesis block JSON configuration to stdout + export Export blockchain into file + export-preimages Export the preimage database into an RLP stream + import Import a blockchain file + import-preimages Import the preimage database from an RLP stream + init Bootstrap and initialize a new genesis block + js Execute the specified JavaScript files + license Display license information + makecache Generate ethash verification cache (for testing) + makedag Generate ethash mining DAG (for testing) + removedb Remove blockchain and state databases + show-deprecated-flags Show flags that have been deprecated + snapshot A set of commands based on the snapshot + version Print version numbers + version-check Checks (online) whether the current version suffers from any known security vulnerabilities + wallet Manage Ethereum presale wallets + help, h Shows a list of commands or help for one command + +ETHEREUM OPTIONS: + --config value TOML configuration file + --datadir.minfreedisk value Minimum free disk space in MB, once reached triggers auto shut down (default = --cache.gc converted to MB, 0 = disabled) + --keystore value Directory for the keystore (default = inside the datadir) + --usb Enable monitoring and management of USB hardware wallets + --pcscdpath value Path to the smartcard daemon (pcscd) socket file + --networkid value Explicitly set network id (integer)(For testnets: use --ropsten, --rinkeby, --goerli instead) (default: 1) + --syncmode value Blockchain sync mode ("snap", "full" or "light") (default: snap) + --exitwhensynced Exits after block synchronisation completes + --gcmode value Blockchain garbage collection mode ("full", "archive") (default: "full") + --txlookuplimit value Number of recent blocks to maintain transactions index for (default = about one year, 0 = entire chain) (default: 2350000) + --ethstats value Reporting URL of a ethstats service (nodename:secret@host:port) + --identity value Custom node name + --lightkdf Reduce key-derivation RAM & CPU usage at some expense of KDF strength + --eth.requiredblocks value Comma separated block number-to-hash mappings to require for peering (=) + --mainnet Ethereum mainnet + --ropsten Ropsten network: pre-configured proof-of-stake test network + --rinkeby Rinkeby network: pre-configured proof-of-authority test network + --goerli Görli network: pre-configured proof-of-authority test network + --sepolia Sepolia network: pre-configured proof-of-work test network + --kiln Kiln network: pre-configured proof-of-work to proof-of-stake test network + --datadir value Data directory for the databases and keystore (default: "~/.ethereum") + --datadir.ancient value Data directory for ancient chain segments (default = inside chaindata) + --remotedb value URL for remote database + +LIGHT CLIENT OPTIONS: + --light.serve value Maximum percentage of time allowed for serving LES requests (multi-threaded processing allows values over 100) (default: 0) + --light.ingress value Incoming bandwidth limit for serving light clients (kilobytes/sec, 0 = unlimited) (default: 0) + --light.egress value Outgoing bandwidth limit for serving light clients (kilobytes/sec, 0 = unlimited) (default: 0) + --light.maxpeers value Maximum number of light clients to serve, or light servers to attach to (default: 100) + --ulc.servers value List of trusted ultra-light servers + --ulc.fraction value Minimum % of trusted ultra-light servers required to announce a new head (default: 75) + --ulc.onlyannounce Ultra light server sends announcements only + --light.nopruning Disable ancient light chain data pruning + --light.nosyncserve Enables serving light clients before syncing + +DEVELOPER CHAIN OPTIONS: + --dev Ephemeral proof-of-authority network with a pre-funded developer account, mining enabled + --dev.period value Block period to use in developer mode (0 = mine only if transaction pending) (default: 0) + --dev.gaslimit value Initial block gas limit (default: 11500000) + +ETHASH OPTIONS: + --ethash.cachedir value Directory to store the ethash verification caches (default = inside the datadir) + --ethash.cachesinmem value Number of recent ethash caches to keep in memory (16MB each) (default: 2) + --ethash.cachesondisk value Number of recent ethash caches to keep on disk (16MB each) (default: 3) + --ethash.cacheslockmmap Lock memory maps of recent ethash caches + --ethash.dagdir value Directory to store the ethash mining DAGs (default: "~/.ethash") + --ethash.dagsinmem value Number of recent ethash mining DAGs to keep in memory (1+GB each) (default: 1) + --ethash.dagsondisk value Number of recent ethash mining DAGs to keep on disk (1+GB each) (default: 2) + --ethash.dagslockmmap Lock memory maps for recent ethash mining DAGs + +TRANSACTION POOL OPTIONS: + --txpool.locals value Comma separated accounts to treat as locals (no flush, priority inclusion) + --txpool.nolocals Disables price exemptions for locally submitted transactions + --txpool.journal value Disk journal for local transaction to survive node restarts (default: "transactions.rlp") + --txpool.rejournal value Time interval to regenerate the local transaction journal (default: 1h0m0s) + --txpool.pricelimit value Minimum gas price limit to enforce for acceptance into the pool (default: 1) + --txpool.pricebump value Price bump percentage to replace an already existing transaction (default: 10) + --txpool.accountslots value Minimum number of executable transaction slots guaranteed per account (default: 16) + --txpool.globalslots value Maximum number of executable transaction slots for all accounts (default: 5120) + --txpool.accountqueue value Maximum number of non-executable transaction slots permitted per account (default: 64) + --txpool.globalqueue value Maximum number of non-executable transaction slots for all accounts (default: 1024) + --txpool.lifetime value Maximum amount of time non-executable transaction are queued (default: 3h0m0s) + +PERFORMANCE TUNING OPTIONS: + --cache value Megabytes of memory allocated to internal caching (default = 4096 mainnet full node, 128 light mode) (default: 1024) + --cache.database value Percentage of cache memory allowance to use for database io (default: 50) + --cache.trie value Percentage of cache memory allowance to use for trie caching (default = 15% full mode, 30% archive mode) (default: 15) + --cache.trie.journal value Disk journal directory for trie cache to survive node restarts (default: "triecache") + --cache.trie.rejournal value Time interval to regenerate the trie cache journal (default: 1h0m0s) + --cache.gc value Percentage of cache memory allowance to use for trie pruning (default = 25% full mode, 0% archive mode) (default: 25) + --cache.snapshot value Percentage of cache memory allowance to use for snapshot caching (default = 10% full mode, 20% archive mode) (default: 10) + --cache.noprefetch Disable heuristic state prefetch during block import (less CPU and disk IO, more time waiting for data) + --cache.preimages Enable recording the SHA3/keccak preimages of trie keys + --fdlimit value Raise the open file descriptor resource limit (default = system fd limit) (default: 0) + +ACCOUNT OPTIONS: + --unlock value Comma separated list of accounts to unlock + --password value Password file to use for non-interactive password input + --signer value External signer (url or path to ipc file) + --allow-insecure-unlock Allow insecure account unlocking when account-related RPCs are exposed by http + +API AND CONSOLE OPTIONS: + --ipcdisable Disable the IPC-RPC server + --ipcpath value Filename for IPC socket/pipe within the datadir (explicit paths escape it) + --http Enable the HTTP-RPC server + --http.addr value HTTP-RPC server listening interface (default: "localhost") + --http.port value HTTP-RPC server listening port (default: 8545) + --http.api value API's offered over the HTTP-RPC interface + --http.rpcprefix value HTTP path path prefix on which JSON-RPC is served. Use '/' to serve on all paths. + --http.corsdomain value Comma separated list of domains from which to accept cross origin requests (browser enforced) + --http.vhosts value Comma separated list of virtual hostnames from which to accept requests (server enforced). Accepts '*' wildcard. (default: "localhost") + --ws Enable the WS-RPC server + --ws.addr value WS-RPC server listening interface (default: "localhost") + --ws.port value WS-RPC server listening port (default: 8546) + --ws.api value API's offered over the WS-RPC interface + --ws.rpcprefix value HTTP path prefix on which JSON-RPC is served. Use '/' to serve on all paths. + --ws.origins value Origins from which to accept websockets requests + --authrpc.jwtsecret value Path to a JWT secret to use for authenticated RPC endpoints + --authrpc.addr value Listening address for authenticated APIs (default: "localhost") + --authrpc.port value Listening port for authenticated APIs (default: 8551) + --authrpc.vhosts value Comma separated list of virtual hostnames from which to accept requests (server enforced). Accepts '*' wildcard. (default: "localhost") + --graphql Enable GraphQL on the HTTP-RPC server. Note that GraphQL can only be started if an HTTP server is started as well. + --graphql.corsdomain value Comma separated list of domains from which to accept cross origin requests (browser enforced) + --graphql.vhosts value Comma separated list of virtual hostnames from which to accept requests (server enforced). Accepts '*' wildcard. (default: "localhost") + --rpc.gascap value Sets a cap on gas that can be used in eth_call/estimateGas (0=infinite) (default: 50000000) + --rpc.evmtimeout value Sets a timeout used for eth_call (0=infinite) (default: 5s) + --rpc.txfeecap value Sets a cap on transaction fee (in ether) that can be sent via the RPC APIs (0 = no cap) (default: 1) + --rpc.allow-unprotected-txs Allow for unprotected (non EIP155 signed) transactions to be submitted via RPC + --jspath loadScript JavaScript root path for loadScript (default: ".") + --exec value Execute JavaScript statement + --preload value Comma separated list of JavaScript files to preload into the console + +NETWORKING OPTIONS: + --bootnodes value Comma separated enode URLs for P2P discovery bootstrap + --discovery.dns value Sets DNS discovery entry points (use "" to disable DNS) + --port value Network listening port (default: 30303) + --maxpeers value Maximum number of network peers (network disabled if set to 0) (default: 50) + --maxpendpeers value Maximum number of pending connection attempts (defaults used if set to 0) (default: 0) + --nat value NAT port mapping mechanism (any|none|upnp|pmp|extip:) (default: "any") + --nodiscover Disables the peer discovery mechanism (manual peer addition) + --v5disc Enables the experimental RLPx V5 (Topic Discovery) mechanism + --netrestrict value Restricts network communication to the given IP networks (CIDR masks) + --nodekey value P2P node key file + --nodekeyhex value P2P node key as hex (for testing) + +MINER OPTIONS: + --mine Enable mining + --miner.threads value Number of CPU threads to use for mining (default: 0) + --miner.notify value Comma separated HTTP URL list to notify of new work packages + --miner.notify.full Notify with pending block headers instead of work packages + --miner.gasprice value Minimum gas price for mining a transaction (default: 1000000000) + --miner.gaslimit value Target gas ceiling for mined blocks (default: 30000000) + --miner.etherbase value Public address for block mining rewards (default = first account) (default: "0") + --miner.extradata value Block extra data set by the miner (default = client version) + --miner.recommit value Time interval to recreate the block being mined (default: 3s) + --miner.noverify Disable remote sealing verification + +GAS PRICE ORACLE OPTIONS: + --gpo.blocks value Number of recent blocks to check for gas prices (default: 20) + --gpo.percentile value Suggested gas price is the given percentile of a set of recent transaction gas prices (default: 60) + --gpo.maxprice value Maximum transaction priority fee (or gasprice before London fork) to be recommended by gpo (default: 500000000000) + --gpo.ignoreprice value Gas price below which gpo will ignore transactions (default: 2) + +VIRTUAL MACHINE OPTIONS: + --vmdebug Record information useful for VM and contract debugging + +LOGGING AND DEBUGGING OPTIONS: + --fakepow Disables proof-of-work verification + --nocompaction Disables db compaction after import + --verbosity value Logging verbosity: 0=silent, 1=error, 2=warn, 3=info, 4=debug, 5=detail (default: 3) + --vmodule value Per-module verbosity: comma-separated list of = (e.g. eth/*=5,p2p=4) + --log.json Format logs with JSON + --log.backtrace value Request a stack trace at a specific logging statement (e.g. "block.go:271") + --log.debug Prepends log messages with call-site location (file and line number) + --pprof Enable the pprof HTTP server + --pprof.addr value pprof HTTP server listening interface (default: "127.0.0.1") + --pprof.port value pprof HTTP server listening port (default: 6060) + --pprof.memprofilerate value Turn on memory profiling with the given rate (default: 524288) + --pprof.blockprofilerate value Turn on block profiling with the given rate (default: 0) + --pprof.cpuprofile value Write CPU profile to the given file + --trace value Write execution trace to the given file + +METRICS AND STATS OPTIONS: + --metrics Enable metrics collection and reporting + --metrics.expensive Enable expensive metrics collection and reporting + --metrics.addr value Enable stand-alone metrics HTTP server listening interface (default: "127.0.0.1") + --metrics.port value Metrics HTTP server listening port (default: 6060) + --metrics.influxdb Enable metrics export/push to an external InfluxDB database + --metrics.influxdb.endpoint value InfluxDB API endpoint to report metrics to (default: "http://localhost:8086") + --metrics.influxdb.database value InfluxDB database name to push reported metrics to (default: "geth") + --metrics.influxdb.username value Username to authorize access to the database (default: "test") + --metrics.influxdb.password value Password to authorize access to the database (default: "test") + --metrics.influxdb.tags value Comma-separated InfluxDB tags (key/values) attached to all measurements (default: "host=localhost") + --metrics.influxdbv2 Enable metrics export/push to an external InfluxDB v2 database + --metrics.influxdb.token value Token to authorize access to the database (v2 only) (default: "test") + --metrics.influxdb.bucket value InfluxDB bucket name to push reported metrics to (v2 only) (default: "geth") + --metrics.influxdb.organization value InfluxDB organization name (v2 only) (default: "geth") + +ALIASED (deprecated) OPTIONS: + --nousb Disables monitoring for and managing USB hardware wallets (deprecated) + --whitelist value Comma separated block number-to-hash mappings to enforce (=) (deprecated in favor of --eth.requiredblocks) + +MISC OPTIONS: + --snapshot Enables snapshot-database mode (default = enable) + --bloomfilter.size value Megabytes of memory allocated to bloom-filter for pruning (default: 2048) + --ignore-legacy-receipts Geth will start up even if there are legacy receipts in freezer + --help, -h show help + --override.grayglacier value Manually specify Gray Glacier fork-block, overriding the bundled setting (default: 0) + --override.terminaltotaldifficulty value Manually specify TerminalTotalDifficulty, overriding the bundled setting (default: ) + + +COPYRIGHT: + Copyright 2013-2022 The go-ethereum Authors +``` diff --git a/content/docs/fundamentals/Installing-Geth.md b/content/docs/fundamentals/Installing-Geth.md new file mode 100644 index 0000000000..f82d577cca --- /dev/null +++ b/content/docs/fundamentals/Installing-Geth.md @@ -0,0 +1,356 @@ +--- +title: Installing Geth +sort_key: A +--- + +There are several ways to install Geth, including via a package manager, downloading a pre-built bundle, running as a docker container or building from downloaded source code. On this page the various installation options are explained for several major operating systems. Users prioritizing ease of installation should choose to use a package manager or prebuilt bundle. Users prioritizing customization should build from source. It is important to run the latest version of Geth because each release includes bugfixes and improvement over the previous versions. The stable releases are recommended for most users because they have been fully tested. A list of stable releases can be found [here][geth-releases]. Instructions for updating existing Geth installations are also provided in each section. + + +{:toc} + +- this will be removed by the toc + +## Package managers + +### MacOS via Homebrew + +The easiest way to install go-ethereum is to use the Geth Homebrew tap. The first step is to check that Homebrew is installed. The following command should return a version number. + +```shell +brew -v +``` + +If a version number is returned, then Homebrew is installed. If not, Homebrew can be installed by following the instructions [here][brew]. With Homebrew installed, the following commands add the Geth tap and install Geth: + + +```shell +brew tap ethereum/ethereum +brew install ethereum +``` + +The previous command installs the latest stable release. Developers that wish to install the most up-to-date version can install the Geth repository's master branch by adding the `--devel` parameter to the install command: + +```shell +brew install ethereum --devel +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + +Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: + +```shell +brew update +brew upgrade +brew reinstall ethereum +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + + +### Ubuntu via PPAs + +The easiest way to install Geth on Ubuntu-based distributions is with the built-in launchpad PPAs (Personal Package Archives). A single PPA repository is provided, containing stable and development releases for Ubuntu versions `xenial`, `trusty`, `impish`, `focal`, `bionic`. + +The following command enables the launchpad repository: + +```shell +sudo add-apt-repository -y ppa:ethereum/ethereum +``` + +Then, to install the stable version of go-ethereum: + +```shell +sudo apt-get update +sudo apt-get install ethereum +``` + +Or, alternatively the develop version: + +```shell +sudo apt-get update +sudo apt-get install ethereum-unstable +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + + +Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: + +```shell +sudo apt-get update +sudo apt-get install ethereum +sudo apt-get upgrade geth +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + + +### Windows + +The easiest way to install Geth is to download a pre-compiled binary from the [downloads][geth-dl] page. The page provides an installer as well as a zip file containing the Geth source code. The install wizard offers the user the option to install Geth, or Geth and the developer tools. The installer adds `geth` to the system's `PATH` automatically. The zip file contains the command `.exe` files that can be run from the command prompt. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + +Updating an existing Geth installation can be achieved by stopping the node, downloading and installing the latest version following the instructions above. When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + +### FreeBSD via pkg + +Geth can be installed on FreeBSD using the package manager `pkg`. The following command downloads and installs Geth: + +```shell +pkg install go-ethereum +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. + +The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + + +Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: + +```shell +pkg upgrade +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + + +### FreeBSD via ports + +Installing Geth using ports, simply requires navigating to the `net-p2p/go-ethereum` ports directory and running `make install` as root: + +```shell +cd /usr/ports/net-p2p/go-ethereum +make install +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. + +The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + + +Updating an existing Geth installation can be achieved by stopping the node and running the following command: + +```shell +portsnap fetch +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + +### Arch Linux via pacman + +The Geth package is available from the [community repo][geth-archlinux]. It can be installed by running: + +```shell +pacman -S geth +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/bin/`. + +The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + +Updating an existing Geth installation can be achieved by stopping the node and running the following command: + +```shell +sudo pacman -Sy +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + +## Standalone bundle + +Stable releases and development builds are provided as standalone bundles. These are useful for users who: a) wish to install a specific version of Geth (e.g., for reproducible environments); b) wish to install on machines without internet access (e.g. air-gapped computers); or c) wish to avoid automatic updates and instead prefer to manually install software. + +The following standalone bundles are available: + +- 32bit, 64bit, ARMv5, ARMv6, ARMv7 and ARM64 archives (`.tar.gz`) on Linux +- 64bit archives (`.tar.gz`) on macOS +- 32bit and 64bit archives (`.zip`) and installers (`.exe`) on Windows + + +Some archives contain only Geth, while other archives containing Geth and the various developer tools (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`). More information about these executables is available at the [`README`][geth-readme-exe]. + +The standalone bundles can be downloaded from the [Geth Downloads][geth-dl] page. To update an existing installation, download and manually install the latest version. + +## Docker container + +A Docker image with recent snapshot builds from our `develop` branch is maintained on DockerHub to support users who prefer to run containerized processes. There four different Docker images available for running the latest stable or development versions of Geth. + +- `ethereum/client-go:latest` is the latest development version of Geth (default) +- `ethereum/client-go:stable` is the latest stable version of Geth +- `ethereum/client-go:{version}` is the stable version of Geth at a specific version number +- `ethereum/client-go:release-{version}` is the latest stable version of Geth at a specific version family + +Pulling an image and starting a node is achieved by running these commands: + +```shell +docker pull ethereum/client-go +docker run -it -p 30303:30303 ethereum/client-go +``` + +There are also four different Docker images for running the latest stable or development versions of miscellaneous Ethereum tools. + +- `ethereum/client-go:alltools-latest` is the latest development version of the Ethereum tools +- `ethereum/client-go:alltools-stable` is the latest stable version of the Ethereum tools +- `ethereum/client-go:alltools-{version}` is the stable version of the Ethereum tools at a specific version number +- `ethereum/client-go:alltools-release-{version}` is the latest stable version of the Ethereum tools at a specific version family + +The image has the following ports automatically exposed: + +- `8545` TCP, used by the HTTP based JSON RPC API +- `8546` TCP, used by the WebSocket based JSON RPC API +- `8547` TCP, used by the GraphQL API +- `30303` TCP and UDP, used by the P2P protocol running the network + + +**Note:** if you are running an Ethereum client inside a Docker container, you should mount a data volume as the client's data directory (located at `/root/.ethereum` inside the container) to ensure that downloaded data is preserved between restarts and/or container life-cycles. + + +Updating Geth to the latest version simply requires stopping the container, pulling the latest version from Docker and running it: + +```shell +docker stop ethereum/client-go +docker pull ethereum/client-go:latest +docker run -it -p 30303:30303 ethereum/client-go +``` + +## Build from source code + +### Most Linux systems and macOS + +Geth is written in [Go][go], so building from source code requires the most recent version of Go to be installed. Instructions for installing Go are available at the [Go installation page][go-install] and necessary bundles can be downloaded from the [Go download page][go-dl]. + +With Go installed, Geth can be downloaded into a `GOPATH` workspace via: + + +```shell +go get -d github.com/ethereum/go-ethereum +``` + +You can also install specific versions via: + +```shell +go get -d github.com/ethereum/go-ethereum@v1.9.21 +``` + + +The above commands do not build any executables. To do that you can either build one specifically: + +```shell +go install github.com/ethereum/go-ethereum/cmd/geth +``` + + +Alternatively, the following command, run in the project root directory (`ethereum/go-ethereum`) in the GO workspace, builds the entire project and installs Geth and all the developer tools: + + +```shell +go install ./... +``` + +For macOS users, errors related to macOS header files are usually fixed by installing XCode Command Line Tools with `xcode-select --install`. +Another common error is: `go: cannot use path@version syntax in GOPATH mode`. This and other similar errors can often be fixed by enabling gomodules using `export GO111MODULE=on`. + +Updating an existing Geth installation can be achieved using `go get`: + +```shell +go get -u github.com/ethereum/go-ethereum +``` + + +### Windows + +The Chocolatey package manager provides an easy way to install the required build tools. Chocolatey can be installed by following these [instructions][chocolatey]. Then, to install the build tool the following commands can be run in an Administrator command prompt: + + +``` +C:\Windows\system32> choco install git +C:\Windows\system32> choco install golang +C:\Windows\system32> choco install mingw +``` + +Installing these packages sets up the path environment variables. To get the new path a new command prompt must be opened. To install Geth, a Go workspace directory must first be created, then the Geth source code can be created and built. + +``` +C:\Users\xxx> mkdir src\github.com\ethereum +C:\Users\xxx> git clone https://github.com/ethereum/go-ethereum src\github.com\ethereum\go-ethereum +C:\Users\xxx> cd src\github.com\ethereum\go-ethereum +C:\Users\xxx\src\github.com\ethereum\go-ethereum> go get -u -v golang.org/x/net/context +C:\Users\xxx\src\github.com\ethereum\go-ethereum> go install -v ./cmd/... +``` + +### FreeBSD + +To build Geth from source code on FreeBSD, the Geth Github repository can be cloned into a local directory. + + +```shell +git clone https://github.com/ethereum/go-ethereum +``` + +Then, the Go compiler can be used to build Geth: + +```shell +pkg install go +``` + + +If the Go version currently installed is >= 1.5, Geth can be built using the following command: + +```shell +cd go-ethereum +make geth +``` + +If the installed Go version is < 1.5 (quarterly packages, for example), the following command can be used instead: + +```shell +cd go-ethereum +CC=clang make geth +``` + +To start the node, the followijng command can be run: + +```shell +build/bin/geth +``` + +### Building without a Go workflow + +Geth can also be built without using Go workspaces. In this case, the repository should be cloned to a local repository. Then, the command +`make geth` configures everything for a temporary build and cleans up afterwards. This method of building only works on UNIX-like operating systems, and a Go installation is still required. + +```shell +git clone https://github.com/ethereum/go-ethereum.git +cd go-ethereum +make geth +``` + +These commands create a Geth executable file in the `go-ethereum/build/bin` folder that can be moved and run from another directory if required. The binary is standalone and doesn't require any additional files. + +To update an existing Geth installation simply stop the node, navigate to the project root directory and pull the latest version from the Geth Github repository. then rebuild and restart the node. + +```shell +cd go-ethereum +git pull +make geth +``` + +Additionally all the developer tools provided with Geth (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`) can be compiled by running `make all`. More information about these tools can be found [here][geth-readme-exe]. + +Instructions for cross-compiling to another architecture are available in the [cross-compilation guide](./cross-compile). + +To build a stable release, e.g. v1.9.21, the command `git checkout v1.9.21` retrieves that specific version. Executing that command before running `make geth` switches Geth to a stable branch. + + + +[brew]: https://brew.sh/ +[go]: https://golang.org/ +[go-dl]: https://golang.org/dl/ +[go-install]: https://golang.org/doc/install +[chocolatey]: https://chocolatey.org +[geth-releases]: https://github.com/ethereum/go-ethereum/releases +[geth-readme-exe]: https://github.com/ethereum/go-ethereum#executables +[geth-cl-options]: https://geth.ethereum.org/docs/interface/command-line-options +[geth-archlinux]: https://www.archlinux.org/packages/community/x86_64/geth/ +[geth-dl]: ../../downloads/ + + diff --git a/content/docs/fundamentals/Managing-your-accounts.md b/content/docs/fundamentals/Managing-your-accounts.md new file mode 100644 index 0000000000..cdd6305a22 --- /dev/null +++ b/content/docs/fundamentals/Managing-your-accounts.md @@ -0,0 +1,352 @@ +--- +title: Managing Your Accounts +sort_key: B +--- + +**WARNING** +Remember your password. + +If you lose the password you use to encrypt your account, you will not be able to access that account. +Repeat: It is NOT possible to access your account without a password and there is no _forgot my password_ option here. Do not forget it. + +The ethereum CLI `geth` provides account management via the `account` command: + +``` +$ geth account [options...] [arguments...] +``` + +Manage accounts lets you create new accounts, list all existing accounts, import a private +key into a new account, migrate to newest key format and change your password. + +It supports interactive mode, when you are prompted for password as well as +non-interactive mode where passwords are supplied via a given password file. +Non-interactive mode is only meant for scripted use on test networks or known safe +environments. + +Make sure you remember the password you gave when creating a new account (with new, update +or import). Without it you are not able to unlock your account. + +Note that exporting your key in unencrypted format is NOT supported. + +Keys are stored under `/keystore`. Make sure you backup your keys regularly! See +[DATADIR backup & restore](../install-and-build/backup-restore) +for more information. If a custom datadir and keystore option are given the keystore +option takes preference over the datadir option. + +The newest format of the keyfiles is: `UTC----
`. The +order of accounts when listing, is lexicographic, but as a consequence of the timestamp +format, it is actually order of creation + +It is safe to transfer the entire directory or the individual keys therein between +ethereum nodes. Note that in case you are adding keys to your node from a different node, +the order of accounts may change. So make sure you do not rely or change the index in your +scripts or code snippets. + +And again. **DO NOT FORGET YOUR PASSWORD** + +``` +COMMANDS: + list Print summary of existing accounts + new Create a new account + update Update an existing account + import Import a private key into a new account +``` + +You can get info about subcommands by `geth account --help`. +``` +$ geth account list --help +list [command options] [arguments...] + +Print a short summary of all accounts + +OPTIONS: + --datadir "/home/bas/.ethereum" Data directory for the databases and keystore + --keystore Directory for the keystore (default = inside the datadir) +``` + +Accounts can also be managed via the [Javascript Console](../interface/javascript-console) + +## Examples +### Interactive use + +#### creating an account + +``` +$ geth account new +Your new account is locked with a password. Please give a password. Do not forget this password. +Passphrase: +Repeat Passphrase: +Address: {168bc315a2ee09042d83d7c5811b533620531f67} +``` + +#### Listing accounts in a custom keystore directory + +``` +$ geth account list --keystore /tmp/mykeystore/ +Account #0: {5afdd78bdacb56ab1dad28741ea2a0e47fe41331} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-27.437847599Z--5afdd78bdacb56ab1dad28741ea2a0e47fe41331 +Account #1: {9acb9ff906641a434803efb474c96a837756287f} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-52.180688336Z--9acb9ff906641a434803efb474c96a837756287f + +``` + +#### Import private key into a node with a custom datadir + +``` +$ geth account import --datadir /someOtherEthDataDir ./key.prv +The new account will be encrypted with a passphrase. +Please enter a passphrase now. +Passphrase: +Repeat Passphrase: +Address: {7f444580bfef4b9bc7e14eb7fb2a029336b07c9d} +``` + +#### Account update + +``` +$ geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b +Unlocking account a94f5374fce5edbc8e2a8697c15331677e6ebf0b | Attempt 1/3 +Passphrase: +0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b +Account 'a94f5374fce5edbc8e2a8697c15331677e6ebf0b' unlocked. +Please give a new password. Do not forget this password. +Passphrase: +Repeat Passphrase: +0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b +``` + +### Non-interactive use + +You supply a plaintext password file as argument to the `--password` flag. The data in the +file consists of the raw characters of the password, followed by a single newline. + +**Note**: Supplying the password directly as part of the command line is not recommended, +but you can always use shell trickery to get round this restriction. + +``` +$ geth account new --password /path/to/password + +$ geth account import --datadir /someOtherEthDataDir --password /path/to/anotherpassword ./key.prv +``` + +# Creating accounts + +## Creating a new account + +``` +$ geth account new +$ geth account new --password /path/to/passwdfile +$ geth account new --password <(echo $mypassword) + +``` + +Creates a new account and prints the address. + +On the console, use: + +``` +> personal.newAccount() +... you will be prompted for a password ... + +or + +> personal.newAccount("passphrase") + +``` + +The account is saved in encrypted format. You **must** remember this passphrase to unlock +your account in the future. + +For non-interactive use the passphrase can be specified with the `--password` flag: + +``` +geth account new --password +``` + +Note, this is meant to be used for testing only, it is a bad idea to save your +password to file or expose in any other way. + +## Creating an account by importing a private key + +``` + geth account import +``` + +Imports an unencrypted private key from `` and creates a new account and prints +the address. + +The keyfile is assumed to contain an unencrypted private key as canonical EC raw bytes +encoded into hex. + +The account is saved in encrypted format, you are prompted for a passphrase. + +You must remember this passphrase to unlock your account in the future. + +For non-interactive use the passphrase can be specified with the `--password` flag: + +``` +geth account import --password +``` + +**Note**: Since you can directly copy your encrypted accounts to another ethereum +instance, this import/export mechanism is not needed when you transfer an account between +nodes. + +**Warning:** when you copy keys into an existing node's keystore, the order of accounts +you are used to may change. Therefore you make sure you either do not rely on the account +order or doublecheck and update the indexes used in your scripts. + +**Warning:** If you use the password flag with a password file, best to make sure the file +is not readable or even listable for anyone but you. You achieve this with: + +``` +touch /path/to/password +chmod 700 /path/to/password +cat > /path/to/password +>I type my pass here^D +``` + +## Updating an existing account + +You can update an existing account on the command line with the `update` subcommand with +the account address or index as parameter. You can specify multiple accounts at once. + +``` +geth account update 5afdd78bdacb56ab1dad28741ea2a0e47fe41331 9acb9ff906641a434803efb474c96a837756287f +geth account update 0 1 2 +``` + +The account is saved in the newest version in encrypted format, you are prompted +for a passphrase to unlock the account and another to save the updated file. + +This same command can therefore be used to migrate an account of a deprecated +format to the newest format or change the password for an account. + +After a successful update, all previous formats/versions of that same key are removed! + +# Importing your presale wallet + +Importing your presale wallet is very easy. If you remember your password that is: + +``` +geth wallet import /path/to/my/presale.wallet +``` + +will prompt for your password and imports your ether presale account. It can be used +non-interactively with the --password option taking a passwordfile as argument containing +the wallet password in cleartext. + +# Listing accounts and checking balances + +### Listing your current accounts + +From the command line, call the CLI with: + +``` +$ geth account list +Account #0: {5afdd78bdacb56ab1dad28741ea2a0e47fe41331} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-27.437847599Z--5afdd78bdacb56ab1dad28741ea2a0e47fe41331 +Account #1: {9acb9ff906641a434803efb474c96a837756287f} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-52.180688336Z--9acb9ff906641a434803efb474c96a837756287f +``` + +to list your accounts in order of creation. + +**Note**: +This order can change if you copy keyfiles from other nodes, so make sure you either do not rely on indexes or make sure if you copy keys you check and update your account indexes in your scripts. + +When using the console: +``` +> eth.accounts +["0x5afdd78bdacb56ab1dad28741ea2a0e47fe41331", "0x9acb9ff906641a434803efb474c96a837756287f"] +``` + +or via RPC: +``` +# Request +$ curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":1}' -H 'Content-type: application/json' http://127.0.0.1:8545 + +# Result +{ + "id":1, + "jsonrpc": "2.0", + "result": ["0x5afdd78bdacb56ab1dad28741ea2a0e47fe41331", "0x9acb9ff906641a434803efb474c96a837756287f"] +} +``` + +If you want to use an account non-interactively, you need to unlock it. You can do this on +the command line with the `--unlock` option which takes a comma separated list of accounts +(in hex or index) as argument so you can unlock the accounts programmatically for one +session. This is useful if you want to use your account from Dapps via RPC. `--unlock ` +will unlock the first account. This is useful when you created your account +programmatically, you do not need to know the actual account to unlock it. + +Create account and start node with account unlocked: +``` +geth account new --password <(echo this is not secret!) +geth --password <(echo this is not secret!) --unlock primary --rpccorsdomain localhost --verbosity 6 2>> geth.log +``` + +Instead of the account address, you can use integer indexes which refers to the address +position in the account listing (and corresponds to order of creation) + +The command line allows you to unlock multiple accounts. In this case the argument to +unlock is a comma delimited list of accounts addresses or indexes. + +``` +geth --unlock "0x407d73d8a49eeb85d32cf465507dd71d507100c1,0,5,e470b1a7d2c9c5c6f03bbaa8fa20db6d404a0c32" +``` + +If this construction is used non-interactively, your password file will need to contain +the respective passwords for the accounts in question, one per line. + +On the console you can also unlock accounts (one at a time) for a duration (in seconds). + +``` +personal.unlockAccount(address, "password", 300) +``` + +Note that we do NOT recommend using the password argument here, since the console history +is logged, so you may compromise your account. You have been warned. + +### Checking account balances + +To check your the etherbase account balance: +``` +> web3.fromWei(eth.getBalance(eth.coinbase), "ether") +6.5 +``` + +Print all balances with a JavaScript function: +``` +function checkAllBalances() { + var totalBal = 0; + for (var acctNum in eth.accounts) { + var acct = eth.accounts[acctNum]; + var acctBal = web3.fromWei(eth.getBalance(acct), "ether"); + totalBal += parseFloat(acctBal); + console.log(" eth.accounts[" + acctNum + "]: \t" + acct + " \tbalance: " + acctBal + " ether"); + } + console.log(" Total balance: " + totalBal + " ether"); +}; +``` +That can then be executed with: +``` +> checkAllBalances(); + eth.accounts[0]: 0xd1ade25ccd3d550a7eb532ac759cac7be09c2719 balance: 63.11848 ether + eth.accounts[1]: 0xda65665fc30803cb1fb7e6d86691e20b1826dee0 balance: 0 ether + eth.accounts[2]: 0xe470b1a7d2c9c5c6f03bbaa8fa20db6d404a0c32 balance: 1 ether + eth.accounts[3]: 0xf4dd5c3794f1fd0cdc0327a83aa472609c806e99 balance: 6 ether +``` + +Since this function will disappear after restarting geth, it can be helpful to store +commonly used functions to be recalled later. The +[loadScript](../interface/javascript-console) +function makes this very easy. + +First, save the `checkAllBalances()` function definition to a file on your computer. For +example, `/Users/username/gethload.js`. Then load the file from the interactive console: + +``` +> loadScript("/Users/username/gethload.js") +true +``` + +The file will modify your JavaScript environment as if you has typed the commands +manually. Feel free to experiment! diff --git a/content/docs/fundamentals/cross-compile.md b/content/docs/fundamentals/cross-compile.md new file mode 100644 index 0000000000..55af4e6652 --- /dev/null +++ b/content/docs/fundamentals/cross-compile.md @@ -0,0 +1,167 @@ +--- +title: Cross-Compiling Geth +sort_key: C +--- + +**Note: All of these and much more have been merged into the project Makefile. You can +cross build via `make geth--` without needing to know any of these details +from below.** + +Developers usually have a preferred platform that they feel most comfortable working in, +with all the necessary tools, libraries and environments set up for an optimal workflow. +However, there's often need to build for either a different CPU architecture, or an +entirely different operating system; but maintaining a development environment for each +and switching between the them quickly becomes unwieldy. + +Here we present a very simple way to cross compile Ethereum to various operating systems +and architectures using a minimal set of prerequisites and a completely containerized +approach, guaranteeing that your development environment remains clean even after the +complex requirements and mechanisms of a cross compilation. + +The currently supported target platforms are: + + - ARMv7 Android and iOS + - 32 bit, 64 bit and ARMv5 Linux + - 32 bit and 64 bit Mac OSX + - 32 bit and 64 bit Windows + +Please note, that cross compilation does not replace a release build. Although resulting +binaries can usually run perfectly on the desired platform, compiling on a native system +with the specialized tools provided by the official vendor can often result in more a +finely optimized code. + +## Cross compilation environment + +Although the `go-ethereum` project is written in Go, it does include a bit of C code +shared between all implementations to ensure that all perform equally well, including a +dependency to the GNU Multiple Precision Arithmetic Library. Because of these, Go cannot +by itself compile to a different platform than the host. To overcome this limitation, we +will use [`xgo`](https://github.com/karalabe/xgo), a Go cross compiler package based on +Docker containers that has been architected specifically to allow both embedded C snippets +as well as simpler external C dependencies during compilation. + +The `xgo` project has two simple dependencies: Docker (to ensure that the build +environment is completely contained) and Go. On most platforms these should be available +from the official package repositories. For manually installing them, please consult their +install guides at [Docker](https://docs.docker.com/installation/) and +[Go](https://golang.org/doc/install) respectively. This guide assumes that these two +dependencies are met. + +To install and/or update xgo, simply type: + + $ go get -u github.com/karalabe/xgo + +You can test whether `xgo` is functioning correctly by requesting it to cross +compile itself and verifying that all cross compilations succeeded or not. + + $ xgo github.com/karalabe/xgo + ... + + $ ls -al + -rwxr-xr-x 1 root root 2792436 Sep 14 16:45 xgo-android-21-arm + -rwxr-xr-x 1 root root 2353212 Sep 14 16:45 xgo-darwin-386 + -rwxr-xr-x 1 root root 2906128 Sep 14 16:45 xgo-darwin-amd64 + -rwxr-xr-x 1 root root 2388288 Sep 14 16:45 xgo-linux-386 + -rwxr-xr-x 1 root root 2960560 Sep 14 16:45 xgo-linux-amd64 + -rwxr-xr-x 1 root root 2437864 Sep 14 16:45 xgo-linux-arm + -rwxr-xr-x 1 root root 2551808 Sep 14 16:45 xgo-windows-386.exe + -rwxr-xr-x 1 root root 3130368 Sep 14 16:45 xgo-windows-amd64.exe + + +## Building Ethereum + +Cross compiling Ethereum is analogous to the above example, but an additional flags is +required to satisfy the dependencies: + + - `--deps` is used to inject arbitrary C dependency packages and pre-build them + +Injecting the GNU Arithmetic Library dependency and selecting `geth` would be: + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + github.com/ethereum/go-ethereum/cmd/geth + ... + + $ ls -al + -rwxr-xr-x 1 root root 23213372 Sep 14 17:59 geth-android-21-arm + -rwxr-xr-x 1 root root 14373980 Sep 14 17:59 geth-darwin-386 + -rwxr-xr-x 1 root root 17373676 Sep 14 17:59 geth-darwin-amd64 + -rwxr-xr-x 1 root root 21098910 Sep 14 17:59 geth-linux-386 + -rwxr-xr-x 1 root root 25049693 Sep 14 17:59 geth-linux-amd64 + -rwxr-xr-x 1 root root 20578535 Sep 14 17:59 geth-linux-arm + -rwxr-xr-x 1 root root 16351260 Sep 14 17:59 geth-windows-386.exe + -rwxr-xr-x 1 root root 19418071 Sep 14 17:59 geth-windows-amd64.exe + + +As the cross compiler needs to build all the dependencies as well as the main project +itself for each platform, it may take a while for the build to complete (approximately 3-4 +minutes on a Core i7 3770K machine). + +### Fine tuning the build + +By default Go, and inherently `xgo`, checks out and tries to build the master branch of a +source repository. However, more often than not, you'll probably want to build a different +branch from possibly an entirely different remote repository. These can be controlled via +the `--remote` and `--branch` flags. + +To build the `develop` branch of the official `go-ethereum` repository instead of the +default `master` branch, you just need to specify it as an additional command line flag +(`--branch`): + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + --branch=develop \ + github.com/ethereum/go-ethereum/cmd/geth + +Additionally, during development you will most probably want to not only build a custom +branch, but also one originating from your own fork of the repository instead of the +upstream one. This can be done via the `--remote` flag: + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + --remote=https://github.com/karalabe/go-ethereum \ + --branch=rpi-staging \ + github.com/ethereum/go-ethereum/cmd/geth + +By default `xgo` builds binaries for all supported platforms and architectures, with +Android binaries defaulting to the highest released Android NDK platform. To limit the +build targets or compile to a different Android platform, use the `--targets` CLI +parameter. + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + --targets=android-16/arm,windows/* \ + github.com/ethereum/go-ethereum/cmd/geth + +### Building locally + +If you would like to cross compile your local development version, simply specify a local +path (starting with `.` or `/`), and `xgo` will use all local code from `GOPATH`, only +downloading missing dependencies. In such a case of course, the `--branch`, `--remote` and +`--pkg` arguments are no-op: + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + ./cmd/geth + +## Using the Makefile + +Having understood the gist of `xgo` based cross compilation, you do not need to actually +memorize and maintain these commands, as they have been incorporated into the official +[Makefile](https://github.com/ethereum/go-ethereum/blob/master/Makefile) and can be +invoked with a trivial `make` request: + + * `make geth-cross`: Cross compiles to every supported OS and architecture + * `make geth-`: Cross compiles supported architectures of a particular OS (e.g. `linux`) + * `make geth--`: Cross compiles to a specific OS/architecture (e.g. `linux`, `arm`) + +We advise using the `make` based commands opposed to manually invoking `xgo` as we do +maintain the Makefile actively whereas we cannot guarantee that this document will be +always readily updated to latest advancements. + +### Tuning the cross builds + +A few of the `xgo` build options have also been surfaced directly into the Makefile to +allow fine tuning builds to work around either upstream Go issues, or to enable some +fancier mechanics. + + - `make ... GO=`: Use a specific Go runtime (e.g. `1.5.1`, `1.5-develop`, `develop`) + - `make ... MODE=`: Build a specific target type (e.g. `exe`, `c-archive`). + +Please note that these are not yet fully finalized, so they may or may not change in the +future as our code and the Go runtime features change. diff --git a/content/docs/fundamentals/les.md b/content/docs/fundamentals/les.md new file mode 100644 index 0000000000..ba84a7d52a --- /dev/null +++ b/content/docs/fundamentals/les.md @@ -0,0 +1,61 @@ +--- +title: Light client +sort_key: B +--- + +Running a full node is the most trustless, private, decentralized and censorship resistant way to interact with Ethereum. It is also the best choice for the health of the network, because a decentralized network relies on having many individual nodes that independently verify the head of the chain. In a full node a copy of the blockchain is stored locally enabling users to verify incoming data against a local source of truth. However, running a full node requires a lot of disk space and non-negligible CPU allocation and takes hours (for snap sync) or days (for full sync) to sync the blockchain from genesis. Geth also offers a light mode that overcomes these issues and provides some of the benefits of running a node but requires only a fraction of the resources. + +Read more about the reasons to run nodes on [ethereum.org](https://ethereum.org/en/run-a-node/). + +## Light node vs full node + +Running Geth in light mode has the following advantages for users: + +- Syncing takes minutes rather than hours/days +- Light mode uses significantly less storage +- Light mode is lighter on CPU and other resources +- Light mode is suitable for resource-constrained devices +- Light mode can catch up much quicker after having been offline for a while + +However, the cost of this performance increase is that a light Geth node depends heavily on full-node peers that choose, for altruistic reasons, to run light servers. There is no monetary incentive for full nodes to run light servers and it is an opt-in, rather than opt-out function of a Geth full node. For those reasons light servers are rather rare and can quickly become overwhelmed by data requests from light clients. The result of this is that **Geth nodes run in light mode often struggle to find peers**. + +A light client can be used to query data from Ethereum and submit transactions, acting as a locally-hosted Ethereum wallet. However they have different security guarantees than full nodes. Because they don't keep local copies of the Ethereum state, light nodes can't validate the blocks in the same way as the full nodes. Instead they fetch block headers by requesting them from full nodes and check their proof-of-work (PoW), assuming the heaviest chain is valid. This means that it is sensible to wait until a few additional blocks have been confirmed before trusting the validity of a recently-mined transaction. + +### Running a light server + +Full node operators that choose to enable light serving altruistically enable other users to run light clients. This is good for Ethereum because it makes it easier for a wider population of users to interact with Ethereum without using trusted intermediaries. However, there is naturally a limit to how much resource a node operator is able and willing to dedicate to serving light clients. Therefore, the command that enables light serving requires arguments that define the upper bound on resource allocation. The value given is in percent of a processing thread, for example `--light.serve 300` enables light-serving and dedicates three processing threads to it. + +Recent versions of Geth (>`1.9.14`) unindex older transactions to save disk space. Indexing is required for looking up transactions in Geth's database. Therefore, unindexing limits the data that can be requested by light clients. This unindexing can be disabled by adding `--tx.txlookuplimit 0` to make the maximum data available to light clients. + +The whole command for starting Geth with a light server could look as follows: + +```shell +geth --light.serve 50 --txlookuplimit 0 +``` + +### Running a light client + +Running a light client simply requires Geth to be started in light mode. It is likely that a user would also want to interact with the light node using, for example, RPC. This can be enabled using the `--http` command. + +```shell +geth --syncmode light --http --http.api "eth,debug" +``` + +Data can be requested from this light Geth instance in the same way as for a full node (i.e. using the [JSON-RPC-API](/docs/rpc/server) using tools such as [Curl](https://curl.se/) or Geth's [Javascript console](/docs/interface/javascript-console)). Instead of fetching the data from a local database as in a full node, the light Geth instance requests the data from full-node peers. + +It's also possible to send transactions. However, light clients are not connected directly to Ethereum Mainnet but to a network of light servers that connect to Ethereum Mainnet. This means a transaction submitted by a light client is received first by a light server that then propagates it to full-node peers on the light-client's behalf. This reliance on honest light-servers is one of the trust compromises that comes along with running a light node instead of a full node. + + +### Ultra light clients + +Geth has an even lighter sync mode called ultra light client (ULC). The difference between light mode and ultra-light mode is that a ULC doesn't check the PoW in block headers. There is an assumption that the ULC has access to one or more trusted light servers. This option has the greatest trust assumptions but the smallest resource requirement. + +To start an ultra-light client, the enode addresses of the trusted light servers must be passed to the `--ulc.servers` command and the sync mode is `light`: + +```sh +geth --syncmode light --ulc.servers "enode://...,enode://..." --http --http.api "eth,debug" +``` + +## Summary + +Running a full node is the most trustless way to interact with Ethereum. However, Geth provides a low-resource "light" mode that can be run on modest computers and requires much less disk space. The trade-offs are additional trust assumptions and a small pool of light-serving peers to connect to. diff --git a/content/docs/fundamentals/peer-to-peer.md b/content/docs/fundamentals/peer-to-peer.md new file mode 100644 index 0000000000..8a4d4614d0 --- /dev/null +++ b/content/docs/fundamentals/peer-to-peer.md @@ -0,0 +1,165 @@ +--- +title: Connecting To The Network +sort_key: B +--- + +The default behaviour for Geth is to connect to Ethereum Mainnet. However, Geth can also connect to public testnets, [private networks](/docs/getting-started/private-net) and [local testnets](/docs/getting-started/dev-mode). Command line flags are provided for connecting to the popular public testnets: + +- `--ropsten`, Ropsten proof-of-work test network +- `--rinkeby`, Rinkeby proof-of-authority test network +- `--goerli`, Goerli proof-of-authority test network +- `--sepolia` Sepolia proof-of-work test network + +Providing these flags at startup instructs Geth to connect to the specific public testnet instead of Ethereum Mainnet. Because these are public testnets that have been running for several years, Geth has to download the historical blockchain data from genesis, just the same as for Ethereum Mainnet. + +**Note:** network selection is not persisted in the config file. To connect to a pre-defined network you must always enable it explicitly, even when using the `--config` flag to load other configuration values. For example: + +```shell + +# Generate desired config file. You must specify testnet here. +geth --goerli --syncmode "full" ... dumpconfig > goerli.toml + +# Start geth with given config file. Here too the testnet must be specified. +geth --goerli --config goerli.toml + +``` + +## Finding peers + +Geth continuously attempts to connect to other nodes on the network until it has enough peers. If UPnP (Universal Plug and Play) is enabled at the router or Ethereum is run on an Internet-facing server, it will also accept connections from other nodes. Geth finds peers using the [discovery protocol](https://ethereum.org/en/developers/docs/networking-layer/#discovery). In the discovery protocol, nodes exchange connectivity details and then establish sessions ([RLPx](https://github.com/ethereum/devp2p/blob/master/rlpx.md)). If the nodes support compatible sub-protocols they can start exchanging Ethereum data [on the wire](https://ethereum.org/en/developers/docs/networking-layer/#wire-protocol). + +A new node entering the network for the first time gets introduced to a set of peers by a bootstrap node ("bootnode") whose sole purpose is to connect new nodes to peers. The endpoints for these bootnodes are hardcoded into Geth, but they can also be specified by providing the `--bootnode` flag along with comma-separated bootnode addresses in the form of [enodes](https://ethereum.org/en/developers/docs/networking-layer/network-addresses/#enode) on startup. For example: + +```shell + +geth --bootnodes enode://pubkey1@ip1:port1,enode://pubkey2@ip2:port2,enode://pubkey3@ip3:port3 + +``` + +There are scenarios where disabling the discovery process is useful, for example for running a local test node or an experimental test network with known, fixed nodes. This can be achieved by passing the `--nodiscover` flag to Geth at startup. + + +## Connectivity problems + +There are occasions when Geth simply fails to connect to peers. The common reasons for this are: + +- Local time might be incorrect. An accurate clock is required to participate in the Ethereum network. The local clock can be resynchronized using commands such as `sudo ntpdate -s time.nist.gov` (this will vary depending on operating system). + +- Some firewall configurations can prohibit UDP traffic. The static nodes feature or `admin.addPeer()` on the console can be used to configure connections manually. + +- Running Geth in [light mode](/docs/interface/les) often leads to connectivity issues because there are few nodes running light servers. There is no easy fix for this except to switch Geth out of light mode. + +- The public test network Geth is connecting to might be deprecated or have a low number of active nodes that are hard to find. In this case, the best action is to switch to an alternative test network. + + +## Checking Connectivity + +The `net` module has two attributes that enable checking node connectivity from the [interactive Javascript console](/docs/interface/javascript-console). These are `net.listening` which reports whether the Geth node is listening for inbound requests, and `peerCount` which returns the number of active peers the node is connected to. + + +```javascript + +> net.listening +true + +> net.peerCount +4 + +``` + +Functions in the `admin` module provide more information about the connected peers, including their IP address, port number, supported protocols etc. Calling `admin.peers` returns this information for all connected peers. + +``` +> admin.peers +[{ + ID: 'a4de274d3a159e10c2c9a68c326511236381b84c9ec52e72ad732eb0b2b1a2277938f78593cdbe734e6002bf23114d434a085d260514ab336d4acdc312db671b', + Name: 'Geth/v0.9.14/linux/go1.4.2', + Caps: 'eth/60', + RemoteAddress: '5.9.150.40:30301', + LocalAddress: '192.168.0.28:39219' +}, { + ID: 'a979fb575495b8d6db44f750317d0f4622bf4c2aa3365d6af7c284339968eef29b69ad0dce72a4d8db5ebb4968de0e3bec910127f134779fbcb0cb6d3331163c', + Name: 'Geth/v0.9.15/linux/go1.4.2', + Caps: 'eth/60', + RemoteAddress: '52.16.188.185:30303', + LocalAddress: '192.168.0.28:50995' +}, { + ID: 'f6ba1f1d9241d48138136ccf5baa6c2c8b008435a1c2bd009ca52fb8edbbc991eba36376beaee9d45f16d5dcbf2ed0bc23006c505d57ffcf70921bd94aa7a172', + Name: 'pyethapp_dd52/v0.9.13/linux2/py2.7.9', + Caps: 'eth/60, p2p/3', + RemoteAddress: '144.76.62.101:30303', + LocalAddress: '192.168.0.28:40454' +}, { + ID: 'f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0', + Name: '++eth/Zeppelin/Rascal/v0.9.14/Release/Darwin/clang/int', + Caps: 'eth/60, shh/2', + RemoteAddress: '129.16.191.64:30303', + LocalAddress: '192.168.0.28:39705' +} ] + +``` + +The `admin` module also includes functions for gathering information about the local node rather than its peers. For example, `admin.nodeInfo` returns the name and connectivity details for the local node. + +``` +> admin.nodeInfo +{ + Name: 'Geth/v0.9.14/darwin/go1.4.2', + NodeUrl: 'enode://3414c01c19aa75a34f2dbd2f8d0898dc79d6b219ad77f8155abf1a287ce2ba60f14998a3a98c0cf14915eabfdacf914a92b27a01769de18fa2d049dbf4c17694@[::]:30303', + NodeID: '3414c01c19aa75a34f2dbd2f8d0898dc79d6b219ad77f8155abf1a287ce2ba60f14998a3a98c0cf14915eabfdacf914a92b27a01769de18fa2d049dbf4c17694', + IP: '::', + DiscPort: 30303, + TCPPort: 30303, + Td: '2044952618444', + ListenAddr: '[::]:30303' +} +``` + +## Custom Networks + +It is often useful for developers to connect to private test networks rather than public testnets or Etheruem mainnet. These sandbox environments allow block creation without competing against other miners, easy minting of test ether and give freedom to break things without real-world consequences. A private network is started by providing a value to `--networkid` that is not used by any other existing public network ([Chainlist](https://chainlist.org)) and creating a custom `genesis.json` file. Detailed instructions for this are available on the [Private Networks page](/docs/interface/private-network). + + +## Static nodes + +Geth also supports static nodes. Static nodes are specific peers that are always connected to. Geth reconnects to these peers automatically when it is restarted. Specific nodes are defined to be static nodes by saving their enode addresses to a json file which must be stored in `datadir/geth/static-nodes.json`. The content of `static-nodes.json` should be formatted as follows: + +```javascript +[ + "enode://f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0@33.4.2.1:30303", + "enode://pubkey@ip:port" +] +``` + +Static nodes can also be added at runtime in the Javascript console by passing an enode address to `admin.addPeer()`: + +```javascript + +admin.addPeer("enode://f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0@33.4.2.1:30303") + +``` + +## Peer limit + +It is sometimes desirable to cap the number of peers Geth will connect to in order to limit on the computational and bandwidth cost associated with running a node. By default, the limit is 50 peers, however, this can be updated by passing a value to `--maxpeers`: + +```shell + +geth --maxpeers 15 + +``` + +## Trusted nodes + +Geth supports trusted nodes that are always allowed to reconnect, even if the peer limit is reached. They can be added persistently via a config file `/geth/trusted-nodes.json` or temporarily using the Javascript console. The format for the config file is identical to the one used for static nodes. + +Nodes can be added using the `admin.addTrustedPeer()` call in the Javascript console and removed using `admin.removeTrustedPeer()` call. + +```javascript +admin.addTrustedPeer("enode://f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0@33.4.2.1:30303") +``` + + +## Summary + +Geth connects to Ethereum Mainnet by default. However, this behaviour can be changed using combinations of command line flags and files. This page has described the various options available for connecting a Geth node to Ethereum, public testnets and private networks. diff --git a/content/docs/getting_started/consensus-clients.md b/content/docs/getting_started/consensus-clients.md new file mode 100644 index 0000000000..363997036e --- /dev/null +++ b/content/docs/getting_started/consensus-clients.md @@ -0,0 +1,140 @@ +--- +title: Connecting to Consensus Clients +sort_key: A3 +--- + +Geth is an [execution client][ex-client-link]. Historically, an execution client alone has been enough to run a full Ethereum node. +However, Ethereum will soon swap its consensus mechanism from [proof-of-work][pow-link] (PoW) to +[proof-of-stake][pos-link] (PoS) in a transition known as [The Merge](/docs/interface/merge). + +When that happens, Geth will not be able to track the Ethereum chain on its own. Instead, it will need to +be coupled to another piece of software called a ["consensus client"][con-client-link]. For Geth users that +intend to continue to run full nodes after The Merge, it is sensible to start running a consensus client now, +so that The Merge can happen smoothly. There are five consensus clients available, all of which connect to Geth in the same way. + +This page will outline how Geth can be set up with a consensus client in advance of The Merge (or to interact with an alread-merged testnet). + +{% include note.html content=" It is recommended to practise connecting a consensus client to Geth on a testnet such as Sepolia or Goerli but to +wait until merge-ready releases are available before doing it on Ethereum Mainnet." %} + +## Configuring Geth + +Geth can be downloaded and installed according to the instructions on the +[Installing Geth](/docs/install-and-build/installing-geth) page. In order to connect to a consensus client, +Geth must expose a port for the inter-client RPC connection. + +The RPC connection must be authenticated using a `jwtsecret` file. This is created and saved +to `/geth/jwtsecret` by default but can also be created and saved to a custom location or it can be +self-generated and provided to Geth by passing the file path to `--authrpc.jwtsecret`. The `jwtsecret` file +is required by both Geth and the consensus client. + +The authorization must then be applied to a specific address/port. This is achievd by passing an address to +`--authrpc.addr` and a port number to `--authrpc.port`. It is also safe to provide either `localhost` or a wildcard +`*` to `--authrpc.vhosts` so that incoming requests from virtual hosts are accepted by Geth because it only +applies to the port authenticated using `jwtsecret`. + +The Merge itself will be triggered using a terminal total difficulty (TTD). The specific value for the TTD has not yet +been decided. When it is decided, Geth needs to know what it is in order to merge successfully. This will most likely be +included in a new release, so Geth will have to be stopped, updated and restarted in advance of The Merge. + +A complete command to start Geth so that it can connect to a consensus client looks as follows: + +```shell +geth --authrpc.addr localhost --authrpc.port 8551 --authrpc.vhosts localhost --authrpc.jwtsecret /tmp/jwtsecret +``` + + +## Consensus clients + +There are currently four consensus clients that can be run alongside Geth. These are: + +[Lighthouse](https://lighthouse-book.sigmaprime.io/): written in Rust + +[Nimbus](https://nimbus.team/): written in Nim + +[Prysm](https://docs.prylabs.network/docs/getting-started/): written in Go + +[Teku](https://pegasys.tech/teku): written in Java + +It is recommended to consider [client diversity][client-div-link] when choosing a consensus client. Instructions for installing each client are provided in the documentation linked in the list above. + +The consensus client must be started with the right port configuration to establish an RPC connection +to the local Geth instance. In the example above, `localhost:8551` was authorized +for this purpose. The consensus clients all have a command similar to `--http-webprovider` that +takes the exposed Geth port as an argument. + +The consensus client also needs the path to Geth's `jwt-secret` in order to authenticate the RPC connection between them. +Each consensus client has a command similar to `--jwt-secret` that takes the file path as an argument. This must +be consistent with the `--authrpc.jwtsecret` path provided to Geth. + +The consensus clients all expose a [Beacon API][beacon-api-link] that can be used to check the status +of the Beacon client or download blocks and consensus data by sending requests using tools such as [Curl](https://curl.se). +More information on this can be found in the documentation for each consensus client. + +## Validators + +After The Merge, miners are no longer responsible for securing the Ethereum blockchain. Instead, this becomes the responsibility +of validators that have staked at least 32 ETH into a deposit contract and run validator software. Each of the consensus clients +have their own validator software that is described in detail in their respective documentation. The easiest way to handle +staking and validator key generation is to use the Ethereum Foundation [Staking Launchpad][launchpad-link]. The launchpad is also +available for [Prater][prater-launchpad-link], [Ropsten][ropsten-launchpad-link] and [Kiln][kiln-launchpad-link] testnets. It is +also highly recommended to review the [Merge readiness checklist][checklist-link]. + +## Using Geth + +After the merge, Geth will follow the head of the chain via its connection to the consensus client. However, Geth is still +the portal for users to send transactions to Ethereum. Overall, Geth will not change very much from a user-perspective. +The Geth Javascript console is still available for this purpose, and the majority of the [JSON-RPC API](/docs/rpc/server) will +remain available via web3js or HTTP requests with commands as json payloads. These options are explained in more detail on the +[Javascript Console page](/docs/interface/javascript-console). The Javascript console can be started using the following command +in a separate terminal (assuming Geth's IPC file is saved in `datadir`): + +```shell +geth attach datadir/geth.ipc +``` + + +## Testnets + +Ethereum Mainnet has not yet undergone The Merge, but some public testnets have. This means that running Geth alone is no longer +enough to interact with merged testnets. This includes two testnets that were purpose built to test The Merge (Kiln, Kintsugi) and +the long-standing public PoW chain, Ropsten, as well as the relatively new testnet Sepolia. If Geth is connected to these merged networks alone it will simply stall when it syncs as far +as the merge block, awaiting information from a consensus client. Therefore, any activity on these testnets requires Geth to be +connected to a consensus client. There are many instructional articles that exlain how to connect to these testnets using Geth in +combination with various consensus clients, for example: + +[Connecting to Kiln using Teku](https://github.com/chrishobcroft/TestingTheMerge/blob/main/geku.md) + +[Connecting to Kiln using Lighthouse](https://github.com/remyroy/ethstaker/blob/main/merge-devnet.md) + +[Connecting to Kiln using Prysm](https://hackmd.io/@prysmaticlabs/B1Q2SluWq) + +[Connecting to Ropsten using Lighthouse](https://github.com/remyroy/ethstaker/blob/main/merge-ropsten.md) + + +The Merge testing will soon progress to merging the Goerli testnet. Once this has happened Geth will require a connection +to a consensus client to work on those networks too. + + +## Summary + +As The Merge approaches it is important for Geth users to prepare by installing and running a consensus client. Otherwise, Geth will stop +following the head of the chain immediately after The Merge. There are five consensus clients to choose from. This page provided an overview +of how to choose a consensus client and configure Geth to connect to it. This pre-emptive action will protect against disruption to users as a +result of The Merge. + + +[pow-link]:https://ethereum.org/en/developers/docs/consensus-mechanisms/pow +[pos-link]:https://ethereum.org/en/developers/docs/consensus-mechanisms/pos +[con-client-link]:https://ethereum.org/en/glossary/#consensus-client +[ex-client-link]:https://ethereum.org/en/glossary/#execution-client +[beacon-api-link]:https://ethereum.github.io/beacon-APIs +[engine-api-link]: https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md +[client-div-link]:https://ethereum.org/en/developers/docs/nodes-and-clients/client-diversity +[execution-clients-link]: https://ethereum.org/en/developers/docs/nodes-and-clients/client-diversity/#execution-clients +[launchpad-link]:https://launchpad.ethereum.org/ +[prater-launchpad-link]:https://prater.launchpad.ethereum.org/ +[kiln-launchpad-link]:https://kiln.launchpad.ethereum.org/ +[ropsten-launchpad-link]:https://ropsten.launchpad.ethereum.org/ +[e-org-link]: https://ethereum.org/en/developers/docs/nodes-and-clients/run-a-node/ +[checklist-link]:https://launchpad.ethereum.org/en/merge-readiness diff --git a/content/docs/getting_started/index.md b/content/docs/getting_started/index.md new file mode 100644 index 0000000000..86b3f3a2ca --- /dev/null +++ b/content/docs/getting_started/index.md @@ -0,0 +1,474 @@ +--- +title: Getting Started with Geth +permalink: docs/getting-started +sort_key: A +--- + +This page explains how to set up Geth and execute some basic tasks using the command line tools. In order to use Geth, the software must first be installed. There are several ways Geth can be installed depending on the operating system and the user's choice of installation method, for example using a package manager, container or building from source. Instructions for installing Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. The tutorial on this page assumes Geth and the associated developer tools have been installed successfully. + +This page provides step-by-step instructions covering the fundamentals of using Geth. This includes generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. This tutorial also uses [Clef](clef/tutorial). Clef is an account management tool external to Geth itself that allows users to sign transactions. It is developed and maintained by the Geth team and is intended to eventually replace the account management tool built in to Geth. + +## Prerequisites + +In order to get the most value from the tutorials on this page, the following skills are necessary: + +- Experience using the command line +- Basic knowledge about Ethereum and testnets +- Basic knowledge about HTTP and JavaScript + +Users that need to revisit these fundamentals can find helpful resources relating to the command line [here](https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line), Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and Javascript [here](https://www.javascript.com/learn). + +{% include note.html content="If Geth was installed from source on Linux, `make` saves the binaries for Geth and the associated tools in `/build/bin`. To run these programs it is convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} + +## Background + +Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being managed by a central server. Nodes compete to generate new blocks of transactions to send to its peers because they are rewarded for doing so in Ethereum's native token, ether (ETH). On receiving a new block, each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called a "blockchain". The information provided in each block is used by Geth to update its "state" - the ether balance of each account on Ethereum. There are two types of account: externally-owned accounts (EOAs) and contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, where the public key is used to derive a unique address for the user and the private key is used to protect the account and securely sign messages. Therefore, in order to use Ethereum, it is first necessary to generate an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it with ether and sending some to another address. + +Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). + + +## Step 1: Generating accounts + +There are several methods for generating accounts in Geth. This tutorial demonstrates how to generate accounts using Clef, as this is considered best practice, largely because it decouples the users' key management from Geth, making it more modular and flexible. It can also be run from secure USB sticks or virtual machines, offering security benefits. For convenience, this tutorial will execute Clef on the same computer that will also run Geth, although more secure options are available (see [here](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/docs/setup.md)). + +An account is a pair of keys (public and private). Clef needs to know where to save these keys to so that they can be retrieved later. This information is passed to Clef as an argument. This is achieved using the following command: + +```shell + +clef newaccount --keystore geth-tutorial/keystore + +``` + +The specific function from Clef that generates new accounts is `newaccount` and it accepts a parameter, `--keystore`, that tells it where to store the newly generated keys. In this example the keystore location is a new directory that will be created automatically: `geth-tutorial/keystore`. Clef will return the following result in the terminal: + +```terminal +WARNING! + +Clef is an account management tool. It may, like any software, contain bugs. + +Please take care to +- backup your keystore files, +- verify that the keystore(s) can be opened with your password. + +Clef is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; +without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR +PURPOSE. See the GNU General Public License for more details. + +Enter 'ok' to proceed: +> +``` + +This is important information. The `geth-tutorial/keystore` directory will soon contain a secret key that can be used to access any funds held in the new account. If it is compromised, the funds can be stolen. If it is lost, there is no way to retrieve the funds. This tutorial will only use dummy funds with no real world value, but when these steps are repeated on Ethereum mainnet is critical that the keystore is kept secure and backed up. + + +Typing `ok` into the terminal and pressing `enter` causes Clef to prompt for a password. Clef requires a password that is at least 10 characters long, and best practice would be to use a combination of numbers, characters and special characters. Entering a suitable password and pressing `enter` returns the following result to the terminal: + +```terminal +----------------------- +DEBUG[02-10|13:46:46.436] FS scan times list="92.081µs" set="12.629µs" diff="2.129µs" +INFO [02-10|13:46:46.592] Your new key was generated address=0xCe8dBA5e4157c2B284d8853afEEea259344C1653 +WARN [02-10|13:46:46.595] Please backup your key file! path=keystore:///.../geth-tutorial/keystore/UTC--2022-02-07T17-19-56.517538000Z--ca57f3b40b42fcce3c37b8d18adbca5260ca72ec +WARN [02-10|13:46:46.595] Please remember your password! +Generated account 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 +``` + +It is important to save the account address and the password somewhere secure. They will be used again later in this tutorial. Please note that the account address shown in the code snippets above and later in this tutorials are examples - those generated by followers of this tutorial will be different. The account generated above can be used as the main account throughout the remainder of this tutorial. However in order to demonstrate transactions between accounts it is also necessary to have a second account. A second account can be added to the same keystore by precisely repeating the previous steps, providing the same password. + +## Step 2: Start Clef + +The previous commands used Clef's `newaccount` function to add new key pairs to the keystore. Clef uses the private key(s) saved in the keystore is used to sign transactions. In order to do this, Clef needs to be started and left running while Geth is running simultaneously, so that the two programs can communicate between one another. + +To start Clef, run the Clef executable passing as arguments the keystore file location, config directory location and a chain ID. The config directory was automatically created inside the `geth-tutorial` directory during the previous step. The [chain ID](https://chainlist.org/) is an integer that defines which Ethereum network to connect to. Ethereum mainnet has chain ID 1. In this tutorial Chain ID 5 is used which is that of the Goerli testnet. It is very important that this chain ID parameter is set to 5. The following command starts Clef on Goerli: + +```shell + +clef --keystore geth-tutorial/keystore --configdir geth-tutorial/clef --chainid 5 + +``` + +After running the command above, Clef requests the user to type “ok” to proceed. On typing "ok" and pressing enter, Clef returns the following to the terminal: + +```terminal +INFO [02-10|13:55:30.812] Using CLI as UI-channel +INFO [02-10|13:55:30.946] Loaded 4byte database embeds=146,841 locals=0 local=./4byte-custom.json +WARN [02-10|13:55:30.947] Failed to open master, rules disabled err="failed stat on geth-tutorial/clef/masterseed.json: stat geth-tutorial/clef/masterseed.json: no such file or directory" +INFO [02-10|13:55:30.947] Starting signer chainid=5 keystore=geth-tutorial/keystore light-kdf=false advanced=false +DEBUG[02-10|13:55:30.948] FS scan times list="133.35µs" set="5.692µs" diff="3.262µs" +DEBUG[02-10|13:55:30.970] Ledger support enabled +DEBUG[02-10|13:55:30.973] Trezor support enabled via HID +DEBUG[02-10|13:55:30.976] Trezor support enabled via WebUSB +INFO [02-10|13:55:30.978] Audit logs configured file=audit.log +DEBUG[02-10|13:55:30.981] IPCs registered namespaces=account +INFO [02-10|13:55:30.984] IPC endpoint opened url=geth-tutorial/clef/clef.ipc +------- Signer info ------- +* intapi_version : 7.0.1 +* extapi_version : 6.1.0 +* extapi_http : n/a +* extapi_ipc : geth-tutorial/clef/clef.ipc +``` + +This result indicates that Clef is running. This terminal should be left running for the duration of this tutorial. If the tutorial is stopped and restarted later Clef must also be restarted by running the previous command. + +## Step 3: Start Geth + +Geth is the Ethereum client that will connect the computer to the Ethereum network. In this tutorial the network is Goerli, an Ethereum testnet. Testnets are used to test Ethereum client software and smart contracts in an environment where no real-world value is at risk. To start Geth, run the Geth executable file passing argument that define the data directory (where Geth should save blockchain data), signer (points Geth to Clef), the network ID and the sync mode. For this tutorial, snap sync is recommended (see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). The final argument passed to Geth is the `--http` flag. This enables the http-rpc server that allows external programs to interact with Geth by sending it http requests. By default the http server is only exposed locally using port 8545: `localhost:8545`. + +The following command should be run in a new terminal, separate to the one running Clef: + +```shell + +geth --datadir geth-tutorial --signer=geth-tutorial/clef/clef.ipc --goerli --syncmode snap --http + +``` + +Running the above command starts Geth. The terminal should rapidly fill with status updates, starting with: + +```terminal +INFO [02-10|13:59:06.649] Starting Geth on goerli testnet... +INFO [02-10|13:59:06.649] Dropping default light client cache provided=1024 updated=128 +INFO [02-10|13:59:06.652] Maximum peer count ETH=50 LES=0 total=50 +INFO [02-10|13:59:06.655] Using external signer url=geth-tutorial/clef/clef.ipc +INFO [02-10|13:59:06.660] Set global gas cap cap=50,000,000 +INFO [02-10|13:59:06.661] Allocated cache and file handles database=/.../geth-tutorial/geth/chaindata cache=64.00MiB handles=5120 +INFO [02-10|13:59:06.855] Persisted trie from memory database nodes=361 size=51.17KiB time="643.54µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B +INFO [02-10|13:59:06.855] Initialised chain configuration config="{ChainID: 5 Homestead: 0 DAO: DAOSupport: true EIP150: 0 EIP155: 0 EIP158: 0 Byzantium: 0 Constantinople: 0 Petersburg: 0 Istanbul: 1561651, Muir Glacier: , Berlin: 4460644, London: 5062605, Arrow Glacier: , MergeFork: , Engine: clique}" +INFO [02-10|13:59:06.862] Added trusted checkpoint block=5,799,935 hash=2de018..c32427 +INFO [02-10|13:59:06.863] Loaded most recent local header number=6,340,934 hash=483cf5..858315 td=9,321,576 age=2d9h29m +INFO [02-10|13:59:06.867] Configured checkpoint oracle address=0x18CA0E045F0D772a851BC7e48357Bcaab0a0795D signers=5 threshold=2 +INFO [02-10|13:59:06.867] Gasprice oracle is ignoring threshold set threshold=2 +WARN [02-10|13:59:06.869] Unclean shutdown detected booted=2022-02-08T04:25:08+0100 age=2d9h33m +INFO [02-10|13:59:06.870] Starting peer-to-peer node instance=Geth/v1.10.15-stable/darwin-amd64/go1.17.5 +INFO [02-10|13:59:06.995] New local node record seq=1,644,272,735,880 id=d4ffcd252d322a89 ip=127.0.0.1 udp=30303 tcp=30303 +INFO [02-10|13:59:06.996] Started P2P networking self=enode://4b80ebd341b5308f7a6b61d91aa0ea31bd5fc9e0a6a5483e59fd4ea84e0646b13ecd289e31e00821ccedece0bf4b9189c474371af7393093138f546ac23ef93e@127.0.0.1:30303 +INFO [02-10|13:59:06.997] IPC endpoint opened url=/.../geth-tutorial/geth.ipc +INFO [02-10|13:59:06.998] HTTP server started endpoint=127.0.0.1:8545 prefix= cors= vhosts=localhost +WARN [02-10|13:59:06.998] Light client mode is an experimental feature +WARN [02-10|13:59:06.999] Failed to open wallet url=extapi://geth-tutorial/clef/cle.. err="operation not supported on external signers" +INFO [02-10|13:59:08.793] Block synchronisation started +``` + +This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers it can request block headers from them, starting at the genesis block for the Goerli blockchain. Geth continues to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in the terminal with the following syntax: + +```terminal + +INFO [04-29][15:54:09.238] Looking for peers peercount=2 tried=0 static=0 +INFO [04-29][15:54:19.393] Imported new block headers count=2 elapsed=1.127ms number=996288 hash=09f1e3..718c47 age=13h9m5s +INFO [04-29][15:54:19:656] Imported new block receipts count=698 elapsed=4.464ms number=994566 hash=56dc44..007c93 age=13h9m9s + +``` + +These logs indicate that Geth is running as expected. Sending an empty Curl request to the http server provides a quick way to confirm that this too has been started without any issues. In a third terminal, the following command can be run: + +```shell + +curl http://localhost:8545 + +``` + +If there is no error message reported to the terminal, everything is OK. Geth must be running in order for a user to interact with the Ethereum network. If this terminal is closed down then Geth must be restarted in a new terminal. Geth can be started and stopped easily, but it must be running for any interaction with Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. To start it again, run the previous command `geth --datadir ... ..`. + +{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished you can't use the node to transfer funds. You can also try doing a [light sync](interface/les) which will be much quicker but depends on light servers being available to serve your node the data it needs." %} + +## Step 4: Get Testnet Ether + +In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; 2) receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether to their account. + +The address generated by Clef in Step 1 can be pasted into the Paradigm Multifaucet faucet [here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of personhood. The faucets adds ether to the given address on multiple testnets simultaneously, including Goerli. In the next steps Geth will be used to check that the ether has been sent to the given address and send some of it to the second address created earlier. + + +## Step 5: Interact with Geth via IPC or RPC + +For interacting with the blockchain, Geth provides JSON-RPC APIs. [JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific tasks by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded instructions from locations outside of those managed by Geth. It is possible to interact with Geth by sending these JSON encoded instructions directly over Geth's exposed http port using tools like Curl. However, this is somewhat user-unfriendly and error-prone, especially for more complex instructions. For this reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly interface for interacting with Geth. One of the most widely used is Web3.js. + +Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in one terminal, a Javascript environment can be opened in another allowing the user to interact with Geth using Web3.js. There are two transport protocols that can be used to connect the Javascript environment to Geth: + +- IPC (Inter-Process Communication): This provides unrestricted access to all APIs, but only works when the console is run on the same host as the geth node. + +- HTTP: This connection method by default provides access to the `eth`, `web3` and `net` method namespaces. + +This tutorial will use the HTTP option. Note that the terminals running Geth and Clef should both still be active. In a new (third) terminal, the following command can be run to start the console and connect it to Geth using the exposed http port: + +```shell + +geth attach http://127.0.0.1:8545 + +``` + +This command causes the terminal to hang because it is waiting for approval from Clef. Approving the request in the terminal running Clef will lead to the following welcome message being displayed in the Javascript console: + +```terminal +Welcome to the Geth JavaScript console! + +instance: Geth/v1.10.15-stable/darwin-amd64/go1.17.5 +at block: 6354736 (Thu Feb 10 2022 14:01:46 GMT+0100 (WAT)) + modules: eth:1.0 net:1.0 rpc:1.0 web3:1.0 + +To exit, press ctrl-d or type exit +``` + +The console is now active and connected to Geth. It can now be used to interact with the Ethereum (Goerli) network. + + +### List of accounts + +In this tutorial, the accounts are managed using Clef. This means that requesting information about the accounts requires explicit approval in Clef, which should still be running in its own terminal. Earlier in this tutorial, two accounts were created using Clef. The following command will display the addresses of those two accounts and any others that might have been added to the keystore before or since. + +```javascript + +eth.accounts + +``` + +The console will hang, because Clef is waiting for approval. The following message will be displayed in the Clef terminal: + +```terminal + +-------- List Account request-------------- +A request has been made to list all accounts. +You can select which accounts the caller can see + [x] 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC + URL: keystore:///.../geth-tutorial/keystore/UTC--2022-02-07T17-19-56.517538000Z--ca57f3b40b42fcce3c37b8d18adbca5260ca72ec + [x] 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 + URL: keystore:///.../geth-tutorial/keystore/UTC--2022-02-10T12-46-45.265592000Z--ce8dba5e4157c2b284d8853afeeea259344c1653 +------------------------------------------- +Request context: + NA -> ipc -> NA + +Additional HTTP header data, provided by the external caller: + User-Agent: "" + Origin: "" +Approve? [y/N]: +> y + +``` + +Entering `y` approves the request from the console. In the terminal running the Javascript console, the account addresses are now displayed: + +```terminal + +["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", "0xce8dba5e4157c2b284d8853afeeea259344c1653"] + +``` + +It is also possible for this request to time out if the Clef approval took too long - in this case simply repeat the request and approval. + + +### Checking account balance. + +Having confirmed that the two addresses created earlier are indeed in the keystore and accessible through the Javascript console, it is possible to retrieve information about how much ether they own. The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance of one of the accounts should be 1 ether and the other should be 0. The following command displays the account balance in the console: + +```javascript + +web3.fromWei(eth.getBalance("0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC"), "ether") + +``` + +There are actually two instructions sent in the above command. The inner one is the `getBalance` function from the `eth` namespace. This takes the account address as its only argument. By default, this returns the account balance in units of Wei. There are 1018 Wei to one ether. To present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from the `web3` namespace. Running this command should provide the following result (for the account that received faucet funds): + +```terminal + +1 + +``` + +Repeating the command for the other account should yield: + +```terminal + +0 + +``` + + +### Send ether to another account + +The command `eth.sendTransaction` can be used to send some ether from one address to another. This command takes three arguments: `from`, `to` and `value`. These define the sender and recipient addresses (as strings) and the amount of Wei to transfer. It is far less error prone to enter the transaction value in units of ether rather than Wei, so the value field can take the return value from the `toWei` function. The following command, run in the Javascript console, sends 0.1 ether from one of the accounts in the Clef keystore to the other. Note that the addresses here are examples - the user must replace the address in the `from` field with the address currently owning 1 ether, and the address in the `to` field with the address currently holding 0 ether. + +```javascript +eth.sendTransaction({ + from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", + to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", + value: web3.toWei(0.1, "ether") +}) +``` + +Note that submitting this transaction requires approval in Clef. In the Clef terminal, Clef will prompt for approval and request the account password. If the password is correctly entered, Geth proceeds with the transaction. The transaction request summary is presented by Clef in the Clef terminal. This is an opportunity for the sender to review the details and ensure they are correct. + +```terminal +--------- Transaction request------------- +to: 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 +from: 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC [chksum ok] +value: 10000000000000000 wei +gas: 0x5208 (21000) +maxFeePerGas: 2425000057 wei +maxPriorityFeePerGas: 2424999967 wei +nonce: 0x3 (3) +chainid: 0x5 +Accesslist + +Request context: + NA -> ipc -> NA + +Additional HTTP header data, provided by the external caller: + User-Agent: "" + Origin: "" +------------------------------------------- +Approve? [y/N]: +> y + + +Please enter the password for account 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC +> +``` + +After approving the transaction, the following confirmation screen in displayed in the Clef terminal: + +```terminal +----------------------- +Transaction signed: + { + "type": "0x2", + "nonce": "0x3", + "gasPrice": null, + "maxPriorityFeePerGas": "0x908a901f", + "maxFeePerGas": "0x908a9079", + "gas": "0x5208", + "value": "0x2386f26fc10000", + "input": "0x", + "v": "0x0", + "r": "0x66e5d23ad156e04363e68b986d3a09e879f7fe6c84993cef800bc3b7ba8af072", + "s": "0x647ff82be943ea4738600c831c4a19879f212eb77e32896c05055174045da1bc", + "to": "0xce8dba5e4157c2b284d8853afeeea259344c1653", + "chainId": "0x5", + "accessList": [], + "hash": "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" + } + +``` + +In the Javascript console, the transaction hash is displayed. This will be used in the next section to retrieve the transaction details. + +```terminal + +"0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" + +``` + +It is also advised to check the account balances using Geth by repeating the instructions from earlier. At this point in the tutorial, the two accounts in the Clef keystore should have balances just below 0.9 ether (because 0.1 ether has been transferred out and some small amount paid in transaction gas) and 0.1 ether. + + +### Checking the transaction hash + +The transaction hash is a unique identifier for this specific transaction that can be used later to retrieve the transaction details. For example, the transaction details can be viewed by pasting this hash into the [Goerli block explorer](https://goerli.etherscan.io/). The same information can also be retrieved directly from the Geth node. The hash returned in the previous step can be provided as an argument to `eth.getTransaction` to return the transaction information: + +```javascript + +eth.getTransaction("0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb") + +``` + +This returns the following response (although the actual values for each field will vary because they are specific to each transaction): + +```terminal +{ + accessList: [], + blockHash: "0x1c5d3f8dd997b302935391b57dc3e4fffd1fa2088ef2836d51f844f993eb39c4", + blockNumber: 6355150, + chainId: "0x5", + from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", + gas: 21000, + gasPrice: 2425000023, + hash: "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb", + input: "0x", + maxFeePerGas: 2425000057, + maxPriorityFeePerGas: 2424999967, + nonce: 3, + r: "0x66e5d23ad156e04363e68b986d3a09e879f7fe6c84993cef800bc3b7ba8af072", + s: "0x647ff82be943ea4738600c831c4a19879f212eb77e32896c05055174045da1bc", + to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", + transactionIndex: 630, + type: "0x2", + v: "0x0", + value: 10000000000000000 +} +``` + + +## Using Curl + +Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. This library enables the user to send instructions to Geth using a more user-friendly interface compared to sending raw JSON objects. However, it is also possible for the user to send these JSON objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP requests. This part of the tutorial demonstrates how to check account balances and send a transaction using Curl. + +### Checking account balance + +The command below returns the balance of the given account. This is a HTTP POST request to the local port 8545. The `-H` flag is for header information. It is used here to define the format of the incoming payload, which is JSON. The `--data` flag defines the content of the payload, which is a JSON object. That JSON object contains four fields: `jsonrpc` defines the spec version for the JSON-RPC API, `method` is the specific function being invoked, `params` are the function arguments, and `id` is used for ordering transactions. The two arguments passed to `eth_getBalance` are the account address whose balance to check and the block to query (here `latest` is used to check the balance in the most recently mined block). + +```shell + +curl -X POST http://127.0.0.1:8545 \ + -H "Content-Type: application/json" \ + --data '{"jsonrpc":"2.0", "method":"eth_getBalance", "params":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","latest"], "id":1}' + +``` + +A successful call will return a response like the one below: + +```terminal +{"jsonrpc":"2.0","id":1,"result":"0xc7d54951f87f7c0"} +``` + +The balance is in the `result` field in the returned JSON object. However, it is denominated in Wei and presented as a hexadecimal string. There are many options for converting this value to a decimal in units of ether, for example by opening a Python console and running: + +```python + +0xc7d54951f87f7c0 / 1e18 + +``` +This returns the balance in ether: + +```terminal + +0.8999684999998321 + +``` + + +### Checking the account list + +The curl command below returns the list of all accounts. + +```shell +curl -X POST http://127.0.0.1:8545 \ + -H "Content-Type: application/json" \ + --data '{"jsonrpc":"2.0", "method":"eth_accounts","params":[], "id":1}' +``` + +This requires approval in Clef. Once approved, the following information is returned to the terminal: + +```terminal + +{"jsonrpc":"2.0","id":1,"result":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec"]} + +``` + +### Sending Transactions + +Sending a transaction between accounts can also be achieved using Curl. Notice that the value of the transaction is a hexadecimal string in units of Wei. To transfer 0.1 ether, it is first necessary to convert this to Wei by multiplying by 1018 then converting to hex. 0.1 ether is `"0x16345785d8a0000"` in hex. As before, update the `to` and `from` fields with the addresses in the Clef keystore. + + +```shell +curl -X POST http://127.0.0.1:8545 \ + -H "Content-Type: application/json" \ + --data '{"jsonrpc":"2.0", "method":"eth_sendTransaction", "params":[{"from": "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","to": "0xce8dba5e4157c2b284d8853afeeea259344c1653","value": "0x16345785d8a0000"}], "id":1}' +``` + +This requires approval in Clef. Once the password for the sender account has been provided, Clef will return a summary of the transaction details and the terminal that made the Curl request will display a response containing the transaction hash. + +```terminal + +{"jsonrpc":"2.0","id":5,"result":"0xac8b347d70a82805edb85fc136fc2c4e77d31677c2f9e4e7950e0342f0dc7e7c"} + +``` + +## Summary + +This tutorial has demonstrated how to generate accounts using Clef, fund them with testnet ether and use those accounts to interact with Ethereum (Goerli) through a Geth node. Checking account balances, sending transactions and retrieving transaction details were explained using the web3.js library via the Geth console and using the JSON-RPC directly using Curl. diff --git a/content/docs/install_build/Backup--restore.md b/content/docs/install_build/Backup--restore.md new file mode 100644 index 0000000000..6d038572d1 --- /dev/null +++ b/content/docs/install_build/Backup--restore.md @@ -0,0 +1,65 @@ +--- +title: Backup & Restore +sort_key: C +--- + +Most important info first: **REMEMBER YOUR PASSWORD** and **BACKUP YOUR KEYSTORE**. + +## Data Directory + +Everything `geth` persists gets written inside its data directory. The default data +directory locations are platform specific: + +* Mac: `~/Library/Ethereum` +* Linux: `~/.ethereum` +* Windows: `%LOCALAPPDATA%\Ethereum` + +Accounts are stored in the `keystore` subdirectory. The contents of this directories +should be transportable between nodes, platforms, implementations (C++, Go, Python). + +To configure the location of the data directory, the `--datadir` parameter can be +specified. See [CLI Options](../interface/command-line-options) for more details. + +Note the [ethash dag](../interface/mining) is stored at `~/.ethash` (Mac/Linux) or +`%APPDATA%\Ethash` (Windows) so that it can be reused by all clients. You can store this +in a different location by using a symbolic link. + +## Cleanup + +Geth's blockchain and state databases can be removed with: + +``` +geth removedb +``` + +This is useful for deleting an old chain and sync'ing to a new one. It only affects data +directories that can be re-created on synchronisation and does not touch the keystore. + +## Blockchain Import/Export + +Export the blockchain in binary format with: + +``` +geth export +``` + +Or if you want to back up portions of the chain over time, a first and last block can be +specified. For example, to back up the first epoch: + +``` +geth export 0 29999 +``` + +Note that when backing up a partial chain, the file will be appended rather than +truncated. + +Import binary-format blockchain exports with: + +``` +geth import +``` + +_See https://eth.wiki/en/howto/blockchain-import-and-export-instructions for more info_ + + +And finally: **REMEMBER YOUR PASSWORD** and **BACKUP YOUR KEYSTORE** diff --git a/content/docs/install_build/Installing-Geth.md b/content/docs/install_build/Installing-Geth.md new file mode 100644 index 0000000000..f82d577cca --- /dev/null +++ b/content/docs/install_build/Installing-Geth.md @@ -0,0 +1,356 @@ +--- +title: Installing Geth +sort_key: A +--- + +There are several ways to install Geth, including via a package manager, downloading a pre-built bundle, running as a docker container or building from downloaded source code. On this page the various installation options are explained for several major operating systems. Users prioritizing ease of installation should choose to use a package manager or prebuilt bundle. Users prioritizing customization should build from source. It is important to run the latest version of Geth because each release includes bugfixes and improvement over the previous versions. The stable releases are recommended for most users because they have been fully tested. A list of stable releases can be found [here][geth-releases]. Instructions for updating existing Geth installations are also provided in each section. + + +{:toc} + +- this will be removed by the toc + +## Package managers + +### MacOS via Homebrew + +The easiest way to install go-ethereum is to use the Geth Homebrew tap. The first step is to check that Homebrew is installed. The following command should return a version number. + +```shell +brew -v +``` + +If a version number is returned, then Homebrew is installed. If not, Homebrew can be installed by following the instructions [here][brew]. With Homebrew installed, the following commands add the Geth tap and install Geth: + + +```shell +brew tap ethereum/ethereum +brew install ethereum +``` + +The previous command installs the latest stable release. Developers that wish to install the most up-to-date version can install the Geth repository's master branch by adding the `--devel` parameter to the install command: + +```shell +brew install ethereum --devel +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + +Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: + +```shell +brew update +brew upgrade +brew reinstall ethereum +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + + +### Ubuntu via PPAs + +The easiest way to install Geth on Ubuntu-based distributions is with the built-in launchpad PPAs (Personal Package Archives). A single PPA repository is provided, containing stable and development releases for Ubuntu versions `xenial`, `trusty`, `impish`, `focal`, `bionic`. + +The following command enables the launchpad repository: + +```shell +sudo add-apt-repository -y ppa:ethereum/ethereum +``` + +Then, to install the stable version of go-ethereum: + +```shell +sudo apt-get update +sudo apt-get install ethereum +``` + +Or, alternatively the develop version: + +```shell +sudo apt-get update +sudo apt-get install ethereum-unstable +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + + +Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: + +```shell +sudo apt-get update +sudo apt-get install ethereum +sudo apt-get upgrade geth +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + + +### Windows + +The easiest way to install Geth is to download a pre-compiled binary from the [downloads][geth-dl] page. The page provides an installer as well as a zip file containing the Geth source code. The install wizard offers the user the option to install Geth, or Geth and the developer tools. The installer adds `geth` to the system's `PATH` automatically. The zip file contains the command `.exe` files that can be run from the command prompt. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + +Updating an existing Geth installation can be achieved by stopping the node, downloading and installing the latest version following the instructions above. When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + +### FreeBSD via pkg + +Geth can be installed on FreeBSD using the package manager `pkg`. The following command downloads and installs Geth: + +```shell +pkg install go-ethereum +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. + +The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + + +Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: + +```shell +pkg upgrade +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + + +### FreeBSD via ports + +Installing Geth using ports, simply requires navigating to the `net-p2p/go-ethereum` ports directory and running `make install` as root: + +```shell +cd /usr/ports/net-p2p/go-ethereum +make install +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. + +The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + + +Updating an existing Geth installation can be achieved by stopping the node and running the following command: + +```shell +portsnap fetch +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + +### Arch Linux via pacman + +The Geth package is available from the [community repo][geth-archlinux]. It can be installed by running: + +```shell +pacman -S geth +``` + +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/bin/`. + +The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. + +Updating an existing Geth installation can be achieved by stopping the node and running the following command: + +```shell +sudo pacman -Sy +``` + +When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. + +## Standalone bundle + +Stable releases and development builds are provided as standalone bundles. These are useful for users who: a) wish to install a specific version of Geth (e.g., for reproducible environments); b) wish to install on machines without internet access (e.g. air-gapped computers); or c) wish to avoid automatic updates and instead prefer to manually install software. + +The following standalone bundles are available: + +- 32bit, 64bit, ARMv5, ARMv6, ARMv7 and ARM64 archives (`.tar.gz`) on Linux +- 64bit archives (`.tar.gz`) on macOS +- 32bit and 64bit archives (`.zip`) and installers (`.exe`) on Windows + + +Some archives contain only Geth, while other archives containing Geth and the various developer tools (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`). More information about these executables is available at the [`README`][geth-readme-exe]. + +The standalone bundles can be downloaded from the [Geth Downloads][geth-dl] page. To update an existing installation, download and manually install the latest version. + +## Docker container + +A Docker image with recent snapshot builds from our `develop` branch is maintained on DockerHub to support users who prefer to run containerized processes. There four different Docker images available for running the latest stable or development versions of Geth. + +- `ethereum/client-go:latest` is the latest development version of Geth (default) +- `ethereum/client-go:stable` is the latest stable version of Geth +- `ethereum/client-go:{version}` is the stable version of Geth at a specific version number +- `ethereum/client-go:release-{version}` is the latest stable version of Geth at a specific version family + +Pulling an image and starting a node is achieved by running these commands: + +```shell +docker pull ethereum/client-go +docker run -it -p 30303:30303 ethereum/client-go +``` + +There are also four different Docker images for running the latest stable or development versions of miscellaneous Ethereum tools. + +- `ethereum/client-go:alltools-latest` is the latest development version of the Ethereum tools +- `ethereum/client-go:alltools-stable` is the latest stable version of the Ethereum tools +- `ethereum/client-go:alltools-{version}` is the stable version of the Ethereum tools at a specific version number +- `ethereum/client-go:alltools-release-{version}` is the latest stable version of the Ethereum tools at a specific version family + +The image has the following ports automatically exposed: + +- `8545` TCP, used by the HTTP based JSON RPC API +- `8546` TCP, used by the WebSocket based JSON RPC API +- `8547` TCP, used by the GraphQL API +- `30303` TCP and UDP, used by the P2P protocol running the network + + +**Note:** if you are running an Ethereum client inside a Docker container, you should mount a data volume as the client's data directory (located at `/root/.ethereum` inside the container) to ensure that downloaded data is preserved between restarts and/or container life-cycles. + + +Updating Geth to the latest version simply requires stopping the container, pulling the latest version from Docker and running it: + +```shell +docker stop ethereum/client-go +docker pull ethereum/client-go:latest +docker run -it -p 30303:30303 ethereum/client-go +``` + +## Build from source code + +### Most Linux systems and macOS + +Geth is written in [Go][go], so building from source code requires the most recent version of Go to be installed. Instructions for installing Go are available at the [Go installation page][go-install] and necessary bundles can be downloaded from the [Go download page][go-dl]. + +With Go installed, Geth can be downloaded into a `GOPATH` workspace via: + + +```shell +go get -d github.com/ethereum/go-ethereum +``` + +You can also install specific versions via: + +```shell +go get -d github.com/ethereum/go-ethereum@v1.9.21 +``` + + +The above commands do not build any executables. To do that you can either build one specifically: + +```shell +go install github.com/ethereum/go-ethereum/cmd/geth +``` + + +Alternatively, the following command, run in the project root directory (`ethereum/go-ethereum`) in the GO workspace, builds the entire project and installs Geth and all the developer tools: + + +```shell +go install ./... +``` + +For macOS users, errors related to macOS header files are usually fixed by installing XCode Command Line Tools with `xcode-select --install`. +Another common error is: `go: cannot use path@version syntax in GOPATH mode`. This and other similar errors can often be fixed by enabling gomodules using `export GO111MODULE=on`. + +Updating an existing Geth installation can be achieved using `go get`: + +```shell +go get -u github.com/ethereum/go-ethereum +``` + + +### Windows + +The Chocolatey package manager provides an easy way to install the required build tools. Chocolatey can be installed by following these [instructions][chocolatey]. Then, to install the build tool the following commands can be run in an Administrator command prompt: + + +``` +C:\Windows\system32> choco install git +C:\Windows\system32> choco install golang +C:\Windows\system32> choco install mingw +``` + +Installing these packages sets up the path environment variables. To get the new path a new command prompt must be opened. To install Geth, a Go workspace directory must first be created, then the Geth source code can be created and built. + +``` +C:\Users\xxx> mkdir src\github.com\ethereum +C:\Users\xxx> git clone https://github.com/ethereum/go-ethereum src\github.com\ethereum\go-ethereum +C:\Users\xxx> cd src\github.com\ethereum\go-ethereum +C:\Users\xxx\src\github.com\ethereum\go-ethereum> go get -u -v golang.org/x/net/context +C:\Users\xxx\src\github.com\ethereum\go-ethereum> go install -v ./cmd/... +``` + +### FreeBSD + +To build Geth from source code on FreeBSD, the Geth Github repository can be cloned into a local directory. + + +```shell +git clone https://github.com/ethereum/go-ethereum +``` + +Then, the Go compiler can be used to build Geth: + +```shell +pkg install go +``` + + +If the Go version currently installed is >= 1.5, Geth can be built using the following command: + +```shell +cd go-ethereum +make geth +``` + +If the installed Go version is < 1.5 (quarterly packages, for example), the following command can be used instead: + +```shell +cd go-ethereum +CC=clang make geth +``` + +To start the node, the followijng command can be run: + +```shell +build/bin/geth +``` + +### Building without a Go workflow + +Geth can also be built without using Go workspaces. In this case, the repository should be cloned to a local repository. Then, the command +`make geth` configures everything for a temporary build and cleans up afterwards. This method of building only works on UNIX-like operating systems, and a Go installation is still required. + +```shell +git clone https://github.com/ethereum/go-ethereum.git +cd go-ethereum +make geth +``` + +These commands create a Geth executable file in the `go-ethereum/build/bin` folder that can be moved and run from another directory if required. The binary is standalone and doesn't require any additional files. + +To update an existing Geth installation simply stop the node, navigate to the project root directory and pull the latest version from the Geth Github repository. then rebuild and restart the node. + +```shell +cd go-ethereum +git pull +make geth +``` + +Additionally all the developer tools provided with Geth (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`) can be compiled by running `make all`. More information about these tools can be found [here][geth-readme-exe]. + +Instructions for cross-compiling to another architecture are available in the [cross-compilation guide](./cross-compile). + +To build a stable release, e.g. v1.9.21, the command `git checkout v1.9.21` retrieves that specific version. Executing that command before running `make geth` switches Geth to a stable branch. + + + +[brew]: https://brew.sh/ +[go]: https://golang.org/ +[go-dl]: https://golang.org/dl/ +[go-install]: https://golang.org/doc/install +[chocolatey]: https://chocolatey.org +[geth-releases]: https://github.com/ethereum/go-ethereum/releases +[geth-readme-exe]: https://github.com/ethereum/go-ethereum#executables +[geth-cl-options]: https://geth.ethereum.org/docs/interface/command-line-options +[geth-archlinux]: https://www.archlinux.org/packages/community/x86_64/geth/ +[geth-dl]: ../../downloads/ + + diff --git a/content/docs/install_build/cross-compile.md b/content/docs/install_build/cross-compile.md new file mode 100644 index 0000000000..55af4e6652 --- /dev/null +++ b/content/docs/install_build/cross-compile.md @@ -0,0 +1,167 @@ +--- +title: Cross-Compiling Geth +sort_key: C +--- + +**Note: All of these and much more have been merged into the project Makefile. You can +cross build via `make geth--` without needing to know any of these details +from below.** + +Developers usually have a preferred platform that they feel most comfortable working in, +with all the necessary tools, libraries and environments set up for an optimal workflow. +However, there's often need to build for either a different CPU architecture, or an +entirely different operating system; but maintaining a development environment for each +and switching between the them quickly becomes unwieldy. + +Here we present a very simple way to cross compile Ethereum to various operating systems +and architectures using a minimal set of prerequisites and a completely containerized +approach, guaranteeing that your development environment remains clean even after the +complex requirements and mechanisms of a cross compilation. + +The currently supported target platforms are: + + - ARMv7 Android and iOS + - 32 bit, 64 bit and ARMv5 Linux + - 32 bit and 64 bit Mac OSX + - 32 bit and 64 bit Windows + +Please note, that cross compilation does not replace a release build. Although resulting +binaries can usually run perfectly on the desired platform, compiling on a native system +with the specialized tools provided by the official vendor can often result in more a +finely optimized code. + +## Cross compilation environment + +Although the `go-ethereum` project is written in Go, it does include a bit of C code +shared between all implementations to ensure that all perform equally well, including a +dependency to the GNU Multiple Precision Arithmetic Library. Because of these, Go cannot +by itself compile to a different platform than the host. To overcome this limitation, we +will use [`xgo`](https://github.com/karalabe/xgo), a Go cross compiler package based on +Docker containers that has been architected specifically to allow both embedded C snippets +as well as simpler external C dependencies during compilation. + +The `xgo` project has two simple dependencies: Docker (to ensure that the build +environment is completely contained) and Go. On most platforms these should be available +from the official package repositories. For manually installing them, please consult their +install guides at [Docker](https://docs.docker.com/installation/) and +[Go](https://golang.org/doc/install) respectively. This guide assumes that these two +dependencies are met. + +To install and/or update xgo, simply type: + + $ go get -u github.com/karalabe/xgo + +You can test whether `xgo` is functioning correctly by requesting it to cross +compile itself and verifying that all cross compilations succeeded or not. + + $ xgo github.com/karalabe/xgo + ... + + $ ls -al + -rwxr-xr-x 1 root root 2792436 Sep 14 16:45 xgo-android-21-arm + -rwxr-xr-x 1 root root 2353212 Sep 14 16:45 xgo-darwin-386 + -rwxr-xr-x 1 root root 2906128 Sep 14 16:45 xgo-darwin-amd64 + -rwxr-xr-x 1 root root 2388288 Sep 14 16:45 xgo-linux-386 + -rwxr-xr-x 1 root root 2960560 Sep 14 16:45 xgo-linux-amd64 + -rwxr-xr-x 1 root root 2437864 Sep 14 16:45 xgo-linux-arm + -rwxr-xr-x 1 root root 2551808 Sep 14 16:45 xgo-windows-386.exe + -rwxr-xr-x 1 root root 3130368 Sep 14 16:45 xgo-windows-amd64.exe + + +## Building Ethereum + +Cross compiling Ethereum is analogous to the above example, but an additional flags is +required to satisfy the dependencies: + + - `--deps` is used to inject arbitrary C dependency packages and pre-build them + +Injecting the GNU Arithmetic Library dependency and selecting `geth` would be: + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + github.com/ethereum/go-ethereum/cmd/geth + ... + + $ ls -al + -rwxr-xr-x 1 root root 23213372 Sep 14 17:59 geth-android-21-arm + -rwxr-xr-x 1 root root 14373980 Sep 14 17:59 geth-darwin-386 + -rwxr-xr-x 1 root root 17373676 Sep 14 17:59 geth-darwin-amd64 + -rwxr-xr-x 1 root root 21098910 Sep 14 17:59 geth-linux-386 + -rwxr-xr-x 1 root root 25049693 Sep 14 17:59 geth-linux-amd64 + -rwxr-xr-x 1 root root 20578535 Sep 14 17:59 geth-linux-arm + -rwxr-xr-x 1 root root 16351260 Sep 14 17:59 geth-windows-386.exe + -rwxr-xr-x 1 root root 19418071 Sep 14 17:59 geth-windows-amd64.exe + + +As the cross compiler needs to build all the dependencies as well as the main project +itself for each platform, it may take a while for the build to complete (approximately 3-4 +minutes on a Core i7 3770K machine). + +### Fine tuning the build + +By default Go, and inherently `xgo`, checks out and tries to build the master branch of a +source repository. However, more often than not, you'll probably want to build a different +branch from possibly an entirely different remote repository. These can be controlled via +the `--remote` and `--branch` flags. + +To build the `develop` branch of the official `go-ethereum` repository instead of the +default `master` branch, you just need to specify it as an additional command line flag +(`--branch`): + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + --branch=develop \ + github.com/ethereum/go-ethereum/cmd/geth + +Additionally, during development you will most probably want to not only build a custom +branch, but also one originating from your own fork of the repository instead of the +upstream one. This can be done via the `--remote` flag: + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + --remote=https://github.com/karalabe/go-ethereum \ + --branch=rpi-staging \ + github.com/ethereum/go-ethereum/cmd/geth + +By default `xgo` builds binaries for all supported platforms and architectures, with +Android binaries defaulting to the highest released Android NDK platform. To limit the +build targets or compile to a different Android platform, use the `--targets` CLI +parameter. + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + --targets=android-16/arm,windows/* \ + github.com/ethereum/go-ethereum/cmd/geth + +### Building locally + +If you would like to cross compile your local development version, simply specify a local +path (starting with `.` or `/`), and `xgo` will use all local code from `GOPATH`, only +downloading missing dependencies. In such a case of course, the `--branch`, `--remote` and +`--pkg` arguments are no-op: + + $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ + ./cmd/geth + +## Using the Makefile + +Having understood the gist of `xgo` based cross compilation, you do not need to actually +memorize and maintain these commands, as they have been incorporated into the official +[Makefile](https://github.com/ethereum/go-ethereum/blob/master/Makefile) and can be +invoked with a trivial `make` request: + + * `make geth-cross`: Cross compiles to every supported OS and architecture + * `make geth-`: Cross compiles supported architectures of a particular OS (e.g. `linux`) + * `make geth--`: Cross compiles to a specific OS/architecture (e.g. `linux`, `arm`) + +We advise using the `make` based commands opposed to manually invoking `xgo` as we do +maintain the Makefile actively whereas we cannot guarantee that this document will be +always readily updated to latest advancements. + +### Tuning the cross builds + +A few of the `xgo` build options have also been surfaced directly into the Makefile to +allow fine tuning builds to work around either upstream Go issues, or to enable some +fancier mechanics. + + - `make ... GO=`: Use a specific Go runtime (e.g. `1.5.1`, `1.5-develop`, `develop`) + - `make ... MODE=`: Build a specific target type (e.g. `exe`, `c-archive`). + +Please note that these are not yet fully finalized, so they may or may not change in the +future as our code and the Go runtime features change. diff --git a/content/docs/interacting_with_geth/JavaScript-Console.md b/content/docs/interacting_with_geth/JavaScript-Console.md new file mode 100644 index 0000000000..db4e49d0f8 --- /dev/null +++ b/content/docs/interacting_with_geth/JavaScript-Console.md @@ -0,0 +1,147 @@ +--- +title: JavaScript Console +sort_key: D +--- + +Geth responds to instructions encoded as JSON objects as defined in the [JSON-RPC-API](/docs/rpc/server). A Geth user can send these instructions directly, for example over HTTP using tools like [Curl](https://github.com/curl/curl). The code snippet below shows a request for an account balance sent to a local Geth node with the HTTP port `8545` exposed. + +``` +curl --data '{"jsonrpc":"2.0","method":"eth_getBalance", "params": ["0x9b1d35635cc34752ca54713bb99d38614f63c955", "latest"], "id":2}' -H "Content-Type: application/json" localhost:8545 +``` + +This returns a result which is also a JSON object, with values expressed as hexadecimal strings, for example: + +```terminal +{"id":2,"jsonrpc":"2.0","result":"0x1639e49bba16280000"} +``` + +While this approach is valid, it is also a very low level and rather error-prone way to interact with Geth. Most developers prefer to use convenience libraries that abstract away some of the more tedious and awkward tasks such as converting values from hexadecimal strings into numbers, or converting between denominations of ether (Wei, Gwei, etc). One such library is [Web3.js](https://web3js.readthedocs.io/en/v1.7.3/). This is a collection of Javascript libraries for interacting with an Ethereum node at a higher level than sending raw JSON objects to the node. The purpose of Geth's Javascript console is to provide a built-in environment to use a subset of the Web3.js libraries to interact with a Geth node. + +{% include note.html content="The web3.js version that comes bundled with Geth is not up to date with the official Web3.js documentation. There are several Web3.js libraries that are not available in the Geth Javascript Console. There are also administrative APIs included in the Geth console that are not documented in the Web3.js documentation. The full list of libraries available in the Geth console is available on the [JSON-RPC API page](/docs/rpc/server)." %} + + +## Starting the console + +There are two ways to start an interactive session using Geth console. The first is to provide the `console` command when Geth is started up. This starts the node and runs the console in the same terminal. It is therefore convenient to suppress the logs from the node to prevent them from obscuring the console. If the logs are not needed, they can be redirected to the `dev/null` path, effectively muting them. Alternatively, if the logs are required they can be redirected to a text file. The level of detail provided in the logs can be adjusted by providing a value between 1-6 to the `--verbosity` flag as in the example below: + +```shell +# to mute logs +geth console 2> /dev/null + +# to save logs to file +geth console --verbosity 3 2> geth-logs.log +``` + +Alternatively, a Javascript console can be attached to an existing Geth instance (i.e. one that is running in another terminal or remotely). In this case, `geth attach` can be used to open a Javascript console connected to the Geth node. It is also necessary to define the method used to connect the console to the node. Geth supports websockets, HTTP or local IPC. To use HTTP or Websockets, these must be enabled at the node by providing the following flags at startup: + +```shell +# enable websockets +geth --ws + +# enable http + +geth --http +``` + +The commands above use default HTTP/WS endpoints and only enables the default JSON-RPC libraries. To update the Websockets or HTTP endpoints used, or to add support for additional libraries, the `.addr` `.port` and `.api` flags can be used as follows: + +```shell +# define a custom http adress, custom http port and enable libraries +geth --http --http.addr 192.60.52.21 --http.port 8552 --http.api eth,web3,admin + +# define a custom Websockets address and enable libraries +geth --ws --ws.addr 192.60.52.21 --ws.port 8552 --ws.api eth,web3,admin +``` + +It is important to note that by default **some functionality, including account unlocking is forbidden when HTTP or Websockets access is enabled**. This is because an attacker that manages to access the node via the externally-exposed HTTP/WS port then control the unlocked account. It is possible to force account unlock by including the `--allow-insecure-unlock` flag but this is not recommended if there is any chance of the node connecting to Ethereum Mainnet. This is not a hypothetical risk: **there are bots that continually scan for http-enabled Ethereum nodes to attack**" + +The Javascript console can also be connected to a Geth node using IPC. When Geth is started, a `geth.ipc` file is automatically generated and saved to the data directory. This file, or a custom path to a specific ipc file can be passed to `geth attach` as follows: + +```shell +geth attach datadir/geth.ipc +``` + +Once started, the console looks like this: + +```terminal +Welcome to the Geth Javascript console! + +instance: Geth/v1.10.18-unstable-8d85a701-20220503/linux-amd64/go1.18.1 +coinbase: 0x281aabb85c68e1638bb092750a0d9bb06ba103ee +at block: 12305815 (Thu May 26 2022 16:16:00 GMT+0100 (BST)) + datadir: /home/go-ethereum/data + modules: admin:1.0 debug:1.0 eth:1.0 ethash:1.0 miner:1.0 net:1.0 personal:1.0 rpc:1.0 txpool:1.0 web3:1.0 + +To exit, press ctrl-d or type exit +> +``` + + +## Interactive use + +Once the console has been started, it can be used to interact with Geth. The console supports Javascript and the full Geth [JSON-RPC API](/docs/rpc/server). For example, to create an account: + +```js +personal.newAccount() +``` + +To check the balance of the first account already existing in the keystore: + +```js +eth.getBalance(personal.listAccounts[0]) +``` + + +To make a transaction (without global account unlocking): + +```js +personal.sendTransaction({to: eth.accounts[0], to: eth.accounts[1], value: web3.toWei(0.5, "ether")}) +``` + +It is also possible to load pre-written Javascript files into the console by passing the `--preload` flag +when starting the console. This is useful for setting up complex contract objects or loading frequently-used +functions. + + +```shell +geth console --preload "/my/scripts/folder/utils.js" +``` + +Once the interactive session is over, the console can be closed down by typing `exit` or `CTRL-D`. + +## Non-interactive Use: Script Mode + +It is also possible to execute JavaScript code non-interactively by passing the `--exec` and a JSON-RPC-API endpoint +to `geth attach` or `geth console`. The result is displayed directly in the terminal rather than in an interactive Javascript console. + +For example, to display the accounts in the keystore: + +```shell +geth attach --exec eth.accounts +``` + + +```shell +geth attach --exec eth.blockNumber +``` + +The same syntax can be used to execute a local script file with more complex statements on a remote node over http, for example: + +```shell +geth attach http://geth.example.org:8545 --exec 'loadScript("/tmp/checkbalances.js")' + +geth attach http://geth.example.org:8545 --jspath "/tmp" --exec 'loadScript("checkbalances.js")' +``` + +The `--jspath` flag is used to set a library directory for the Javascript scripts. Any parameters passed to `loadScript()` +that do not explicitly define an absolute path will be interpreted relative to the `jspath` directory. + + +## Timers + +In addition to the full functionality of JS (as per ECMA5), the Ethereum Javascript Runtime Environment (JSRE) is augmented with various timers. It implements `setInterval`, `clearInterval`, `setTimeout`, `clearTimeout` which some users will be familiar with from browser windows. It also provides implementation for `admin.sleep(seconds)` and a block based timer, `admin.sleepBlocks(n)` which sleeps till the number of new blocks added is equal to or greater than `n`. + + +## Caveats + +Geth's console is built using the [GoJa JS Virtual Machine](https://github.com/dop251/goja) which is compatible with ECMAScript 5.1. This does not support promises or `async` functions. Web3js depends upon the `bignumber.js` library. This is auto-loaded into the console. diff --git a/content/docs/interacting_with_geth/RPC/batch.md b/content/docs/interacting_with_geth/RPC/batch.md new file mode 100644 index 0000000000..4b60c6622d --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/batch.md @@ -0,0 +1,38 @@ +--- +title: Batch requests +sort_key: C +--- + +The JSON-RPC [specification](https://www.jsonrpc.org/specification#batch) outlines how clients can send multiple requests at the same time by filling the request objects in an array. This feature is implemented by Geth's API and can be used to cut network delays. Batching offers visible speed-ups specially when used for fetching larger amounts of mostly independent data objects. Below is an example for fetching a list of blocks in JS: + +```javascript +import fetch from 'node-fetch' + +async function main() { + const endpoint = 'http://127.0.0.1:8545' + const from = parseInt(process.argv[2]) + const to = parseInt(process.argv[3]) + + const reqs = [] + for (let i = from; i < to; i++) { + reqs.push({ + method: 'eth_getBlockByNumber', + params: [`0x${i.toString(16)}`, false], + id: i-from, + jsonrpc: '2.0', + }) + } + + const res = await fetch(endpoint, {method: 'POST', body: JSON.stringify(reqs), headers: {'Content-Type': 'application/json'}}) + const data = await res.json() +} + +main().then().catch((err) => console.log(err)) +``` + +In this case there's no dependency between the requests. Often the retrieved data from one request is needed to issue a second one. Let's take the example of fetching all the receipts for a range of blocks. The JSON-RPC API provides `eth_getTransactionReceipt` which takes in a transaction hash and returns the corresponding receipt object, but no method to fetch receipt objects for a whole block. We need to get the list of transactions in a block, and then call `eth_getTransactionReceipt` for each of them. We can break this into 2 batch requests: + +- First to download the list of transaction hashes for all of the blocks in our desired range +- And then to download the list of receipts objects for all of the transaction hashes + +For use-cases which depend on several JSON-RPC endpoints the batching approach can get easily complicated. In that case Geth offers a [GraphQL API](./graphql) which is more suitable. diff --git a/content/docs/interacting_with_geth/RPC/graphql.md b/content/docs/interacting_with_geth/RPC/graphql.md new file mode 100644 index 0000000000..8cb82f4ebb --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/graphql.md @@ -0,0 +1,65 @@ +--- +title: GraphQL Server +sort_key: C +--- + +In addition to the [JSON-RPC APIs](../rpc/server), Geth supports the GraphQL API as specified by [EIP-1767](eip-1767). GraphQL lets you specify which fields of an objects you need as part of the query, eliminating the extra load on the client for filling in fields which are not needed. It also allows for combining several traditional JSON-RPC requests into one query which translates into less overhead and more performance. + +The GraphQL endpoint piggybacks on the HTTP transport used by JSON-RPC. Hence you'll have to enable and configure the relevant `--http` flags, and the `--graphql` flag itself: + +```bash +geth --http --graphql +``` + +Now you can start querying against `http://localhost:8545/graphql`. To change the port, you'll need to provide `--http.port`, e.g.: + +```bash +geth --http --http.port 9545 --graphql +``` + +### GraphiQL + +An easy way to get started right away and try out queries is the GraphiQL interface shipped with Geth. To open it visit `http://localhost:8545/graphql/ui`. To see how this works let's read the sender, recipient and value of all transactions in block number 6000000. Try this out in GraphiQL: + +```graphql +query txInfo { + block (number: 6000000) { transactions { hash from { address } to { address } value } } +} +``` + +GraphiQL also provides a way to explore the schema Geth provides to help you formulate your queries, which you can see on the right sidebar. Under the title `Root Types` click on `Query` to see the high-level types and their fields. + +### Query + +Reading out data from Geth is the biggest use-case for GraphQL. However after trying out queries in the UI you may want to do it programmatically. You can consult the official [docs](graphql-code) to find bindings for your language. Or use your favorite tool for sending HTTP requests. For sake of completeness we briefly touch on two approaches here. First via cURL, and second via a JS script. + +Here's how you'd get the latest block's number via cURL. Note the use of a JSON object for the data section: + +```bash +❯ curl -X POST http://localhost:8545/graphql -H "Content-Type: application/json" --data '{ "query": "query { block { number } }" }' +{"data":{"block":{"number":6004069}}} +``` + +Alternatively store the JSON-ified query in a file (let's call it `block-num.query`) and do: + +```bash +❯ curl -X POST http://localhost:8545/graphql -H "Content-Type: application/json" --data '@block-num.query' +``` + +Executing a simple query in JS looks like the following. Here we're using the lightweight library `graphql-request` to perform the request. Note the use of variables instead of hardcoding the block number in the query: + +```javascript +const { request, gql } = require('graphql-request') + +const query = gql` + query blockInfo($number: Long) { + block (number: $number) { hash stateRoot } + } +` +request('http://localhost:8545/graphql', query, { number: '6004067' }) + .then((res) => { console.log(res) }) + .catch((err) => { console.log(err) }) +``` + +[eip-1767]: https://eips.ethereum.org/EIPS/eip-1767 +[graphql-code]: https://graphql.org/code/ diff --git a/content/docs/interacting_with_geth/RPC/ns-admin.md b/content/docs/interacting_with_geth/RPC/ns-admin.md new file mode 100644 index 0000000000..fc15227b55 --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-admin.md @@ -0,0 +1,296 @@ +--- +title: admin Namespace +sort_key: C +--- + +The `admin` API gives you access to several non-standard RPC methods, which will allow you to have +a fine grained control over your Geth instance, including but not limited to network peer and RPC +endpoint management. + +* TOC +{:toc} + +### admin_addPeer + +The `addPeer` administrative method requests adding a new remote node to the list of tracked static +nodes. The node will try to maintain connectivity to these nodes at all times, reconnecting every +once in a while if the remote connection goes down. + +The method accepts a single argument, the [`enode`](https://github.com/ethereum/wiki/wiki/enode-url-format) +URL of the remote peer to start tracking and returns a `BOOL` indicating whether the peer was accepted +for tracking or some error occurred. + +| Client | Method invocation | +|:--------|------------------------------------------------| +| Go | `admin.AddPeer(url string) (bool, error)` | +| Console | `admin.addPeer(url)` | +| RPC | `{"method": "admin_addPeer", "params": [url]}` | + +#### Example + +```javascript +> admin.addPeer("enode://a979fb575495b8d6db44f750317d0f4622bf4c2aa3365d6af7c284339968eef29b69ad0dce72a4d8db5ebb4968de0e3bec910127f134779fbcb0cb6d3331163c@52.16.188.185:30303") +true +``` + +### admin_addTrustedPeer + +Adds the given node to a reserved trusted list which allows the +node to always connect, even if the slots are full. + +It returns a `BOOL` to indicate whether the peer was successfully added to the list. + +| Client | Method invocation | +|:--------|------------------------------------------------| +| Console | `admin.addTrustedPeer(url)` | +| RPC | `{"method": "admin_addTrustedPeer", "params": [url]}` | + +### admin_datadir + +The `datadir` administrative property can be queried for the absolute path the running Geth node +currently uses to store all its databases. + +| Client | Method invocation | +|:--------|-----------------------------------| +| Go | `admin.Datadir() (string, error`) | +| Console | `admin.datadir` | +| RPC | `{"method": "admin_datadir"}` | + +#### Example + +```javascript +> admin.datadir +"/home/john/.ethereum" +``` + +### admin_exportChain + +Exports the current blockchain into a local file. +It optionally takes a first and last block number, in which case it exports only that range of blocks. + +It returns a boolean indicating whether the operation succeeded. + +| Client | Method invocation | +|:--------|---------------------------------------------------------------------- | +| Console | `admin.exportChain(file, first, last)` | +| RPC | `{"method": "admin_exportChain", "params": [string, uint64, uint64]}` | + +### admin_importChain + +Imports an exported list of blocks from a local file. Importing involves processing the blocks and inserting them +into the canonical chain. The state from the parent block of this range is required. + +It returns a boolean indicating whether the operation succeeded. + +| Client | Method invocation | +|:--------|-------------------------------------------------------| +| Console | `admin.importChain(file)` | +| RPC | `{"method": "admin_importChain", "params": [string]}` | + +### admin_nodeInfo + +The `nodeInfo` administrative property can be queried for all the information known about the running +Geth node at the networking granularity. These include general information about the node itself as a +participant of the [ÐΞVp2p](https://github.com/ethereum/wiki/wiki/%C3%90%CE%9EVp2p-Wire-Protocol) P2P +overlay protocol, as well as specialized information added by each of the running application protocols +(e.g. `eth`, `les`, `shh`, `bzz`). + +| Client | Method invocation | +|:--------|-------------------------------------------| +| Go | `admin.NodeInfo() (*p2p.NodeInfo, error`) | +| Console | `admin.nodeInfo` | +| RPC | `{"method": "admin_nodeInfo"}` | + +#### Example + +```javascript +> admin.nodeInfo +{ + enode: "enode://44826a5d6a55f88a18298bca4773fca5749cdc3a5c9f308aa7d810e9b31123f3e7c5fba0b1d70aac5308426f47df2a128a6747040a3815cc7dd7167d03be320d@[::]:30303", + id: "44826a5d6a55f88a18298bca4773fca5749cdc3a5c9f308aa7d810e9b31123f3e7c5fba0b1d70aac5308426f47df2a128a6747040a3815cc7dd7167d03be320d", + ip: "::", + listenAddr: "[::]:30303", + name: "Geth/v1.5.0-unstable/linux/go1.6", + ports: { + discovery: 30303, + listener: 30303 + }, + protocols: { + eth: { + difficulty: 17334254859343145000, + genesis: "0xd4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa3", + head: "0xb83f73fbe6220c111136aefd27b160bf4a34085c65ba89f24246b3162257c36a", + network: 1 + } + } +} +``` + +### admin_peerEvents + +PeerEvents creates an [RPC subscription](/docs/rpc/pubsub) which receives peer events from the node's p2p server. + +The type of events emitted by the server are as follows: + +- `add`: emitted when a peer is added +- `drop`: emitted when a peer is dropped +- `msgsend`: emitted when a message is successfully sent to a peer +- `msgrecv`: emitted when a message is received from a peer + +### admin_peers + +The `peers` administrative property can be queried for all the information known about the connected +remote nodes at the networking granularity. These include general information about the nodes themselves +as participants of the [ÐΞVp2p](https://github.com/ethereum/wiki/wiki/%C3%90%CE%9EVp2p-Wire-Protocol) +P2P overlay protocol, as well as specialized information added by each of the running application +protocols (e.g. `eth`, `les`, `shh`, `bzz`). + +| Client | Method invocation | +|:--------|------------------------------------------| +| Go | `admin.Peers() ([]*p2p.PeerInfo, error`) | +| Console | `admin.peers` | +| RPC | `{"method": "admin_peers"}` | + +#### Example + +```javascript +> admin.peers +[{ + caps: ["eth/61", "eth/62", "eth/63"], + id: "08a6b39263470c78d3e4f58e3c997cd2e7af623afce64656cfc56480babcea7a9138f3d09d7b9879344c2d2e457679e3655d4b56eaff5fd4fd7f147bdb045124", + name: "Geth/v1.5.0-unstable/linux/go1.5.1", + network: { + localAddress: "192.168.0.104:51068", + remoteAddress: "71.62.31.72:30303" + }, + protocols: { + eth: { + difficulty: 17334052235346465000, + head: "5794b768dae6c6ee5366e6ca7662bdff2882576e09609bf778633e470e0e7852", + version: 63 + } + } +}, /* ... */ { + caps: ["eth/61", "eth/62", "eth/63"], + id: "fcad9f6d3faf89a0908a11ddae9d4be3a1039108263b06c96171eb3b0f3ba85a7095a03bb65198c35a04829032d198759edfca9b63a8b69dc47a205d94fce7cc", + name: "Geth/v1.3.5-506c9277/linux/go1.4.2", + network: { + localAddress: "192.168.0.104:55968", + remoteAddress: "121.196.232.205:30303" + }, + protocols: { + eth: { + difficulty: 17335165914080772000, + head: "5794b768dae6c6ee5366e6ca7662bdff2882576e09609bf778633e470e0e7852", + version: 63 + } + } +}] +``` + +### admin_removePeer + +Disconnects from a remote node if the connection exists. + +It returns a boolean indicating validations succeeded. Note a `true` value doesn't necessarily mean +that there was a connection which was disconnected. + +| Client | Method invocation | +|:--------|----------------------------------------------------- | +| Console | `admin.removePeer(url)` | +| RPC | `{"method": "admin_removePeer", "params": [string]}` | + +### admin_removeTrustedPeer + +Removes a remote node from the trusted peer set, but it does not disconnect it automatically. + +It returns a boolean indicating validations succeeded. + +| Client | Method invocation | +|:--------|----------------------------------------------------- | +| Console | `admin.removeTrustedPeer(url)` | +| RPC | `{"method": "admin_removeTrustedPeer", "params": [string]}` | + +### admin_startHTTP + +The `startHTTP` administrative method starts an HTTP based JSON-RPC [API](/docs/rpc/server) +webserver to handle client requests. All the parameters are optional: + +* `host`: network interface to open the listener socket on (defaults to `"localhost"`) +* `port`: network port to open the listener socket on (defaults to `8545`) +* `cors`: [cross-origin resource sharing](https://en.wikipedia.org/wiki/Cross-origin_resource_sharing) header to use (defaults to `""`) +* `apis`: API modules to offer over this interface (defaults to `"eth,net,web3"`) + +The method returns a boolean flag specifying whether the HTTP RPC listener was opened or not. Please note, only one HTTP endpoint is allowed to be active at any time. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------------------------------------------| +| Go | `admin.StartHTTP(host *string, port *rpc.HexNumber, cors *string, apis *string) (bool, error)` | +| Console | `admin.startHTTP(host, port, cors, apis)` | +| RPC | `{"method": "admin_startHTTP", "params": [host, port, cors, apis]}` | + +#### Example + +```javascript +> admin.startHTTP("127.0.0.1", 8545) +true +``` + +### admin_startWS + +The `startWS` administrative method starts an WebSocket based [JSON RPC](https://www.jsonrpc.org/specification) +API webserver to handle client requests. All the parameters are optional: + +* `host`: network interface to open the listener socket on (defaults to `"localhost"`) +* `port`: network port to open the listener socket on (defaults to `8546`) +* `cors`: [cross-origin resource sharing](https://en.wikipedia.org/wiki/Cross-origin_resource_sharing) header to use (defaults to `""`) +* `apis`: API modules to offer over this interface (defaults to `"eth,net,web3"`) + +The method returns a boolean flag specifying whether the WebSocket RPC listener was opened or not. Please note, only one WebSocket endpoint is allowed to be active at any time. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------------------------------------------| +| Go | `admin.StartWS(host *string, port *rpc.HexNumber, cors *string, apis *string) (bool, error)` | +| Console | `admin.startWS(host, port, cors, apis)` | +| RPC | `{"method": "admin_startWS", "params": [host, port, cors, apis]}` | + +#### Example + +```javascript +> admin.startWS("127.0.0.1", 8546) +true +``` + +### admin_stopHTTP + +The `stopHTTP` administrative method closes the currently open HTTP RPC endpoint. As the node can only have a single HTTP endpoint running, this method takes no parameters, returning a boolean whether the endpoint was closed or not. + +| Client | Method invocation | +|:--------|---------------------------------| +| Go | `admin.StopHTTP() (bool, error`) | +| Console | `admin.stopHTTP()` | +| RPC | `{"method": "admin_stopHTTP"` | + +#### Example + +```javascript +> admin.stopHTTP() +true +``` + +### admin_stopWS + +The `stopWS` administrative method closes the currently open WebSocket RPC endpoint. As the node can only have a single WebSocket endpoint running, this method takes no parameters, returning a boolean whether the endpoint was closed or not. + +| Client | Method invocation | +|:--------|--------------------------------| +| Go | `admin.StopWS() (bool, error`) | +| Console | `admin.stopWS()` | +| RPC | `{"method": "admin_stopWS"` | + +#### Example + +```javascript +> admin.stopWS() +true +``` diff --git a/content/docs/interacting_with_geth/RPC/ns-clique.md b/content/docs/interacting_with_geth/RPC/ns-clique.md new file mode 100644 index 0000000000..ac0b09f19f --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-clique.md @@ -0,0 +1,148 @@ +--- +title: clique Namespace +sort_key: C +--- + +The `clique` API provides access to the state of the clique consensus engine. You can use +this API to manage signer votes and to check the health of a private network. + +* TOC +{:toc} + +### clique_getSnapshot + +Retrieves a snapshot of all clique state at a given block. + +| Client | Method invocation | +|:--------|------------------------------------------------------------| +| Console | `clique.getSnapshot(blockNumber)` | +| RPC | `{"method": "clique_getSnapshot", "params": [blockNumber]}` | + +Example: + +```javascript +> clique.getSnapshot(5463755) +{ + hash: "0x018194fc50ca62d973e2f85cffef1e6811278ffd2040a4460537f8dbec3d5efc", + number: 5463755, + recents: { + 5463752: "0x42eb768f2244c8811c63729a21a3569731535f06", + 5463753: "0x6635f83421bf059cd8111f180f0727128685bae4", + 5463754: "0x7ffc57839b00206d1ad20c69a1981b489f772031", + 5463755: "0xb279182d99e65703f0076e4812653aab85fca0f0" + }, + signers: { + 0x42eb768f2244c8811c63729a21a3569731535f06: {}, + 0x6635f83421bf059cd8111f180f0727128685bae4: {}, + 0x7ffc57839b00206d1ad20c69a1981b489f772031: {}, + 0xb279182d99e65703f0076e4812653aab85fca0f0: {}, + 0xd6ae8250b8348c94847280928c79fb3b63ca453e: {}, + 0xda35dee8eddeaa556e4c26268463e26fb91ff74f: {}, + 0xfc18cbc391de84dbd87db83b20935d3e89f5dd91: {} + }, + tally: {}, + votes: [] +} +``` + +### clique_getSnapshotAtHash + +Retrieves the state snapshot at a given block. + +| Client | Method invocation | +|:--------|----------------------------------------------------------| +| Console | `clique.getSnapshotAtHash(blockHash)` | +| RPC | `{"method": "clique_getSnapshotAtHash", "params": [blockHash]}` | + +### clique_getSigner + +Returns the signer for a specific clique block. Can be called with either a blocknumber, blockhash or an rlp encoded blob. +The RLP encoded blob can either be a block or a header. + +| Client | Method invocation | +|:--------|------------------------------------------------------| +| Console | `clique.getSigner(blockNrOrHashOrRlp)` | +| RPC | `{"method": "clique_getSigner", "params": [string]}` | + +### clique_getSigners + +Retrieves the list of authorized signers at the specified block number. + +| Client | Method invocation | +|:--------|------------------------------------------------------------| +| Console | `clique.getSigners(blockNumber)` | +| RPC | `{"method": "clique_getSigners", "params": [blockNumber]}` | + +### clique_getSignersAtHash + +Retrieves the list of authorized signers at the specified block hash. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Console | `clique.getSignersAtHash(blockHash)` | +| RPC | `{"method": "clique_getSignersAtHash", "params": [string]}` | + +### clique_proposals + +Returns the current proposals the node is voting on. + +| Client | Method invocation | +|:--------|------------------------------------------------| +| Console | `clique.proposals()` | +| RPC | `{"method": "clique_proposals", "params": []}` | + +### clique_propose + +Adds a new authorization proposal that the signer will attempt to push through. If the +`auth` parameter is true, the local signer votes for the given address to be included in +the set of authorized signers. With `auth` set to `false`, the vote is against the +address. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------| +| Console | `clique.propose(address, auth)` | +| RPC | `{"method": "clique_propose", "params": [address, auth]}` | + +### clique_discard + +This method drops a currently running proposal. The signer will not cast +further votes (either for or against) the address. + +| Client | Method invocation | +|:--------|-----------------------------------------------------| +| Console | `clique.discard(address)` | +| RPC | `{"method": "clique_discard", "params": [address]}` | + +### clique_status + +This is a debugging method which returns statistics about signer activity +for the last 64 blocks. The returned object contains the following fields: + +- `inturnPercent`: percentage of blocks signed in-turn +- `sealerActivity`: object containing signer addresses and the number + of blocks signed by them +- `numBlocks`: number of blocks analyzed + +| Client | Method invocation | +|:--------|-----------------------------------------------------| +| Console | `clique.status()` | +| RPC | `{"method": "clique_status", "params": []}` | + +Example: + +``` +> clique.status() +{ + inturnPercent: 100, + numBlocks: 64, + sealerActivity: { + 0x42eb768f2244c8811c63729a21a3569731535f06: 9, + 0x6635f83421bf059cd8111f180f0727128685bae4: 9, + 0x7ffc57839b00206d1ad20c69a1981b489f772031: 9, + 0xb279182d99e65703f0076e4812653aab85fca0f0: 10, + 0xd6ae8250b8348c94847280928c79fb3b63ca453e: 9, + 0xda35dee8eddeaa556e4c26268463e26fb91ff74f: 9, + 0xfc18cbc391de84dbd87db83b20935d3e89f5dd91: 9 + } +} +``` diff --git a/content/docs/interacting_with_geth/RPC/ns-debug.md b/content/docs/interacting_with_geth/RPC/ns-debug.md new file mode 100644 index 0000000000..57640283d0 --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-debug.md @@ -0,0 +1,947 @@ +--- +title: debug Namespace +sort_key: C +--- + +The `debug` API gives you access to several non-standard RPC methods, which will allow you +to inspect, debug and set certain debugging flags during runtime. + +* TOC +{:toc} + +### debug_accountRange + +Enumerates all accounts at a given block with paging capability. `maxResults` are returned in the page and the items have keys that come after the `start` key (hashed address). + +If `incompletes` is false, then accounts for which the key preimage (i.e: the `address`) doesn't exist in db are skipped. NB: geth by default does not store preimages. + +| Client | Method invocation | +|:--------|------------------------------------------------------------------------------------------------------------------| +| Console | `debug.accountRange(blockNrOrHash, start, maxResults, nocode, nostorage, incompletes)` | +| RPC | `{"method": "debug_getHeaderRlp", "params": [blockNrOrHash, start, maxResults, nocode, nostorage, incompletes]}` | + +### debug_backtraceAt + +Sets the logging backtrace location. When a backtrace location +is set and a log message is emitted at that location, the stack +of the goroutine executing the log statement will be printed to stderr. + +The location is specified as `:`. + +| Client | Method invocation | +|:--------|-------------------------------------------------------| +| Console | `debug.backtraceAt(string)` | +| RPC | `{"method": "debug_backtraceAt", "params": [string]}` | + +Example: + +``` javascript +> debug.backtraceAt("server.go:443") +``` + +### debug_blockProfile + +Turns on block profiling for the given duration and writes +profile data to disk. It uses a profile rate of 1 for most +accurate information. If a different rate is desired, set +the rate and write the profile manually using +`debug_writeBlockProfile`. + +| Client | Method invocation | +|:--------|----------------------------------------------------------------| +| Console | `debug.blockProfile(file, seconds)` | +| RPC | `{"method": "debug_blockProfile", "params": [string, number]}` | + + +### debug_chaindbCompact + +Flattens the entire key-value database into a single level, removing all unused slots and merging all keys. + +| Client | Method invocation | +|:--------|----------------------------------------------------| +| Console | `debug.chaindbCompact()` | +| RPC | `{"method": "debug_chaindbCompact", "params": []}` | + + +### debug_chaindbProperty + +Returns leveldb properties of the key-value database. + +| Client | Method invocation | +|:--------|----------------------------------------------------------------| +| Console | `debug.chaindbProperty(property string)` | +| RPC | `{"method": "debug_chaindbProperty", "params": [property]}` | + + +### debug_cpuProfile + +Turns on CPU profiling for the given duration and writes +profile data to disk. + +| Client | Method invocation | +|:--------|--------------------------------------------------------------| +| Console | `debug.cpuProfile(file, seconds)` | +| RPC | `{"method": "debug_cpuProfile", "params": [string, number]}` | + + +### debug_dbAncient + +Retrieves an ancient binary blob from the freezer. The freezer is a collection of append-only immutable files. +The first argument `kind` specifies which table to look up data from. The list of all table kinds are as follows: + +- `headers`: block headers +- `hashes`: canonical hash table (block number -> block hash) +- `bodies`: block bodies +- `receipts`: block receipts +- `diffs`: total difficulty table (block number -> td) + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Console | `debug.dbAncient(kind string, number uint64)` | +| RPC | `{"method": "debug_dbAncient", "params": [string, number]}` | + +### debug_dbAncients + +Returns the number of ancient items in the ancient store. + +| Client | Method invocation | +|:--------|----------------------------------| +| Console | `debug.dbAncients()` | +| RPC | `{"method": "debug_dbAncients"}` | + +### debug_dbGet + +Returns the raw value of a key stored in the database. + +| Client | Method invocation | +|:--------|----------------------------------------------------------------| +| Console | `debug.dbGet(key string)` | +| RPC | `{"method": "debug_dbGet", "params": [key]}` | + + + +### debug_dumpBlock + +Retrieves the state that corresponds to the block number and returns a list of accounts (including +storage and code). + +| Client | Method invocation | +|:--------|-------------------------------------------------------| +| Go | `debug.DumpBlock(number uint64) (state.World, error)` | +| Console | `debug.traceBlockByHash(number, [options])` | +| RPC | `{"method": "debug_dumpBlock", "params": [number]}` | + +#### Example + +```javascript +> debug.dumpBlock(10) +{ + fff7ac99c8e4feb60c9750054bdc14ce1857f181: { + balance: "49358640978154672", + code: "", + codeHash: "c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470", + nonce: 2, + root: "56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421", + storage: {} + }, + fffbca3a38c3c5fcb3adbb8e63c04c3e629aafce: { + balance: "3460945928", + code: "", + codeHash: "c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470", + nonce: 657, + root: "56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421", + storage: {} + } + }, + root: "19f4ed94e188dd9c7eb04226bd240fa6b449401a6c656d6d2816a87ccaf206f1" +} +``` + +### debug_freeOSMemory + +Forces garbage collection + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Go | `debug.FreeOSMemory()` | +| Console | `debug.freeOSMemory()` | +| RPC | `{"method": "debug_freeOSMemory", "params": []}` | + + + +### debug_freezeClient + +Forces a temporary client freeze, normally when the server is overloaded. +Available as part of LES light server. + +| Client | Method invocation | +|:--------|------------------------------------------------------| +| Console | `debug.freezeClient(node string)` | +| RPC | `{"method": "debug_freezeClient", "params": [node]}` | + + + +### debug_gcStats + +Returns garbage collection statistics. + +See https://golang.org/pkg/runtime/debug/#GCStats for information about +the fields of the returned object. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Console | `debug.gcStats()` | +| RPC | `{"method": "debug_gcStats", "params": []}` | + + +### debug_getAccessibleState + +Returns the first number where the node has accessible state on disk. +This is the post-state of that block and the pre-state of the next +block. The (from, to) parameters are the sequence of blocks +to search, which can go either forwards or backwards. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------------------| +| Console | `debug.getAccessibleState(from, to rpc.BlockNumber)` | +| RPC | `{"method": "debug_getAccessibleState", "params": [from, to]}` | + + +### debug_getBadBlocks + +Returns a list of the last 'bad blocks' that the client has seen on +the network and returns them as a JSON list of block-hashes. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Console | `debug.getBadBlocks()` | +| RPC | `{"method": "debug_getBadBlocks", "params": []}` | + + +### debug_getBlockRlp + +Retrieves and returns the RLP encoded block by number. + +| Client | Method invocation | +|:--------|-------------------------------------------------------| +| Go | `debug.GetBlockRlp(number uint64) (string, error)` | +| Console | `debug.getBlockRlp(number, [options])` | +| RPC | `{"method": "debug_getBlockRlp", "params": [number]}` | + +References: [RLP](https://github.com/ethereum/wiki/wiki/RLP) + +### debug_getHeaderRlp + +Returns an RLP-encoded header. + +| Client | Method invocation | +|:--------|-----------------------------------------------------| +| Console | `debug.getHeaderRlp(blockNum)` | +| RPC | `{"method": "debug_getHeaderRlp", "params": [num]}` | + +### debug_getModifiedAccountsByHash + +Returns all accounts that have changed between the two blocks specified. A change is defined as a difference in nonce, balance, code hash, or storage hash. With one parameter, returns the list of accounts modified in the specified block. + +| Client | Method invocation | +|:--------|---------------------------------------------------------------------------------| +| Console | `debug.getModifiedAccountsByHash(startHash, endHash)` | +| RPC | `{"method": "debug_getModifiedAccountsByHash", "params": [startHash, endHash]}` | + +### debug_getModifiedAccountsByNumber + +Returns all accounts that have changed between the two blocks specified. +A change is defined as a difference in nonce, balance, code hash or +storage hash. + +| Client | Method invocation | +|:--------|---------------------------------------------------------------------------------| +| Console | `debug.getModifiedAccountsByNumber(startNum uint64, endNum uint64)` | +| RPC | `{"method": "debug_getModifiedAccountsByNumber", "params": [startNum, endNum]}` | + +### debug_getRawReceipts + +Returns the consensus-encoding of all receipts in a single block. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------------| +| Console | `debug.getRawReceipts(blockNrOrHash)` | +| RPC | `{"method": "debug_getRawReceipts", "params": [blockNrOrHash]}` | + +### debug_goTrace + +Turns on Go runtime tracing for the given duration and writes +trace data to disk. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------| +| Console | `debug.goTrace(file, seconds)` | +| RPC | `{"method": "debug_goTrace", "params": [string, number]}` | + +### debug_intermediateRoots + +Executes a block (bad- or canon- or side-), and returns a list of intermediate roots: the stateroot after each transaction. + +| Client | Method invocation | +|:--------|--------------------------------------------------------------------| +| Console | `debug.intermediateRoots(blockHash, [options])` | +| RPC | `{"method": "debug_intermediateRoots", "params": [blockHash, {}]}` | + +### debug_memStats + +Returns detailed runtime memory statistics. + +See https://golang.org/pkg/runtime/#MemStats for information about +the fields of the returned object. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Console | `debug.memStats()` | +| RPC | `{"method": "debug_memStats", "params": []}` | + +### debug_mutexProfile + +Turns on mutex profiling for nsec seconds and writes profile data to file. It uses a profile rate of 1 for most accurate information. If a different rate is desired, set the rate and write the profile manually. + +| Client | Method invocation | +|:--------|------------------------------------------------------------| +| Console | `debug.mutexProfile(file, nsec)` | +| RPC | `{"method": "debug_mutexProfile", "params": [file, nsec]}` | + +### debug_preimage + +Returns the preimage for a sha3 hash, if known. + +| Client | Method invocation | +|:--------|--------------------------------------------------| +| Console | `debug.preimage(hash)` | +| RPC | `{"method": "debug_preimage", "params": [hash]}` | + + +### debug_printBlock + +Retrieves a block and returns its pretty printed form. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Console | `debug.printBlock(number uint64)` | +| RPC | `{"method": "debug_printBlock", "params": [number]}` | + + +### debug_seedHash + +Fetches and retrieves the seed hash of the block by number + +| Client | Method invocation | +|:--------|----------------------------------------------------| +| Go | `debug.SeedHash(number uint64) (string, error)` | +| Console | `debug.seedHash(number, [options])` | +| RPC | `{"method": "debug_seedHash", "params": [number]}` | + +### debug_setBlockProfileRate + +Sets the rate (in samples/sec) of goroutine block profile +data collection. A non-zero rate enables block profiling, +setting it to zero stops the profile. Collected profile data +can be written using `debug_writeBlockProfile`. + +| Client | Method invocation | +|:--------|---------------------------------------------------------------| +| Console | `debug.setBlockProfileRate(rate)` | +| RPC | `{"method": "debug_setBlockProfileRate", "params": [number]}` | + +### debug_setGCPercent + +Sets the garbage collection target percentage. A negative value disables garbage +collection. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Go | `debug.SetGCPercent(v int)` | +| Console | `debug.setGCPercent(v)` | +| RPC | `{"method": "debug_setGCPercent", "params": [v]}` | + + +### debug_setHead + +Sets the current head of the local chain by block number. **Note**, this is a +destructive action and may severely damage your chain. Use with *extreme* caution. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Go | `debug.SetHead(number uint64)` | +| Console | `debug.setHead(number)` | +| RPC | `{"method": "debug_setHead", "params": [number]}` | + +References: +[Ethash](https://eth.wiki/en/concepts/ethash/ethash) + +### debug_setMutexProfileFraction + +Sets the rate of mutex profiling. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------------| +| Console | `debug.setMutexProfileFraction(rate int)` | +| RPC | `{"method": "debug_setMutexProfileFraction", "params": [rate]}` | + +### debug_stacks + +Returns a printed representation of the stacks of all goroutines. +Note that the web3 wrapper for this method takes care of the printing +and does not return the string. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Console | `debug.stacks()` | +| RPC | `{"method": "debug_stacks", "params": []}` | + + +### debug_standardTraceBlockToFile + +When JS-based tracing (see below) was first implemented, the intended usecase was to enable long-running tracers that could stream results back via a subscription channel. +This method works a bit differently. (For full details, see [PR](https://github.com/ethereum/go-ethereum/pull/17914)) + +- It streams output to disk during the execution, to not blow up the memory usage on the node +- It uses `jsonl` as output format (to allow streaming) +- Uses a cross-client standardized output, so called 'standard json' + * Uses `op` for string-representation of opcode, instead of `op`/`opName` for numeric/string, and other simlar small differences. + * has `refund` + * Represents memory as a contiguous chunk of data, as opposed to a list of `32`-byte segments like `debug_traceTransaction` + +This means that this method is only 'useful' for callers who control the node -- at least sufficiently to be able to read the artefacts from the filesystem after the fact. + +The method can be used to dump a certain transaction out of a given block: +``` +> debug.standardTraceBlockToFile("0x0bbe9f1484668a2bf159c63f0cf556ed8c8282f99e3ffdb03ad2175a863bca63", {txHash:"0x4049f61ffbb0747bb88dc1c85dd6686ebf225a3c10c282c45a8e0c644739f7e9", disableMemory:true}) +["/tmp/block_0x0bbe9f14-14-0x4049f61f-099048234"] +``` +Or all txs from a block: +``` +> debug.standardTraceBlockToFile("0x0bbe9f1484668a2bf159c63f0cf556ed8c8282f99e3ffdb03ad2175a863bca63", {disableMemory:true}) +["/tmp/block_0x0bbe9f14-0-0xb4502ea7-409046657", "/tmp/block_0x0bbe9f14-1-0xe839be8f-954614764", "/tmp/block_0x0bbe9f14-2-0xc6e2052f-542255195", "/tmp/block_0x0bbe9f14-3-0x01b7f3fe-209673214", "/tmp/block_0x0bbe9f14-4-0x0f290422-320999749", "/tmp/block_0x0bbe9f14-5-0x2dc0fb80-844117472", "/tmp/block_0x0bbe9f14-6-0x35542da1-256306111", "/tmp/block_0x0bbe9f14-7-0x3e199a08-086370834", "/tmp/block_0x0bbe9f14-8-0x87778b88-194603593", "/tmp/block_0x0bbe9f14-9-0xbcb081ba-629580052", "/tmp/block_0x0bbe9f14-10-0xc254381a-578605923", "/tmp/block_0x0bbe9f14-11-0xcc434d58-405931366", "/tmp/block_0x0bbe9f14-12-0xce61967d-874423181", "/tmp/block_0x0bbe9f14-13-0x05a20b35-267153288", "/tmp/block_0x0bbe9f14-14-0x4049f61f-606653767", "/tmp/block_0x0bbe9f14-15-0x46d473d2-614457338", "/tmp/block_0x0bbe9f14-16-0x35cf5500-411906321", "/tmp/block_0x0bbe9f14-17-0x79222961-278569788", "/tmp/block_0x0bbe9f14-18-0xad84e7b1-095032683", "/tmp/block_0x0bbe9f14-19-0x4bd48260-019097038", "/tmp/block_0x0bbe9f14-20-0x1517411d-292624085", "/tmp/block_0x0bbe9f14-21-0x6857e350-971385904", "/tmp/block_0x0bbe9f14-22-0xbe3ae2ca-236639695"] + +``` +Files are created in a temp-location, with the naming standard `block_---`. Each opcode immediately streams to file, with no in-geth buffering aside from whatever buffering the os normally does. + +On the server side, it also adds some more info when regenerating historical state, namely, the reexec-number if `required historical state is not avaiable` is encountered, so a user can experiment with increasing that setting. It also prints out the remaining block until it reaches target: + +``` +INFO [10-15|13:48:25.263] Regenerating historical state block=2385959 target=2386012 remaining=53 elapsed=3m30.990537767s +INFO [10-15|13:48:33.342] Regenerating historical state block=2386012 target=2386012 remaining=0 elapsed=3m39.070073163s +INFO [10-15|13:48:33.343] Historical state regenerated block=2386012 elapsed=3m39.070454362s nodes=10.03mB preimages=652.08kB +INFO [10-15|13:48:33.352] Wrote trace file=/tmp/block_0x14490c57-0-0xfbbd6d91-715824834 +INFO [10-15|13:48:33.352] Wrote trace file=/tmp/block_0x14490c57-1-0x71076194-187462969 +INFO [10-15|13:48:34.421] Wrote trace file=/tmp/block_0x14490c57-2-0x3f4263fe-056924484 +``` + +The `options` is as follows: +``` +type StdTraceConfig struct { + *vm.LogConfig + Reexec *uint64 + TxHash *common.Hash +} +``` + +### debug_standardTraceBadBlockToFile + +This method is similar to `debug_standardTraceBlockToFile`, but can be used to obtain info about a block which has been _rejected_ as invalid (for some reason). + + +### debug_startCPUProfile + +Turns on CPU profiling indefinitely, writing to the given file. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------| +| Console | `debug.startCPUProfile(file)` | +| RPC | `{"method": "debug_startCPUProfile", "params": [string]}` | + +### debug_startGoTrace + +Starts writing a Go runtime trace to the given file. + +| Client | Method invocation | +|:--------|--------------------------------------------------------| +| Console | `debug.startGoTrace(file)` | +| RPC | `{"method": "debug_startGoTrace", "params": [string]}` | + +### debug_stopCPUProfile + +Stops an ongoing CPU profile. + +| Client | Method invocation | +|:--------|----------------------------------------------------| +| Console | `debug.stopCPUProfile()` | +| RPC | `{"method": "debug_stopCPUProfile", "params": []}` | + +### debug_stopGoTrace + +Stops writing the Go runtime trace. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Console | `debug.startGoTrace(file)` | +| RPC | `{"method": "debug_stopGoTrace", "params": []}` | + +### debug_storageRangeAt + +Returns the storage at the given block height and transaction index. The result can be paged by providing a `maxResult` to cap the number of storage slots returned as well as specifying the offset via `keyStart` (hash of storage key). + +| Client | Method invocation | +|:--------|----------------------------------------------------------------------------------------------------------| +| Console | `debug.storageRangeAt(blockHash, txIdx, contractAddress, keyStart, maxResult)` | +| RPC | `{"method": "debug_storageRangeAt", "params": [blockHash, txIdx, contractAddress, keyStart, maxResult]}` | + +### debug_traceBadBlock + +Returns the structured logs created during the execution of EVM against a block pulled from the pool of bad ones and returns them as a JSON object. + +| Client | Method invocation | +|:--------|----------------------------------------------------------------| +| Console | `debug.traceBadBlock(blockHash, [options])` | +| RPC | `{"method": "debug_traceBadBlock", "params": [blockHash, {}]}` | + +### debug_traceBlock + +The `traceBlock` method will return a full stack trace of all invoked opcodes of all transaction +that were included in this block. **Note**, the parent of this block must be present or it will +fail. + +| Client | Method invocation | +|:--------|--------------------------------------------------------------------------| +| Go | `debug.TraceBlock(blockRlp []byte, config. *vm.Config) BlockTraceResult` | +| Console | `debug.traceBlock(tblockRlp, [options])` | +| RPC | `{"method": "debug_traceBlock", "params": [blockRlp, {}]}` | + +References: +[RLP](https://github.com/ethereum/wiki/wiki/RLP) + +#### Example + +```javascript +> debug.traceBlock("0xblock_rlp") +{ + gas: 85301, + returnValue: "", + structLogs: [{ + depth: 1, + error: "", + gas: 162106, + gasCost: 3, + memory: null, + op: "PUSH1", + pc: 0, + stack: [], + storage: {} + }, + /* snip */ + { + depth: 1, + error: "", + gas: 100000, + gasCost: 0, + memory: ["0000000000000000000000000000000000000000000000000000000000000006", "0000000000000000000000000000000000000000000000000000000000000000", "0000000000000000000000000000000000000000000000000000000000000060"], + op: "STOP", + pc: 120, + stack: ["00000000000000000000000000000000000000000000000000000000d67cbec9"], + storage: { + 0000000000000000000000000000000000000000000000000000000000000004: "8241fa522772837f0d05511f20caa6da1d5a3209000000000000000400000001", + 0000000000000000000000000000000000000000000000000000000000000006: "0000000000000000000000000000000000000000000000000000000000000001", + f652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f: "00000000000000000000000002e816afc1b5c0f39852131959d946eb3b07b5ad" + } + }] +``` + +### debug_traceBlockByNumber + +Similar to [debug_traceBlock](#debug_traceblock), `traceBlockByNumber` accepts a block number and will replay the +block that is already present in the database. + +| Client | Method invocation | +|:--------|--------------------------------------------------------------------------------| +| Go | `debug.TraceBlockByNumber(number uint64, config. *vm.Config) BlockTraceResult` | +| Console | `debug.traceBlockByNumber(number, [options])` | +| RPC | `{"method": "debug_traceBlockByNumber", "params": [number, {}]}` | + +References: +[RLP](https://github.com/ethereum/wiki/wiki/RLP) + +### debug_traceBlockByHash + +Similar to [debug_traceBlock](#debug_traceblock), `traceBlockByHash` accepts a block hash and will replay the +block that is already present in the database. + +| Client | Method invocation | +|:--------|---------------------------------------------------------------------------------| +| Go | `debug.TraceBlockByHash(hash common.Hash, config. *vm.Config) BlockTraceResult` | +| Console | `debug.traceBlockByHash(hash, [options])` | +| RPC | `{"method": "debug_traceBlockByHash", "params": [hash {}]}` | + +References: +[RLP](https://github.com/ethereum/wiki/wiki/RLP) + + +### debug_traceBlockFromFile + +Similar to [debug_traceBlock](#debug_traceblock), `traceBlockFromFile` accepts a file containing the RLP of the block. + +| Client | Method invocation | +|:--------|----------------------------------------------------------------------------------| +| Go | `debug.TraceBlockFromFile(fileName string, config. *vm.Config) BlockTraceResult` | +| Console | `debug.traceBlockFromFile(fileName, [options])` | +| RPC | `{"method": "debug_traceBlockFromFile", "params": [fileName, {}]}` | + +References: +[RLP](https://github.com/ethereum/wiki/wiki/RLP) + +### debug_traceCall + +The `debug_traceCall` method lets you run an `eth_call` within the context of the given block execution using the final state of parent block as the base. The first argument (just as in `eth_call`) is a [transaction object](/docs/rpc/objects#transaction-call-object). The block can be specified either by hash or by number as the second argument. A tracer can be specified as a third argument, similar to `debug_traceTransaction`. It returns the same output as `debug_traceTransaction`. + +| Client | Method invocation | +|:-------:|-----------------------------------| +| Go | `debug.TraceCall(args ethapi.CallArgs, blockNrOrHash rpc.BlockNumberOrHash, config *TraceConfig) (*ExecutionResult, error)` | +| Console | `debug.traceCall(object, blockNrOrHash, [options])` | +| RPC | `{"method": "debug_traceCall", "params": [object, blockNrOrHash, {}]}` | + +#### Example + +No specific call options: +``` +> debug.traceCall(null, "0x0") +{ + failed: false, + gas: 53000, + returnValue: "", + structLogs: [] +} +``` +Tracing a call with a destination and specific sender, disabling the storage and memory output (less data returned over RPC) +``` +debug.traceCall({ + "from": "0xdeadbeef29292929192939494959594933929292", + "to": "0xde929f939d939d393f939393f93939f393929023", + "gas": "0x7a120", + "data": "0xf00d4b5d00000000000000000000000001291230982139282304923482304912923823920000000000000000000000001293123098123928310239129839291010293810" + }, + "latest", {"disableStorage": true, "disableMemory": true}) +``` + +It is possible to supply 'overrides' for both state-data (accounts/storage) and block data (number, timestamp etc). In the example below, +a call which executes `NUMBER` is performed, and the overridden number is placed on the stack: +``` +> debug.traceCall({ + from: eth.accounts[0], + value:"0x1", + gasPrice: "0xffffffff", + gas: "0xffff", + input: "0x43"}, + "latest", + {"blockoverrides": + {"number": "0x50"} + }) +{ + failed: false, + gas: 53018, + returnValue: "", + structLogs: [{ + depth: 1, + gas: 12519, + gasCost: 2, + op: "NUMBER", + pc: 0, + stack: [] + }, { + depth: 1, + gas: 12517, + gasCost: 0, + op: "STOP", + pc: 1, + stack: ["0x50"] + }] +} +``` + +Curl example: +``` +> curl -H "Content-Type: application/json" -X POST localhost:8545 --data '{"jsonrpc":"2.0","method":"debug_traceCall","params":[null, "pending"],"id":1}' +{"jsonrpc":"2.0","id":1,"result":{"gas":53000,"failed":false,"returnValue":"","structLogs":[]}} +``` + +### debug_traceChain + +Returns the structured logs created during the execution of EVM between two blocks (excluding start) as a JSON object. +This endpoint must be invoked via `debug_subscribe` as follows: + +`const res = provider.send('debug_subscribe', ['traceChain', '0x3f3a2a', '0x3f3a2b'])` + +please refer to the [subscription page](https://geth.ethereum.org/docs/rpc/pubsub) for more details. + + +### debug_traceTransaction + +**OBS** In most scenarios, `debug.standardTraceBlockToFile` is better suited for tracing! + +The `traceTransaction` debugging method will attempt to run the transaction in the exact same manner +as it was executed on the network. It will replay any transaction that may have been executed prior +to this one before it will finally attempt to execute the transaction that corresponds to the given +hash. + +In addition to the hash of the transaction you may give it a secondary *optional* argument, which +specifies the options for this specific call. The possible options are: + +* `disableStorage`: `BOOL`. Setting this to true will disable storage capture (default = false). +* `disableStack`: `BOOL`. Setting this to true will disable stack capture (default = false). +* `enableMemory`: `BOOL`. Setting this to true will enable memory capture (default = false). +* `enableReturnData`: `BOOL`. Setting this to true will enable return data capture (default = false). +* `tracer`: `STRING`. Setting this will enable JavaScript-based transaction tracing, described below. If set, the previous four arguments will be ignored. +* `timeout`: `STRING`. Overrides the default timeout of 5 seconds for JavaScript-based tracing calls. Valid values are described [here](https://golang.org/pkg/time/#ParseDuration). + +| Client | Method invocation | +|:--------|----------------------------------------------------------------------------------------------| +| Go | `debug.TraceTransaction(txHash common.Hash, logger *vm.LogConfig) (*ExecutionResult, error)` | +| Console | `debug.traceTransaction(txHash, [options])` | +| RPC | `{"method": "debug_traceTransaction", "params": [txHash, {}]}` | + +#### Example + +```javascript +> debug.traceTransaction("0x2059dd53ecac9827faad14d364f9e04b1d5fe5b506e3acc886eff7a6f88a696a") +{ + gas: 85301, + returnValue: "", + structLogs: [{ + depth: 1, + error: "", + gas: 162106, + gasCost: 3, + memory: null, + op: "PUSH1", + pc: 0, + stack: [], + storage: {} + }, + /* snip */ + { + depth: 1, + error: "", + gas: 100000, + gasCost: 0, + memory: ["0000000000000000000000000000000000000000000000000000000000000006", "0000000000000000000000000000000000000000000000000000000000000000", "0000000000000000000000000000000000000000000000000000000000000060"], + op: "STOP", + pc: 120, + stack: ["00000000000000000000000000000000000000000000000000000000d67cbec9"], + storage: { + 0000000000000000000000000000000000000000000000000000000000000004: "8241fa522772837f0d05511f20caa6da1d5a3209000000000000000400000001", + 0000000000000000000000000000000000000000000000000000000000000006: "0000000000000000000000000000000000000000000000000000000000000001", + f652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f: "00000000000000000000000002e816afc1b5c0f39852131959d946eb3b07b5ad" + } + }] +``` + + +#### JavaScript-based tracing + +Specifying the `tracer` option in the second argument enables JavaScript-based tracing. In this mode, `tracer` is interpreted as a JavaScript expression that is expected to evaluate to an object which must expose the `result` and `fault` methods. There exist 3 additional methods, namely: `step`, `enter` and `exit`. You must provide either `step`, or `enter` AND `exit` (i.e. these two must be exposed together). You may expose all three if you choose to do so. + +##### Step + +`step`is a function that takes two arguments, log and db, and is called for each step of the EVM, or when an error occurs, as the specified transaction is traced. + +`log` has the following fields: + + - `op`: Object, an OpCode object representing the current opcode + - `stack`: array[big.Int], the EVM execution stack + - `memory`: Object, a structure representing the contract's memory space + - `contract`: Object, an object representing the account executing the current operation + +and the following methods: + + - `getPC()` - returns a Number with the current program counter + - `getGas()` - returns a Number with the amount of gas remaining + - `getCost()` - returns the cost of the opcode as a Number + - `getDepth()` - returns the execution depth as a Number + - `getRefund()` - returns the amount to be refunded as a Number + - `getError()` - returns information about the error if one occured, otherwise returns `undefined` + +If error is non-empty, all other fields should be ignored. + +For efficiency, the same `log` object is reused on each execution step, updated with current values; make sure to copy values you want to preserve beyond the current call. For instance, this step function will not work: + + function(log) { + this.logs.append(log); + } + +But this step function will: + + function(log) { + this.logs.append({gas: log.getGas(), pc: log.getPC(), ...}); + } + +`log.op` has the following methods: + + - `isPush()` - returns true iff the opcode is a PUSHn + - `toString()` - returns the string representation of the opcode + - `toNumber()` - returns the opcode's number + +`log.memory` has the following methods: + + - `slice(start, stop)` - returns the specified segment of memory as a byte slice + - `getUint(offset)` - returns the 32 bytes at the given offset + +`log.stack` has the following methods: + + - `peek(idx)` - returns the idx-th element from the top of the stack (0 is the topmost element) as a big.Int + - `length()` - returns the number of elements in the stack + +`log.contract` has the following methods: + +- `getCaller()` - returns the address of the caller +- `getAddress()` - returns the address of the current contract +- `getValue()` - returns the amount of value sent from caller to contract as a big.Int +- `getInput()` - returns the input data passed to the contract + +`db` has the following methods: + + - `getBalance(address)` - returns a `big.Int` with the specified account's balance + - `getNonce(address)` - returns a Number with the specified account's nonce + - `getCode(address)` - returns a byte slice with the code for the specified account + - `getState(address, hash)` - returns the state value for the specified account and the specified hash + - `exists(address)` - returns true if the specified address exists + +If the step function throws an exception or executes an illegal operation at any point, it will not be called on any further VM steps, and the error will be returned to the caller. + +##### Result + +`result` is a function that takes two arguments `ctx` and `db`, and is expected to return a JSON-serializable value to return to the RPC caller. + +`ctx` is the context in which the transaction is executing and has the following fields: + +- `type` - String, one of the two values `CALL` and `CREATE` +- `from` - Address, sender of the transaction +- `to` - Address, target of the transaction +- `input` - Buffer, input transaction data +- `gas` - Number, gas budget of the transaction +- `value` - big.Int, amount to be transferred in wei +- `block` - Number, block number +- `output` - Buffer, value returned from EVM +- `gasUsed` - Number, amount of gas used in executing the transaction (excludes txdata costs) +- `time` - String, execution runtime + +##### Fault + +`fault` is a function that takes two arguments, `log` and `db`, just like `step` and is invoked when an error happens during the execution of an opcode which wasn't reported in `step`. The method `log.getError()` has information about the error. + +##### Enter & Exit + +`enter` and `exit` are respectively invoked on stepping in and out of an internal call. More specifically they are invoked on the `CALL` variants, `CREATE` variants and also for the transfer implied by a `SELFDESTRUCT`. + +`enter` takes a `callFrame` object as argument which has the following methods: + +- `getType()` - returns a string which has the type of the call frame +- `getFrom()` - returns the address of the call frame sender +- `getTo()` - returns the address of the call frame target +- `getInput()` - returns the input as a buffer +- `getGas()` - returns a Number which has the amount of gas provided for the frame +- `getValue()` - returns a `big.Int` with the amount to be transferred only if available, otherwise `undefined` + +`exit` takes in a `frameResult` object which has the following methods: + +- `getGasUsed()` - returns amount of gas used throughout the frame as a Number +- `getOutput()` - returns the output as a buffer +` -getError()` - returns an error if one occured during execution and `undefined` otherwise + +##### Usage + +Note that several values are Golang big.Int objects, not JavaScript numbers or JS bigints. As such, they have the same interface as described in the godocs. Their default serialization to JSON is as a Javascript number; to serialize large numbers accurately call `.String()` on them. For convenience, `big.NewInt(x)` is provided, and will convert a uint to a Go BigInt. + +Usage example, returns the top element of the stack at each CALL opcode only: + + debug.traceTransaction(txhash, {tracer: '{data: [], fault: function(log) {}, step: function(log) { if(log.op.toString() == "CALL") this.data.push(log.stack.peek(0)); }, result: function() { return this.data; }}'}); + + +### debug_verbosity + +Sets the logging verbosity ceiling. Log messages with level +up to and including the given level will be printed. + +The verbosity of individual packages and source files +can be raised using `debug_vmodule`. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Console | `debug.verbosity(level)` | +| RPC | `{"method": "debug_vmodule", "params": [number]}` | + +### debug_vmodule + +Sets the logging verbosity pattern. + +| Client | Method invocation | +|:--------|---------------------------------------------------| +| Console | `debug.vmodule(string)` | +| RPC | `{"method": "debug_vmodule", "params": [string]}` | + + +#### Examples + +If you want to see messages from a particular Go package (directory) +and all subdirectories, use: + +``` javascript +> debug.vmodule("eth/*=6") +``` + +If you want to restrict messages to a particular package (e.g. p2p) +but exclude subdirectories, use: + +``` javascript +> debug.vmodule("p2p=6") +``` + +If you want to see log messages from a particular source file, use + +``` javascript +> debug.vmodule("server.go=6") +``` + +You can compose these basic patterns. If you want to see all +output from peer.go in a package below eth (eth/peer.go, +eth/downloader/peer.go) as well as output from package p2p +at level <= 5, use: + +``` javascript +debug.vmodule("eth/*/peer.go=6,p2p=5") +``` + +### debug_writeBlockProfile + +Writes a goroutine blocking profile to the given file. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Console | `debug.writeBlockProfile(file)` | +| RPC | `{"method": "debug_writeBlockProfile", "params": [string]}` | + +### debug_writeMemProfile + +Writes an allocation profile to the given file. +Note that the profiling rate cannot be set through the API, +it must be set on the command line using the `--pprof.memprofilerate` +flag. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Console | `debug.writeMemProfile(file string)` | +| RPC | `{"method": "debug_writeBlockProfile", "params": [string]}` | + +### debug_writeMutexProfile + +Writes a goroutine blocking profile to the given file. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------| +| Console | `debug.writeMutexProfile(file)` | +| RPC | `{"method": "debug_writeMutexProfile", "params": [file]}` | diff --git a/content/docs/interacting_with_geth/RPC/ns-eth.md b/content/docs/interacting_with_geth/RPC/ns-eth.md new file mode 100644 index 0000000000..e8589ac56e --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-eth.md @@ -0,0 +1,207 @@ +--- +title: eth Namespace +sort_key: C +--- + +Geth provides several extensions to the standard "eth" JSON-RPC namespace. + +* TOC +{:toc} + +### eth_subscribe, eth_unsubscribe + +These methods are used for real-time events through subscriptions. See the [subscription +documentation](./pubsub) for more information. + +### eth_call + +Executes a new message call immediately, without creating a transaction on the block +chain. The `eth_call` method can be used to query internal contract state, to execute +validations coded into a contract or even to test what the effect of a transaction would +be without running it live. + +#### Parameters + +The method takes 3 parameters: an unsigned transaction object to execute in read-only +mode; the block number to execute the call against; and an optional state override-set to +allow executing the call against a modified chain state. + +##### 1. `Object` - Transaction call object + +The *transaction call object* is mandatory. Please see [here](/docs/rpc/objects#transaction-call-object) for details. + +##### 2. `Quantity | Tag` - Block number or the string `latest` or `pending` + +The *block number* is mandatory and defines the context (state) against which the +specified transaction should be executed. It is not possible to execute calls against +reorged blocks; or blocks older than 128 (unless the node is an archive node). + +##### 3. `Object` - State override set + +The *state override set* is an optional address-to-state mapping, where each entry +specifies some state to be ephemerally overridden prior to executing the call. Each +address maps to an object containing: + +| Field | Type | Bytes | Optional | Description | +|:------------|:-----------|:------|:---------|:------------| +| `balance` | `Quantity` | <32 | Yes | Fake balance to set for the account before executing the call. | +| `nonce` | `Quantity` | <8 | Yes | Fake nonce to set for the account before executing the call. | +| `code` | `Binary` | any | Yes | Fake EVM bytecode to inject into the account before executing the call. | +| `state` | `Object` | any | Yes | Fake key-value mapping to override **all** slots in the account storage before executing the call. | +| `stateDiff` | `Object` | any | Yes | Fake key-value mapping to override **individual** slots in the account storage before executing the call. | + +The goal of the *state override set* is manyfold: + + * It can be used by DApps to reduce the amount of contract code needed to be deployed on + chain. Code that simply returns internal state or does pre-defined validations can be + kept off chain and fed to the node on-demand. + * It can be used for smart contract analysis by extending the code deployed on chain with + custom methods and invoking them. This avoids having to download and reconstruct the + entire state in a sandbox to run custom code against. + * It can be used to debug smart contracts in an already deployed large suite of contracts + by selectively overriding some code or state and seeing how execution changes. + Specialized tooling will probably be necessary. + +Example: + +```json +{ + "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3": { + "balance": "0xde0b6b3a7640000" + }, + "0xebe8efa441b9302a0d7eaecc277c09d20d684540": { + "code": "0x...", + "state": { + "" + } + } +} +``` + +#### Return Values + +The method returns a single `Binary` consisting the return value of the executed contract +call. + +#### Simple example + +With a synced Rinkeby node with RPC exposed on localhost (`geth --rinkeby --http`) we can +make a call against the [Checkpoint +Oracle](https://rinkeby.etherscan.io/address/0xebe8efa441b9302a0d7eaecc277c09d20d684540) +to retrieve the list of administrators: + +``` +$ curl --data '{"method":"eth_call","params":[{"to":"0xebe8efa441b9302a0d7eaecc277c09d20d684540","data":"0x45848dfc"},"latest"],"id":1,"jsonrpc":"2.0"}' -H "Content-Type: application/json" -X POST localhost:8545 +``` + +And the result is an Ethereum ABI encoded list of accounts: + +```json +{ + "id": 1, + "jsonrpc": "2.0", + "result": "0x00000000000000000000000000000000000000000000000000000000000000200000000000000000000000000000000000000000000000000000000000000004000000000000000000000000d9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f300000000000000000000000078d1ad571a1a09d60d9bbf25894b44e4c8859595000000000000000000000000286834935f4a8cfb4ff4c77d5770c2775ae2b0e7000000000000000000000000b86e2b0ab5a4b1373e40c51a7c712c70ba2f9f8e" +} +``` + +Just for the sake of completeness, decoded the response is: + +``` +0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3, +0x78d1ad571a1a09d60d9bbf25894b44e4c8859595, +0x286834935f4a8cfb4ff4c77d5770c2775ae2b0e7, +0xb86e2b0ab5a4b1373e40c51a7c712c70ba2f9f8e +``` + +#### Override example + +The above *simple example* showed how to call a method already exposed by an on-chain +smart contract. What if we want to access some data not exposed by it? + +We can gut out the +[original](https://github.com/ethereum/go-ethereum/blob/master/contracts/checkpointoracle/contract/oracle.sol) +checkpoint oracle contract with one that retains the same fields (to retain the same +storage layout), but one that includes a different method set: + +``` +pragma solidity ^0.5.10; + +contract CheckpointOracle { + mapping(address => bool) admins; + address[] adminList; + uint64 sectionIndex; + uint height; + bytes32 hash; + uint sectionSize; + uint processConfirms; + uint threshold; + + function VotingThreshold() public view returns (uint) { + return threshold; + } +} +``` + +With a synced Rinkeby node with RPC exposed on localhost (`geth --rinkeby --http`) we can +make a call against the live [Checkpoint +Oracle](https://rinkeby.etherscan.io/address/0xebe8efa441b9302a0d7eaecc277c09d20d684540), +but override its byte code with our own version that has an accessor for the voting +threshold field: + +``` +$ curl --data '{"method":"eth_call","params":[{"to":"0xebe8efa441b9302a0d7eaecc277c09d20d684540","data":"0x0be5b6ba"}, "latest", {"0xebe8efa441b9302a0d7eaecc277c09d20d684540": {"code":"0x6080604052348015600f57600080fd5b506004361060285760003560e01c80630be5b6ba14602d575b600080fd5b60336045565b60408051918252519081900360200190f35b6007549056fea265627a7a723058206f26bd0433456354d8d1228d8fe524678a8aeeb0594851395bdbd35efc2a65f164736f6c634300050a0032"}}],"id":1,"jsonrpc":"2.0"}' -H "Content-Type: application/json" -X POST localhost:8545 +``` + +And the result is the Ethereum ABI encoded threshold number: + +```json +{ + "id": 1, + "jsonrpc": "2.0", + "result": "0x0000000000000000000000000000000000000000000000000000000000000002" +} +``` + +Just for the sake of completeness, decoded the response is: `2`. + +### eth_createAccessList + +This method creates an [EIP2930](https://eips.ethereum.org/EIPS/eip-2930) type `accessList` based on a given `Transaction`. +The `accessList` contains all storage slots and addresses read and written by the transaction, except for the sender account and the precompiles. +This method uses the same `transaction` call [object](/docs/rpc/objects#transaction-call-object) and `blockNumberOrTag` object as `eth_call`. +An `accessList` can be used to unstuck contracts that became inaccessible due to gas cost increases. + +#### Parameters + +| Field | Type | Description | +|:-------------------|:-----------|:---------------------| +| `transaction` | `Object` | `TransactionCall` object | +| `blockNumberOrTag` | `Object` | Optional, blocknumber or `latest` or `pending` | + +#### Usage + +``` +curl --data '{"method":"eth_createAccessList","params":[{"from": "0x8cd02c6cbd8375b39b06577f8d50c51d86e8d5cd", "data": "0x608060806080608155"}, "pending"],"id":1,"jsonrpc":"2.0"}' -H "Content-Type: application/json" -X POST localhost:8545 +``` + +#### Response + +The method `eth_createAccessList` returns list of addresses and storage keys used by the transaction, plus the gas consumed when the access list is added. + +That is, it gives you the list of addresses and storage keys that will be used by that transaction, plus the gas consumed if the access list is included. Like `eth_estimateGas`, this is an estimation; the list could change when the transaction is actually mined. +Adding an `accessList` to your transaction does not necessary result in lower gas usage compared to a transaction without an access list. + +Example: +```json +{ + "accessList": [ + { + "address": "0xa02457e5dfd32bda5fc7e1f1b008aa5979568150", + "storageKeys": [ + "0x0000000000000000000000000000000000000000000000000000000000000081", + ] + } + ] + "gasUsed": "0x125f8" +} +``` diff --git a/content/docs/interacting_with_geth/RPC/ns-les.md b/content/docs/interacting_with_geth/RPC/ns-les.md new file mode 100644 index 0000000000..457efc2175 --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-les.md @@ -0,0 +1,318 @@ +--- +title: les Namespace +sort_key: C +--- + +The `les` API allows you to manage LES server settings, including client parameters and payment settings for prioritized clients. It also provides functions to query checkpoint information in both server and client mode. + +* TOC +{:toc} + +### les_serverInfo + +Get information about currently connected and total/individual allowed connection capacity. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Go | `les.ServerInfo() map[string]interface{}` | +| Console | `les.serverInfo()` | +| RPC | `{"method": "les_serverInfo", "params": []}` | + +#### Example + +```javascript +> les.serverInfo +{ + freeClientCapacity: 16000, + maximumCapacity: 1600000, + minimumCapacity: 16000, + priorityConnectedCapacity: 180000, + totalCapacity: 1600000, + totalConnectedCapacity: 180000 +} +``` + +### les_clientInfo + +Get individual client information (connection, balance, pricing) on the specified list of clients or for all connected clients if the ID list is empty. + +| Client | Method invocation | +|:--------|---------------------------------------------------------------------------| +| Go | `les.ClientInfo(ids []enode.ID) map[enode.ID]map[string]interface{}` | +| Console | `les.clientInfo([id, ...])` | +| RPC | `{"method": "les_clientInfo", "params": [[id, ...]]}` | + +#### Example + +```javascript +> les.clientInfo([]) +{ + 37078bf8ea160a2b3d129bb4f3a930ce002356f83b820f467a07c1fe291531ea: { + capacity: 16000, + connectionTime: 11225.335901136, + isConnected: true, + pricing/balance: 998266395881, + pricing/balanceMeta: "", + pricing/negBalance: 501657912857, + priority: true + }, + 6a47fe7bb23fd335df52ef1690f37ab44265a537b1d18eb616a3e77f898d9e77: { + capacity: 100000, + connectionTime: 9874.839293082, + isConnected: true, + pricing/balance: 2908840710198, + pricing/balanceMeta: "qwerty", + pricing/negBalance: 206242704507, + priority: true + }, + 740c78f7d914e5c763731bc751b513fc2388ffa0b47db080ded3e8b305e68c75: { + capacity: 16000, + connectionTime: 3089.286712188, + isConnected: true, + pricing/balance: 998266400174, + pricing/balanceMeta: "", + pricing/negBalance: 55135348863, + priority: true + }, + 9985ade55b515f79f64274bf2ae440ca8c433cfb0f283fb6010bf46f796b2a3b: { + capacity: 16000, + connectionTime: 11479.335479545, + isConnected: true, + pricing/balance: 998266452203, + pricing/balanceMeta: "", + pricing/negBalance: 564116425655, + priority: true + }, + ce65ada2c3e17d6da00cec0b3cc4c8ed5e74428b60f42fa287eaaec8cca62544: { + capacity: 16000, + connectionTime: 7095.794385419, + isConnected: true, + pricing/balance: 998266448492, + pricing/balanceMeta: "", + pricing/negBalance: 214617753229, + priority: true + }, + e1495ceb6db842f3ee66428d4bb7f4a124b2b17111dae35d141c3d568b869ef1: { + capacity: 16000, + connectionTime: 8614.018237937, + isConnected: true, + pricing/balance: 998266391796, + pricing/balanceMeta: "", + pricing/negBalance: 185964891797, + priority: true + } +} +``` + +### les_priorityClientInfo + +Get individual client information on clients with a positive balance in the specified ID range, `start` included, `stop` excluded. If `stop` is zero then results are returned until the last existing balance entry. `maxCount` limits the number of returned results. If the count limit is reached but there are more IDs in the range then the first missing ID is included in the result with an empty value assigned to it. + +| Client | Method invocation | +|:--------|----------------------------------------------------------------------------------------------------| +| Go | `les.PriorityClientInfo(start, stop enode.ID, maxCount int) map[enode.ID]map[string]interface{}` | +| Console | `les.priorityClientInfo(id, id, number)` | +| RPC | `{"method": "les_priorityClientInfo", "params": [id, id, number]}` | + +#### Example + +```javascript +> les.priorityClientInfo("0x0000000000000000000000000000000000000000000000000000000000000000", "0x0000000000000000000000000000000000000000000000000000000000000000", 100) +{ + 37078bf8ea160a2b3d129bb4f3a930ce002356f83b820f467a07c1fe291531ea: { + capacity: 16000, + connectionTime: 11128.247204027, + isConnected: true, + pricing/balance: 999819815030, + pricing/balanceMeta: "", + pricing/negBalance: 501657912857, + priority: true + }, + 6a47fe7bb23fd335df52ef1690f37ab44265a537b1d18eb616a3e77f898d9e77: { + capacity: 100000, + connectionTime: 9777.750592047, + isConnected: true, + pricing/balance: 2918549830576, + pricing/balanceMeta: "qwerty", + pricing/negBalance: 206242704507, + priority: true + }, + 740c78f7d914e5c763731bc751b513fc2388ffa0b47db080ded3e8b305e68c75: { + capacity: 16000, + connectionTime: 2992.198001116, + isConnected: true, + pricing/balance: 999819845102, + pricing/balanceMeta: "", + pricing/negBalance: 55135348863, + priority: true + }, + 9985ade55b515f79f64274bf2ae440ca8c433cfb0f283fb6010bf46f796b2a3b: { + capacity: 16000, + connectionTime: 11382.246766963, + isConnected: true, + pricing/balance: 999819871598, + pricing/balanceMeta: "", + pricing/negBalance: 564116425655, + priority: true + }, + ce65ada2c3e17d6da00cec0b3cc4c8ed5e74428b60f42fa287eaaec8cca62544: { + capacity: 16000, + connectionTime: 6998.705683407, + isConnected: true, + pricing/balance: 999819882177, + pricing/balanceMeta: "", + pricing/negBalance: 214617753229, + priority: true + }, + e1495ceb6db842f3ee66428d4bb7f4a124b2b17111dae35d141c3d568b869ef1: { + capacity: 16000, + connectionTime: 8516.929533901, + isConnected: true, + pricing/balance: 999819891640, + pricing/balanceMeta: "", + pricing/negBalance: 185964891797, + priority: true + } +} + +> les.priorityClientInfo("0x4000000000000000000000000000000000000000000000000000000000000000", "0xe000000000000000000000000000000000000000000000000000000000000000", 2) +{ + 6a47fe7bb23fd335df52ef1690f37ab44265a537b1d18eb616a3e77f898d9e77: { + capacity: 100000, + connectionTime: 9842.11178361, + isConnected: true, + pricing/balance: 2912113588853, + pricing/balanceMeta: "qwerty", + pricing/negBalance: 206242704507, + priority: true + }, + 740c78f7d914e5c763731bc751b513fc2388ffa0b47db080ded3e8b305e68c75: { + capacity: 16000, + connectionTime: 3056.559199029, + isConnected: true, + pricing/balance: 998790060237, + pricing/balanceMeta: "", + pricing/negBalance: 55135348863, + priority: true + }, + 9985ade55b515f79f64274bf2ae440ca8c433cfb0f283fb6010bf46f796b2a3b: {} +} +``` + +### les_addBalance + +Add signed value to the token balance of the specified client and update its `meta` tag. The balance cannot go below zero or over `2^^63-1`. The balance values before and after the update are returned. The `meta` tag can be used to store a sequence number or reference to the last processed incoming payment, token expiration info, balance in other currencies or any application-specific additional information. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------------------------------| +| Go | `les.AddBalance(id enode.ID, value int64, meta string) ([2]uint64, error)}` | +| Console | `les.addBalance(id, number, string)` | +| RPC | `{"method": "les_addBalance", "params": [id, number, string]}` | + +#### Example + +```javascript +> les.addBalance("0x6a47fe7bb23fd335df52ef1690f37ab44265a537b1d18eb616a3e77f898d9e77", 1000000000, "qwerty") +[968379616, 1968379616] +``` + +### les_setClientParams + +Set capacity and pricing factors for the specified list of connected clients or for all connected clients if the ID list is empty. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------------------------------| +| Go | `les.SetClientParams(ids []enode.ID, params map[string]interface{}) error` | +| Console | `les.setClientParams([id, ...], {string: value, ...})` | +| RPC | `{"method": "les_setClientParams", "params": [[id, ...], {string: value, ...}]}` | + +#### Example + +```javascript +> les.setClientParams(["0x6a47fe7bb23fd335df52ef1690f37ab44265a537b1d18eb616a3e77f898d9e77"], { + "capacity": 100000, + "pricing/timeFactor": 0, + "pricing/capacityFactor": 1000000000, + "pricing/requestCostFactor": 1000000000, + "pricing/negative/timeFactor": 0, + "pricing/negative/capacityFactor": 1000000000, + "pricing/negative/requestCostFactor": 1000000000, +}) +null +``` + +### les_setDefaultParams + +Set default pricing factors for subsequently connected clients. + +| Client | Method invocation | +|:--------|-----------------------------------------------------------------------------------| +| Go | `les.SetDefaultParams(params map[string]interface{}) error` | +| Console | `les.setDefaultParams({string: value, ...})` | +| RPC | `{"method": "les_setDefaultParams", "params": [{string: value, ...}]}` | + +#### Example + +```javascript +> les.setDefaultParams({ + "pricing/timeFactor": 0, + "pricing/capacityFactor": 1000000000, + "pricing/requestCostFactor": 1000000000, + "pricing/negative/timeFactor": 0, + "pricing/negative/capacityFactor": 1000000000, + "pricing/negative/requestCostFactor": 1000000000, +}) +null +``` + +### les_latestCheckpoint + +Get the index and hashes of the latest known checkpoint. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Go | `les.LatestCheckpoint() ([4]string, error)` | +| Console | `les.latestCheckpoint()` | +| RPC | `{"method": "les_latestCheckpoint", "params": []}` | + +#### Example + +```javascript +> les.latestCheckpoint +["0x110", "0x6eedf8142d06730b391bfcbd32e9bbc369ab0b46ae226287ed5b29505a376164", "0x191bb2265a69c30201a616ae0d65a4ceb5937c2f0c94b125ff55343d707463e5", "0xf58409088a5cb2425350a59d854d546d37b1e7bef8bbf6afee7fd15f943d626a"] +``` + +### les_getCheckpoint + +Get checkpoint hashes by index. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Go | `les.GetCheckpoint(index uint64) ([3]string, error)` | +| Console | `les.getCheckpoint(number)` | +| RPC | `{"method": "les_getCheckpoint", "params": [number]}` | + +#### Example + +```javascript +> les.getCheckpoint(256) +["0x93eb4af0b224b1097e09181c2e51536fe0a3bf3bb4d93e9a69cab9eb3e28c75f", "0x0eb055e384cf58bc72ca20ca5e2b37d8d4115dce80ab4a19b72b776502c4dd5b", "0xda6c02f7c51f9ecc3eca71331a7eaad724e5a0f4f906ce9251a2f59e3115dd6a"] +``` + +### les_getCheckpointContractAddress + +Get the address of the checkpoint oracle contract. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------------| +| Go | `les.GetCheckpointContractAddress() (string, error)` | +| Console | `les.checkpointContractAddress()` | +| RPC | `{"method": "les_getCheckpointContractAddress", "params": []}` | + +#### Example + +```javascript +> les.checkpointContractAddress +"0x9a9070028361F7AAbeB3f2F2Dc07F82C4a98A02a" +``` + diff --git a/content/docs/interacting_with_geth/RPC/ns-miner.md b/content/docs/interacting_with_geth/RPC/ns-miner.md new file mode 100644 index 0000000000..303f177b9d --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-miner.md @@ -0,0 +1,91 @@ +--- +title: miner Namespace +sort_key: C +--- + +The `miner` API allows you to remote control the node's mining operation and set various +mining specific settings. + +* TOC +{:toc} + +### miner_getHashrate + +Get your hashrate in H/s (Hash operations per second). + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Console | `miner.getHashrate()` | +| RPC | `{"method": "miner_getHashrate", "params": []}` | + +### miner_setExtra + +Sets the extra data a miner can include when miner blocks. This is capped at +32 bytes. + +| Client | Method invocation | +|:--------|----------------------------------------------------| +| Go | `miner.setExtra(extra string) (bool, error)` | +| Console | `miner.setExtra(string)` | +| RPC | `{"method": "miner_setExtra", "params": [string]}` | + +### miner_setGasPrice + +Sets the minimal accepted gas price when mining transactions. Any transactions that are +below this limit are excluded from the mining process. + +| Client | Method invocation | +|:--------|-------------------------------------------------------| +| Go | `miner.setGasPrice(number *rpc.HexNumber) bool` | +| Console | `miner.setGasPrice(number)` | +| RPC | `{"method": "miner_setGasPrice", "params": [number]}` | + +### miner_setRecommitInterval + +Updates the interval for recomitting the miner sealing work. + +| Client | Method invocation | +|:--------|---------------------------------------------------------------| +| Console | `miner.setRecommitInterval(interval int)` | +| RPC | `{"method": "miner_setRecommitInterval", "params": [number]}` | + +### miner_start + +Start the CPU mining process with the given number of threads and generate a new DAG +if need be. + +| Client | Method invocation | +|:--------|-----------------------------------------------------| +| Go | `miner.Start(threads *rpc.HexNumber) (bool, error)` | +| Console | `miner.start(number)` | +| RPC | `{"method": "miner_start", "params": [number]}` | + +### miner_stop + +Stop the CPU mining operation. + +| Client | Method invocation | +|:--------|----------------------------------------------| +| Go | `miner.Stop() bool` | +| Console | `miner.stop()` | +| RPC | `{"method": "miner_stop", "params": []}` | + +### miner_setEtherbase + +Sets the etherbase, where mining rewards will go. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Go | `miner.SetEtherbase(common.Address) bool` | +| Console | `miner.setEtherbase(address)` | +| RPC | `{"method": "miner_setEtherbase", "params": [address]}` | + +### miner_setGasLimit + +Sets the gas limit the miner will target when mining. Note: on networks where EIP-1559 is activated, this should be set to twice what you want the gas target (i.e. the effective gas used on average per block) to be. + +| Client | Method invocation | +|:--------|-------------------------------------------------------------| +| Go | `miner.SetGasLimit(number *rpc.HexNumber) bool` | +| Console | `miner.SetGasLimit(number)` | +| RPC | `{"method": "miner_setGasLimit", "params": [number]}` | diff --git a/content/docs/interacting_with_geth/RPC/ns-net.md b/content/docs/interacting_with_geth/RPC/ns-net.md new file mode 100644 index 0000000000..1a92cabb9d --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-net.md @@ -0,0 +1,36 @@ +--- +title: net Namespace +sort_key: C +--- + +The `net` API provides insight about the networking aspect of the client. + +* TOC +{:toc} + +### net_listening + +Returns an indication if the node is listening for network connections. + +| Client | Method invocation | +|:--------|-------------------------------| +| Console | `net.listening` | +| RPC | `{"method": "net_listening"}` | + +### net_peerCount + +Returns the number of connected peers. + +| Client | Method invocation | +|:--------|-------------------------------| +| Console | `net.peerCount` | +| RPC | `{"method": "net_peerCount"}` | + +### net_version + +Returns the devp2p network ID (e.g. 1 for mainnet, 5 for goerli). + +| Client | Method invocation | +|:--------|-----------------------------| +| Console | `net.version` | +| RPC | `{"method": "net_version"}` | diff --git a/content/docs/interacting_with_geth/RPC/ns-personal.md b/content/docs/interacting_with_geth/RPC/ns-personal.md new file mode 100644 index 0000000000..c3086ccb50 --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-personal.md @@ -0,0 +1,255 @@ +--- +title: personal Namespace +sort_key: C +--- + +The personal API manages private keys in the key store. + +* TOC +{:toc} + +### personal_deriveAccount + +Requests a HD wallet to derive a new account, optionally pinning it for later reuse. + +| Client | Method invocation | +| :--------| ------------------------------------------------------------------------ | +| Console | `personal.deriveAccount(url, path, pin)` | +| RPC | `{"method": "personal_deriveAccount", "params": [string, string, bool]}` | + +### personal_importRawKey + +Imports the given unencrypted private key (hex string) into the key store, +encrypting it with the passphrase. + +Returns the address of the new account. + +| Client | Method invocation | +| :--------| ----------------------------------------------------------------- | +| Console | `personal.importRawKey(keydata, passphrase)` | +| RPC | `{"method": "personal_importRawKey", "params": [string, string]}` | + +### personal_initializeWallets + +Initializes a new wallet at the provided URL by generating and returning a new private key. + +| Client | Method invocation | +| :--------| ------------------------------------------------------------- | +| Console | `personal.initializeWallet(url)` | +| RPC | `{"method": "personal_initializeWallet", "params": [string]}` | + +### personal_listAccounts + +Returns all the Ethereum account addresses of all keys +in the key store. + +| Client | Method invocation | +| :--------| --------------------------------------------------- | +| Console | `personal.listAccounts` | +| RPC | `{"method": "personal_listAccounts", "params": []}` | + +#### Example + +``` javascript +> personal.listAccounts +["0x5e97870f263700f46aa00d967821199b9bc5a120", "0x3d80b31a78c30fc628f20b2c89d7ddbf6e53cedc"] +``` + +### personal_listWallets + +Returns a list of wallets this node manages. + +| Client | Method invocation | +| :--------| --------------------------------------------------- | +| Console | `personal.listWallets` | +| RPC | `{"method": "personal_listWallets", "params": []}` | + +#### Example + +``` javascript +> personal.listWallets +[{ + accounts: [{ + address: "0x51594065a986c58d4698c23e3d932b68a22c4d21", + url: "keystore:///var/folders/cp/k3x0xm3959qf9l0pcbbdxdt80000gn/T/go-ethereum-keystore65174700/UTC--2022-06-28T10-31-09.477982000Z--51594065a986c58d4698c23e3d932b68a22c4d21" + }], + status: "Unlocked", + url: "keystore:///var/folders/cp/k3x0xm3959qf9l0pcbbdxdt80000gn/T/go-ethereum-keystore65174700/UTC--2022-06-28T10-31-09.477982000Z--51594065a986c58d4698c23e3d932b68a22c4d21" +}] +``` + +### personal_lockAccount + +Removes the private key with given address from memory. +The account can no longer be used to send transactions. + +| Client | Method invocation | +| :--------| -------------------------------------------------------- | +| Console | `personal.lockAccount(address)` | +| RPC | `{"method": "personal_lockAccount", "params": [string]}` | + +### personal_newAccount + +Generates a new private key and stores it in the key store directory. +The key file is encrypted with the given passphrase. +Returns the address of the new account. + +At the geth console, `newAccount` will prompt for a passphrase when +it is not supplied as the argument. + +| Client | Method invocation | +| :--------| --------------------------------------------------- | +| Console | `personal.newAccount()` | +| RPC | `{"method": "personal_newAccount", "params": [string]}` | + +#### Example + +``` javascript +> personal.newAccount() +Passphrase: +Repeat passphrase: +"0x5e97870f263700f46aa00d967821199b9bc5a120" +``` + +The passphrase can also be supplied as a string. + +``` javascript +> personal.newAccount("h4ck3r") +"0x3d80b31a78c30fc628f20b2c89d7ddbf6e53cedc" +``` + +### personal_openWallet + +Initiates a hardware wallet opening procedure by establishing a USB +connection and then attempting to authenticate via the provided passphrase. Note, +the method may return an extra challenge requiring a second open (e.g. the +Trezor PIN matrix challenge). + +| Client | Method invocation | +| :--------| ----------------------------------------------------------- | +| Console | `personal.openWallet(url, passphrase)` | +| RPC | `{"method": "personal_openWallet", "params": [string, string]}` | + +### personal_unlockAccount + +Decrypts the key with the given address from the key store. + +Both passphrase and unlock duration are optional when using the JavaScript console. +If the passphrase is not supplied as an argument, the console will prompt for +the passphrase interactively. + +The unencrypted key will be held in memory until the unlock duration expires. +If the unlock duration defaults to 300 seconds. An explicit duration +of zero seconds unlocks the key until geth exits. + +The account can be used with `eth_sign` and `eth_sendTransaction` while it is unlocked. + +| Client | Method invocation | +| :--------| -------------------------------------------------------------------------- | +| Console | `personal.unlockAccount(address, passphrase, duration)` | +| RPC | `{"method": "personal_unlockAccount", "params": [string, string, number]}` | + +#### Examples + +``` javascript +> personal.unlockAccount("0x5e97870f263700f46aa00d967821199b9bc5a120") +Unlock account 0x5e97870f263700f46aa00d967821199b9bc5a120 +Passphrase: +true +``` + +Supplying the passphrase and unlock duration as arguments: + +``` javascript +> personal.unlockAccount("0x5e97870f263700f46aa00d967821199b9bc5a120", "foo", 30) +true +``` + +If you want to type in the passphrase and stil override the default unlock duration, +pass `null` as the passphrase. + +``` +> personal.unlockAccount("0x5e97870f263700f46aa00d967821199b9bc5a120", null, 30) +Unlock account 0x5e97870f263700f46aa00d967821199b9bc5a120 +Passphrase: +true +``` + +### personal_unpair + +Deletes a pairing between wallet and geth. + +| Client | Method invocation | +| :--------| ----------------------------------------------------------- | +| Console | `personal.unpair(url, pin)` | +| RPC | `{"method": "personal_unpair", "params": [string, string]}` | + +### personal_sendTransaction + +Validate the given passphrase and submit transaction. + +The transaction is the same argument as for `eth_sendTransaction` (i.e. [transaction object](/docs/rpc/objects#transaction-call-object)) and contains the `from` address. If the passphrase can be used to decrypt the private key belogging to `tx.from` the transaction is verified, signed and send onto the network. The account is not unlocked globally in the node and cannot be used in other RPC calls. + +| Client | Method invocation | +| :--------| -----------------------------------------------------------------| +| Console | `personal.sendTransaction(tx, passphrase)` | +| RPC | `{"method": "personal_sendTransaction", "params": [tx, string]}` | + +#### Examples + +``` javascript +> var tx = {from: "0x391694e7e0b0cce554cb130d723a9d27458f9298", to: "0xafa3f8684e54059998bc3a7b0d2b0da075154d66", value: web3.toWei(1.23, "ether")} +undefined +> personal.sendTransaction(tx, "passphrase") +0x8474441674cdd47b35b875fd1a530b800b51a5264b9975fb21129eeb8c18582f +``` + +### personal_sign + +The sign method calculates an Ethereum specific signature with: +`sign(keccak256("\x19Ethereum Signed Message:\n" + len(message) + message)))`. + +By adding a prefix to the message makes the calculated signature recognisable as an Ethereum specific signature. This prevents misuse where a malicious DApp can sign arbitrary data (e.g. transaction) and use the signature to impersonate the victim. + +See ecRecover to verify the signature. + +| Client | Method invocation | +|:--------|-------------------------------------------------------| +| Console | `personal.sign(message, account, [password])` | +| RPC | `{"method": "personal_sign", "params": [message, account, password]}` | + + +#### Examples + +``` javascript +> personal.sign("0xdeadbeaf", "0x9b2055d370f73ec7d8a03e965129118dc8f5bf83", "") +"0xa3f20717a250c2b0b729b7e5becbff67fdaef7e0699da4de7ca5895b02a170a12d887fd3b17bfdce3481f10bea41f45ba9f709d39ce8325427b57afcfc994cee1b" +``` + +### personal_signTransaction + +SignTransaction will create a transaction from the given arguments and tries to sign it with the key associated with `tx.from`. If the given passwd isn't able to decrypt the key it fails. The transaction is returned in RLP-form, not broadcast to other nodes. The first argument is a [transaction object](/docs/rpc/objects#transaction-call-object) and the second argument is the password, similar to `personal_sendTransaction`. + +| Client | Method invocation | +| :--------| -----------------------------------------------------------------| +| Console | `personal.signTransaction(tx, passphrase)` | +| RPC | `{"method": "personal_signTransaction", "params": [tx, string]}` | + +### personal_ecRecover + +`ecRecover` returns the address associated with the private key that was used to calculate the signature in `personal_sign`. + +| Client | Method invocation | +|:--------|-------------------------------------------------------| +| Console | `personal.ecRecover(message, signature)` | +| RPC | `{"method": "personal_ecRecover", "params": [message, signature]}` | + + +#### Examples + +``` javascript +> personal.sign("0xdeadbeaf", "0x9b2055d370f73ec7d8a03e965129118dc8f5bf83", "") +"0xa3f20717a250c2b0b729b7e5becbff67fdaef7e0699da4de7ca5895b02a170a12d887fd3b17bfdce3481f10bea41f45ba9f709d39ce8325427b57afcfc994cee1b" +> personal.ecRecover("0xdeadbeaf", "0xa3f20717a250c2b0b729b7e5becbff67fdaef7e0699da4de7ca5895b02a170a12d887fd3b17bfdce3481f10bea41f45ba9f709d39ce8325427b57afcfc994cee1b") +"0x9b2055d370f73ec7d8a03e965129118dc8f5bf83" +``` diff --git a/content/docs/interacting_with_geth/RPC/ns-txpool.md b/content/docs/interacting_with_geth/RPC/ns-txpool.md new file mode 100644 index 0000000000..fc935c77a6 --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/ns-txpool.md @@ -0,0 +1,226 @@ +--- +title: txpool Namespace +sort_key: C +--- + +The `txpool` API gives you access to several non-standard RPC methods to inspect the contents of the +transaction pool containing all the currently pending transactions as well as the ones queued for +future processing. + +* TOC +{:toc} + +### txpool_content + +The `content` inspection property can be queried to list the exact details of all the transactions +currently pending for inclusion in the next block(s), as well as the ones that are being scheduled +for future execution only. + +The result is an object with two fields `pending` and `queued`. Each of these fields are associative +arrays, in which each entry maps an origin-address to a batch of scheduled transactions. These batches +themselves are maps associating nonces with actual transactions. + +Please note, there may be multiple transactions associated with the same account and nonce. This can +happen if the user broadcast mutliple ones with varying gas allowances (or even completely different +transactions). + +| Client | Method invocation | +|:-------:|-----------------------------------------------------------------------| +| Go | `txpool.Content() (map[string]map[string]map[string]*RPCTransaction)` | +| Console | `txpool.content` | +| RPC | `{"method": "txpool_content"}` | + +#### Example + +```javascript +> txpool.content +{ + pending: { + 0x0216d5032f356960cd3749c31ab34eeff21b3395: { + 806: { + blockHash: "0x0000000000000000000000000000000000000000000000000000000000000000", + blockNumber: null, + from: "0x0216d5032f356960cd3749c31ab34eeff21b3395", + gas: "0x5208", + gasPrice: "0xba43b7400", + hash: "0xaf953a2d01f55cfe080c0c94150a60105e8ac3d51153058a1f03dd239dd08586", + input: "0x", + nonce: "0x326", + to: "0x7f69a91a3cf4be60020fb58b893b7cbb65376db8", + transactionIndex: null, + value: "0x19a99f0cf456000" + } + }, + 0x24d407e5a0b506e1cb2fae163100b5de01f5193c: { + 34: { + blockHash: "0x0000000000000000000000000000000000000000000000000000000000000000", + blockNumber: null, + from: "0x24d407e5a0b506e1cb2fae163100b5de01f5193c", + gas: "0x44c72", + gasPrice: "0x4a817c800", + hash: "0xb5b8b853af32226755a65ba0602f7ed0e8be2211516153b75e9ed640a7d359fe", + input: "0xb61d27f600000000000000000000000024d407e5a0b506e1cb2fae163100b5de01f5193c00000000000000000000000000000000000000000000000053444835ec580000000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + nonce: "0x22", + to: "0x7320785200f74861b69c49e4ab32399a71b34f1a", + transactionIndex: null, + value: "0x0" + } + } + }, + queued: { + 0x976a3fc5d6f7d259ebfb4cc2ae75115475e9867c: { + 3: { + blockHash: "0x0000000000000000000000000000000000000000000000000000000000000000", + blockNumber: null, + from: "0x976a3fc5d6f7d259ebfb4cc2ae75115475e9867c", + gas: "0x15f90", + gasPrice: "0x4a817c800", + hash: "0x57b30c59fc39a50e1cba90e3099286dfa5aaf60294a629240b5bbec6e2e66576", + input: "0x", + nonce: "0x3", + to: "0x346fb27de7e7370008f5da379f74dd49f5f2f80f", + transactionIndex: null, + value: "0x1f161421c8e0000" + } + }, + 0x9b11bf0459b0c4b2f87f8cebca4cfc26f294b63a: { + 2: { + blockHash: "0x0000000000000000000000000000000000000000000000000000000000000000", + blockNumber: null, + from: "0x9b11bf0459b0c4b2f87f8cebca4cfc26f294b63a", + gas: "0x15f90", + gasPrice: "0xba43b7400", + hash: "0x3a3c0698552eec2455ed3190eac3996feccc806970a4a056106deaf6ceb1e5e3", + input: "0x", + nonce: "0x2", + to: "0x24a461f25ee6a318bdef7f33de634a67bb67ac9d", + transactionIndex: null, + value: "0xebec21ee1da40000" + }, + 6: { + blockHash: "0x0000000000000000000000000000000000000000000000000000000000000000", + blockNumber: null, + from: "0x9b11bf0459b0c4b2f87f8cebca4cfc26f294b63a", + gas: "0x15f90", + gasPrice: "0x4a817c800", + hash: "0xbbcd1e45eae3b859203a04be7d6e1d7b03b222ec1d66dfcc8011dd39794b147e", + input: "0x", + nonce: "0x6", + to: "0x6368f3f8c2b42435d6c136757382e4a59436a681", + transactionIndex: null, + value: "0xf9a951af55470000" + } + } + } +} +``` + +### txpool_contentFrom + +Retrieves the transactions contained within the txpool, +returning pending as well as queued transactions of this address, grouped by nonce. + +| Client | Method invocation | +|:-------:|--------------------------------------------------------| +| Console | `txpool.contentFrom(address)` | +| RPC | `{"method": "txpool_contentFrom, "params": [string]"}` | + +### txpool_inspect + +The `inspect` inspection property can be queried to list a textual summary of all the transactions +currently pending for inclusion in the next block(s), as well as the ones that are being scheduled +for future execution only. This is a method specifically tailored to developers to quickly see the +transactions in the pool and find any potential issues. + +The result is an object with two fields `pending` and `queued`. Each of these fields are associative +arrays, in which each entry maps an origin-address to a batch of scheduled transactions. These batches +themselves are maps associating nonces with transactions summary strings. + +Please note, there may be multiple transactions associated with the same account and nonce. This can +happen if the user broadcast mutliple ones with varying gas allowances (or even completely different +transactions). + +| Client | Method invocation | +|:-------:|--------------------------------------------------------------| +| Go | `txpool.Inspect() (map[string]map[string]map[string]string)` | +| Console | `txpool.inspect` | +| RPC | `{"method": "txpool_inspect"}` | + +#### Example + +```javascript +> txpool.inspect +{ + pending: { + 0x26588a9301b0428d95e6fc3a5024fce8bec12d51: { + 31813: "0x3375ee30428b2a71c428afa5e89e427905f95f7e: 0 wei + 500000 × 20000000000 wei" + }, + 0x2a65aca4d5fc5b5c859090a6c34d164135398226: { + 563662: "0x958c1fa64b34db746925c6f8a3dd81128e40355e: 1051546810000000000 wei + 90000 gas × 20000000000 wei", + 563663: "0x77517b1491a0299a44d668473411676f94e97e34: 1051190740000000000 wei + 90000 gas × 20000000000 wei", + 563664: "0x3e2a7fe169c8f8eee251bb00d9fb6d304ce07d3a: 1050828950000000000 wei + 90000 gas × 20000000000 wei", + 563665: "0xaf6c4695da477f8c663ea2d8b768ad82cb6a8522: 1050544770000000000 wei + 90000 gas × 20000000000 wei", + 563666: "0x139b148094c50f4d20b01caf21b85edb711574db: 1048598530000000000 wei + 90000 gas × 20000000000 wei", + 563667: "0x48b3bd66770b0d1eecefce090dafee36257538ae: 1048367260000000000 wei + 90000 gas × 20000000000 wei", + 563668: "0x468569500925d53e06dd0993014ad166fd7dd381: 1048126690000000000 wei + 90000 gas × 20000000000 wei", + 563669: "0x3dcb4c90477a4b8ff7190b79b524773cbe3be661: 1047965690000000000 wei + 90000 gas × 20000000000 wei", + 563670: "0x6dfef5bc94b031407ffe71ae8076ca0fbf190963: 1047859050000000000 wei + 90000 gas × 20000000000 wei" + }, + 0x9174e688d7de157c5c0583df424eaab2676ac162: { + 3: "0xbb9bc244d798123fde783fcc1c72d3bb8c189413: 30000000000000000000 wei + 85000 gas × 21000000000 wei" + }, + 0xb18f9d01323e150096650ab989cfecd39d757aec: { + 777: "0xcd79c72690750f079ae6ab6ccd7e7aedc03c7720: 0 wei + 1000000 gas × 20000000000 wei" + }, + 0xb2916c870cf66967b6510b76c07e9d13a5d23514: { + 2: "0x576f25199d60982a8f31a8dff4da8acb982e6aba: 26000000000000000000 wei + 90000 gas × 20000000000 wei" + }, + 0xbc0ca4f217e052753614d6b019948824d0d8688b: { + 0: "0x2910543af39aba0cd09dbb2d50200b3e800a63d2: 1000000000000000000 wei + 50000 gas × 1171602790622 wei" + }, + 0xea674fdde714fd979de3edf0f56aa9716b898ec8: { + 70148: "0xe39c55ead9f997f7fa20ebe40fb4649943d7db66: 1000767667434026200 wei + 90000 gas × 20000000000 wei" + } + }, + queued: { + 0x0f6000de1578619320aba5e392706b131fb1de6f: { + 6: "0x8383534d0bcd0186d326c993031311c0ac0d9b2d: 9000000000000000000 wei + 21000 gas × 20000000000 wei" + }, + 0x5b30608c678e1ac464a8994c3b33e5cdf3497112: { + 6: "0x9773547e27f8303c87089dc42d9288aa2b9d8f06: 50000000000000000000 wei + 90000 gas × 50000000000 wei" + }, + 0x976a3fc5d6f7d259ebfb4cc2ae75115475e9867c: { + 3: "0x346fb27de7e7370008f5da379f74dd49f5f2f80f: 140000000000000000 wei + 90000 gas × 20000000000 wei" + }, + 0x9b11bf0459b0c4b2f87f8cebca4cfc26f294b63a: { + 2: "0x24a461f25ee6a318bdef7f33de634a67bb67ac9d: 17000000000000000000 wei + 90000 gas × 50000000000 wei", + 6: "0x6368f3f8c2b42435d6c136757382e4a59436a681: 17990000000000000000 wei + 90000 gas × 20000000000 wei", + 7: "0x6368f3f8c2b42435d6c136757382e4a59436a681: 17900000000000000000 wei + 90000 gas × 20000000000 wei" + } + } +} +``` + +### txpool_status + +The `status` inspection property can be queried for the number of transactions currently pending for +inclusion in the next block(s), as well as the ones that are being scheduled for future execution only. + +The result is an object with two fields `pending` and `queued`, each of which is a counter representing +the number of transactions in that particular state. + +| Client | Method invocation | +|:--------|-----------------------------------------------| +| Go | `txpool.Status() (map[string]*rpc.HexNumber)` | +| Console | `txpool.status` | +| RPC | `{"method": "txpool_status"}` | + +#### Example + +```javascript +> txpool.status +{ + pending: 10, + queued: 7 +} +``` diff --git a/content/docs/interacting_with_geth/RPC/objects.md b/content/docs/interacting_with_geth/RPC/objects.md new file mode 100644 index 0000000000..6331680e39 --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/objects.md @@ -0,0 +1,72 @@ +--- +title: Objects +sort_key: D +--- + +The following are data structures which are used for various RPC methods. + +### Transaction call object + +The *transaction call object* contains all the necessary parameters for executing an EVM contract method. + +| Field | Type | Bytes | Optional | Description | +|:-----------|:-----------|:------|:---------|:------------| +| `from` | `Address` | 20 | Yes | Address the transaction is simulated to have been sent from. Defaults to first account in the local keystore or the `0x00..0` address if no local accounts are available. | +| `to` | `Address` | 20 | No | Address the transaction is sent to. | +| `gas` | `Quantity` | <8 | Yes | Maximum gas allowance for the code execution to avoid infinite loops. Defaults to `2^63` or whatever value the node operator specified via `--rpc.gascap`. | +| `gasPrice` | `Quantity` | <32 | Yes | Number of `wei` to simulate paying for each unit of gas during execution. Defaults to `1 gwei`. | +| `maxFeePerGas` | `Quantity` | <32 | Yes | Maximum fee per gas the transaction should pay in total. Relevant for type-2 transactions. | +| `maxPriorityFeePerGas` | `Quantity` | <32 | Yes | Maximum tip per gas that's given directly to the miner. Relevant for type-2 transactions. | +| `value` | `Quantity` | <32 | Yes | Amount of `wei` to simulate sending along with the transaction. Defaults to `0`. | +| `nonce` | `Quantity` | <8 | Yes | Nonce of sender account. | +| `input` | `Binary` | any | Yes | Binary data to send to the target contract. Generally the 4 byte hash of the method signature followed by the ABI encoded parameters. For details please see the [Ethereum Contract ABI](https://github.com/ethereum/wiki/wiki/Ethereum-Contract-ABI). This field was previously called `data`. | +| `accessList` | `AccessList` | any | Yes | A list of addresses and storage keys that the transaction plans to access. Used in non-legacy, i.e. type 1 and 2 transactions. | +| `chainId` | `Quantity` | <32 | Yes | Transaction only valid on networks with this chain ID. Used in non-legacy, i.e. type 1 and 2 transactions. | + +Example for a legacy transaction: + +```json +{ + "from": "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3", + "to": "0xebe8efa441b9302a0d7eaecc277c09d20d684540", + "gas": "0x1bd7c", + "data": "0xd459fc46000000000000000000000000000000000000000000000000000000000046c650dbb5e8cb2bac4d2ed0b1e6475d37361157738801c494ca482f96527eb48f9eec488c2eba92d31baeccfb6968fad5c21a3df93181b43b4cf253b4d572b64172ef000000000000000000000000000000000000000000000000000000000000008c00000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000014000000000000000000000000000000000000000000000000000000000000001a00000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000001c000000000000000000000000000000000000000000000000000000000000001c0000000000000000000000000000000000000000000000000000000000000002b85c0c828d7a98633b4e1b65eac0c017502da909420aeade9a280675013df36bdc71cffdf420cef3d24ba4b3f9b980bfbb26bd5e2dcf7795b3519a3fd22ffbb2000000000000000000000000000000000000000000000000000000000000000238fb6606dc2b5e42d00c653372c153da8560de77bd9afaba94b4ab6e4aa11d565d858c761320dbf23a94018d843772349bd9d92301b0ca9ca983a22d86a70628", +} +``` + +Example for a type-1 transaction: + +```json +{ + "from": "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3", + "to": "0xebe8efa441b9302a0d7eaecc277c09d20d684540", + "gas": "0x1bd7c", + "data": "0xd459fc46000000000000000000000000000000000000000000000000000000000046c650dbb5e8cb2bac4d2ed0b1e6475d37361157738801c494ca482f96527eb48f9eec488c2eba92d31baeccfb6968fad5c21a3df93181b43b4cf253b4d572b64172ef000000000000000000000000000000000000000000000000000000000000008c00000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000014000000000000000000000000000000000000000000000000000000000000001a00000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000001c000000000000000000000000000000000000000000000000000000000000001c0000000000000000000000000000000000000000000000000000000000000002b85c0c828d7a98633b4e1b65eac0c017502da909420aeade9a280675013df36bdc71cffdf420cef3d24ba4b3f9b980bfbb26bd5e2dcf7795b3519a3fd22ffbb2000000000000000000000000000000000000000000000000000000000000000238fb6606dc2b5e42d00c653372c153da8560de77bd9afaba94b4ab6e4aa11d565d858c761320dbf23a94018d843772349bd9d92301b0ca9ca983a22d86a70628", + "chainId": "0x1", + "accessList": [ + { + "address": "0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48", + "storageKeys": ["0xda650992a54ccb05f924b3a73ba785211ba39a8912b6d270312f8e2c223fb9b1", "0x10d6a54a4754c8869d6886b5f5d7fbfa5b4 + 522237ea5c60d11bc4e7a1ff9390b"] + }, { + "address": "0xa2327a938febf5fec13bacfb16ae10ecbc4cbdcf", + "storageKeys": [] + }, + ] +} +``` + +Example for a type-2 transaction: + +```json +{ + "from": "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3", + "to": "0xebe8efa441b9302a0d7eaecc277c09d20d684540", + "gas": "0x1bd7c", + "maxFeePerGas": "0x6b44b0285", + "maxPriorityFeePerGas": "0x6b44b0285", + "data": "0xd459fc46000000000000000000000000000000000000000000000000000000000046c650dbb5e8cb2bac4d2ed0b1e6475d37361157738801c494ca482f96527eb48f9eec488c2eba92d31baeccfb6968fad5c21a3df93181b43b4cf253b4d572b64172ef000000000000000000000000000000000000000000000000000000000000008c00000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000014000000000000000000000000000000000000000000000000000000000000001a00000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000001c000000000000000000000000000000000000000000000000000000000000001c0000000000000000000000000000000000000000000000000000000000000002b85c0c828d7a98633b4e1b65eac0c017502da909420aeade9a280675013df36bdc71cffdf420cef3d24ba4b3f9b980bfbb26bd5e2dcf7795b3519a3fd22ffbb2000000000000000000000000000000000000000000000000000000000000000238fb6606dc2b5e42d00c653372c153da8560de77bd9afaba94b4ab6e4aa11d565d858c761320dbf23a94018d843772349bd9d92301b0ca9ca983a22d86a70628", + "chainId": "0x1", + "accessList": [] +} +``` diff --git a/content/docs/interacting_with_geth/RPC/pubsub.md b/content/docs/interacting_with_geth/RPC/pubsub.md new file mode 100644 index 0000000000..be62f0ac94 --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/pubsub.md @@ -0,0 +1,168 @@ +--- +title: Real-time Events +sort_key: B +--- + +Geth v1.4 and later support publish / subscribe using JSON-RPC notifications. This allows +clients to wait for events instead of polling for them. + +It works by subscribing to particular events. The node will return a subscription id. For +each event that matches the subscription a notification with relevant data is send +together with the subscription id. + +Example: + + // create subscription + >> {"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} + << {"jsonrpc":"2.0","id":1,"result":"0xcd0c3e8af590364c09d0fa6a1210faf5"} + + // incoming notifications + << {"jsonrpc":"2.0","method":"eth_subscription","params":{"subscription":"0xcd0c3e8af590364c09d0fa6a1210faf5","result":{"difficulty":"0xd9263f42a87",<...>, "uncles":[]}}} + << {"jsonrpc":"2.0","method":"eth_subscription","params":{"subscription":"0xcd0c3e8af590364c09d0fa6a1210faf5","result":{"difficulty":"0xd90b1a7ad02", <...>, "uncles":["0x80aacd1ea4c9da32efd8c2cc9ab38f8f70578fcd46a1a4ed73f82f3e0957f936"]}}} + + // cancel subscription + >> {"id": 1, "method": "eth_unsubscribe", "params": ["0xcd0c3e8af590364c09d0fa6a1210faf5"]} + << {"jsonrpc":"2.0","id":1,"result":true} + +### Considerations + +1. notifications are sent for current events and not for past events. If your use case + requires you not to miss any notifications then subscriptions are probably not the best + option. +2. subscriptions require a full duplex connection. Geth offers such connections in the + form of WebSocket and IPC (enabled by default). +3. subscriptions are coupled to a connection. If the connection is closed all + subscriptions that are created over this connection are removed. +4. notifications are stored in an internal buffer and sent from this buffer to the client. + If the client is unable to keep up and the number of buffered notifications reaches a + limit (currently 10k) the connection is closed. Keep in mind that subscribing to some + events can cause a flood of notifications, e.g. listening for all logs/blocks when the + node starts to synchronize. + +## Create subscription + +Subscriptions are created with a regular RPC call with `eth_subscribe` as method and the +subscription name as first parameter. If successful it returns the subscription id. + +### Parameters + +1. subscription name +2. optional arguments + +### Example + + >> {"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} + << {"id": 1, "jsonrpc": "2.0", "result": "0x9cef478923ff08bf67fde6c64013158d"} + +## Cancel subscription + +Subscriptions are cancelled with a regular RPC call with `eth_unsubscribe` as method and +the subscription id as first parameter. It returns a bool indicating if the subscription +was cancelled successful. + +### Parameters +1. subscription id + +### Example + + >> {"id": 1, "method": "eth_unsubscribe", "params": ["0x9cef478923ff08bf67fde6c64013158d"]} + << {"jsonrpc":"2.0","id":1,"result":true} + +## Supported Subscriptions + +### newHeads + +Fires a notification each time a new header is appended to the chain, including chain reorganizations. Users can use the bloom filter to determine if the block contains logs that are interested to them. Note that if geth receives multiple blocks simultaneously, e.g. catching up after being out of sync, only the last block is emitted. + +In case of a chain reorganization the subscription will emit the last header in the new +chain. Therefore the subscription can emit multiple headers on the same height. + +#### Example + + >> {"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} + << {"jsonrpc":"2.0","id":2,"result":"0x9ce59a13059e417087c02d3236a0b1cc"} + + << { + "jsonrpc": "2.0", + "method": "eth_subscription", + "params": { + "result": { + "difficulty": "0x15d9223a23aa", + "extraData": "0xd983010305844765746887676f312e342e328777696e646f7773", + "gasLimit": "0x47e7c4", + "gasUsed": "0x38658", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "miner": "0xf8b483dba2c3b7176a3da549ad41a48bb3121069", + "nonce": "0x084149998194cc5f", + "number": "0x1348c9", + "parentHash": "0x7736fab79e05dc611604d22470dadad26f56fe494421b5b333de816ce1f25701", + "receiptRoot": "0x2fab35823ad00c7bb388595cb46652fe7886e00660a01e867824d3dceb1c8d36", + "sha3Uncles": "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347", + "stateRoot": "0xb3346685172db67de536d8765c43c31009d0eb3bd9c501c9be3229203f15f378", + "timestamp": "0x56ffeff8", + "transactionsRoot": "0x0167ffa60e3ebc0b080cdb95f7c0087dd6c0e61413140e39d94d3468d7c9689f" + }, + "subscription": "0x9ce59a13059e417087c02d3236a0b1cc" + } + } + +### logs + +Returns logs that are included in new imported blocks and match the given filter criteria. + +In case of a chain reorganization previous sent logs that are on the old chain will be resend with the `removed` property set to true. Logs from transactions that ended up in the new chain are emitted. Therefore a subscription can emit logs for the same transaction multiple times. + +#### Parameters + +1. `object` with the following (optional) fields + - **address**, either an address or an array of addresses. Only logs that are created from these addresses are returned (optional) + - **topics**, only logs which match the specified topics (optional) + + +#### Example + + >> {"id": 1, "method": "eth_subscribe", "params": ["logs", {"address": "0x8320fe7702b96808f7bbc0d4a888ed1468216cfd", "topics": ["0xd78a0cb8bb633d06981248b816e7bd33c2a35a6089241d099fa519e361cab902"]}]} + << {"jsonrpc":"2.0","id":2,"result":"0x4a8a4c0517381924f9838102c5a4dcb7"} + + << {"jsonrpc":"2.0","method":"eth_subscription","params": {"subscription":"0x4a8a4c0517381924f9838102c5a4dcb7","result":{"address":"0x8320fe7702b96808f7bbc0d4a888ed1468216cfd","blockHash":"0x61cdb2a09ab99abf791d474f20c2ea89bf8de2923a2d42bb49944c8c993cbf04","blockNumber":"0x29e87","data":"0x00000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000003","logIndex":"0x0","topics":["0xd78a0cb8bb633d06981248b816e7bd33c2a35a6089241d099fa519e361cab902"],"transactionHash":"0xe044554a0a55067caafd07f8020ab9f2af60bdfe337e395ecd84b4877a3d1ab4","transactionIndex":"0x0"}}} + +### newPendingTransactions + +Returns the hash for all transactions that are added to the pending state and are signed with a key that is available in the node. + +When a transaction that was previously part of the canonical chain isn't part of the new canonical chain after a reorganization its again emitted. + +#### Parameters + +none + +#### Example + + >> {"id": 1, "method": "eth_subscribe", "params": ["newPendingTransactions"]} + << {"jsonrpc":"2.0","id":2,"result":"0xc3b33aa549fb9a60e95d21862596617c"} + << { + "jsonrpc":"2.0", + "method":"eth_subscription", + "params":{ + "subscription":"0xc3b33aa549fb9a60e95d21862596617c", + "result":"0xd6fdc5cc41a9959e922f30cb772a9aef46f4daea279307bc5f7024edc4ccd7fa" + } + } + +### syncing + +Indicates when the node starts or stops synchronizing. The result can either be a boolean +indicating that the synchronization has started (true), finished (false) or an object with +various progress indicators. + +#### Parameters + +none + +#### Example + + >> {"id": 1, "method": "eth_subscribe", "params": ["syncing"]} + << {"jsonrpc":"2.0","id":2,"result":"0xe2ffeb2703bcf602d42922385829ce96"} + + << {"subscription":"0xe2ffeb2703bcf602d42922385829ce96","result":{"syncing":true,"status":{"startingBlock":674427,"currentBlock":67400,"highestBlock":674432,"pulledStates":0,"knownStates":0}}}} + diff --git a/content/docs/interacting_with_geth/RPC/server.md b/content/docs/interacting_with_geth/RPC/server.md new file mode 100644 index 0000000000..5021a7b8d7 --- /dev/null +++ b/content/docs/interacting_with_geth/RPC/server.md @@ -0,0 +1,182 @@ +--- +title: JSON-RPC Server +sort_key: A +--- + +Interacting with Geth requires sending requests to specific JSON-RPC API +methods. Geth supports all standard [JSON-RPC API][web3-rpc] endpoints. +The RPC requests must be sent to the node and the response returned to the client +using some transport protocol. This page outlines the available transport protocols +in Geth, providing the information users require to choose a transport protocol for +a specific user scenario. + +{:toc} +- this will be removed by the toc + +## Introduction + +JSON-RPC is provided on multiple transports. Geth supports JSON-RPC over HTTP, +WebSocket and Unix Domain Sockets. Transports must be enabled through +command-line flags. + +Ethereum JSON-RPC APIs use a name-space system. RPC methods are grouped into +several categories depending on their purpose. All method names are composed of +the namespace, an underscore, and the actual method name within the namespace. +For example, the `eth_call` method resides in the `eth` namespace. + +Access to RPC methods can be enabled on a per-namespace basis. Find +documentation for individual namespaces in the sidebar. + +## Transports + +There are three transport protocols available in Geth: IPC, HTTP and Websockets. + +### HTTP Server + +[HTTP](https://developer.mozilla.org/en-US/docs/Web/HTTP) is a unidirectional transport protocol +that connects a client and server. The client sends a request to the server, and the server +returns a response back to the client. An HTTP connection is closed after the response for a given +request is sent. + +HTTP is supported in every browser as well as almost all programming toolchains. Due to its ubiquity +it has become the most widely used transport for interacting with Geth. To start a HTTP server in Geth, include the `--http` flag: + +```sh +geth --http +``` + +If no other commands are provided, Geth falls back to its default behaviour of accepting connections +from the local loopback interface (127.0.0.1). The default listening port is 8545. The ip address and +listening port can be customized using the `--http.addr` and `--http.port` flags: + +```sh +geth --http --http.port 3334 +``` + +Not all of the JSON-RPC method namespaces are enabled for HTTP requests by default. +Instead, they have to be whitelisted explicitly when Geth is started. Calling non-whitelisted +RPC namespaces returns an RPC error with code `-32602`. + +The default whitelist allows access to the `eth`, `net` and `web3` namespaces. To enable access +to other APIs like account management (`personal`) and debugging (`debug`), they must be configured +using the `--http.api` flag. Enabling these APIs over HTTP is **not recommended** because access +to these methods increases the attack surface. + +```sh +geth --http --http.api personal,eth,net,web3 +``` + +Since the HTTP server is reachable from any local application, additional protection is built into +the server to prevent misuse of the API from web pages. To enable access to the API from a web page +(for example to use the online IDE, [Remix](https://remix.ethereum.org)), the server needs to be +configured to accept Cross-Origin requests. This is achieved using the `--http.corsdomain` flag. + +```sh +geth --http --http.corsdomain https://remix.ethereum.org +``` + +The `--http.corsdomain` command also acceptsd wildcards that enable access to the RPC from any +origin: + +```sh +--http.corsdomain '*' +``` + +### WebSocket Server + +Websocket is a bidirectional transport protocol. A Websocket connection is maintained by client and server +until it is explicitly terminated by one. Most modern browsers support Websocket which means +it has good tooling. + +Because Websocket is bidirectional, servers can push events to clients. That makes Websocket a good +choice for use-cases involving [event subscription](https://geth.ethereum.org/docs/rpc/pubsub). Another +benefit of Websocket is that after the handshake procedure, the overhead of individual messages is low, +making it good for sending high number of requests. + +Configuration of the WebSocket endpoint in Geth follows the same pattern as the HTTP transport. +WebSocket access can be enabled using the `--ws` flag. If no additional information is provided, +Geth falls back to its default behaviour which is to establish the Websocket on port 8546. +The `--ws.addr`, `--ws.port` and `--ws.api` flags can be used to customize settings +for the WebSocket server. For example, to start Geth with a Websocket connection for RPC using +the custom port 3334 and whitelisting the `eth`, `net` and `web3` namespaces: + +```sh +geth --ws --ws.port 3334 --ws.api eth,net,web3 +``` + +Cross-Origin request protection also applies to the WebSocket server. The +`--ws.origins` flag can be used to allow access to the server from web pages: + +```sh +geth --ws --ws.origins http://myapp.example.com +``` + +As with `--http.corsdomain`, using the wildcard `--ws.origins '*'` allows access from any origin. + +{% include note.html content=" By default, **account unlocking is forbidden when HTTP or +Websocket access is enabled** (i.e. by passing `--http` or `ws` flag). This is because an +attacker that manages to access the node via the externally-exposed HTTP/WS port can then +control the unlocked account. It is possible to force account unlock by including the +`--allow-insecure-unlock` flag but this is unsafe and **not recommended** except for expert +users that completely understand how it can be used safely. +This is not a hypothetical risk: **there are bots that continually scan for http-enabled +Ethereum nodes to attack**" %} + + +### IPC Server + +IPC is normally available for use in local environments where the node and the console +exist on the same machine. Geth creates a pipe in the computers local file system +(at `ipcpath`) that configures a connection between node and console. The `geth.ipc` file can +also be used by other processes on the same machine to interact with Geth. + +On UNIX-based systems (Linux, OSX) the IPC is a UNIX domain socket. On Windows IPC is +provided using named pipes. The IPC server is enabled by default and has access to all +JSON-RPC namespaces. + +The listening socket is placed into the data directory by default. On Linux and macOS, +the default location of the geth socket is + +```sh +~/.ethereum/geth.ipc +``` + +On Windows, IPC is provided via named pipes. The default location of the geth pipe is: + +```sh +\\.\pipe\geth.ipc +``` + +The location of the socket can be customized using the `--ipcpath` flag. IPC can be disabled +using the `--ipcdisable` flag. + +## Choosing a transport protocol + +The following table summarizes the relative strengths and weaknesses of each transport +protocol so that users can make informed decisions about which to use. + +| | HTTP | WS | IPC | +| :----------------------------------:|:-----------:|:--------:|:-------:| +| Event subscription | N | **Y** | **Y** | +| Remote connection | **Y** | **Y** | N | +| Per-message metadata overhead | high | low | low | + +As a general rule IPC is most secure because it is limited to interactions on the +local machine and cannot be exposed to external traffic. It can also be used +to subscribe to events. HTTP is a familiar and idempotent transport that closes +connections between requests and can therefore have lower overall overheads if the number +of requests is fairly low. Websockets provides a continuous open channel that can enable +event subscriptions and streaming and handle large volumes of requests with smaller per-message +overheads. + + +## Summary + +RPC requests to a Geth node can be made using three different transport protocols. The +protocols are enabled at startup using their respective flags. The right choice of transport +protocol depends on the specific use case. + + +[web3-rpc]: https://github.com/ethereum/execution-apis +[remix]: https://remix.ethereum.org +[rpc]: https://www.ibm.com/docs/en/aix/7.1?topic=concepts-remote-procedure-call diff --git a/content/docs/monitoring/dashboards.md b/content/docs/monitoring/dashboards.md new file mode 100644 index 0000000000..cef0a02270 --- /dev/null +++ b/content/docs/monitoring/dashboards.md @@ -0,0 +1,173 @@ +--- +title: Monitoring Geth with InfluxDB and Grafana +--- + +There are several ways to monitor the performance of a Geth node. Insights into a node's +performance are useful for debugging, tuning and understanding what is really happening when +Geth is running. + +## Prerequisites {#prerequisites} + +To follow along with the instructions on this page it will be useful to have: + +- a running Geth instance. +- basic working knowlegde of bash/terminal. + +[This video](https://www.youtube.com/watch?v=cOBab8IJMYI) provides an excellent introduction +to Geth monitoring. + +## Monitoring stack {#monitoring-stack} + +An Ethereum client collects lots of data which can be read in the form of a chronological +database. To make monitoring easier, this data can be fed into data visualisation software. +There are many options available: + +- [Prometheus](https://prometheus.io/) (pull model) +- [InfluxDB](https://www.influxdata.com/get-influxdb/) (push model) +- [Telegraf](https://www.influxdata.com/get-influxdb/) +- [Grafana](https://www.grafana.com/) +- [Datadog](https://www.datadoghq.com/) +- [Chronograf](https://www.influxdata.com/time-series-platform/chronograf/) + +There's also [Geth Prometheus Exporter](https://github.com/hunterlong/gethexporter), an option +preconfigured with InfluxDB and Grafana. You can set it up easily using docker and +[Ethbian OS](https://ethbian.org/index.html) for RPi 4. + +On this page, a Geth client will be configured to push data into a InfluxDB database and +Grafana will be used to visualize the data. + +## Setting up InfluxDB {#setting-up-influxdb} + +InfluxDB can be downloaded from the [Influxdata release page](https://portal.influxdata.com/downloads/). +It can also be installed from a [repository](https://repos.influxdata.com/). +For example for a Debian based Linux operating system: + +```sh +curl -tlsv1.3 --proto =https -sL https://repos.influxdata.com/influxdb.key | sudo apt-key add +source /etc/lsb-release +echo "deb https://repos.influxdata.com/${DISTRIB_ID,,} ${DISTRIB_CODENAME} stable" | sudo tee /etc/apt/sources.list.d/influxdb.list +sudo apt update +sudo apt install influxdb -y +sudo systemctl enable influxdb +sudo systemctl start influxdb +sudo apt install influxdb-client +``` + +By default,InfluxDB it is reachable at `localhost:8086`. Before using the `influx` client, a new user with admin privileges +needs to be created. This user will serve for high level management, creating databases and users. + +```sh +curl -XPOST "http://localhost:8086/query" --data-urlencode "q=CREATE USER username WITH PASSWORD 'password' WITH ALL PRIVILEGES" +``` + +Now the influx client can be used to enter [InfluxDB shell](https://docs.influxdata.com/influxdb/v1.8/tools/shell/) with the new user. + +```sh +influx -username 'username' -password 'password' +``` + +A database and user for geth metrics can be created by communicatign with it directly via its shell. + +```sh +create database geth +create user geth with password choosepassword +``` + +Verify created entries with: + +``` +show databases +show users +``` + +Leave InfluxDB shell. + +```sh +exit +``` + +InfluxDB is running and configured to store metrics from Geth. + +## Preparing Geth {#preparing-geth} + +After setting up database, metrics need to be enabled in Geth. Various options are available, +as documented in the `METRICS AND STATS OPTIONS` in `geth --help` and in our [metrics page](). +In this case Geth will be configured to push data into InfluxDB. Basic setup specifies the endpoint +where InfluxDB is reachable and authenticates the database. + +```sh +geth --metrics --metrics.influxdb --metrics.influxdb.endpoint "http://0.0.0.0:8086" --metrics.influxdb.username "geth" --metrics.influxdb.password "chosenpassword" +``` + +These flags can be provided when Geth is started or saved to the configuration file. + +Listing the metrics in the database verifies that Geth is pushing data correctly. In InfluxDB shell: + +```sh +use geth +show measurements +``` + +## Setting up Grafana {#setting-up-grafana} + +With the InfluxDB database setup and successfully receiving data from Geth, the next step is to +install Grafana so that the data can be visualized. Instructions for specific operating systems +are available on the Grafana [downloads page](https://grafana.com/grafana/download?pg=get&plcmt=selfmanaged-box1-cta1). + +Alternatively, the following code snippet shows how to download, install and run Grafana on a Debian +based Linux system: + +```sh +curl -tlsv1.3 --proto =https -sL https://packages.grafana.com/gpg.key | sudo apt-key add - +echo "deb https://packages.grafana.com/oss/deb stable main" | sudo tee -a /etc/apt/sources.list.d/grafana.list +sudo apt update +sudo apt install grafana +sudo systemctl enable grafana-server +sudo systemctl start grafana-server +``` + +When Grafana is up and running, it should be reachable at `localhost:3000`. A browser can be pointed to that URL +to access a visualization dashboard. The browser will prompt for login credentials (user: `admin` and password: `admin`). +When prompted, the default password should be changed and saved. + +![](./grafana1.png) + +The browser first redirects to the Grafana home page to set up the source data. +Click on the configuration icon in the left bar and select "Data sources". + +![](./grafana2.png) + +There aren't any data sources yet, click on "Add data source" to define one. + +![](./grafana3.png) + +Select "InfluxDB" and proceed. + +![](./grafana4.png) + +Data source configuration is pretty straight forward if you are running tools on the same machine. You need to set the +InfluxDB address and details for accessing the database. Refer to the picture below. + +![](./grafana5.png) + +If everything is complete and InfluxDB is reachable, click on "Save and test" and wait for the confirmation to pop up. + +![](./grafana6.png) + +Grafana is now set up to read data from InfluxDB. Now you need to create a dashboard which will interpret and display it. +Dashboards properties are encoded in JSON files which can be created by anybody and easily imported. On the left bar, +click on "Create and Import". + +![](./grafana7.png) + +For a Geth monitoring dashboard, copy the ID of [this dashboard](https://grafana.com/grafana/dashboards/13877/) +and paste it in the "Import page" in Grafana. After saving the dashboard, it should look like this: + +![](./grafana8.png) + +The dashboards can be customized further. Each panel can be edited, moved, removed or added. +To learn more about how dashboards work, refer to [Grafana's documentation](https://grafana.com/docs/grafana/latest/dashboards/). + +Some users might also be interested in automatic [alerting](https://grafana.com/docs/grafana/latest/alerting/), which +sets up alert notifications that are sent automatically when metrics reach certain values. Various communication channels are supported. + diff --git a/content/docs/monitoring/ethstats-mainnet.png b/content/docs/monitoring/ethstats-mainnet.png new file mode 100644 index 0000000000000000000000000000000000000000..080dd335fc7ef9d832ba73d4aa749183700dde5f GIT binary patch literal 299699 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

ZOJjdOkjoIFEI26rda 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 literal 0 HcmV?d00001 diff --git a/content/docs/monitoring/grafana2.png b/content/docs/monitoring/grafana2.png new file mode 100644 index 0000000000000000000000000000000000000000..ca01d2ad4aee20e066734fac55e2b6d3d8b5eaa6 GIT binary patch literal 338418 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͙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 Ay#N3J literal 0 HcmV?d00001 diff --git a/content/docs/monitoring/grafana3.png b/content/docs/monitoring/grafana3.png new file mode 100644 index 0000000000000000000000000000000000000000..e66c61b2cb899426b67d4f9acbe4d63833131d77 GIT binary patch literal 43904 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 literal 0 HcmV?d00001 diff --git a/content/docs/monitoring/grafana4.png b/content/docs/monitoring/grafana4.png new file mode 100644 index 0000000000000000000000000000000000000000..9136e0e4283b93f96a57180ca2f48996b15d9b17 GIT binary patch literal 157130 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¥&(OBM0u>B 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 KeE9?OkpBxVW<@gq literal 0 HcmV?d00001 diff --git a/content/docs/monitoring/grafana7.png b/content/docs/monitoring/grafana7.png new file mode 100644 index 0000000000000000000000000000000000000000..ff15dba8723de430b06b07fb38577d3494ef6b58 GIT binary patch literal 97692 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 z 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 literal 0 HcmV?d00001 diff --git a/content/docs/monitoring/grafana8.png b/content/docs/monitoring/grafana8.png new file mode 100644 index 0000000000000000000000000000000000000000..f4ede6a96527355cdf06973027aed60c80f32c6a GIT binary patch literal 316703 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

L&vf#;mYN0Br^?cFEZK4{(VyP;Ws4Z$~ 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

JJ)Hw{se}D2D?6> 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

YRX1qK{vvo+(v#RphjN-IHR|VjjOvE3v=Y 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

` to store a password for a given address. `clef` asks for the password, and it also asks for the clef master-password, in order to update and store the new secrets inside clef vault. + +``` +$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn setpw 0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 + +Please enter a password to store for this address: +Password: +Repeat password: + +Decrypt master seed of clef +Password: +INFO [06-16|11:27:09.153] Credential store updated set=0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 + +``` + +At this point, if we were to use clef as a sealer, we would be forced to manually click Approve for each block, but we would not be required to provide the password. + +#### Testing stored password + +Let's test using the stored password when sealing Clique-blocks. Start `clef` with +``` +$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn +``` +And start `geth` with +``` +$ geth --datadir ./ddir --signer ./clef/clef.ipc --mine +``` + +Geth will ask what accounts are present, to which we need to manually enter `y` to approve: + +``` +-------- List Account request-------------- +A request has been made to list all accounts. +You can select which accounts the caller can see + [x] 0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 + URL: keystore:///home/user/tmp/clique_clef/ddir/keystore/UTC--2022-06-16T09-10-48.578523828Z--9cd932f670f7ede5de86f756a6d02548e5899f47 +------------------------------------------- +Request context: + NA -> ipc -> NA + +Additional HTTP header data, provided by the external caller: + User-Agent: "" + Origin: "" +Approve? [y/N]: +> y +DEBUG[06-16|11:36:42.499] Served account_list reqid=2 duration=3.213768195s +``` + +After this, `geth` will start asking `clef` to sign things: + +``` +-------- Sign data request-------------- +Account: 0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 [chksum ok] +messages: +  Clique header [clique]: "clique header 1 [0x9b08fa3705e8b6e1b327d84f7936c21a3cb11810d9344dc4473f78f8da71e571]" +raw data: + "\xf9\x02\x14\xa0\x18t\x12:\x91f\xa2\x90U\b\xf9\xac\xc02i\xffs\x9f\xf4\xc9⮷!\x0f\x16\xaa?#M똠\x1d\xccM\xe8\xde\xc7]z\xab\x85\xb5g\xb6\xcc\xd4\x1a\xd3\x12E\x1b\x94\x8at\x13\xf0\xa1B\xfd@ԓG\x94\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xa0]1%\n\xfc\xee'\xd0e\xce\xc7t\xcc\\?\t4v\x8f\x06\xcb\xf8\xa0P5\xfeN\xea\x0ff\xfe\x9c\xa0V\xe8\x1f\x17\x1b\xccU\xa6\xff\x83E\xe6\x92\xc0\xf8n[H\xe0\x1b\x99l\xad\xc0\x01b/\xb5\xe3c\xb4!\xa0V\xe8\x1f\x17\x1b\xccU\xa6\xff\x83E\xe6\x92\xc0\xf8n[H\xe0\x1b\x99l\xad\xc0\x01b/\xb5\xe3c\xb4!\xb9\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x01\x83z0\x83\x80\x84b\xaa\xf9\xaa\xa0\u0603\x01\n\x14\x84geth\x88go1.18.1\x85linux\x00\x00\x00\x00\x00\x00\x00\xa0\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x88\x00\x00\x00\x00\x00\x00\x00\x00" +data hash: 0x9589ed81e959db6330b3d70e5f8e426fb683d03512f203009f7e41fc70662d03 +------------------------------------------- +Request context: + NA -> ipc -> NA + +Additional HTTP header data, provided by the external caller: + User-Agent: "" + Origin: "" +Approve? [y/N]: +> y +``` +And indeed, after approving with `y`, we are not required to provide the password -- the signed block is returned to geth: +``` +INFO [06-16|11:36:46.714] Successfully sealed new block number=1 sealhash=9589ed..662d03 hash=bd20b9..af8b87 elapsed=4.214s +``` +This mode of operation is somewhat unusable, since we'd need to keep "Approving" each block to be sealed. So let's fix that too. + +### Using rules to approve blocks + +The basic idea with clef rules, is to let a piece of javascript take over the Approve/Deny decision. The javascript snippet has access to the same information as the manual operator. + +Let's try with a simplistic first approach, which approves listing, and spits out the request data for `ApproveListing` + +```js +function ApproveListing(){ + return "Approve" +} + +function ApproveSignData(r){ + console.log("In Approve Sign data") + console.log(JSON.stringify(r)) +} +``` +In order to use a certain rule-file, we must first `attest` it. This is to prevent someone from modifying a ruleset-file on disk after creation. +``` +$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn attest `sha256sum rules.js | cut -f1` +Decrypt master seed of clef +Password: +INFO [06-16|13:49:00.298] Ruleset attestation updated sha256=54aae496c3f0eda063a62c73ee284ca9fae3f43b401da847ef30ea30e85e35d1 +``` +And then we can start clef, pointing out the `rules.js` file. OBS: if you later modify this file, you need to redo the `attest`-step. +``` +$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn --rules ./rules.js +``` + +Once `geth` starts asking it to seal blocks, we will now see the data. And from that, we can decide on how to make a rule which allows signing clique headers but nothing else. + +The actual data that gets passed to the js environment (and which our ruleset spit out to the console) looks like this: +```json +{ + "content_type": "application/x-clique-header", + "address": "0x9CD932F670F7eDe5dE86F756A6D02548e5899f47", + "raw_data": "+QIUoL0guY+66jZpzZh1wDX4Si/ycX4zD8FQqF/1Apy/r4uHoB3MTejex116q4W1Z7bM1BrTEkUblIp0E/ChQv1A1JNHlAAAAAAAAAAAAAAAAAAAAAAAAAAAoF0xJQr87ifQZc7HdMxcPwk0do8Gy/igUDX+TuoPZv6coFboHxcbzFWm/4NF5pLA+G5bSOAbmWytwAFiL7XjY7QhoFboHxcbzFWm/4NF5pLA+G5bSOAbmWytwAFiL7XjY7QhuQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAICg3pPDoCEYqsY1qDYgwEKFIRnZXRoiGdvMS4xOC4xhWxpbnV4AAAAAAAAAKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIgAAAAAAAAAAA==", + "messages": [ + { + "name": "Clique header", + "value": "clique header 2 [0xae525b65bc7f711bc136f502650039cd6959c3abc28fdf0ebfe2a5f85c92f3b6]", + "type": "clique" + } + ], + "call_info": null, + "hash": "0x8ca6c78af7d5ae67ceb4a1e465a8b639b9fbdec4b78e4d19cd9b1232046fbbf4", + "meta": { + "remote": "NA", + "local": "NA", + "scheme": "ipc", + "User-Agent": "", + "Origin": "" + } +} +``` + +If we wanted our js to be extremely trustless/paranoid, we could (inside the javascript) take the `raw_data` and verify that it's the rlp structure for a clique header: + +``` + echo "+QIUoL0guY+66jZpzZh1wDX4Si/ycX4zD8FQqF/1Apy/r4uHoB3MTejex116q4W1Z7bM1BrTEkUblIp0E/ChQv1A1JNHlAAAAAAAAAAAAAAAAAAAAAAAAAAAoF0xJQr87ifQZc7HdMxcPwk0do8Gy/igUDX+TuoPZv6coFboHxcbzFWm/4NF5pLA+G5bSOAbmWytwAFiL7XjY7QhoFboHxcbzFWm/4NF5pLA+G5bSOAbmWytwAFiL7XjY7QhuQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAICg3pPDoCEYqsY1qDYgwEKFIRnZXRoiGdvMS4xOC4xhWxpbnV4AAAAAAAAAKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIgAAAAAAAAAAA==" | base64 -d | rlpdump +[ + bd20b98fbaea3669cd9875c035f84a2ff2717e330fc150a85ff5029cbfaf8b87, + 1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347, + 0000000000000000000000000000000000000000, + 5d31250afcee27d065cec774cc5c3f0934768f06cbf8a05035fe4eea0f66fe9c, + 56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421, + 56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421, + 00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000, + 02, + 02, + 7a4f0e, + "", + 62ab18d6, + d883010a14846765746888676f312e31382e31856c696e757800000000000000, + 0000000000000000000000000000000000000000000000000000000000000000, + 0000000000000000, +] +``` +However, we can also use the `messages`. They do not come from the external caller, but are generated from the `clef` internals: `clef` parsed the incoming request and verified the Clique wellformedness of the content. So we let's just check for such a message: + +```js +function OnSignerStartup(info){} + +function ApproveListing(){ + return "Approve" +} + +function ApproveSignData(r){ + if (r.content_type == "application/x-clique-header"){ + for(var i = 0; i < r.messages.length; i++){ + var msg = r.messages[i] + if (msg.name=="Clique header" && msg.type == "clique"){ + return "Approve" + } + } + } + return "Reject" +} +``` +Attest +``` +$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn attest `sha256sum rules.js | cut -f1` +Decrypt master seed of clef +Password: +INFO [06-16|14:18:53.476] Ruleset attestation updated sha256=7d5036d22d1cc66599e7050fb1877f4e48b89453678c38eea06e3525996c2379 +``` +Run clef +``` +$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn --rules ./rules.js + +``` +Run geth +``` +$ geth --datadir ./ddir --signer ./clef/clef.ipc --mine +``` +And you should now see `clef` happily signing blocks: +``` +DEBUG[06-16|14:20:02.136] Served account_version reqid=1 duration="131.38µs" +INFO [06-16|14:20:02.289] Op approved +DEBUG[06-16|14:20:02.289] Served account_list reqid=2 duration=4.672441ms +INFO [06-16|14:20:02.303] Op approved +DEBUG[06-16|14:20:03.450] Served account_signData reqid=3 duration=1.152074109s +INFO [06-16|14:20:03.456] Op approved +DEBUG[06-16|14:20:04.267] Served account_signData reqid=4 duration=815.874746ms +INFO [06-16|14:20:32.823] Op approved +DEBUG[06-16|14:20:33.584] Served account_signData reqid=5 duration=766.840681ms + +``` +### Further refinements + + +If an attacker find the clef "external" interface (which would only happen if you start it with `http` enabled) , he +- cannot make it sign arbitrary transactions, +- cannot sign arbitrary data message, + +However, he could still make it sign e.g. 1000 versions of a certain block height, making the chain very unstable. + +It is possible for rule execution to be stateful -- storing data. In this case, one could for example store what block heights have been sealed, and thus reject sealing a particular block height twice. In other words, we can use these rules to build our own version of an Execution-Layer slashing-db. + +We simply split the `clique header 2 [0xae525b65bc7f711bc136f502650039cd6959c3abc28fdf0ebfe2a5f85c92f3b6]` line, and store/check the number, using `storage.get` and `storage.put`: + +```js +function OnSignerStartup(info){} + +function ApproveListing(){ + return "Approve" +} + +function ApproveSignData(r){ + + if (r.content_type != "application/x-clique-header"){ + return "Reject" + } + for(var i = 0; i < r.messages.length; i++){ + var msg = r.messages[i] + if (msg.name=="Clique header" && msg.type == "clique"){ + var number = parseInt(msg.value.split(" ")[2]) + var latest = storage.get("lastblock") || 0 + console.log("number", number, "latest", latest) + if ( number > latest ){ + storage.put("lastblock", number) + return "Approve" + } + } + } + return "Reject" +} +``` +Running with this ruleset: +``` +JS:> number 45 latest 44 +INFO [06-16|22:26:43.023] Op approved +DEBUG[06-16|22:26:44.305] Served account_signData reqid=3 duration=1.287465394s +JS:> number 46 latest 45 +INFO [06-16|22:26:44.313] Op approved +DEBUG[06-16|22:26:45.317] Served account_signData reqid=4 duration=1.010612774s +``` +This might be a bit over-the-top, security-wise, and may cause problems, if for some reason a clique-deadlock needs to be resolved by rolling back and continuing on a side-chain. It is mainly meant as a demonstration that rules can use javascript and statefulness to construct very intricate signing logic. + + +### TLDR quick-version + +Creation and attestation is a one-off event: +```bash +## Create the rules-file +cat << END > rules.js +function OnSignerStartup(info){} + +function ApproveListing(){ + return "Approve" +} + +function ApproveSignData(r){ + if (r.content_type == "application/x-clique-header"){ + for(var i = 0; i < r.messages.length; i++){ + var msg = r.messages[i] + if (msg.name=="Clique header" && msg.type == "clique"){ + return "Approve" + } + } + } + return "Reject" +} +END +## Attest it, assumes clef master password is in `./clefpw` +clef --keystore ./ddir/keystore \ + --configdir ./clef --chainid 15 \ + --suppress-bootwarn --signersecret ./clefpw \ + attest `sha256sum rules.js | cut -f1` +``` +The normal startup command for `clef`: +```bash +clef --keystore ./ddir/keystore \ + --configdir ./clef --chainid 15 \ + --suppress-bootwarn --signersecret ./clefpw --rules ./rules.js +``` +For `geth`, the only change is to provide `--signer `. diff --git a/content/docs/tools/Clef/Introduction.md b/content/docs/tools/Clef/Introduction.md new file mode 100644 index 0000000000..2aeadde9ac --- /dev/null +++ b/content/docs/tools/Clef/Introduction.md @@ -0,0 +1,208 @@ +--- +title: Introduction to Clef +sort_key: A +--- + +{:toc} +- this will be removed by the toc + +## What is Clef? + +Clef is a tool for **signing transactions and data** in a secure local environment. +t is intended to become a more composable and secure replacement for Geth's built-in +account management. Clef decouples key management from Geth itself, meaning it can be +used as an independent, standalone key management and signing application, or it +can be integrated into Geth. This provides a more flexible modular tool compared to +Geth's account manager. Clef can be used safely in situations where access to Ethereum is +via a remote and/or untrusted node because signing happens locally, either manually or +automatically using custom rulesets. The separation of Clef from the node itself enables it +to run as a daemon on the same machine as the client software, on a secure usb-stick like +[USB armory](https://inversepath.com/usbarmory), or even a separate VM in a +[QubesOS](https://www.qubes-os.org/) type setup. + +## Installing and starting Clef + +Clef comes bundled with Geth and can be built along with Geth and the other bundled tools using: + +`make all` + +However, Clef is not bound to Geth and can be built on its own using: + +`make clef` + +Once built, Clef must be initialized. This includes storing some data, some of which is sensitive +(such as passwords, account data, signing rules etc). Initializing Clef takes that data and +encrypts it using a user-defined password. + +`clef init` + +```terminal +WARNING! + +Clef is an account management tool. It may, like any software, contain bugs. + +Please take care to +- backup your keystore files, +- verify that the keystore(s) can be opened with your password. + +Clef is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY +without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR +PURPOSE. See the GNU General Public License for more details. + +Enter 'ok' to proceed: +> ok + +The master seed of clef will be locked with a password. +Please specify a password. Do not forget this password! +Password: +Repeat password: + +A master seed has been generated into /home/martin/.clef/masterseed.json + +This is required to be able to store credentials, such as: +* Passwords for keystores (used by rule engine) +* Storage for JavaScript auto-signing rules +* Hash of JavaScript rule-file + +You should treat 'masterseed.json' with utmost secrecy and make a backup of it! +* The password is necessary but not enough, you need to back up the master seed too! +* The master seed does not contain your accounts, those need to be backed up separately! +``` + +## Security model + +One of the major benefits of Clef is that it is decoupled from the client software, +meaning it can be used by users and dapps to sign data and transactions in a secure, +local environment and send the signed packet to an arbitrary Ethereum entry-point, which +might include, for example, an untrusted remote node. Alternatively, Clef can simply be +used as a standalone, composable signer that can be a backend component for decentralized +applications. This requires a secure architecture that separates cryptographic operations +from user interactions and internal/external communication. + +The security model of Clef is as follows: + +* A self-contained binary controls all cryptographic operations including encryption, + decryption and storage of keystore files, and signing data and transactions. + +* A well defined, deliberately minimal "external" API is used to communicate with the + Clef binary - Clef considers this external traffic to be UNTRUSTED. This means Clef + does not accept any credentials and does not recognize authority of requests received + over this channel. Clef listens on `http.addr:http.port` or `ipcpath` - the same as Geth - + and expects messages to be formatted using the [JSON-RPC 2.0 standard](https://www.jsonrpc.org/specification). + Some of the external API calls require some user interaction (manual approve/deny)- if it is + not received responses can be delayed indefinitely. + +* Clef communicates with the process that invoked the binary using stin/stout. The process + invoking the binary is usually the native console-based user interface (UI) but there is + also an API that enables communication with an external UI. This has to be enabled using `--stdio-ui` + at startup. This channel is considered TRUSTED and is used to pass approvals and passwords between + the user and Clef. + +* Clef does not store keys - the user is responsible for securely storing and backing up keyfiles. + Clef does store account passwords in its encrypted vault if they are explicitly provided to + Clef by the user to enable automatic account unlocking. + +The external API never handles any sensitive data directly, but it can be used to request Clef to +sign some data or a transaction. It is the internal API that controls signing and triggers requests for +manual approval (automatic approves actions that conform to attested rulesets) and passwords. + +The general flow for a basic transaction-signing operation using Clef and an Ethereum node such as +Geth is as follows: + +![Clef signing logic](/static/images/clef_sign_flow.png) + +In the case illustrated in the schematic above, Geth would be started with `--signer :` and +would relay requests to `eth.sendTransaction`. Text in `mono` font positioned along arrows shows the objects +passed between each component. + +Most users use Clef by manually approving transactions through the UI as in the schematic above, but it is also +possible to configure Clef to sign transactions without always prompting the user. This requires defining the +precise conditions under which a transaction will be signed. These conditions are known as `Rules` and they are +small Javascript snippets that are *attested* by the user by injecting the snippet's hash into Clef's secure +whitelist. Clef is then started with the rule file, so that requests that satisfy the conditions in the whitelisted +rule files are automatically signed. This is covered in detail on the [Rules page](/docs/_clef/Rules.md). + + +## Basic usage + +Clef is started on the command line using the `clef` command. Clef can be configured by providing flags and +commands to `clef` on startup. The full list of command line options is available [below](#command-line-options). +Frequently used options include `--keystore` and `--chainid` which configure the path to an existing keystore +and a network to connect to. These options default to `$HOME/.ethereum/keystore` and `1` (corresponding to +Ethereum Mainnet) respectively. The following code snippet starts Clef, providing a custom path to an existing +keystore and connecting to the Goerli testnet: + +```sh +clef --keystore /my/keystore --chainid 5 +``` + +On starting Clef, the following welcome messgae is displayed in the terminal: + +```terminal +WARNING! + +Clef is an account management tool. It may, like any software, contain bugs. + +Please take care to +- backup your keystore files, +- verify that the keystore(s) can be opened with your password. + +Clef is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY. +without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR +PURPOSE. See the GNU General Public License for more details. + +Enter 'ok' to proceed: +> +``` + +Requests requiring account access or signing now require explicit consent in this terminal. +Activities such as sending transactions via a local Geth node's attached Javascript console or +RPC will now hang indefinitely, awaiting approval in this terminal. + +A much more detailed Clef tutorial is available on the [Tutorial page](/docs/clef/tutorial). + + +## Command line options + +```sh +COMMANDS: + init Initialize the signer, generate secret storage + attest Attest that a js-file is to be used + setpw Store a credential for a keystore file + delpw Remove a credential for a keystore file + newaccount Create a new account + gendoc Generate documentation about json-rpc format + help, h Shows a list of commands or help for one command + +GLOBAL OPTIONS: + --loglevel value log level to emit to the screen (default: 4) + --keystore value Directory for the keystore (default: "$HOME/.ethereum/keystore") + --configdir value Directory for Clef configuration (default: "$HOME/.clef") + --chainid value Chain id to use for signing (1=mainnet, 3=Ropsten, 4=Rinkeby, 5=Goerli) (default: 1) + --lightkdf Reduce key-derivation RAM & CPU usage at some expense of KDF strength + --nousb Disables monitoring for and managing USB hardware wallets + --pcscdpath value Path to the smartcard daemon (pcscd) socket file (default: "/run/pcscd/pcscd.comm") + --http.addr value HTTP-RPC server listening interface (default: "localhost") + --http.vhosts value Comma separated list of virtual hostnames from which to accept requests (server enforced). Accepts '*' wildcard. (default: "localhost") + --ipcdisable Disable the IPC-RPC server + --ipcpath value Filename for IPC socket/pipe within the datadir (explicit paths escape it) + --http Enable the HTTP-RPC server + --http.port value HTTP-RPC server listening port (default: 8550) + --signersecret value A file containing the (encrypted) master seed to encrypt Clef data, e.g. keystore credentials and ruleset hash + --4bytedb-custom value File used for writing new 4byte-identifiers submitted via API (default: "./4byte-custom.json") + --auditlog value File used to emit audit logs. Set to "" to disable (default: "audit.log") + --rules value Path to the rule file to auto-authorize requests with + --stdio-ui Use STDIN/STDOUT as a channel for an external UI. This means that an STDIN/STDOUT is used for RPC-communication with a e.g. a graphical user interface, and can be used when Clef is started by an external process. + --stdio-ui-test Mechanism to test interface between Clef and UI. Requires 'stdio-ui'. + --advanced If enabled, issues warnings instead of rejections for suspicious requests. Default off + --suppress-bootwarn If set, does not show the warning during boot +``` + +## Summary + +Clef is an external key management and signer tool that comes bundled with Geth but can either be used +as a backend account manager and signer for Geth or as a completely separate standalone application. Being +modular and composable it can be used as a component in decentralized applications or to sign data and +transactions in untrusted environments. Clef is intended to eventually replace Geth's built-in account +management tools. + \ No newline at end of file diff --git a/content/docs/tools/Clef/Rules.md b/content/docs/tools/Clef/Rules.md new file mode 100644 index 0000000000..9441181716 --- /dev/null +++ b/content/docs/tools/Clef/Rules.md @@ -0,0 +1,237 @@ +--- +title: Rules +sort_key: B +--- + +The `signer` binary contains a ruleset engine, implemented with [OttoVM](https://github.com/robertkrimen/otto) + +It enables usecases like the following: + +* I want to auto-approve transactions with contract `CasinoDapp`, with up to `0.05 ether` in value to maximum `1 ether` per 24h period +* I want to auto-approve transaction to contract `EthAlarmClock` with `data`=`0xdeadbeef`, if `value=0`, `gas < 44k` and `gasPrice < 40Gwei` + +The two main features that are required for this to work well are; + +1. Rule Implementation: how to create, manage and interpret rules in a flexible but secure manner +2. Credential managements and credentials; how to provide auto-unlock without exposing keys unnecessarily. + +The section below deals with both of them + +## Rule Implementation + +A ruleset file is implemented as a `js` file. Under the hood, the ruleset-engine is a `SignerUI`, implementing the same methods as the `json-rpc` methods +defined in the UI protocol. Example: + +```js +function asBig(str) { + if (str.slice(0, 2) == "0x") { + return new BigNumber(str.slice(2), 16) + } + return new BigNumber(str) +} + +// Approve transactions to a certain contract if value is below a certain limit +function ApproveTx(req) { + var limit = big.Newint("0xb1a2bc2ec50000") + var value = asBig(req.transaction.value); + + if (req.transaction.to.toLowerCase() == "0xae967917c465db8578ca9024c205720b1a3651a9") && value.lt(limit)) { + return "Approve" + } + // If we return "Reject", it will be rejected. + // By not returning anything, it will be passed to the next UI, for manual processing +} + +// Approve listings if request made from IPC +function ApproveListing(req){ + if (req.metadata.scheme == "ipc"){ return "Approve"} +} +``` + +Whenever the external API is called (and the ruleset is enabled), the `signer` calls the UI, which is an instance of a ruleset-engine. The ruleset-engine +invokes the corresponding method. In doing so, there are three possible outcomes: + +1. JS returns "Approve" + * Auto-approve request +2. JS returns "Reject" + * Auto-reject request +3. Error occurs, or something else is returned + * Pass on to `next` ui: the regular UI channel. + +A more advanced example can be found below, "Example 1: ruleset for a rate-limited window", using `storage` to `Put` and `Get` `string`s by key. + +* At the time of writing, storage only exists as an ephemeral unencrypted implementation, to be used during testing. + +### Things to note + +The Otto vm has a few [caveats](https://github.com/robertkrimen/otto): + +* "use strict" will parse, but does nothing. +* The regular expression engine (re2/regexp) is not fully compatible with the ECMA5 specification. +* Otto targets ES5. ES6 features (eg: Typed Arrays) are not supported. + +Additionally, a few more have been added + +* The rule execution cannot load external javascript files. +* The only preloaded library is [`bignumber.js`](https://github.com/MikeMcl/bignumber.js) version `2.0.3`. This one is fairly old, and is not aligned with the documentation at the github repository. +* Each invocation is made in a fresh virtual machine. This means that you cannot store data in global variables between invocations. This is a deliberate choice -- if you want to store data, use the disk-backed `storage`, since rules should not rely on ephemeral data. +* Javascript API parameters are _always_ an object. This is also a design choice, to ensure that parameters are accessed by _key_ and not by order. This is to prevent mistakes due to missing parameters or parameter changes. +* The JS engine has access to `storage` and `console`. + +#### Security considerations + +##### Security of ruleset + +Some security precautions can be made, such as: + +* Never load `ruleset.js` unless the file is `readonly` (`r-??-??-?`). If the user wishes to modify the ruleset, he must make it writeable and then set back to readonly. + * This is to prevent attacks where files are dropped on the users disk. +* Since we're going to have to have some form of secure storage (not defined in this section), we could also store the `sha3` of the `ruleset.js` file in there. + * If the user wishes to modify the ruleset, he'd then have to perform e.g. `signer --attest /path/to/ruleset --credential ` + +##### Security of implementation + +The drawbacks of this very flexible solution is that the `signer` needs to contain a javascript engine. This is pretty simple to implement, since it's already +implemented for `geth`. There are no known security vulnerabilities in, nor have we had any security-problems with it so far. + +The javascript engine would be an added attack surface; but if the validation of `rulesets` is made good (with hash-based attestation), the actual javascript cannot be considered +an attack surface -- if an attacker can control the ruleset, a much simpler attack would be to implement an "always-approve" rule instead of exploiting the js vm. The only benefit +to be gained from attacking the actual `signer` process from the `js` side would be if it could somehow extract cryptographic keys from memory. + +##### Security in usability + +Javascript is flexible, but also easy to get wrong, especially when users assume that `js` can handle large integers natively. Typical errors +include trying to multiply `gasCost` with `gas` without using `bigint`:s. + +It's unclear whether any other DSL could be more secure; since there's always the possibility of erroneously implementing a rule. + + +## Credential management + +The ability to auto-approve transaction means that the signer needs to have necessary credentials to decrypt keyfiles. These passwords are hereafter called `ksp` (keystore pass). + +### Example implementation + +Upon startup of the signer, the signer is given a switch: `--seed ` +The `seed` contains a blob of bytes, which is the master seed for the `signer`. + +The `signer` uses the `seed` to: + +* Generate the `path` where the settings are stored. + * `./settings/1df094eb-c2b1-4689-90dd-790046d38025/vault.dat` + * `./settings/1df094eb-c2b1-4689-90dd-790046d38025/rules.js` +* Generate the encryption password for `vault.dat`. + +The `vault.dat` would be an encrypted container storing the following information: + +* `ksp` entries +* `sha256` hash of `rules.js` +* Information about pair:ed callers (not yet specified) + +### Security considerations + +This would leave it up to the user to ensure that the `path/to/masterseed` is handled in a secure way. It's difficult to get around this, although one could +imagine leveraging OS-level keychains where supported. The setup is however in general similar to how ssh-keys are stored in `.ssh/`. + + +# Implementation status + +This is now implemented (with ephemeral non-encrypted storage for now, so not yet enabled). + +## Example 1: ruleset for a rate-limited window + + +```js +function big(str) { + if (str.slice(0, 2) == "0x") { + return new BigNumber(str.slice(2), 16) + } + return new BigNumber(str) +} + +// Time window: 1 week +var window = 1000* 3600*24*7; + +// Limit : 1 ether +var limit = new BigNumber("1e18"); + +function isLimitOk(transaction) { + var value = big(transaction.value) + // Start of our window function + var windowstart = new Date().getTime() - window; + + var txs = []; + var stored = storage.get('txs'); + + if (stored != "") { + txs = JSON.parse(stored) + } + // First, remove all that have passed out of the time-window + var newtxs = txs.filter(function(tx){return tx.tstamp > windowstart}); + console.log(txs, newtxs.length); + + // Secondly, aggregate the current sum + sum = new BigNumber(0) + + sum = newtxs.reduce(function(agg, tx){ return big(tx.value).plus(agg)}, sum); + console.log("ApproveTx > Sum so far", sum); + console.log("ApproveTx > Requested", value.toNumber()); + + // Would we exceed weekly limit ? + return sum.plus(value).lt(limit) + +} +function ApproveTx(r) { + if (isLimitOk(r.transaction)) { + return "Approve" + } + return "Nope" +} + +/** +* OnApprovedTx(str) is called when a transaction has been approved and signed. The parameter + * 'response_str' contains the return value that will be sent to the external caller. +* The return value from this method is ignore - the reason for having this callback is to allow the +* ruleset to keep track of approved transactions. +* +* When implementing rate-limited rules, this callback should be used. +* If a rule responds with neither 'Approve' nor 'Reject' - the tx goes to manual processing. If the user +* then accepts the transaction, this method will be called. +* +* TLDR; Use this method to keep track of signed transactions, instead of using the data in ApproveTx. +*/ +function OnApprovedTx(resp) { + var value = big(resp.tx.value) + var txs = [] + // Load stored transactions + var stored = storage.get('txs'); + if (stored != "") { + txs = JSON.parse(stored) + } + // Add this to the storage + txs.push({tstamp: new Date().getTime(), value: value}); + storage.put("txs", JSON.stringify(txs)); +} +``` + +## Example 2: allow destination + +```js +function ApproveTx(r) { + if (r.transaction.from.toLowerCase() == "0x0000000000000000000000000000000000001337") { + return "Approve" + } + if (r.transaction.from.toLowerCase() == "0x000000000000000000000000000000000000dead") { + return "Reject" + } + // Otherwise goes to manual processing +} +``` + +## Example 3: Allow listing + +```js +function ApproveListing() { + return "Approve" +} +``` diff --git a/content/docs/tools/Clef/Setup.md b/content/docs/tools/Clef/Setup.md new file mode 100644 index 0000000000..ded3652eee --- /dev/null +++ b/content/docs/tools/Clef/Setup.md @@ -0,0 +1,202 @@ +--- +title: Advanced setup +sort_key: D +--- + + +This document describes how Clef can be used in a more secure manner than executing it from your everyday laptop, +in order to ensure that the keys remain safe in the event that your computer should get compromised. + +## Qubes OS + + +### Background + +The Qubes operating system is based around virtual machines (qubes), where a set of virtual machines are configured, typically for +different purposes such as: + +- personal + - Your personal email, browsing etc +- work + - Work email etc +- vault + - a VM without network access, where gpg-keys and/or keepass credentials are stored. + +A couple of dedicated virtual machines handle externalities: + +- sys-net provides networking to all other (network-enabled) machines +- sys-firewall handles firewall rules +- sys-usb handles USB devices, and can map usb-devices to certain qubes. + +The goal of this document is to describe how we can set up clef to provide secure transaction +signing from a `vault` vm, to another networked qube which runs Dapps. + +### Setup + +There are two ways that this can be achieved: integrated via Qubes or integrated via networking. + + +#### 1. Qubes Integrated + +Qubes provides a facility for inter-qubes communication via `qrexec`. A qube can request to make a cross-qube RPC request +to another qube. The OS then asks the user if the call is permitted. + +![Example](qrexec-example.png) + +A policy-file can be created to allow such interaction. On the `target` domain, a service is invoked which can read the +`stdin` from the `client` qube. + +This is how [Split GPG](https://www.qubes-os.org/doc/split-gpg/) is implemented. We can set up Clef the same way: + +##### Server + +![Clef via qrexec](clef_qubes_qrexec.png) + +On the `target` qubes, we need to define the RPC service. + +[qubes.Clefsign](qubes.Clefsign): + +```bash +#!/bin/bash + +SIGNER_BIN="/home/user/tools/clef/clef" +SIGNER_CMD="/home/user/tools/gtksigner/gtkui.py -s $SIGNER_BIN" + +# Start clef if not already started +if [ ! -S /home/user/.clef/clef.ipc ]; then + $SIGNER_CMD & + sleep 1 +fi + +# Should be started by now +if [ -S /home/user/.clef/clef.ipc ]; then + # Post incoming request to HTTP channel + curl -H "Content-Type: application/json" -X POST -d @- http://localhost:8550 2>/dev/null +fi + +``` +This RPC service is not complete (see notes about HTTP headers below), but works as a proof-of-concept. +It will forward the data received on `stdin` (forwarded by the OS) to Clef's HTTP channel. + +It would have been possible to send data directly to the `/home/user/.clef/.clef.ipc` +socket via e.g `nc -U /home/user/.clef/clef.ipc`, but the reason for sending the request +data over `HTTP` instead of `IPC` is that we want the ability to forward `HTTP` headers. + +To enable the service: + +``` bash +sudo cp qubes.Clefsign /etc/qubes-rpc/ +sudo chmod +x /etc/qubes-rpc/ qubes.Clefsign +``` + +This setup uses [gtksigner](https://github.com/holiman/gtksigner), which is a very minimal GTK-based UI that works well +with minimal requirements. + +##### Client + + +On the `client` qube, we need to create a listener which will receive the request from the Dapp, and proxy it. + + +[qubes-client.py](qubes-client.py): + +```python + +""" +This implements a dispatcher which listens to localhost:8550, and proxies +requests via qrexec to the service qubes.EthSign on a target domain +""" + +import http.server +import socketserver,subprocess + +PORT=8550 +TARGET_DOMAIN= 'debian-work' + +class Dispatcher(http.server.BaseHTTPRequestHandler): + def do_POST(self): + post_data = self.rfile.read(int(self.headers['Content-Length'])) + p = subprocess.Popen(['/usr/bin/qrexec-client-vm',TARGET_DOMAIN,'qubes.Clefsign'],stdin=subprocess.PIPE, stdout=subprocess.PIPE) + output = p.communicate(post_data)[0] + self.wfile.write(output) + + +with socketserver.TCPServer(("",PORT), Dispatcher) as httpd: + print("Serving at port", PORT) + httpd.serve_forever() + + +``` + +#### Testing + +To test the flow, if we have set up `debian-work` as the `target`, we can do + +```bash +$ cat newaccnt.json +{ "id": 0, "jsonrpc": "2.0","method": "account_new","params": []} + +$ cat newaccnt.json| qrexec-client-vm debian-work qubes.Clefsign +``` + +A dialog should pop up first to allow the IPC call: + +![one](qubes_newaccount-1.png) + +Followed by a GTK-dialog to approve the operation: + +![two](qubes_newaccount-2.png) + +To test the full flow, we use the client wrapper. Start it on the `client` qube: +``` +[user@work qubes]$ python3 qubes-client.py +``` + +Make the request over http (`client` qube): +``` +[user@work clef]$ cat newaccnt.json | curl -X POST -d @- http://localhost:8550 +``` +And it should show the same popups again. + +##### Pros and cons + +The benefits of this setup are: + +- This is the qubes-os intended model for inter-qube communication, +- and thus benefits from qubes-os dialogs and policies for user approval + +However, it comes with a couple of drawbacks: + +- The `qubes-gpg-client` must forward the http request via RPC to the `target` qube. When doing so, the proxy + will either drop important headers, or replace them. + - The `Host` header is most likely `localhost` + - The `Origin` header must be forwarded + - Information about the remote ip must be added as a `X-Forwarded-For`. However, Clef cannot always trust an `XFF` header, + since malicious clients may lie about `XFF` in order to fool the http server into believing it comes from another address. +- Even with a policy in place to allow RPC calls between `caller` and `target`, there will be several popups: + - One qubes-specific where the user specifies the `target` vm + - One clef-specific to approve the transaction + + +#### 2. Network integrated + +The second way to set up Clef on a qubes system is to allow networking, and have Clef listen to a port which is accessible +from other qubes. + +![Clef via http](clef_qubes_http.png) + + + + +## USBArmory + +The [USB armory](https://inversepath.com/usbarmory) is an open source hardware design with an 800 MHz ARM processor. It is a pocket-size +computer. When inserted into a laptop, it identifies itself as a USB network interface, basically adding another network +to your computer. Over this new network interface, you can SSH into the device. + +Running Clef off a USB armory means that you can use the armory as a very versatile offline computer, which only +ever connects to a local network between your computer and the device itself. + +Needless to say, while this model should be fairly secure against remote attacks, an attacker with physical access +to the USB Armory would trivially be able to extract the contents of the device filesystem. + diff --git a/content/docs/tools/Clef/Tutorial.md b/content/docs/tools/Clef/Tutorial.md new file mode 100644 index 0000000000..d7919bfde1 --- /dev/null +++ b/content/docs/tools/Clef/Tutorial.md @@ -0,0 +1,685 @@ +--- +title: Tutorial +sort_key: A +--- + +This page provides a step-by-step walkthrough tutorial demonstrating some common uses of Clef. This +includes manual approvals and automated rules. Clef is presented both as a standalone general signer +with requests made via RPC and also as a backend signer for Geth. + +{:toc} +- this will be removed by the toc + + +## Initializing Clef + +First things first, Clef needs to store some data itself. Since that data might be sensitive +(passwords, signing rules, accounts), Clef's entire storage is encrypted. To support encrypting data, +the first step is to initialize Clef with a random master seed, itself too encrypted with your chosen +password: + +```text +$ clef init + +WARNING! + +Clef is an account management tool. It may, like any software, contain bugs. + +Please take care to +- backup your keystore files, +- verify that the keystore(s) can be opened with your password. + +Clef is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; +without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR +PURPOSE. See the GNU General Public License for more details. + +Enter 'ok' to proceed: +> ok + +The master seed of clef will be locked with a password. +Please specify a password. Do not forget this password! +Password: +Repeat password: + +A master seed has been generated into /home/martin/.clef/masterseed.json + +This is required to be able to store credentials, such as: +* Passwords for keystores (used by rule engine) +* Storage for JavaScript auto-signing rules +* Hash of JavaScript rule-file + +You should treat 'masterseed.json' with utmost secrecy and make a backup of it! +* The password is necessary but not enough, you need to back up the master seed too! +* The master seed does not contain your accounts, those need to be backed up separately! +``` + +*For readability purposes, we'll remove the WARNING printout, user confirmation and the unlocking of the master seed in the rest of this document.* + +## Remote interactions + +This tutorial will use Clef with Geth on the Goerli testnet. The accounts used will be in the +Goerli keystore with the path `~/go-ethereum/goerli-data/keystore`. The tutorial assumes there +are two accounts in this keystore. Instructions for creating accounts can be found on the +[Account managament page](/docs/interface/managing-your-accounts). Note that Clef can also interact +with hardware wallets, although that is not demonstrated here. + +Clef should be started before Geth, otherwise Geth will complain that it cannot find a Clef +instance to connect to. Clef should be started with the correct `chainid` for Goerli. Clef +itself does not connect to a blockchain, but the `chainID` parameter is included in the data +that is aggregated to form a signature. Clef also needs a path to the correct keystore passed to +the `--keystore` command. A custom path to the config directory can also be provided. This is where the +`ipc` file will be saved which is needed to connect Clef to Geth: + +```sh +clef --keystore ~/go-ethereum/goerli-data/keystore --configdir ~/go-ethereum/goerli-data/clef --chainid=5 +``` + +The following logs will be displayed in the console: + +```terminal +INFO [07-01|11:00:46.385] Starting signer chainid=4 keystore= go-ethereum/goerli-data/keystore light-kdf=false advanced=false +DEBUG[07-01|11:00:46.389] FS scan times list=3.521941ms set=9.017µs diff=4.112µs +DEBUG[07-01|11:00:46.391] Ledger support enabled +DEBUG[07-01|11:00:46.391] Trezor support enabled via HID +DEBUG[07-01|11:00:46.391] Trezor support enabled via WebUSB +INFO [07-01|11:00:46.391] Audit logs configured file=audit.log +DEBUG[07-01|11:00:46.392] IPC registered namespace=account +INFO [07-01|11:00:46.392] IPC endpoint opened url=go-ethereum/goerli-data/clef/clef.ipc +------- Signer info ------- +* intapi_version : 7.0.1 +* extapi_version : 6.1.0 +* extapi_http : n/a +* extapi_ipc : go-ethereum/goerli-data/clef/clef.ipc +``` + +Clef starts up in CLI (Command Line Interface) mode by default. Arbitrary remote +processes may *request* account interactions (e.g. sign a transaction), which the user +can individually *confirm* or *deny*. + +The code snippet below shows a request made to Clef via its *External API endpoint* using +[NetCat](http://netcat.sourceforge.net/). The request invokes the +["account_list"](/docs/_clef/apis#accountlist) endpoint which lists the accounts in the keystore. +This command should be run in a new terminal. + +```sh +echo '{"id": 1, "jsonrpc": "2.0", "method": "account_list"}' | nc -U ~/.clef/clef.ipc +``` + +The terminal used to send the command will now hang. This is because the process is awaiting +confirmation from Clef. Switching to the Clef console reveals Clef's prompt to the user to +confirm or deny the request: + +```terminal +-------- List Account request-------------- +A request has been made to list all accounts. +You can select which accounts the caller can see + [x] 0xD9C9Cd5f6779558b6e0eD4e6Acf6b1947E7fA1F3 + URL: keystore://go-ethereum/goerli-data/keystore/UTC--2017-04-14T15-15-00.327614556Z--d9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3 + [x] 0x086278A6C067775F71d6B2BB1856Db6E28c30418 + URL: keystore://go-ethereum/goerli-data/keystore/UTC--2018-02-06T22-53-11.211657239Z--086278a6c067775f71d6b2bb1856db6e28c30418 +------------------------------------------- +Request context: + NA - ipc - NA + +Additional HTTP header data, provided by the external caller: + User-Agent: + Origin: +Approve? [y/N]: +``` + +Depending on whether the request is approved or denied, the NetCat process in the other terminal +will receive one of the following responses: + +```terminal +{"jsonrpc":"2.0","id":1,"result":["0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3","0x086278a6c067775f71d6b2bb1856db6e28c30418"]} +``` + +or + +```terminal +{"jsonrpc":"2.0","id":1,"error":{"code":-32000,"message":"Request denied"}} +``` + +Apart from listing accounts, you can also *request* creating a new account, signing transactions +and data or recovering signatures. The available methods are documented in the Clef +[External API Spec](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef#external-api-1) +and the [External API Changelog](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/extapi_changelog.md). + +*Note, the number of things you can do from the External API is deliberately small to limit +the power of remote calls as much as possible! Clef has an +[Internal API](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef#ui-api-1) +too for the UI (User Interface) which is much richer and can support custom interfaces on top. +But that's out of scope here.* + +The example above used Clef completely independently of Geth. However, by defining Clef as +the signer when Geth is started imposes Clef's `request - confirm - result` pattern to any +interaction with the local Geth node that touches accounts, including requests made using +RPC or an attached Javascript console. To demonstrate this, Geth can be started, +with Clef as the signer: + +```sh +geth --goerli --datadir goerli-data --signer=goerli-data/clef/clef.ipc +``` + +With Geth running, open a new terminal and attach a Javascript console: + +```sh +geth attach goerli-data/geth.ipc +``` + +A simple request to list the accounts in the keystore will cause the Javascript console to hang. + +```js +eth.accounts +``` + +Switching to the Clef terminal reveals that this is because the request is awaiting explicit +confirmation from the user. The log is identical to the one shown above, when the same request +for account information was made to Clef via Netcat: + +```terminal +-------- List Account request-------------- +A request has been made to list all accounts. +You can select which accounts the caller can see + [x] 0xD9C9Cd5f6779558b6e0eD4e6Acf6b1947E7fA1F3 + URL: keystore://go-ethereum/goerli-data/keystore/UTC--2017-04-14T15-15-00.327614556Z--d9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3 + [x] 0x086278A6C067775F71d6B2BB1856Db6E28c30418 + URL: keystore://go-ethereum/goerli-data/keystore/UTC--2018-02-06T22-53-11.211657239Z--086278a6c067775f71d6b2bb1856db6e28c30418 +------------------------------------------- +Request context: + NA - ipc - NA + +Additional HTTP header data, provided by the external caller: + User-Agent: + Origin: +Approve? [y/N]: +``` + +In this mode, the user is required to manually confirm every action that touches account data, +including querying accounts, signing and sending transactions. + +The example below shows an ether transaction between the two accounts in the keystore +using `eth.sendTransaction` in the attached Javascript console. + +```js +// this command requires 2x approval in Clef because it loads account data via eth.accounts[0] +// and eth.accounts[1] +var tx = {from: eth.accounts[0], to: eth.accounts[1], value: web3.toWei(0.1, "ether")} + +// then send the transaction +eth.sendTransaction(tx) +``` + +This example demonstrates the power of Clef much more clearly than the account-listing example. +In the Clef terminal, all the details of the transaction are presented to the user so that they +can be reviewed before being confirmed. This gives the user an opportunity to review the fine +details and make absolutely sure they really want to sign the transaction. `eth.sendTransaction` +returns the following confirmation prompt in the Clef terminal: + + +```terminal +-------- Transaction request---------------- +to: 0x086278A6C067775F71d6B2BB1856Db6E28c30418 +from: 0xD9C9Cd5f6779558b6e0eD4e6Acf6b1947E7fA1F3 [chksum ok] +value: 100000000000000000 wei +gas: 0x5208 (21000) +maxFeePerGas: 1500000016 wei +maxPriorityFeePerGas: 1500000000 wei +nonce: 0x0 (0) +chainid: 0x5 +Accesslist + +Request context: + NA - ipc - NA + +Additional HTTP header data, provided by the external caller: + User-Agent: "" + Origin: "" +--------------------------------------------- + +Approve? [y/N] + +``` + +Approving this transaction causes Clef to prompt the user to provide the password for +the sender account. Providing the password enables the transaction to be signed and sent to +Geth for broadcasting to the network. The details of the signed transaction are displayed +in the console. Account passwords can also be stored in Clef's encrypted vault so that they +do not have to be manually entered - [more on this below](#account-passwords). + + +## Automatic rules + +For most users, manually confirming every transaction is the right way to use Clef because a +human-in-the-loop can review every action. However, there are cases when it makes sense to +set up some rules which permit Clef to sign a transaction without prompting the user. + +For example, well defined rules such as: + +* Auto-approve transactions with Uniswap v2, with value between 0.1 and 0.5 ETH + per 24h period +* Auto-approve transactions to address `0xD9C9Cd5f6779558b6e0eD4e6Acf6b1947E7fA1F3` + as long as gas < 44k and gasPrice < 80Gwei + +can be encoded and intepreted by Clef's built-in ruleset engine. + +### Rule files + +Rules are implemented as Javascript code in `js` files. The ruleset engine includes the +same methods as the JSON_RPC defined in the [UI Protocol](/docs/_clef/datatypes.md). +The following code snippet demonstrates a rule file that approves a transaction if it +satisfies the following conditions: + +* the recipient is `0xae967917c465db8578ca9024c205720b1a3651a9` +* the value is less than 50000000000000000 wei (0.05 ETH) + +and approves account listing if: + +* the request has arrived via ipc + +```js +//ancillary function for formatting numbers +function asBig(str) { + if (str.slice(0, 2) == "0x") { + return new BigNumber(str.slice(2), 16) + } + return new BigNumber(str) +} + +// Approve transactions to a certain contract if value is below a certain limit +function ApproveTx(req) { + var limit = big.Newint("0xb1a2bc2ec50000") + var value = asBig(req.transaction.value); + + if (req.transaction.to.toLowerCase() == "0xae967917c465db8578ca9024c205720b1a3651a9") + && value.lt(limit)) { + return "Approve" + } + else{ + return "Reject" + } +} + +// Approve listings if request made from IPC +function ApproveListing(req){ + if (req.metadata.scheme == "ipc"){ return "Approve"} +} +// returning nothing passes the decision to the next UI for manual assessment +``` + +There are three possible outcomes to this ruleset that are handled in different ways: + +| Return value | Action | +| ----------- | ----------- | +| "Approve" | Auto-approve request | +| "Reject" | Auto-approve request | +| Error | Pass decision to UI for manual approval | +| Unexpected value | Pass decision to UI for manual approval | +| Nothing | Pass decision to UI for manual approval | + + +### Attestations + +Clef will not just accept and run arbitrary scripts - that would create an attack vector because a malicious party could +change the rule file. Instead, the user explicitly *attests* to a rule file, which involves injecting the file's SHA256 +hash into Clef's secure store. The following code snippet shows how to calculate a SHA256 hash for a file named `rules.js` +and pass it to Clef. Note that Clef will prompt the user to provide the master password because the Clef store has to +be decrypted in order to add the attestation to it. + +```sh +# calculate hash +sha256sum rules.js + +# attest to rules.js in Clef +clef attest 645b58e4f945e24d0221714ff29f6aa8e860382ced43490529db1695f5fcc71c +``` + +Once this attestation has been added to the Clef store, it can be used to automatically approve +interactions that satisfy the conditions encoded in `rules.js` in Clef. + + +### Account passwords + +The rules described in `rules.js` above require access to the accounts in the Clef keystore which +are protected by user-defined passwords. The signer therefore requires access to these passwords +in order to automatically unlock the keystore and sign data and transactions using the accounts. + +This is done using `clef setpw`, passing the account address as the sole argument: + +```sh +clef setpw 0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3 +``` + +which displays the following in the terminal: + +```terminal +Please enter a password to store for this address: +Password: +Repeat password: + +Decrypt master seed of clef +Password: +INFO [07-01|14:05:56.031] Credential store updated key=0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3 +``` + +Note that Clef does not really 'unlock' an account, it just abstracts the process of providing the +password away from the end-user in specific, predefined scenarios. If an account password +exists in the Clef vault and the rule evaluates to "Approve" then Clef decrypts the password, +uses it to decrypt the key, does the requested signing and then re-locks the account. + + +### Implementing rules + +Clef can be instructed to run an attested rule file simply by passing the path to `rules.js` +to the `--rules` flag: + +```sh +clef --keystore go-ethereum/goerli-data/ --configdir go-ethereum/goerli-data/clef --chainid 5 --rules rules.js +``` + +The following logs will be displayed in the terminal: + +``` +INFO [07-01|13:39:49.726] Rule engine configured file=rules.js +INFO [07-01|13:39:49.726] Starting signer chainid=5 keystore=$go-ethereum/goerli-data/ light-kdf=false advanced=false +DEBUG[07-01|13:39:49.726] FS scan times list=35.15µs set=4.251µs diff=2.766µs +DEBUG[07-01|13:39:49.727] Ledger support enabled +DEBUG[07-01|13:39:49.727] Trezor support enabled via HID +DEBUG[07-01|13:39:49.727] Trezor support enabled via WebUSB +INFO [07-01|13:39:49.728] Audit logs configured file=audit.log +DEBUG[07-01|13:39:49.728] IPC registered namespace=account +INFO [07-01|13:39:49.728] IPC endpoint opened url=go-ethereum/goerli-data/clef/clef.ipc +------- Signer info ------- +* intapi_version : 7.0.0 +* extapi_version : 6.0.0 +* extapi_http : n/a +* extapi_ipc : go-ethereum/goerli-data/clef/clef.ipc +``` + +Any request that satisfies the ruleset will now be auto-approved by the rule file, for example +the following request to sign a transaction made using the Geth Javascript console +(note that the password for account `0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3` +has already been provided to `setpw` and the recipient and value comply with the rules in `rules.js`): + +```js +var tx = {to: "0xae967917c465db8578ca9024c205720b1a3651a9", from: "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3", value: web3.toWei(0.01, "ether")} +eth.sendTransaction(tx) +``` + +By contrast, the following transactions *do not* satisfy the rules in `rules.js`: + +```js +// violate maximum transaction value condition +var tx = {to: "0xae967917c465db8578ca9024c205720b1a3651a9", from: "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3", value: web3.toWei(1, "ether")} +eth.sendTransaction(tx) +``` + +```js +// violate recipient condition +var tx = {to: "0xae967917c465db8578ca9024c205720b1a3651a9", from: "0xd4c4bb7d6889453c6c6ea3e9eab3c4177b4fbcc3", value: web3.toWei(0.01, "ether")} +eth.sendTransaction(tx) +``` + +These latter two transactions, that do not satisfy the encoded rules in `rules.js`, are not automatically approved, but instead pass the +decision back to the UI for manual approval by the user. + + +### Summary of basic usage + +To summarize, the steps required to run Clef with an automated ruleset that requires account access is as follows: + +**1)** Define rules as Javascript and save as a `.js` file, e.g. `rules.js` + +**2)** Calculate hash of rule file using `sha256sum rules.js` + +**3)** Attest the rules in Clef using `clef attest ` + +**4)** Set account passwords in Clef using `clef --setpw
` + +**5)** Start Clef with rule file enabled using `clef --keystore --chainid --rules rules.js` + +**6)** Make requests directly to Clef using the external API or connect to Geth by passing `--signer=` at Geth startup + + +## More rules + +Since rules are defined as Javascript code, rulesets of arbitrary complexity can be created and they can +impose conditions on any part of a transaction, not only the recipient and value. + +A simple example is implementing a "whitelist" of recipients where transactions that have those +accounts in the `to` field are automatically signed (for example perhaps transactions between +a user's own accounts might be whitelisted): + +```js +function ApproveTx(r) { + if (r.transaction.to.toLowerCase() == "0xd4c4bb7d6889453c6c6ea3e9eab3c4177b4fbcc3") { + return "Approve" + } + if (r.transaction.to.toLowerCase() == "0xae967917c465db8578ca9024c205720b1a3651a9") { + return "Reject" + } + // Otherwise goes to manual processing +} +``` + +In addition to addresses and values, other properties of a request can also be incorporated +into a ruleset. The example below demonstrates a ruleset for `approve_signData` imposing +the following conditions on a transaction's sender and message data. + +1. The sender must be `0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3` +2. The transaction message must include the text `wen-merge`, which is `77656E2D6D65726765` in hex. + +If these conditions are satisfied then the transaction is auto-approved (assuming the password for +`0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3` has been provided to `setpw`). + +```js +function ApproveListing() { + return "Approve" +} + +function ApproveSignData(req) { + if (req.address.toLowerCase() == "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3") { + if (req.messages[0].value.indexOf("wen-merge") >= 0) { + return "Approve" + } + return "Reject" + } + // Otherwise goes to manual processing +} +``` + +This file should be saved as a `.js` file, hashed and attested in Clef: + +```sh +sha256sum rules.js +``` + +which returns: + +```terminal +84d9e70aa30d0e5ffb3c4b376c9490f428390a196bfdc1d36770ffd2bbe66845 rules.js +``` + +then: + +```sh +clef attest 84d9e70aa30d0e5ffb3c4b376c9490f428390a196bfdc1d36770ffd2bbe66845 +``` + +which returns: + +```terminal +Decrypt master seed of clef +Password: +INFO [07-01|14:11:28.509] Ruleset attestation updated sha256=84d9e70aa30d0e5ffb3c4b376c9490f428390a196bfdc1d36770ffd2bbe66845 +``` + +Then, Clef can be restarted with the new rules in place: + +```sh +clef --keystore go-ethereum/goerli-data/clef --configdir go-ethereum/goerli-data/clef --chainid 5 --rules rules.js +``` + +```terminal +INFO [07-01|14:12:41.636] Rule engine configured file=rules.js +INFO [07-01|14:12:41.636] Starting signer chainid=5 keystore=go-ethereum/goerli-data/clef/keystore light-kdf=false advanced=false +DEBUG[07-01|14:12:41.636] FS scan times list=46.722µs set=4.47µs diff=2.157µs +DEBUG[07-01|14:12:41.637] Ledger support enabled +DEBUG[07-01|14:12:41.637] Trezor support enabled via HID +DEBUG[07-01|14:12:41.638] Trezor support enabled via WebUSB +INFO [07-01|14:12:41.638] Audit logs configured file=audit.log +DEBUG[07-01|14:12:41.638] IPC registered namespace=account +INFO [07-01|14:12:41.638] IPC endpoint opened url=go-ethereum/goerli-data/clef/clef.ipc +------- Signer info ------- +* intapi_version : 7.0.0 +* extapi_version : 6.0.0 +* extapi_http : n/a +* extapi_ipc : go-ethereum/goerli-data/clef/clef.ipc +``` + +Finally, a request can be submitted to test that the rules are being applied as expected. +Here, Clef is used independently of Geth by making a request via RPC, but the same logic +would be imposed if the request was made via a connected Geth node. Some arbitrary text +will be included in the message data that includes the term `wen-merge`. The plaintext +`clefdemotextthatincludeswen-merge` is `636c656664656d6f7465787474686174696e636c7564657377656e2d6d65726765` +when represented as a hexadecimal string. This can be passed as data to an `account_signData` +request as follows: + +```sh +echo '{"id": 1, "jsonrpc":"2.0", "method":"account_signData", "params":["data/plain", "0x636c656664656d6f7465787474686174696e636c7564657377656e2d6d65726765"]}' | nc -U ~/go-ethereum.goerli-data/clef/clef.ipc +``` + +This will be automatically signed, returning a result that looks like the following: + +```terminal +{"jsonrpc":"2.0","id":1,"result":"0x4f93e3457027f6be99b06b3392d0ebc60615ba448bb7544687ef1248dea4f5317f789002df783979c417d969836b6fda3710f5bffb296b4d51c8aaae6e2ac4831c"} +``` + +Alternatively, a request that does not include the phrase `wen-merge` will not automatically approve. For example, the following request passes the hexadecimal +string representing the plaintext `clefdemotextwithoutspecialtext`: + +```sh +echo '{"id": 1, "jsonrpc":"2.0", "method":"account_signData", "params":["data/plain", "0x636c656664656d6f74657874776974686f75747370656369616c74657874"]}' | nc -U ~/go-ethereum.goerli-data/clef/clef.ipc +``` +This returns a `Request denied` message as follows: + +```terminal +{"jsonrpc":"2.0","id":1,"error":{"code":-32000,"message":"Request denied"}} +``` + +Meanwhile, in the output logs in the Clef terminal you can see: +```text +INFO [02-21|14:42:41] Op approved +INFO [02-21|14:42:56] Op rejected +``` + +The signer also stores all traffic over the external API in a log file. +The last 4 lines shows the two requests and their responses: + +```text +$ tail -n 4 audit.log +t=2022-07-01T15:52:14+0300 lvl=info msg=SignData api=signer type=request metadata="{\"remote\":\"NA\",\"local\":\"NA\",\"scheme\":\"NA\",\"User-Agent\":\"\",\"Origin\":\"\"}" addr="0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3 [chksum INVALID]" data=0x202062617a6f6e6b2062617a2067617a0a content-type=data/plain +t=2022-07-01T15:52:14+0300 lvl=info msg=SignData api=signer type=response data=0x636c656664656d6f7465787474686174696e636c7564657377656e2d6d65726765 error=nil +t=2022-07-01T15:52:23+0300 lvl=info msg=SignData api=signer type=request metadata="{\"remote\":\"NA\",\"local\":\"NA\",\"scheme\":\"NA\",\"User-Agent\":\"\",\"Origin\":\"\"}" addr="0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3 [chksum INVALID]" data=0x636c656664656d6f74657874776974686f75747370656369616c74657874 content-type=data/plain +t=2022-07-01T15:52:23+0300 lvl=info msg=SignData api=signer type=response data= error="Request denied" +``` + +More examples, including a ruleset for a rate-limited window, are available on the [Clef Github][rate-limited-window-example] +and on the [Rules page](/docs/clef/rules). + + +## Under the hood + +The examples on this page have provided step-by-step instructions for verious operations using Clef. +However, they have not provided much detail as to what is happening under the hood. +This section will provide some more details about how Clef organizes itself locally. + +Initializing Clef with a master password and providing an account password to `clef setpw` +and attesting a ruleset creates the following files in the directory `~/.clef/` +(this path is independent of the paths provided to `--keystore` and `--configdir` on startup): + +```terminal +# displayed using $ ls -laR ~/.clef/ + +/home/user/.clef/: +total 24 +drwxr-x--x 3 user user 4096 Jul 1 13:45 . +drwxr-xr-x 102 user user 12288 Jul 1 13:39 .. +drwx------ 2 user user 4096 Jul 1 13:25 02f90c0603f4f2f60188 +-r-------- 1 user user 868 Jun 28 13:55 masterseed.json + +/home/user/.clef/02f90c0603f4f2f60188: +total 12 +drwx------ 2 user user 4096 Jul 1 13:25 . +drwxr-x--x 3 user user 4096 Jul 1 13:45 .. +-rw------- 1 user user 159 Jul 1 13:25 config.json +-rw------- 1 user user 115 Jul 1 13:35 credentials.json +``` + +The file `masterseed.json` includes a json object containing the masterseed which was used to derive +the vault directory (in this case `02f90c0603f4f2f60188`). The vault is encrypted using a password +which is also derived from the masterseed. Inside the vault are two subdirectories: + +`credentials.json` + +`config.json` + + +Inside `credentials.json` are the confidential `ksp` data (standing for "keystore pass" - these +are the account passwords used to unlock the keystore). + +The `config.json` file contains encrypted key/value pairs for configuration data. Usually +this is only the `sha256` hashes of any attested rulesets. + +Vault locations map uniquely to masterseeds so that multiple instances of Clef can co-exist +each with their own attested rules and their own set of keystore passwords. This is useful for, +for example, maintaining separate setups for Mainnet and testnets. + +The contents of each of these json files can be viewed using `cat` and should look something +like the following: + +For `config.json`: + +```sh +cat ~/.clef/02f90c0603f4f2f60188/config.json +``` + +```terminal +{"ruleset_sha256":{"iv":"SWWEtnl+R+I+wfG7","c":"I3fjmwmamxVcfGax7D0MdUOL29/rBWcs73WBILmYK0o1CrX7wSMc3y37KsmtlZUAjp0oItYq01Ow8VGUOzilG91tDHInB5YHNtm/YkufEbo="}} +``` + +and for `credentials.json`: + +```sh +cat ~/.clef/02f90c0603f4f2f60188/config.json +``` + +```terminal +{"0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3": {"iv": "6SC062CfaUW8uSqH","c":"C+S5kaJyrarrxrAESs4EmPjL5zmg5tRh0Q=="}} +``` + +## Geth integration + +This tutorial has bounced back and forth between demonstrating Clef as a standalone tool by making +'manual` JSON RPC requests from the terminal and integrating it as a backend singer for Geth. +Using Clef for account management is considered best practise for Geth users because of the additional +security benefits it offers over and above what it offered by Geth's built-in accounts module. Clef is +far more flexible and composable than Geth's built-in account management tool and can interface directly +with hardware wallets, while Apps and wallets can request signatures directly from Clef. + +Ultimately, the goal is to deprecate Geth's account management tools completely and replace them with +Clef. Until then, users are simply encouraged to choose to use Clef as an optional backend signer for Geth. +In addition to the examples on this page, the [Getting started tutorial](/docs/_getting-started/index.md) +also demonstrates Clef/Geth integration. + + +## Summary + +This page includes step-by-step instructions for basic and intermediate uses of Clef, including using +it as a standalone app and a backend signer for Geth. Further information is available on our other +Clef pages, including [Introduction](/docs/clef/introduction), [Setup](/docs/clef/setup), +[Rules](/docs/clef/rules), [Communication Datatypes](/docs/clef/datatypes) and [Communication APIs](/docs/clef/apis). +Also see the [Clef Github](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef) for further reading. + + +[rate-limited-window-example]:https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/rules.md#example-1-ruleset-for-a-rate-limited-window \ No newline at end of file diff --git a/content/docs/tools/Clef/apis.md b/content/docs/tools/Clef/apis.md new file mode 100644 index 0000000000..d8556e799b --- /dev/null +++ b/content/docs/tools/Clef/apis.md @@ -0,0 +1,851 @@ +--- +title: Communication APIs +sort_key: E +--- + +### External API + +Clef listens to HTTP requests on `http.addr`:`http.port` (or to IPC on `ipcpath`), with the same JSON-RPC standard as Geth. The messages are expected to be [JSON-RPC 2.0 standard](https://www.jsonrpc.org/specification). + +Some of these calls can require user interaction. Clients must be aware that responses may be delayed significantly or may never be received if a user decides to ignore the confirmation request. + +The External API is **untrusted**: it does not accept credentials, nor does it expect that requests have any authority. + +### Internal UI API + +Clef has one native console-based UI, for operation without any standalone tools. However, there is also an API to communicate with an external UI. To enable that UI, the signer needs to be executed with the `--stdio-ui` option, which allocates `stdin` / `stdout` for the UI API. + +An example (insecure) proof-of-concept of has been implemented in `pythonsigner.py`. + +The model is as follows: + +* The user starts the UI app (`pythonsigner.py`). +* The UI app starts `clef` with `--stdio-ui`, and listens to the +process output for confirmation-requests. +* `clef` opens the external HTTP API. +* When the `signer` receives requests, it sends a JSON-RPC request via `stdout`. +* The UI app prompts the user accordingly, and responds to `clef`. +* `clef` signs (or not), and responds to the original request. + +### More resoruces + + +* Changelog for [External API](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/extapi_changelog.md) +* Changelog for [UI API](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/intapi_changelog.md) +* Documentation about [Datatypes](datatypes) + + +## External API + +See the [external API changelog](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/extapi_changelog.md) for information about changes to this API. + + +### Encoding +- number: positive integers that are hex encoded +- data: hex encoded data +- string: ASCII string + +All hex encoded values must be prefixed with `0x`. + +### account_new + +#### Create new password protected account + +The signer will generate a new private key, encrypt it according to [web3 keystore spec](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) and store it in the keystore directory. +The client is responsible for creating a backup of the keystore. If the keystore is lost there is no method of retrieving lost accounts. + +#### Arguments + +None + +#### Result + - address [string]: account address that is derived from the generated key + +#### Sample call +```json +{ + "id": 0, + "jsonrpc": "2.0", + "method": "account_new", + "params": [] +} +``` +Response +```json +{ + "id": 0, + "jsonrpc": "2.0", + "result": "0xbea9183f8f4f03d427f6bcea17388bdff1cab133" +} +``` + +### account_list + +#### List available accounts + List all accounts that this signer currently manages + +#### Arguments + +None + +#### Result + - array with account records: + - account.address [string]: account address that is derived from the generated key + +#### Sample call +```json +{ + "id": 1, + "jsonrpc": "2.0", + "method": "account_list" +} +``` +Response +```json +{ + "id": 1, + "jsonrpc": "2.0", + "result": [ + "0xafb2f771f58513609765698f65d3f2f0224a956f", + "0xbea9183f8f4f03d427f6bcea17388bdff1cab133" + ] +} +``` + +### account_signTransaction + +#### Sign transactions + Signs a transaction and responds with the signed transaction in RLP-encoded and JSON forms. Supports both legacy and EIP-1559-style transactions. + +#### Arguments + 1. transaction object (legacy): + - `from` [address]: account to send the transaction from + - `to` [address]: receiver account. If omitted or `0x`, will cause contract creation. + - `gas` [number]: maximum amount of gas to burn + - `gasPrice` [number]: gas price + - `value` [number:optional]: amount of Wei to send with the transaction + - `data` [data:optional]: input data + - `nonce` [number]: account nonce + 1. transaction object (1559): + - `from` [address]: account to send the transaction from + - `to` [address]: receiver account. If omitted or `0x`, will cause contract creation. + - `gas` [number]: maximum amount of gas to burn + - `maxPriorityFeePerGas` [number]: maximum priority fee per unit of gas for the transaction + - `maxFeePerGas` [number]: maximum fee per unit of gas for the transaction + - `value` [number:optional]: amount of Wei to send with the transaction + - `data` [data:optional]: input data + - `nonce` [number]: account nonce + 3. method signature [string:optional] + - The method signature, if present, is to aid decoding the calldata. Should consist of `methodname(paramtype,...)`, e.g. `transfer(uint256,address)`. The signer may use this data to parse the supplied calldata, and show the user. The data, however, is considered totally untrusted, and reliability is not expected. + + +#### Result + - raw [data]: signed transaction in RLP encoded form + - tx [json]: signed transaction in JSON form + +#### Sample call (legacy) +```json +{ + "id": 2, + "jsonrpc": "2.0", + "method": "account_signTransaction", + "params": [ + { + "from": "0x1923f626bb8dc025849e00f99c25fe2b2f7fb0db", + "gas": "0x55555", + "gasPrice": "0x1234", + "input": "0xabcd", + "nonce": "0x0", + "to": "0x07a565b7ed7d7a678680a4c162885bedbb695fe0", + "value": "0x1234" + } + ] +} +``` +Response + +```json +{ + "jsonrpc": "2.0", + "id": 2, + "result": { + "raw": "0xf88380018203339407a565b7ed7d7a678680a4c162885bedbb695fe080a44401a6e4000000000000000000000000000000000000000000000000000000000000001226a0223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20ea02aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663", + "tx": { + "nonce": "0x0", + "gasPrice": "0x1234", + "gas": "0x55555", + "to": "0x07a565b7ed7d7a678680a4c162885bedbb695fe0", + "value": "0x1234", + "input": "0xabcd", + "v": "0x26", + "r": "0x223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20e", + "s": "0x2aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663", + "hash": "0xeba2df809e7a612a0a0d444ccfa5c839624bdc00dd29e3340d46df3870f8a30e" + } + } +} +``` + +#### Sample call (1559) +```json +{ + "id": 2, + "jsonrpc": "2.0", + "method": "account_signTransaction", + "params": [ + { + "from": "0xd1a9C60791e8440AEd92019a2C3f6c336ffefA27", + "to": "0x8A8eAFb1cf62BfBeb1741769DAE1a9dd47996192", + "gas": "0x33333", + "maxPriorityFeePerGas": "0x174876E800", + "maxFeePerGas": "0x174876E800", + "nonce": "0x0", + "value": "0x10", + "data": "0x4401a6e40000000000000000000000000000000000000000000000000000000000000012" + } + ] +} +``` +Response + +```json +{ + "jsonrpc": "2.0", + "id": 2, + "result": { + "raw": "0x02f891018085174876e80085174876e80083033333948a8eafb1cf62bfbeb1741769dae1a9dd4799619210a44401a6e40000000000000000000000000000000000000000000000000000000000000012c080a0c8b59180c6e0c154284402b52d772f1afcf8ec2d245cf75bfb3212ebe676135ba02c660aaebf92d5e314fc2ba4c70f018915d174c3c1fc6e4e38d00ebf1a5bb69f", + "tx": { + "type": "0x2", + "nonce": "0x0", + "gasPrice": null, + "maxPriorityFeePerGas": "0x174876e800", + "maxFeePerGas": "0x174876e800", + "gas": "0x33333", + "value": "0x10", + "input": "0x4401a6e40000000000000000000000000000000000000000000000000000000000000012", + "v": "0x0", + "r": "0xc8b59180c6e0c154284402b52d772f1afcf8ec2d245cf75bfb3212ebe676135b", + "s": "0x2c660aaebf92d5e314fc2ba4c70f018915d174c3c1fc6e4e38d00ebf1a5bb69f", + "to": "0x8a8eafb1cf62bfbeb1741769dae1a9dd47996192", + "chainId": "0x1", + "accessList": [], + "hash": "0x8e096eb11ea89aa83900e6816fb182ff0adb2c85d270998ca2dd2394ec6c5a73" + } + } +} +``` + +#### Sample call with ABI-data + + +```json +{ + "id": 67, + "jsonrpc": "2.0", + "method": "account_signTransaction", + "params": [ + { + "from": "0x694267f14675d7e1b9494fd8d72fefe1755710fa", + "gas": "0x333", + "gasPrice": "0x1", + "nonce": "0x0", + "to": "0x07a565b7ed7d7a678680a4c162885bedbb695fe0", + "value": "0x0", + "data": "0x4401a6e40000000000000000000000000000000000000000000000000000000000000012" + }, + "safeSend(address)" + ] +} +``` +Response + +```json +{ + "jsonrpc": "2.0", + "id": 67, + "result": { + "raw": "0xf88380018203339407a565b7ed7d7a678680a4c162885bedbb695fe080a44401a6e4000000000000000000000000000000000000000000000000000000000000001226a0223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20ea02aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663", + "tx": { + "nonce": "0x0", + "gasPrice": "0x1", + "gas": "0x333", + "to": "0x07a565b7ed7d7a678680a4c162885bedbb695fe0", + "value": "0x0", + "input": "0x4401a6e40000000000000000000000000000000000000000000000000000000000000012", + "v": "0x26", + "r": "0x223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20e", + "s": "0x2aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663", + "hash": "0xeba2df809e7a612a0a0d444ccfa5c839624bdc00dd29e3340d46df3870f8a30e" + } + } +} +``` + +Bash example: +```bash +> curl -H "Content-Type: application/json" -X POST --data '{"jsonrpc":"2.0","method":"account_signTransaction","params":[{"from":"0x694267f14675d7e1b9494fd8d72fefe1755710fa","gas":"0x333","gasPrice":"0x1","nonce":"0x0","to":"0x07a565b7ed7d7a678680a4c162885bedbb695fe0", "value":"0x0", "data":"0x4401a6e40000000000000000000000000000000000000000000000000000000000000012"},"safeSend(address)"],"id":67}' http://localhost:8550/ + +{"jsonrpc":"2.0","id":67,"result":{"raw":"0xf88380018203339407a565b7ed7d7a678680a4c162885bedbb695fe080a44401a6e4000000000000000000000000000000000000000000000000000000000000001226a0223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20ea02aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663","tx":{"nonce":"0x0","gasPrice":"0x1","gas":"0x333","to":"0x07a565b7ed7d7a678680a4c162885bedbb695fe0","value":"0x0","input":"0x4401a6e40000000000000000000000000000000000000000000000000000000000000012","v":"0x26","r":"0x223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20e","s":"0x2aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663","hash":"0xeba2df809e7a612a0a0d444ccfa5c839624bdc00dd29e3340d46df3870f8a30e"}}} +``` + +### account_signData + +#### Sign data + Signs a chunk of data and returns the calculated signature. + +#### Arguments + - content type [string]: type of signed data + - `text/validator`: hex data with custom validator defined in a contract + - `application/clique`: [clique](https://github.com/ethereum/EIPs/issues/225) headers + - `text/plain`: simple hex data validated by `account_ecRecover` + - account [address]: account to sign with + - data [object]: data to sign + +#### Result + - calculated signature [data] + +#### Sample call +```json +{ + "id": 3, + "jsonrpc": "2.0", + "method": "account_signData", + "params": [ + "data/plain", + "0x1923f626bb8dc025849e00f99c25fe2b2f7fb0db", + "0xaabbccdd" + ] +} +``` +Response + +```json +{ + "id": 3, + "jsonrpc": "2.0", + "result": "0x5b6693f153b48ec1c706ba4169960386dbaa6903e249cc79a8e6ddc434451d417e1e57327872c7f538beeb323c300afa9999a3d4a5de6caf3be0d5ef832b67ef1c" +} +``` + +### account_signTypedData + +#### Sign data + Signs a chunk of structured data conformant to [EIP-712](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-712.md) and returns the calculated signature. + +#### Arguments + - account [address]: account to sign with + - data [object]: data to sign + +#### Result + - calculated signature [data] + +#### Sample call +```json +{ + "id": 68, + "jsonrpc": "2.0", + "method": "account_signTypedData", + "params": [ + "0xcd2a3d9f938e13cd947ec05abc7fe734df8dd826", + { + "types": { + "EIP712Domain": [ + { + "name": "name", + "type": "string" + }, + { + "name": "version", + "type": "string" + }, + { + "name": "chainId", + "type": "uint256" + }, + { + "name": "verifyingContract", + "type": "address" + } + ], + "Person": [ + { + "name": "name", + "type": "string" + }, + { + "name": "wallet", + "type": "address" + } + ], + "Mail": [ + { + "name": "from", + "type": "Person" + }, + { + "name": "to", + "type": "Person" + }, + { + "name": "contents", + "type": "string" + } + ] + }, + "primaryType": "Mail", + "domain": { + "name": "Ether Mail", + "version": "1", + "chainId": 1, + "verifyingContract": "0xCcCCccccCCCCcCCCCCCcCcCccCcCCCcCcccccccC" + }, + "message": { + "from": { + "name": "Cow", + "wallet": "0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826" + }, + "to": { + "name": "Bob", + "wallet": "0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB" + }, + "contents": "Hello, Bob!" + } + } + ] +} +``` +Response + +```json +{ + "id": 1, + "jsonrpc": "2.0", + "result": "0x4355c47d63924e8a72e509b65029052eb6c299d53a04e167c5775fd466751c9d07299936d304c153f6443dfa05f40ff007d72911b6f72307f996231605b915621c" +} +``` + +### account_ecRecover + +#### Recover the signing address + +Derive the address from the account that was used to sign data with content type `text/plain` and the signature. + +#### Arguments + - data [data]: data that was signed + - signature [data]: the signature to verify + +#### Result + - derived account [address] + +#### Sample call +```json +{ + "id": 4, + "jsonrpc": "2.0", + "method": "account_ecRecover", + "params": [ + "0xaabbccdd", + "0x5b6693f153b48ec1c706ba4169960386dbaa6903e249cc79a8e6ddc434451d417e1e57327872c7f538beeb323c300afa9999a3d4a5de6caf3be0d5ef832b67ef1c" + ] +} +``` +Response + +```json +{ + "id": 4, + "jsonrpc": "2.0", + "result": "0x1923f626bb8dc025849e00f99c25fe2b2f7fb0db" +} +``` + +### account_version + +#### Get external API version + +Get the version of the external API used by Clef. + +#### Arguments + +None + +#### Result + +* external API version [string] + +#### Sample call +```json +{ + "id": 0, + "jsonrpc": "2.0", + "method": "account_version", + "params": [] +} +``` + +Response +```json +{ + "id": 0, + "jsonrpc": "2.0", + "result": "6.0.0" +} +``` + +## UI API + +These methods needs to be implemented by a UI listener. + +By starting the signer with the switch `--stdio-ui-test`, the signer will invoke all known methods, and expect the UI to respond with +denials. This can be used during development to ensure that the API is (at least somewhat) correctly implemented. +See `pythonsigner`, which can be invoked via `python3 pythonsigner.py test` to perform the 'denial-handshake-test'. + +All methods in this API use object-based parameters, so that there can be no mixup of parameters: each piece of data is accessed by key. + +See the [ui API changelog](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/intapi_changelog.md) for information about changes to this API. + +OBS! A slight deviation from `json` standard is in place: every request and response should be confined to a single line. +Whereas the `json` specification allows for linebreaks, linebreaks __should not__ be used in this communication channel, to make +things simpler for both parties. + +### ApproveTx / `ui_approveTx` + +Invoked when there's a transaction for approval. + + +#### Sample call + +Here's a method invocation: +```bash + +curl -i -H "Content-Type: application/json" -X POST --data '{"jsonrpc":"2.0","method":"account_signTransaction","params":[{"from":"0x694267f14675d7e1b9494fd8d72fefe1755710fa","gas":"0x333","gasPrice":"0x1","nonce":"0x0","to":"0x07a565b7ed7d7a678680a4c162885bedbb695fe0", "value":"0x0", "data":"0x4401a6e40000000000000000000000000000000000000000000000000000000000000012"},"safeSend(address)"],"id":67}' http://localhost:8550/ +``` +Results in the following invocation on the UI: +```json + +{ + "jsonrpc": "2.0", + "id": 1, + "method": "ui_approveTx", + "params": [ + { + "transaction": { + "from": "0x0x694267f14675d7e1b9494fd8d72fefe1755710fa", + "to": "0x0x07a565b7ed7d7a678680a4c162885bedbb695fe0", + "gas": "0x333", + "gasPrice": "0x1", + "value": "0x0", + "nonce": "0x0", + "data": "0x4401a6e40000000000000000000000000000000000000000000000000000000000000012", + "input": null + }, + "call_info": [ + { + "type": "WARNING", + "message": "Invalid checksum on to-address" + }, + { + "type": "Info", + "message": "safeSend(address: 0x0000000000000000000000000000000000000012)" + } + ], + "meta": { + "remote": "127.0.0.1:48486", + "local": "localhost:8550", + "scheme": "HTTP/1.1" + } + } + ] +} + +``` + +The same method invocation, but with invalid data: +```bash + +curl -i -H "Content-Type: application/json" -X POST --data '{"jsonrpc":"2.0","method":"account_signTransaction","params":[{"from":"0x694267f14675d7e1b9494fd8d72fefe1755710fa","gas":"0x333","gasPrice":"0x1","nonce":"0x0","to":"0x07a565b7ed7d7a678680a4c162885bedbb695fe0", "value":"0x0", "data":"0x4401a6e40000000000000002000000000000000000000000000000000000000000000012"},"safeSend(address)"],"id":67}' http://localhost:8550/ +``` + +```json + +{ + "jsonrpc": "2.0", + "id": 1, + "method": "ui_approveTx", + "params": [ + { + "transaction": { + "from": "0x0x694267f14675d7e1b9494fd8d72fefe1755710fa", + "to": "0x0x07a565b7ed7d7a678680a4c162885bedbb695fe0", + "gas": "0x333", + "gasPrice": "0x1", + "value": "0x0", + "nonce": "0x0", + "data": "0x4401a6e40000000000000002000000000000000000000000000000000000000000000012", + "input": null + }, + "call_info": [ + { + "type": "WARNING", + "message": "Invalid checksum on to-address" + }, + { + "type": "WARNING", + "message": "Transaction data did not match ABI-interface: WARNING: Supplied data is stuffed with extra data. \nWant 0000000000000002000000000000000000000000000000000000000000000012\nHave 0000000000000000000000000000000000000000000000000000000000000012\nfor method safeSend(address)" + } + ], + "meta": { + "remote": "127.0.0.1:48492", + "local": "localhost:8550", + "scheme": "HTTP/1.1" + } + } + ] +} + + +``` + +One which has missing `to`, but with no `data`: + + +```json + +{ + "jsonrpc": "2.0", + "id": 3, + "method": "ui_approveTx", + "params": [ + { + "transaction": { + "from": "", + "to": null, + "gas": "0x0", + "gasPrice": "0x0", + "value": "0x0", + "nonce": "0x0", + "data": null, + "input": null + }, + "call_info": [ + { + "type": "CRITICAL", + "message": "Tx will create contract with empty code!" + } + ], + "meta": { + "remote": "signer binary", + "local": "main", + "scheme": "in-proc" + } + } + ] +} +``` + +### ApproveListing / `ui_approveListing` + +Invoked when a request for account listing has been made. + +#### Sample call + +```json + +{ + "jsonrpc": "2.0", + "id": 5, + "method": "ui_approveListing", + "params": [ + { + "accounts": [ + { + "url": "keystore:///home/bazonk/.ethereum/keystore/UTC--2017-11-20T14-44-54.089682944Z--123409812340981234098123409812deadbeef42", + "address": "0x123409812340981234098123409812deadbeef42" + }, + { + "url": "keystore:///home/bazonk/.ethereum/keystore/UTC--2017-11-23T21-59-03.199240693Z--cafebabedeadbeef34098123409812deadbeef42", + "address": "0xcafebabedeadbeef34098123409812deadbeef42" + } + ], + "meta": { + "remote": "signer binary", + "local": "main", + "scheme": "in-proc" + } + } + ] +} + +``` + + +### ApproveSignData / `ui_approveSignData` + +#### Sample call + +```json +{ + "jsonrpc": "2.0", + "id": 4, + "method": "ui_approveSignData", + "params": [ + { + "address": "0x123409812340981234098123409812deadbeef42", + "raw_data": "0x01020304", + "messages": [ + { + "name": "message", + "value": "\u0019Ethereum Signed Message:\n4\u0001\u0002\u0003\u0004", + "type": "text/plain" + } + ], + "hash": "0x7e3a4e7a9d1744bc5c675c25e1234ca8ed9162bd17f78b9085e48047c15ac310", + "meta": { + "remote": "signer binary", + "local": "main", + "scheme": "in-proc" + } + } + ] +} +``` + +### ApproveNewAccount / `ui_approveNewAccount` + +Invoked when a request for creating a new account has been made. + +#### Sample call + +```json +{ + "jsonrpc": "2.0", + "id": 4, + "method": "ui_approveNewAccount", + "params": [ + { + "meta": { + "remote": "signer binary", + "local": "main", + "scheme": "in-proc" + } + } + ] +} +``` + +### ShowInfo / `ui_showInfo` + +The UI should show the info (a single message) to the user. Does not expect response. + +#### Sample call + +```json +{ + "jsonrpc": "2.0", + "id": 9, + "method": "ui_showInfo", + "params": [ + "Tests completed" + ] +} + +``` + +### ShowError / `ui_showError` + +The UI should show the error (a single message) to the user. Does not expect response. + +```json + +{ + "jsonrpc": "2.0", + "id": 2, + "method": "ui_showError", + "params": [ + "Something bad happened!" + ] +} + +``` + +### OnApprovedTx / `ui_onApprovedTx` + +`OnApprovedTx` is called when a transaction has been approved and signed. The call contains the return value that will be sent to the external caller. The return value from this method is ignored - the reason for having this callback is to allow the ruleset to keep track of approved transactions. + +When implementing rate-limited rules, this callback should be used. + +TLDR; Use this method to keep track of signed transactions, instead of using the data in `ApproveTx`. + +Example call: +```json + +{ + "jsonrpc": "2.0", + "id": 1, + "method": "ui_onApprovedTx", + "params": [ + { + "raw": "0xf88380018203339407a565b7ed7d7a678680a4c162885bedbb695fe080a44401a6e4000000000000000000000000000000000000000000000000000000000000001226a0223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20ea02aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663", + "tx": { + "nonce": "0x0", + "gasPrice": "0x1", + "gas": "0x333", + "to": "0x07a565b7ed7d7a678680a4c162885bedbb695fe0", + "value": "0x0", + "input": "0x4401a6e40000000000000000000000000000000000000000000000000000000000000012", + "v": "0x26", + "r": "0x223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20e", + "s": "0x2aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663", + "hash": "0xeba2df809e7a612a0a0d444ccfa5c839624bdc00dd29e3340d46df3870f8a30e" + } + } + ] +} +``` + +### OnSignerStartup / `ui_onSignerStartup` + +This method provides the UI with information about what API version the signer uses (both internal and external) as well as build-info and external API, +in k/v-form. + +Example call: +```json + +{ + "jsonrpc": "2.0", + "id": 1, + "method": "ui_onSignerStartup", + "params": [ + { + "info": { + "extapi_http": "http://localhost:8550", + "extapi_ipc": null, + "extapi_version": "2.0.0", + "intapi_version": "1.2.0" + } + } + ] +} + +``` + +### OnInputRequired / `ui_onInputRequired` + +Invoked when Clef requires user input (e.g. a password). + +Example call: +```json + +{ + "jsonrpc": "2.0", + "id": 1, + "method": "ui_onInputRequired", + "params": [ + { + "title": "Account password", + "prompt": "Please enter the password for account 0x694267f14675d7e1b9494fd8d72fefe1755710fa", + "isPassword": true + } + ] +} +``` diff --git a/content/docs/tools/Clef/datatypes.md b/content/docs/tools/Clef/datatypes.md new file mode 100644 index 0000000000..bdf8e2782d --- /dev/null +++ b/content/docs/tools/Clef/datatypes.md @@ -0,0 +1,229 @@ +--- +title: Communication data types +sort_key: F +--- + +## UI Client interface + +These data types are defined in the channel between clef and the UI +### SignDataRequest + +SignDataRequest contains information about a pending request to sign some data. The data to be signed can be of various types, defined by content-type. Clef has done most of the work in canonicalizing and making sense of the data, and it's up to the UI to present the user with the contents of the `message` + +Example: +```json +{ + "content_type": "text/plain", + "address": "0xDEADbEeF000000000000000000000000DeaDbeEf", + "raw_data": "GUV0aGVyZXVtIFNpZ25lZCBNZXNzYWdlOgoxMWhlbGxvIHdvcmxk", + "messages": [ + { + "name": "message", + "value": "\u0019Ethereum Signed Message:\n11hello world", + "type": "text/plain" + } + ], + "hash": "0xd9eba16ed0ecae432b71fe008c98cc872bb4cc214d3220a36f365326cf807d68", + "meta": { + "remote": "localhost:9999", + "local": "localhost:8545", + "scheme": "http", + "User-Agent": "Firefox 3.2", + "Origin": "www.malicious.ru" + } +} +``` +### SignDataResponse - approve + +Response to SignDataRequest + +Example: +```json +{ + "approved": true +} +``` +### SignDataResponse - deny + +Response to SignDataRequest + +Example: +```json +{ + "approved": false +} +``` +### SignTxRequest + +SignTxRequest contains information about a pending request to sign a transaction. Aside from the transaction itself, there is also a `call_info`-struct. That struct contains messages of various types, that the user should be informed of. + +As in any request, it's important to consider that the `meta` info also contains untrusted data. + +The `transaction` (on input into clef) can have either `data` or `input` -- if both are set, they must be identical, otherwise an error is generated. However, Clef will always use `data` when passing this struct on (if Clef does otherwise, please file a ticket) + +Example: +```json +{ + "transaction": { + "from": "0xDEADbEeF000000000000000000000000DeaDbeEf", + "to": null, + "gas": "0x3e8", + "gasPrice": "0x5", + "value": "0x6", + "nonce": "0x1", + "data": "0x01020304" + }, + "call_info": [ + { + "type": "Warning", + "message": "Something looks odd, show this message as a warning" + }, + { + "type": "Info", + "message": "User should see this aswell" + } + ], + "meta": { + "remote": "localhost:9999", + "local": "localhost:8545", + "scheme": "http", + "User-Agent": "Firefox 3.2", + "Origin": "www.malicious.ru" + } +} +``` +### SignTxResponse - approve + +Response to request to sign a transaction. This response needs to contain the `transaction`, because the UI is free to make modifications to the transaction. + +Example: +```json +{ + "transaction": { + "from": "0xDEADbEeF000000000000000000000000DeaDbeEf", + "to": null, + "gas": "0x3e8", + "gasPrice": "0x5", + "value": "0x6", + "nonce": "0x4", + "data": "0x04030201" + }, + "approved": true +} +``` +### SignTxResponse - deny + +Response to SignTxRequest. When denying a request, there's no need to provide the transaction in return + +Example: +```json +{ + "transaction": { + "from": "0x", + "to": null, + "gas": "0x0", + "gasPrice": "0x0", + "value": "0x0", + "nonce": "0x0", + "data": null + }, + "approved": false +} +``` +### OnApproved - SignTransactionResult + +SignTransactionResult is used in the call `clef` -> `OnApprovedTx(result)` + +This occurs _after_ successful completion of the entire signing procedure, but right before the signed transaction is passed to the external caller. This method (and data) can be used by the UI to signal to the user that the transaction was signed, but it is primarily useful for ruleset implementations. + +A ruleset that implements a rate limitation needs to know what transactions are sent out to the external interface. By hooking into this methods, the ruleset can maintain track of that count. + +**OBS:** Note that if an attacker can restore your `clef` data to a previous point in time (e.g through a backup), the attacker can reset such windows, even if he/she is unable to decrypt the content. + +The `OnApproved` method cannot be responded to, it's purely informative + +Example: +```json +{ + "raw": "0xf85d640101948a8eafb1cf62bfbeb1741769dae1a9dd47996192018026a0716bd90515acb1e68e5ac5867aa11a1e65399c3349d479f5fb698554ebc6f293a04e8a4ebfff434e971e0ef12c5bf3a881b06fd04fc3f8b8a7291fb67a26a1d4ed", + "tx": { + "nonce": "0x64", + "gasPrice": "0x1", + "gas": "0x1", + "to": "0x8a8eafb1cf62bfbeb1741769dae1a9dd47996192", + "value": "0x1", + "input": "0x", + "v": "0x26", + "r": "0x716bd90515acb1e68e5ac5867aa11a1e65399c3349d479f5fb698554ebc6f293", + "s": "0x4e8a4ebfff434e971e0ef12c5bf3a881b06fd04fc3f8b8a7291fb67a26a1d4ed", + "hash": "0x662f6d772692dd692f1b5e8baa77a9ff95bbd909362df3fc3d301aafebde5441" + } +} +``` +### UserInputRequest + +Sent when clef needs the user to provide data. If 'password' is true, the input field should be treated accordingly (echo-free) + +Example: +```json +{ + "prompt": "The question to ask the user", + "title": "The title here", + "isPassword": true +} +``` +### UserInputResponse + +Response to UserInputRequest + +Example: +```json +{ + "text": "The textual response from user" +} +``` +### ListRequest + +Sent when a request has been made to list addresses. The UI is provided with the full `account`s, including local directory names. Note: this information is not passed back to the external caller, who only sees the `address`es. + +Example: +```json +{ + "accounts": [ + { + "address": "0xdeadbeef000000000000000000000000deadbeef", + "url": "keystore:///path/to/keyfile/a" + }, + { + "address": "0x1111111122222222222233333333334444444444", + "url": "keystore:///path/to/keyfile/b" + } + ], + "meta": { + "remote": "localhost:9999", + "local": "localhost:8545", + "scheme": "http", + "User-Agent": "Firefox 3.2", + "Origin": "www.malicious.ru" + } +} +``` +### ListResponse + +Response to list request. The response contains a list of all addresses to show to the caller. Note: the UI is free to respond with any address the caller, regardless of whether it exists or not + +Example: +```json +{ + "accounts": [ + { + "address": "0x0000000000000000000000000000000000000000", + "url": ".. ignored .." + }, + { + "address": "0xffffffffffffffffffffffffffffffffffffffff", + "url": "" + } + ] +} +``` diff --git a/content/homepage.md b/content/homepage.md new file mode 100644 index 0000000000..8671709070 --- /dev/null +++ b/content/homepage.md @@ -0,0 +1,27 @@ +--- +title: Home +root: .. +--- + +## What is Geth? + +Geth (go-ethereum) is a [Go](https://go.dev/) implementation of [Ethereum](http://ethereum.org) - a +gateway into the decentralized web. + +Geth has been a core part of Etheruem since the very beginning. Geth was one of the original +Ethereum implementations making it the most battle-hardened and tested client. + +Geth is an Ethereum *execution client* meaning it handles transactions, deployment and execution +of smart contracts and contains an embedded computer known as the *Ethereum Virtual Machine*. + + +## What is Ethereum? + +Ethereum is a technology for building apps and organizations, holding assets, transacting and +communicating without being controlled by a central authority. It is the base of a new, decentralized +internet. + +Read more on our [Ethereum page](/ethereum) or on [ethereum.org](http://ethereum.org). + + + diff --git a/misc/page-tracker.xlsx b/misc/page-tracker.xlsx new file mode 100644 index 0000000000000000000000000000000000000000..c248c3bcaa4ca496e2b8ba8ba1cadc5b7a6af263 GIT binary patch literal 6742 zcmaKR1ys~s*Doa@-3+BXU?wq?cY&VKtv*dLq$b})3?6XfcrzxAD)e!&23%S*&g4^jN?kLHOu5yT{lk@)GAiSYe)US2Q$~|UZDewXn{acebA~AXHn8H(@CPGQw%HX!)h!2&=qne#iX_LC$%@e#In^P_u^)4b8wQ=Uf?UgiKT z8b0*pMvo`Fjgk=m9NA)}(KyB0GdqAkaRWl9-t}7?#oJW$Z-T(!D{2hGFSMaiW7xcm z2Vxkq(Y;GrIn}oHtiiy-3Yr-HQA;CyC~!Fas#F_n9F=t9?PsMn6s~4%qmZjS#oUV-y{NF9 zfqTOFh9J+46llh_W%g5_2-5PM(=A`;S)D%2IFF9}xBoKVc!X+0uDxuoB zNE|15U{VB0-(ttX*kriQ3X_;~=2G>Yd?H?k1|{<|9GhP9mr{NnDvr}o<=7WP1o6;} z|KWPCprmGoEO;xx#Ch~iYQ(oKQ+mpbFA8}=kOH&&*q!T=gG>c^*DiH(C0>b3#V@{$ zVlU8FPG&hL+hGHK2pX*Ab@;r&J<)q;?~anYL%Vm6_%UWaedLD1;Njrx5&tb_F#i)X zF0LN7<}QyB1JymMOb{lxJ2V!*HZ%bchnghsd&BzJ`*wIaIemAss`@75CwI4u9k3xJ z2Mu@0^oR6Stm7`%>92jp-pjOXTveDZ5z~@0Um_@dMH-+J#(%ZBi2&-*7x_w8`8Ihw z8BLkUN`>rP*e8+4`ujjDCe6?k?#Eg&^87u^_GL42wbiZgBDC4B5(7_JAc^_QKjK%~ z;8nlQ{H1oPwB_jtRI?�>guTQEel2=pKk4PI@}kD~cqW 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 literal 0 HcmV?d00001 From ba2cdc567fbae26ee039fa4285405b568c15c45d Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 27 Jul 2022 13:41:56 +0100 Subject: [PATCH 003/432] add placeholders for blog and downloads --- blog/index.md | 1 + downloads/index.md | 1 + 2 files changed, 2 insertions(+) create mode 100644 blog/index.md create mode 100644 downloads/index.md diff --git a/blog/index.md b/blog/index.md new file mode 100644 index 0000000000..e59d0382ee --- /dev/null +++ b/blog/index.md @@ -0,0 +1 @@ +boop diff --git a/downloads/index.md b/downloads/index.md new file mode 100644 index 0000000000..0f700ee2a1 --- /dev/null +++ b/downloads/index.md @@ -0,0 +1 @@ +beep From 19a11731bd79da97db7ce227eba65da523a9c0c2 Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 27 Jul 2022 13:50:45 +0100 Subject: [PATCH 004/432] add resource list to readme --- README.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/README.md b/README.md index f16547e5f1..7e90b7b622 100644 --- a/README.md +++ b/README.md @@ -2,3 +2,9 @@ This repo will act as a shared workspace for the geth website team in developing new content, designs etc +Resources: + +- the project management notes: https://www.notion.so/efdn/Geth-Site-project-management-b750d23d90694b2cb90f6fa729afb1df +- some draft figma files for design sketching: https://www.figma.com/file/ekzIgwyeVKLtFSAcnA0Q0D/geth-website?node-id=6%3A31 +- content planning notes: https://www.notion.so/efdn/Content-Strategy-3252234338814a749374fa7f11049083 +- meeting notes: https://www.notion.so/efdn/Call-notes-46aa0202810a402ebfda07b046761cbd From da2f82ff3c0eccb16a4980509e2510f4d331af6a Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 28 Jul 2022 09:43:09 +0100 Subject: [PATCH 005/432] update content structure --- .../developers/geth-developer/contributing.md | 34 +++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 content/docs/developers/geth-developer/contributing.md diff --git a/content/docs/developers/geth-developer/contributing.md b/content/docs/developers/geth-developer/contributing.md new file mode 100644 index 0000000000..f01d2c1a59 --- /dev/null +++ b/content/docs/developers/geth-developer/contributing.md @@ -0,0 +1,34 @@ +--- +title: Contributing +--- + +We welcome contributions from anyone on the internet, and are grateful for even the smallest of fixes! + +## Contributing to the Geth source code + +If you'd like to contribute to the Geth source code, please fork the +[Github repository](https://github.com/ethereum/go-ethereum), fix, commit and send a pull request for the +maintainers to review and merge into the main code base. If you wish to submit more complex changes +though, please check up with the core devs first on our Discord Server to ensure those changes are in +line with the general philosophy of the project and/or get some early feedback which can make both your +efforts much lighter as well as our review and merge procedures quick and simple. + +Please make sure your contributions adhere to our coding guidelines: + +* Code must adhere to the official Go formatting guidelines (i.e. uses gofmt). +* Code must be documented adhering to the official Go commentary guidelines. +* Pull requests need to be based on and opened against the master branch. +* Commit messages should be prefixed with the package(s) they modify. + E.g. "eth, rpc: make trace configs optional" + + +## Contributing to the Geth website + +The Geth website is hosted separately from Geth itself. The contribution guidelines are the same. Please +for the Geth website Github repository and raise pull requests for the maintainers to review and merge. + +## License + +The go-ethereum library (i.e. all code outside of the cmd directory) is licensed under the GNU Lesser General Public License v3.0, also included in our repository in the COPYING.LESSER file. + +The go-ethereum binaries (i.e. all code inside of the cmd directory) is licensed under the GNU General Public License v3.0, also included in our repository in the COPYING file. From 40f24dbf3c6bdc09ead1711adc20ce3c87788742 Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 28 Jul 2022 09:46:58 +0100 Subject: [PATCH 006/432] update content structure --- blog/index.md | 1 - content/about-geth/about_us.md | 0 content/about-geth/contributing.md | 34 ----------- content/about-geth/ethereum.md | 56 ------------------- content/{about-geth => docs}/faq.md | 0 .../fundamentals/node-architecture.md} | 40 ------------- content/homepage.md | 12 ++++ 7 files changed, 12 insertions(+), 131 deletions(-) delete mode 100644 blog/index.md delete mode 100644 content/about-geth/about_us.md delete mode 100644 content/about-geth/contributing.md delete mode 100644 content/about-geth/ethereum.md rename content/{about-geth => docs}/faq.md (100%) rename content/{about-geth/about_geth.md => docs/fundamentals/node-architecture.md} (65%) diff --git a/blog/index.md b/blog/index.md deleted file mode 100644 index e59d0382ee..0000000000 --- a/blog/index.md +++ /dev/null @@ -1 +0,0 @@ -boop diff --git a/content/about-geth/about_us.md b/content/about-geth/about_us.md deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/content/about-geth/contributing.md b/content/about-geth/contributing.md deleted file mode 100644 index f01d2c1a59..0000000000 --- a/content/about-geth/contributing.md +++ /dev/null @@ -1,34 +0,0 @@ ---- -title: Contributing ---- - -We welcome contributions from anyone on the internet, and are grateful for even the smallest of fixes! - -## Contributing to the Geth source code - -If you'd like to contribute to the Geth source code, please fork the -[Github repository](https://github.com/ethereum/go-ethereum), fix, commit and send a pull request for the -maintainers to review and merge into the main code base. If you wish to submit more complex changes -though, please check up with the core devs first on our Discord Server to ensure those changes are in -line with the general philosophy of the project and/or get some early feedback which can make both your -efforts much lighter as well as our review and merge procedures quick and simple. - -Please make sure your contributions adhere to our coding guidelines: - -* Code must adhere to the official Go formatting guidelines (i.e. uses gofmt). -* Code must be documented adhering to the official Go commentary guidelines. -* Pull requests need to be based on and opened against the master branch. -* Commit messages should be prefixed with the package(s) they modify. - E.g. "eth, rpc: make trace configs optional" - - -## Contributing to the Geth website - -The Geth website is hosted separately from Geth itself. The contribution guidelines are the same. Please -for the Geth website Github repository and raise pull requests for the maintainers to review and merge. - -## License - -The go-ethereum library (i.e. all code outside of the cmd directory) is licensed under the GNU Lesser General Public License v3.0, also included in our repository in the COPYING.LESSER file. - -The go-ethereum binaries (i.e. all code inside of the cmd directory) is licensed under the GNU General Public License v3.0, also included in our repository in the COPYING file. diff --git a/content/about-geth/ethereum.md b/content/about-geth/ethereum.md deleted file mode 100644 index 7515053e4c..0000000000 --- a/content/about-geth/ethereum.md +++ /dev/null @@ -1,56 +0,0 @@ ---- -title: Intro to Ethereum -description: A brief introduction to Ethereum. ---- - - -Ethereum is a technology for building apps and organizations, holding assets, transacting and -communicating without being controlled by a central authority. There is no need to hand over all -your personal details to use Ethereum - you keep control of your own data and what is being shared. -Ethereum has its own cryptocurrency, Ether (ETH), which is used to pay for certain activities on -the Ethereum network. In essence, Ethereum is a blockchain with an embedded computer. - - -## What is a blockchain? - -A blockchain is a database of transactions that is updated and shared across many computers in a -network. Every time a new set of transactions is added, its called a “block” - hence the name -blockchain. Most blockchains are public and immutable, and you can only add data, not remove. If someone -wanted to alter any of the information or cheat the system, they’d need to do so in such a way that the -majority of computers on the network accept. There are very strong crypto-economic defenses against this -on Ethereum. This makes established blockchains like Ethereum highly secure base-layers for organizations -and applications. - - -## What are smart contracts? - -Smart contracts are computer programs living on the Ethereum blockchain. They only execute when -triggered by a transaction from a user (or another contract). They make Ethereum very flexible in what -it can do and distinguish it from other cryptocurrencies. These programs are what we now call -decentralized apps, or dapps. - -Once a smart contract is published to Ethereum, it will be online and operational for as long as Ethereum -exists. Not even the author can take it down. Since smart contracts are automated, they do not discriminate -against any user and are always ready to use. - -Popular examples of smart contracts are lending apps, decentralized trading exchanges, insurance, -crowdfunding apps - basically anything you can think of. - - -## Who runs Ethereum? - -Ethereum is not controlled by any one entity. It exists solely through the decentralized participation -and cooperation of the community. Ethereum makes use of nodes (a computer with a copy of the Ethereum -blockchain data) run by volunteers to replace individual server and cloud systems owned by major -internet providers and services. - -These distributed nodes, run by individuals and businesses all over the world, provide resiliency to -the Ethereum network infrastructure. It is therefore much less vulnerable to hacks or shutdowns. -Since its launch in 2015, Ethereum has never suffered downtime. There are thousands of individual nodes -running Ethereum network. - - -## Learn more about Ethereum - -[ethereum.org](https://ethereum.org/) - diff --git a/content/about-geth/faq.md b/content/docs/faq.md similarity index 100% rename from content/about-geth/faq.md rename to content/docs/faq.md diff --git a/content/about-geth/about_geth.md b/content/docs/fundamentals/node-architecture.md similarity index 65% rename from content/about-geth/about_geth.md rename to content/docs/fundamentals/node-architecture.md index c66810c594..9ad8662e1e 100644 --- a/content/about-geth/about_geth.md +++ b/content/docs/fundamentals/node-architecture.md @@ -1,41 +1,3 @@ ---- -title: What is Geth -root: .. ---- - -## What is Geth? - -Geth (go-ethereum) is a [Go](https://go.dev/) implementation of [Ethereum](http://ethereum.org) - a -gateway into the decentralized web. - -Running Geth alongside a consensus client turns a computer into an Ethereum node. -Nodes communicate with one another, agreeing on the data they should each add to their local databases. -Ethereum itself is the network of connected nodes running Ethereum software. - - -## Why run a node? - -Running your own node enables you to use Ethereum in a truly private, self-sufficient and trustless -manner. You don't need to trust information you receive because you can verify the data yourself -using your Geth instance. - -**"Don't trust, verify"** - -![node basic](/assets/node-basic.png) - -Your node verifies all changes to its database by itself. This means: - -- you don’t have to trust any other nodes in the network. -- You never have to leak your addresses and balances to other nodes. -- You can use Ethereum securely and privately. Most wallet software can be pointed to your own local node. -- You can program your own custom RPC endpoints and make your own modifications to the source code. -- You get low latency, fast access to Ethereum. - -A large and diverse set of nodes independently verifying new information is critical for Ethereum’s health, -security and operational resiliency. - -**If you run a full node, the whole Ethereum network benefits.** - ## Node architecture @@ -82,5 +44,3 @@ In summary, Geth is: - - diff --git a/content/homepage.md b/content/homepage.md index 8671709070..eb6ec09174 100644 --- a/content/homepage.md +++ b/content/homepage.md @@ -14,6 +14,7 @@ Ethereum implementations making it the most battle-hardened and tested client. Geth is an Ethereum *execution client* meaning it handles transactions, deployment and execution of smart contracts and contains an embedded computer known as the *Ethereum Virtual Machine*. +Running Geth alongside a consensus client turns a computer into an Ethereum node. ## What is Ethereum? @@ -24,4 +25,15 @@ internet. Read more on our [Ethereum page](/ethereum) or on [ethereum.org](http://ethereum.org). +## Why run a node? + +Running your own node enables you to use Ethereum in a truly private, self-sufficient and trustless +manner. You don't need to trust information you receive because you can verify the data yourself +using your Geth instance. + +**"Don't trust, verify"** + +[Read more about running a node](http://https://ethereum.org/en/run-a-node/#main-content) + + From 9d3ed9287fa9986ea5a25838ab4187ce14764a2f Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 28 Jul 2022 09:48:09 +0100 Subject: [PATCH 007/432] move downloads to content --- {downloads => content/downloads/downloads}/index.md | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename {downloads => content/downloads/downloads}/index.md (100%) diff --git a/downloads/index.md b/content/downloads/downloads/index.md similarity index 100% rename from downloads/index.md rename to content/downloads/downloads/index.md From 6b24a1e50bfbfa118db48231db495c5f17f8885d Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 28 Jul 2022 09:49:00 +0100 Subject: [PATCH 008/432] update link to content planning docs --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 7e90b7b622..735b089fed 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ This repo will act as a shared workspace for the geth website team in developing Resources: -- the project management notes: https://www.notion.so/efdn/Geth-Site-project-management-b750d23d90694b2cb90f6fa729afb1df +- the project management notes: https://www.notion.so/efdn/Build-new-Geth-website-bf35a46cfe5848db83ac3acb5191eb1c - some draft figma files for design sketching: https://www.figma.com/file/ekzIgwyeVKLtFSAcnA0Q0D/geth-website?node-id=6%3A31 - content planning notes: https://www.notion.so/efdn/Content-Strategy-3252234338814a749374fa7f11049083 - meeting notes: https://www.notion.so/efdn/Call-notes-46aa0202810a402ebfda07b046761cbd From 8285cccc7ca4820857d3f678470818fbf29ecb00 Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 28 Jul 2022 12:04:48 +0100 Subject: [PATCH 009/432] update pages to newest aproved versions --- .../{mobile/mobile-accounts.md => mobile.md} | 261 ++++---- .../dapp-developer/mobile/mobile.md | 180 ------ .../fundamentals/Managing-your-accounts.md | 402 +++++------- content/docs/fundamentals/mining.md | 208 ++++++ .../getting-started-with-clef.md | 597 ++++++++++++++++++ content/docs/getting_started/index.md | 466 +++++++------- content/docs/tools/Clef/Rules.md | 285 ++++++--- 7 files changed, 1520 insertions(+), 879 deletions(-) rename content/docs/developers/dapp-developer/{mobile/mobile-accounts.md => mobile.md} (51%) delete mode 100644 content/docs/developers/dapp-developer/mobile/mobile.md create mode 100644 content/docs/fundamentals/mining.md create mode 100644 content/docs/getting_started/getting-started-with-clef.md diff --git a/content/docs/developers/dapp-developer/mobile/mobile-accounts.md b/content/docs/developers/dapp-developer/mobile.md similarity index 51% rename from content/docs/developers/dapp-developer/mobile/mobile-accounts.md rename to content/docs/developers/dapp-developer/mobile.md index 9d4bd39219..6eb3111e9a 100644 --- a/content/docs/developers/dapp-developer/mobile/mobile-accounts.md +++ b/content/docs/developers/dapp-developer/mobile.md @@ -1,148 +1,197 @@ --- -title: Mobile Account Management -sort_key: G +title: Geth for Mobile +sort_key: F --- -To provide Ethereum integration for your mobile applications, the very first thing you -should be interested in doing is account management. +Embedding clients into mobile devices is an important part of Ethereum's decentralization vision. +This is because being able to verify data, follow the chain and submit transactions without +relying on centralized intermediaries is critical for censorship resistant access +to the network. Doing so on a mobile device is the most convenient route for many users. +This relies on Geth running a [light client](/docs/interface/les) on the mobile +device and exposing an API that developers can use to build mobile apps on top of Geth. This +page outlines how to download Geth for mobile and how to get started with managing Ethereum +accounts in mobile applications. Ethereum mobile development is relatively nascent, but there is +an active developer community. For further information on Geth mobile development visit the +#mobile channel in the [Geth discord](https://discord.gg/wQdpS5aA). -Although all current leading Ethereum implementations provide account management built in, -it is ill advised to keep accounts in any location that is shared between multiple -applications and/or multiple people. The same way you do not entrust your ISP (who is -after all your gateway into the internet) with your login credentials; you should not -entrust an Ethereum node (who is your gateway into the Ethereum network) with your -credentials either. +## Download and install -The proper way to handle user accounts in your mobile applications is to do client side -account management, everything self-contained within your own application. This way you -can ensure as fine grained (or as coarse) access permissions to the sensitive data as -deemed necessary, without relying on any third party application's functionality and/or -vulnerabilities. +### Android -To support this, `go-ethereum` provides a simple, yet thorough accounts library that gives -you all the tools to do properly secured account management via encrypted keystores and -passphrase protected accounts. You can leverage all the security of the `go-ethereum` -crypto implementation while at the same time running everything in your own application. +#### Android Studio -## Encrypted keystores +Geth for Mobile bundles can be downloaded directly from [the download page](https://geth.ethereum.org/downloads/) +and inserted into a project in Android Studio via `File -> New -> New module... -> Import .JAR/.AAR Package`. -Although handling your users' accounts locally on their own mobile device does provide -certain security guarantees, access keys to Ethereum accounts should never lay around in -clear-text form. As such, we provide an encrypted keystore that provides the proper -security guarantees for you without requiring a thorough understanding from your part of -the associated cryptographic primitives. +It is also necessary to configure `gradle` to link the mobile library bundle to the +application. This can be done by adding a new entry to the `dependencies` section of the +`build.gradle` script, pointing it to the module that was just added (named `geth` by default). -The important thing to know when using the encrypted keystore is that the cryptographic -primitives used within can operate either in *standard* or *light* mode. The former -provides a higher level of security at the cost of increased computational burden and -resource consumption: +```gradle +dependencies { + // All previous dependencies + compile project(':geth') +} +``` - * *standard* needs 256MB memory and 1 second processing on a modern CPU to access a key - * *light* needs 4MB memory and 100 millisecond processing on a modern CPU to access a key +#### Manual build -As such, *light* is more suitable for mobile applications, but you should be aware of the -trade-offs nonetheless. +Geth can also be built it locally using a `make` command. This will create an Android +archive called `geth.aar` in the `build/bin` folder that can be imported into Android +Studio as described above. -*For those interested in the cryptographic and/or implementation details, the key-store -uses the `secp256k1` elliptic curve as defined in the [Standards for Efficient -Cryptography](sec2), implemented by the [`libsecp256k`][secp256k1] library and wrapped by -[`github.com/ethereum/go-ethereum/accounts`][accounts-go]. Accounts are stored on disk in -the [Web3 Secret Storage][secstore] format.* +```shell +$ make android +[...] +Done building. +Import "build/bin/geth.aar" to use the library. +``` + +### iOS + +Geth must be downloaded and built locally for IoS. Building locally is achieved using the +`make` command. This will create an iOS XCode framework called `Geth.framework` in the +`build/bin` folder that can be imported into XCode as described above. + +```bash +$ make ios +[...] +Done building. +Import "build/bin/Geth.framework" to use the library. +``` + +## Mobile API + +Similarly to the reusable [Go libraries](/docs/dapp/native), the mobile wrappers focus on +three main usage areas: + +- Simplified client side account management +- Remote node interfacing via different transports +- Contract interactions through auto-generated bindings + +The Geth mobile API is broadly equivalent to the [Go API](/docs/dapp/native). +The source code can be found in the `mobile` section of Geth's +[Github](https://github.com/ethereum/go-ethereum/tree/master/mobile). + +## Mobile Account Management + +Best practise for account management is to do it client-side, with all sensitive information +self-contained inside the local application. This ensures the developer/user retains +fine-grained control over the access permissions for user-data instead of outsourcing security +to a third party. + +To support this, Geth provides an accounts library that includes the tools required +for secure account management via encrypted keystores and passphrase protected accounts, +similarly to running a full Geth node. + +### Encrypted keystores + +Access keys to Ethereum accounts should never be stored in plain-text. Instead, they should +be stored encrypted so that even if the mobile device is accessed by a malicious third party +the keys are still hidden under an additional layer of security. Geth provides a keystore +that enables developers to store keys securely using the [`secp256k1` elliptic curve](sec2), +implemented using [`libsecp256k`][secp256k1] and wrapped by [Geth accounts][accounts-go]. +Accounts are stored on disk in the [Web3 Secret Storage][secstore] format. Developers should be +aware of these implementation details but are not required to deeply understand the cryptographic +primitives in order to use the keystore. + +One thing that should be understood, though, is that the cryptographic primitives underpinning +the keystore can operate in *light* or *standard* mode. Light mode is computationally cheaper, while +standard mode has extra security. Light mode is appropriate for mobile devices, but developers +should be aware that there is a security trade-off. + +* *standard* needs 256MB memory and 1 second processing on a modern CPU to access a key +* *light* needs 4MB memory and 100 millisecond processing on a modern CPU to access a key ### Keystores on Android (Java) The encrypted keystore on Android is implemented by the `KeyStore` class from the -`org.ethereum.geth` package. The configuration constants (for the *standard* or *light* -security modes described above) are located in the `Geth` abstract class, similarly from -the `org.ethereum.geth` package. Hence to do client side account management on Android, -you'll need to import two classes into your Java code: +`org.ethereum.geth` package. The configuration constants are located in the `Geth` +abstract class, similarly from the `org.ethereum.geth` package. +Hence to do client side account management on Android, two classes should be +imported into the Java code: ```java import org.ethereum.geth.Geth; import org.ethereum.geth.KeyStore; ``` -Afterwards you can create a new encrypted keystore via: +Then new encrypted keystore can be created via: ```java KeyStore ks = new KeyStore("/path/to/keystore", Geth.LightScryptN, Geth.LightScryptP); ``` -The path to the keystore folder needs to be a location that is writable by the local -mobile application but non-readable for other installed applications (for security reasons -obviously), so we'd recommend placing it inside your app's data directory. If you are -creating the `KeyStore` from within a class extending an Android object, you will most -probably have access to the `Context.getFilesDir()` method via `this.getFilesDir()`, so -you could set the keystore path to `this.getFilesDir() + "/keystore"`. +The keystore should be in a location writable by the local mobile application but +on-readable for other installed applications such as inside the app's data directory. +If the `KeyStore` is created from within a class extending an Android object, access +to the `Context.getFilesDir()` method is probably provided via `this.getFilesDir()`, +so the keystore path could be set to `this.getFilesDir() + "/keystore"`. The last two arguments of the `KeyStore` constructor are the crypto parameters defining -how resource-intensive the keystore encryption should be. You can choose between +how resource-intensive the keystore encryption should be. The choices are `Geth.StandardScryptN, Geth.StandardScryptP`, `Geth.LightScryptN, Geth.LightScryptP` or -specify your own numbers (please make sure you understand the underlying cryptography for -this). We recommend using the *light* version. +custom numbers. The *light* version is recommended. + ### Keystores on iOS (Swift 3) The encrypted keystore on iOS is implemented by the `GethKeyStore` class from the `Geth` -framework. The configuration constants (for the *standard* or *light* security modes -described above) are located in the same namespace as global variables. Hence to do client -side account management on iOS, you'll need to import the framework into your Swift code: +framework. The configuration constants are located in the same namespace as global +variables. Hence to do client side account management on iOS, `Geth` framework should be +imported into the Swift code: ```swift import Geth ``` -Afterwards you can create a new encrypted account manager via: +Then a new encrypted account manager can be created using: ```swift let ks = GethNewKeyStore("/path/to/keystore", GethLightScryptN, GethLightScryptP); ``` -The path to the keystore folder needs to be a location that is writable by the local -mobile application but non-readable for other installed applications (for security reasons -obviously), so we'd recommend placing it inside your app's document directory. You should -be able to retrieve the document directory via `let datadir = -NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0]`, so you -could set the keystore path to `datadir + "/keystore"`. +The keystore folder needs to be in a location writable by the local mobile application +but non-readable for other installed applications such as inside the app's document +directory. The document directory shopuld be retrievable using +`let datadir = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0]`, +so the keystore path could be `datadir + "/keystore"`. The last two arguments of the `GethNewKeyStore` factory method are the crypto parameters -defining how resource-intensive the keystore encryption should be. You can choose between +defining how resource-intensive the keystore encryption should be. The choices are `GethStandardScryptN, GethStandardScryptP`, `GethLightScryptN, GethLightScryptP` or -specify your own numbers (please make sure you understand the underlying cryptography for -this). We recommend using the *light* version. +custom numbers. The *light* version is recommended. -## Account lifecycle +### Account lifecycle -Having created an encrypted keystore for your Ethereum accounts, you can use this for the -entire account lifecycle requirements of your mobile application. This includes the basic -functionality of creating new accounts and deleting existing ones; as well as the more -advanced functionality of updating access credentials, exporting existing accounts, and -importing them on another device. +The encyrpted keystore can be used for the entire account lifecycle requirements of a mobile +application. This includes the basic functionality of creating new accounts and deleting +existing ones as well as more advanced functions like updating access credentials and account +import/export. -Although the keystore defines the encryption strength it uses to store your accounts, +Although the keystore defines the encryption strength it uses to store accounts, there is no global master password that can grant access to all of them. Rather each account is maintained individually, and stored on disk in its [encrypted format][secstore] individually, ensuring a much cleaner and stricter separation of credentials. -This individuality however means that any operation requiring access to an account will +This individuality means that any operation requiring access to an account will need to provide the necessary authentication credentials for that particular account in the form of a passphrase: * When creating a new account, the caller must supply a passphrase to encrypt the account - with. This passphrase will be required for any subsequent access, the lack of which - will forever forfeit using the newly created account. + with. This passphrase will be required for any subsequent access. * When deleting an existing account, the caller must supply a passphrase to verify ownership of the account. This isn't cryptographically necessary, rather a protective measure against accidental loss of accounts. * When updating an existing account, the caller must supply both current and new passphrases. After completing the operation, the account will not be accessible via the - old passphrase any more. + old passphrase. * When exporting an existing account, the caller must supply both the current passphrase to decrypt the account, as well as an export passphrase to re-encrypt it with before returning the key-file to the user. This is required to allow moving accounts between devices without sharing original credentials. * When importing a new account, the caller must supply both the encryption passphrase of - the key-file being imported, as well as a new passhprase with which to store the + the key-file being imported, as well as a new passphrase with which to store the account. This is required to allow storing account with different credentials than used for moving them around. @@ -153,9 +202,9 @@ guarantee that account credentials cannot be brute forced in any meaningful time ### Accounts on Android (Java) An Ethereum account on Android is implemented by the `Account` class from the -`org.ethereum.geth` package. Assuming we already have an instance of a `KeyStore` called -`ks` from the previous section, we can easily execute all of the described lifecycle -operations with a handful of function calls. +`org.ethereum.geth` package. Assuming an instance of a `KeyStore` called +`ks` exists, all of the described lifecycle operations can be executed with +a handful of function calls: ```java // Create a new account with the specified encryption passphrase. @@ -176,16 +225,15 @@ ks.deleteAccount(newAcc, "Update password"); Account impAcc = ks.importKey(jsonAcc, "Export password", "Import password"); ``` -*Although instances of `Account` can be used to access various information about specific +Although instances of `Account` can be used to access various information about specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or private -keys), rather act solely as identifiers for client code and the keystore.* +keys), rather they act solely as identifiers for client code and the keystore. ### Accounts on iOS (Swift 3) An Ethereum account on iOS is implemented by the `GethAccount` class from the `Geth` -framework. Assuming we already have an instance of a `GethKeyStore` called `ks` from the -previous section, we can easily execute all of the described lifecycle operations with a -handful of function calls. +framework. Assuming an instance of a `GethKeyStore` called `ks` exists, all of the described +lifecycle operations can be executed with a handful of function calls: ```swift // Create a new account with the specified encryption passphrase. @@ -206,20 +254,20 @@ try! ks?.delete(newAcc, passphrase: "Update password") let impAcc = try! ks?.importKey(jsonKey, passphrase: "Export password", newPassphrase: "Import password") ``` -*Although instances of `GethAccount` can be used to access various information about +Although instances of `GethAccount` can be used to access various information about specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or -private keys), rather act solely as identifiers for client code and the keystore.* +private keys), rather they act solely as identifiers for client code and the keystore. ## Signing authorization As mentioned above, account objects do not hold the sensitive private keys of the -associated Ethereum accounts, but are merely placeholders to identify the cryptographic +associated Ethereum accounts - they are merely placeholders to identify the cryptographic keys with. All operations that require authorization (e.g. transaction signing) are performed by the account manager after granting it access to the private keys. There are a few different ways one can authorize the account manager to execute signing -operations, each having its advantages and drawbacks. Since the different methods have -wildly different security guarantees, it is essential to be clear on how each works: +operations. Since the different methods have very different security guarantees, +it is essential to be clear on how each works: * **Single authorization**: The simplest way to sign a transaction via the keystore is to provide the passphrase of the account every time something needs to be signed, which @@ -240,17 +288,12 @@ wildly different security guarantees, it is essential to be clear on how each wo manager can sign transactions while a particular account is unlocked** (e.g. device left unattended; application running untrusted code). -*Note, creating transactions is out of scope here, so the remainder of this section will -assume we already have a transaction to sign, and will focus only on creating an -authorized version of it. Creating an actually meaningful transaction will be covered -later.* ### Signing on Android (Java) -Assuming we already have an instance of a `KeyStore` called `ks` from the previous -sections, we can create a new account to sign transactions with via it's already -demonstrated `newAccount` method; and to avoid going into transaction creation for now, we -can hard-code a random transaction to sign instead. +Assuming an instance of a `KeyStore` called `ks` exists, a new account to sign transactions +can be created using its `newAccount` method. For this demonstation a hard-coded +example transaction is created to sign: ```java // Create a new account to sign transactions with @@ -261,8 +304,7 @@ Transaction tx = new Transaction( BigInt chain = new BigInt(1); // Chain identifier of the main net ``` -With the boilerplate out of the way, we can now sign transaction using the authorization -mechanisms described above: +The transaction `tx` can be signed using the authorization mechanisms described above: ```java // Sign a transaction with a single authorization @@ -280,10 +322,9 @@ signed = ks.signTx(signer, tx, chain); ### Signing on iOS (Swift 3) -Assuming we already have an instance of a `GethKeyStore` called `ks` from the previous -sections, we can create a new account to sign transactions with via it's already -demonstrated `newAccount` method; and to avoid going into transaction creation for now, we -can hard-code a random transaction to sign instead. +Assuming an instance of a `GethKeyStore` called `ks` exists, a new account +can be created to sign transactions with its `newAccount` method. For +this demonstation a hard-coded example transaction is created to sign: ```swift // Create a new account to sign transactions with @@ -295,13 +336,12 @@ let tx = GethNewTransaction(1, to, GethNewBigInt(0), GethNewBigInt(0), GethNe let chain = GethNewBigInt(1) // Chain identifier of the main net ``` -*Note, although Swift usually rewrites `NSError` returns to throws, this particular +*Although Swift usually rewrites `NSError` returns to throws, this particular instance seems to have been missed for some reason (possibly due to it being a constructor). It will be fixed in a later version of the iOS bindings when the appropriate -fixed are implemented upstream in the `gomobile` project.* +fixes are implemented upstream in the `gomobile` project.* -With the boilerplate out of the way, we can now sign transaction using the authorization -methods described above: +The transaction `tx` can now be signed using the authorization methods described above: ```swift // Sign a transaction with a single authorization @@ -317,6 +357,11 @@ try! ks?.timedUnlock(signer, passphrase: "Signer password", timeout: 1000000000) signed = try! ks?.signTx(signer, tx: tx, chainID: chain) ``` +## Summary + +This page introduced Geth for mobile. In addition to download and installation instructions, basic +account management was demonstrated for mobile applications on iOS and Android. + [sec2]: https://www.secg.org/sec2-v2.pdf [accounts-go]: https://godoc.org/github.com/ethereum/go-ethereum/accounts [secp256k1]: https://github.com/bitcoin-core/secp256k1 diff --git a/content/docs/developers/dapp-developer/mobile/mobile.md b/content/docs/developers/dapp-developer/mobile/mobile.md deleted file mode 100644 index efcc107451..0000000000 --- a/content/docs/developers/dapp-developer/mobile/mobile.md +++ /dev/null @@ -1,180 +0,0 @@ ---- -title: Mobile API -sort_key: F ---- - -The Ethereum blockchain along with its two extension protocols Whisper and Swarm was -originally conceptualized to become the supporting pillar of web3, providing the -consensus, messaging and storage backbone for a new generation of distributed (actually, -decentralized) applications called DApps. - -The first incarnation towards this dream of web3 was a command line client providing an -RPC interface into the peer-to-peer protocols. The client was soon enough extended with a -web-browser-like graphical user interface, permitting developers to write DApps based on -the tried and proven HTML/CSS/JS technologies. - -As many DApps have more complex requirements than what a browser environment can handle, -it became apparent that providing programmatic access to the web3 pillars would open the -door towards a new class of applications. As such, the second incarnation of the web -dream is to open up all our technologies for other projects as reusable components. - -Starting with the 1.5 release family of `go-ethereum`, we transitioned away from providing -only a full blown Ethereum client and started shipping official Go packages that could be -embedded into third party desktop and server applications. It took only a small leap from -here to begin porting our code to mobile platforms. - -## Quick overview - -Similarly to our reusable Go libraries, the mobile wrappers also focus on four main usage -areas: - -- Simplified client side account management -- Remote node interfacing via different transports -- Contract interactions through auto-generated bindings -- In-process Ethereum, Whisper and Swarm peer-to-peer node - -You can watch a quick overview about these in Peter's (@karalabe) talk titled "Import -Geth: Ethereum from Go and beyond", presented at the Ethereum Devcon2 developer conference -in September, 2016 (Shanghai). Slides are [available -here](https://ethereum.karalabe.com/talks/2016-devcon.html). - -[![Peter's Devcon2 talk](https://img.youtube.com/vi/R0Ia1U9Gxjg/0.jpg)](https://www.youtube.com/watch?v=R0Ia1U9Gxjg) - -## Library bundles - -The `go-ethereum` mobile library is distributed either as an Android `.aar` archive -(containing binaries for `arm-7`, `arm64`, `x86` and `x64`); or as an iOS XCode framework -(containing binaries for `arm-7`, `arm64` and `x86`). We do not provide library bundles -for Windows phone the moment. - -### Android archive - -The simplest way to use `go-ethereum` in your Android project is through a Maven -dependency. We provide bundles of all our stable releases (starting from v1.5.0) through -Maven Central, and also provide the latest develop bundle through the Sonatype OSS -repository. - -#### Stable dependency (Maven Central) - -To add an Android dependency to the **stable** library release of `go-ethereum`, you'll -need to ensure that the Maven Central repository is enabled in your Android project, and -that the `go-ethereum` code is listed as a required dependency of your application. You -can do both of these by editing the `build.gradle` script in your Android app's folder: - -```gradle -repositories { - mavenCentral() -} - -dependencies { - // All your previous dependencies - compile 'org.ethereum:geth:1.5.2' // Change the version to the latest release -} -``` - -#### Develop dependency (Sonatype) - -To add an Android dependency to the current version of `go-ethereum`, you'll need to -ensure that the Sonatype snapshot repository is enabled in your Android project, and that -the `go-ethereum` code is listed as a required `SNAPSHOT` dependency of your application. -You can do both of these by editing the `build.gradle` script in your Android app's -folder: - -```gradle -repositories { - maven { - url "https://oss.sonatype.org/content/groups/public" - } -} - -dependencies { - // All your previous dependencies - compile 'org.ethereum:geth:1.5.3-SNAPSHOT' // Change the version to the latest release -} -``` - -#### Custom dependency - -If you prefer not to depend on Maven Central or Sonatype; or would like to access an older -develop build not available any more as an online dependency, you can download any bundle -directly from [our website](https://geth.ethereum.org/downloads/) and insert it into your -project in Android Studio via `File -> New -> New module... -> Import .JAR/.AAR Package`. - -You will also need to configure `gradle` to link the mobile library bundle to your -application. This can be done by adding a new entry to the `dependencies` section of your -`build.gradle` script, pointing it to the module you just added (named `geth` by default). - -```gradle -dependencies { - // All your previous dependencies - compile project(':geth') -} -``` - -#### Manual builds - -Lastly, if you would like to make modifications to the `go-ethereum` mobile code and/or -build it yourself locally instead of downloading a pre-built bundle, you can do so using a -`make` command. This will create an Android archive called `geth.aar` in the `build/bin` -folder that you can import into your Android Studio as described above. - -```bash -$ make android -[...] -Done building. -Import "build/bin/geth.aar" to use the library. -``` - -### iOS framework - -The simplest way to use `go-ethereum` in your iOS project is through a -[CocoaPods](https://cocoapods.org/) dependency. We provide bundles of all our stable -releases (starting from v1.5.3) and also latest develop versions. - -#### Automatic dependency - -To add an iOS dependency to the current stable or latest develop version of `go-ethereum`, -you'll need to ensure that your iOS XCode project is configured to use CocoaPods. -Detailing that is out of scope in this document, but you can find a guide in the upstream -[Using CocoaPods](https://guides.cocoapods.org/using/using-cocoapods.html) page. -Afterwards you can edit your `Podfile` to list `go-ethereum` as a dependency: - -```ruby -target 'MyApp' do - # All your previous dependencies - pod 'Geth', '1.5.4' # Change the version to the latest release -end -``` - -Alternatively, if you'd like to use the latest develop version, replace the package -version `1.5.4` with `~> 1.5.5-unstable` to switch to pre-releases and to always pull in -the latest bundle from a particular release family. - -#### Custom dependency - -If you prefer not to depend on CocoaPods; or would like to access an older develop build -not available any more as an online dependency, you can download any bundle directly from -[our website](https://geth.ethereum.org/downloads/) and insert it into your project in -XCode via `Project Settings -> Build Phases -> Link Binary With Libraries`. - -Do not forget to extract the framework from the compressed `.tar.gz` archive. You can do -that either using a GUI tool or from the command line via (replace the archive with your -downloaded file): - -``` -tar -zxvf geth-ios-all-1.5.3-unstable-e05d35e6.tar.gz -``` - -#### Manual builds - -Lastly, if you would like to make modifications to the `go-ethereum` mobile code and/or -build it yourself locally instead of downloading a pre-built bundle, you can do so using a -`make` command. This will create an iOS XCode framework called `Geth.framework` in the -`build/bin` folder that you can import into XCode as described above. - -```bash -$ make ios -[...] -Done building. -Import "build/bin/Geth.framework" to use the library. -``` diff --git a/content/docs/fundamentals/Managing-your-accounts.md b/content/docs/fundamentals/Managing-your-accounts.md index cdd6305a22..1df734593d 100644 --- a/content/docs/fundamentals/Managing-your-accounts.md +++ b/content/docs/fundamentals/Managing-your-accounts.md @@ -1,48 +1,22 @@ --- -title: Managing Your Accounts -sort_key: B +title: Account Management +sort_key: C --- -**WARNING** -Remember your password. +It is recommended to use the external key manager Clef for interacting with Geth because it can be run from secure external devices and has additional security benefits such as the ability to sign transactions according to custom rules. Instructions for setting up and using Clef can be found on the [Clef page](../clef/tutorial). However, Geth also has its own built-in account management tools that are more convenient and secure enough for many use-cases. This page will describe how to manage accounts using Geth's built in tools. The command line is considered first and then managing accounts from the Javascript console is considered in a [separate section](#accounts-in-the-javascript-console). -If you lose the password you use to encrypt your account, you will not be able to access that account. -Repeat: It is NOT possible to access your account without a password and there is no _forgot my password_ option here. Do not forget it. -The ethereum CLI `geth` provides account management via the `account` command: +## Account command + +Interacting with accounts is achieved using Geth's `account` command: ``` -$ geth account [options...] [arguments...] +geth account [options...] [arguments...] ``` -Manage accounts lets you create new accounts, list all existing accounts, import a private -key into a new account, migrate to newest key format and change your password. +The account command enables the user to create new accounts, list existing accounts, import private keys into a new account, update key formats and update the passwords that lock each account. In interactive mode, the user is prompted for passwords in the console when the `account` functions are invoked, whereas in non-interactive mode passwords to unlock accounts are saved to text files whose path is passed to Geth at startup. Non-interactive mode is only intended for use on private networks or known safe environments. -It supports interactive mode, when you are prompted for password as well as -non-interactive mode where passwords are supplied via a given password file. -Non-interactive mode is only meant for scripted use on test networks or known safe -environments. - -Make sure you remember the password you gave when creating a new account (with new, update -or import). Without it you are not able to unlock your account. - -Note that exporting your key in unencrypted format is NOT supported. - -Keys are stored under `/keystore`. Make sure you backup your keys regularly! See -[DATADIR backup & restore](../install-and-build/backup-restore) -for more information. If a custom datadir and keystore option are given the keystore -option takes preference over the datadir option. - -The newest format of the keyfiles is: `UTC----
`. The -order of accounts when listing, is lexicographic, but as a consequence of the timestamp -format, it is actually order of creation - -It is safe to transfer the entire directory or the individual keys therein between -ethereum nodes. Note that in case you are adding keys to your node from a different node, -the order of accounts may change. So make sure you do not rely or change the index in your -scripts or code snippets. - -And again. **DO NOT FORGET YOUR PASSWORD** +The `account` subcommands are: ``` COMMANDS: @@ -52,7 +26,8 @@ COMMANDS: import Import a private key into a new account ``` -You can get info about subcommands by `geth account --help`. +Information about the subcommands can be displayed in the terminal using `geth account --help`. For example, for the `list` subcommand: + ``` $ geth account list --help list [command options] [arguments...] @@ -60,49 +35,110 @@ list [command options] [arguments...] Print a short summary of all accounts OPTIONS: - --datadir "/home/bas/.ethereum" Data directory for the databases and keystore - --keystore Directory for the keystore (default = inside the datadir) + --datadir "/home/.ethereum" Data directory for the databases and keystore + --keystore Directory for the keystore (default = inside the datadir) ``` -Accounts can also be managed via the [Javascript Console](../interface/javascript-console) -## Examples -### Interactive use +## Creating new accounts -#### creating an account +New accounts can be created using `account new`. This generates a new key pair and adds them to the `keystore` directory in the `datadir`. To create a new account in the default data directory: -``` + +```shell $ geth account new +``` + +This returns the following to the terminal: + +```terminal Your new account is locked with a password. Please give a password. Do not forget this password. Passphrase: Repeat Passphrase: Address: {168bc315a2ee09042d83d7c5811b533620531f67} ``` -#### Listing accounts in a custom keystore directory +It is critical to backup the account password safely and securely as it cannot be retrieved or reset. -``` -$ geth account list --keystore /tmp/mykeystore/ -Account #0: {5afdd78bdacb56ab1dad28741ea2a0e47fe41331} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-27.437847599Z--5afdd78bdacb56ab1dad28741ea2a0e47fe41331 -Account #1: {9acb9ff906641a434803efb474c96a837756287f} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-52.180688336Z--9acb9ff906641a434803efb474c96a837756287f +{% include note.html content=" If the password provided on account creation is lost or forgotten, there is no way to retrive it and the account will simply stay locked forever. The password MUST be backed up safely and securely! **IT IS CRITICAL TO BACKUP THE KEYSTORE AND REMEMBER PASSWORDS**" %} +The newly generated key files can be viewed in `/keystore/`. The file naming format is `UTC----
` where `date` is the date and time of key creation formatted according to [UTC 8601](https://www.iso.org/iso-8601-date-and-time-format.html) with zero time offset and seconds precise to eight decimal places. `address` is the 40 hexadecimal characters that make up the account address without a leading `0x`, for example: + +`UTC--2022-05-19T12-34-36.47413510Z--0b85e5a13e118466159b1e1b6a4234e5f9f784bb` + + +## Listing Accounts + +Listing all existing accounts is achieved using the `account list` command. If the keystore is located anywhere other than the default location its path should be included with the `keystore` flag. For example, if the datadir is `some-dir`: + +```shell +geth account list --keystore some-dir/keystore ``` -#### Import private key into a node with a custom datadir +This command returns the following to the terminal for a keystore with two files: +```terminal +Account 0: {5afdd78bdacb56ab1dad28741ea2a0e47fe41331} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-27.437847599Z--5afdd78bdacb56ab1dad28741ea2a0e47fe41331 +Account 1: {9acb9ff906641a434803efb474c96a837756287f} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-52.180688336Z--9acb9ff906641a434803efb474c96a837756287f ``` -$ geth account import --datadir /someOtherEthDataDir ./key.prv -The new account will be encrypted with a passphrase. + +The ordering of accounts when they are listed is lexicographic, but is effectively chronological based on time of creation due to the timestamp in the file name. It is safe to transfer the entire `keystore` directory or individual key files between Ethereum nodes. This is important because when accounts are added from other nodes the order of accounts in the keystore may change. It is therefore important not to rely on account indexes in scripts or code snippets. + + +## Importing accounts + +### Import a keyfile + +It is also possible to create a new account by importing a private key. For example, a user might already have some ether at an address they created using a browser wallet and now wish to use a new Geth node to interact with their funds. In this case, the private key can be exported from the browser wallet and imported into Geth. Geth requires the private key to be stored as a file which contains the private key as unencrypted canonical elliptic curve bytes encoded into hex (i.e. plain text key without leading 0x). The new account is then saved in encrypted format, protected by a passphrase the user provides on request. As always, this passphrase must be securely and safely backed up - there is no way to retrieve or reset it if it is forgotten! + +```shell +$ geth account import --datadir /some-dir ./keyfile +``` + +The following information will be displayed in the terminal, indicating a successful import: + +```terminal Please enter a passphrase now. Passphrase: Repeat Passphrase: Address: {7f444580bfef4b9bc7e14eb7fb2a029336b07c9d} ``` -#### Account update +This import/export process is not necessary for transferring accounts between Geth instances because the key files can simply be copied directly from one keystore to another. +It is also possible to import an account in non-interactive mode by saving the account password as plaintext in a `.txt` file and passing its path with the `--password` flag on startup. + +```shell +geth account import --password path/password.txt path/keyfile ``` -$ geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b +In this case, it is important to ensure the password file is not readable by anyone but the intended user. This can be achieved by changing the file permissions. On Linux, the following commands update the file permissions so only the current user has access: + +```shell +chmod 700 /path/to/password +cat > /path/to/password + +``` + +### Import a presale wallet + +Assuming the password is known, importing a presale wallet is very easy. The `wallet import` commands are used, passing the path to the wallet. + +```shell +geth wallet import /path/presale.wallet +``` + + +## Updating accounts + +The `account update` subcommand is used to unlock an account and migrate it to the newest format. This is useful for accounts that may have been created in a format that has since been deprecated. The same command can be used to update the account password. The current password and account address are needed in order to update the account, as follows: + +```shell +geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b +``` + +The following will be returned to the terminal: + +```terminal Unlocking account a94f5374fce5edbc8e2a8697c15331677e6ebf0b | Attempt 1/3 Passphrase: 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b @@ -113,240 +149,110 @@ Repeat Passphrase: 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b ``` -### Non-interactive use +Alternatively, in non-interactive mode the path to a password file containing the account password in unencrypted plaintext can be passed with the `--password` flag: -You supply a plaintext password file as argument to the `--password` flag. The data in the -file consists of the raw characters of the password, followed by a single newline. - -**Note**: Supplying the password directly as part of the command line is not recommended, -but you can always use shell trickery to get round this restriction. - -``` -$ geth account new --password /path/to/password - -$ geth account import --datadir /someOtherEthDataDir --password /path/to/anotherpassword ./key.prv +```shell +geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b --password path/password.txt ``` -# Creating accounts +Updating the account replaces the original file with a new one - this means the original file is no longer available after it has been updated. -## Creating a new account -``` -$ geth account new -$ geth account new --password /path/to/passwdfile -$ geth account new --password <(echo $mypassword) +## Unlocking accounts +In Geth, accounts are locked unless they are explicitly unlocked. If an account is intended to be used by apps connecting to Geth via RPC then it can be unlocked in non-interactive mode by passing the `--unlock` flag with a comma-separated list of account addresses (or keystore indexes) to unlock. This unlocks the accounts for one session only. Including the `--unlock` flag without any account addresses defaults to unlocking the first account in the keystore. + +```shell +geth --unlock 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b ``` -Creates a new account and prints the address. - -On the console, use: - -``` -> personal.newAccount() -... you will be prompted for a password ... - -or - -> personal.newAccount("passphrase") +Geth will start and prompt the user to input the account password in the terminal. Alternatively, the user can provide a password as a text file and pass its path to `--password`: +```shell +geth --unlock 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b --password path/password.txt ``` -The account is saved in encrypted format. You **must** remember this passphrase to unlock -your account in the future. +{% include note.html content=" By default, account **unlocking is forbidden when HTTP or Websocket access is enabled** (i.e. by passing `--http` or `ws` flag). This is because an attacker that manages to access the node via the externally-exposed HTTP/WS port can then control the unlocked account. It is possible to force account unlock by including the `--allow-insecure-unlock` flag but this is unsafe and **not recommended** except for expert users that completely understand how it can be used safely. This is not a hypothetical risk: **there are bots that continually scan for http-enabled Ethereum nodes to attack**" %} -For non-interactive use the passphrase can be specified with the `--password` flag: -``` -geth account new --password +## Accounts in the Javascript console + +Account management can also be achieved in the Javascript console attached to a running Geth instance. Assuming Geth is already running, in a new terminal attach a Javascript console using the `geth.ipc` file. This file can be found in the data directory. Assuming the data directory is named `data` the console can be started using: + +```shell +geth attach data/geth.ipc ``` -Note, this is meant to be used for testing only, it is a bad idea to save your -password to file or expose in any other way. +### New accounts -## Creating an account by importing a private key +New accounts can be generated using the Javascript console using `personal.newAccount()`. A new password is requested in the console and successful account creation is confirmed by the new account address being displayed. -``` - geth account import +```shell +personal.newAccount() ``` -Imports an unencrypted private key from `` and creates a new account and prints -the address. +Accounts can also be created by importing private keys directly in the Javascript console. The private key is passed as an unencrypted hex-encoded string to `personal.importRawKey()` along with a passphrase that will be used to encrypt the key. A new key file will be generated from the private key and saved to the keystore. -The keyfile is assumed to contain an unencrypted private key as canonical EC raw bytes -encoded into hex. - -The account is saved in encrypted format, you are prompted for a passphrase. - -You must remember this passphrase to unlock your account in the future. - -For non-interactive use the passphrase can be specified with the `--password` flag: - -``` -geth account import --password +```shell +personal.importRawKey("hexstringkey", "password") ``` -**Note**: Since you can directly copy your encrypted accounts to another ethereum -instance, this import/export mechanism is not needed when you transfer an account between -nodes. +### Listing accounts -**Warning:** when you copy keys into an existing node's keystore, the order of accounts -you are used to may change. Therefore you make sure you either do not rely on the account -order or doublecheck and update the indexes used in your scripts. - -**Warning:** If you use the password flag with a password file, best to make sure the file -is not readable or even listable for anyone but you. You achieve this with: +The `accounts` function in the `eth` namespace can be used to list the accounts that currently exist in the keystore.: ``` -touch /path/to/password -chmod 700 /path/to/password -cat > /path/to/password ->I type my pass here^D +eth.accounts ``` -## Updating an existing account - -You can update an existing account on the command line with the `update` subcommand with -the account address or index as parameter. You can specify multiple accounts at once. +or alternatively the same is achieved using: ``` -geth account update 5afdd78bdacb56ab1dad28741ea2a0e47fe41331 9acb9ff906641a434803efb474c96a837756287f -geth account update 0 1 2 +personal.listAccounts ``` -The account is saved in the newest version in encrypted format, you are prompted -for a passphrase to unlock the account and another to save the updated file. +This returns an array of account addresses to the terminal. -This same command can therefore be used to migrate an account of a deprecated -format to the newest format or change the password for an account. -After a successful update, all previous formats/versions of that same key are removed! +### Unlocking accounts -# Importing your presale wallet - -Importing your presale wallet is very easy. If you remember your password that is: +To unlock an account, the `personal.unlockAccount` function can be used: ``` -geth wallet import /path/to/my/presale.wallet +personal.unlockAccount(eth.accounts[1]) ``` -will prompt for your password and imports your ether presale account. It can be used -non-interactively with the --password option taking a passwordfile as argument containing -the wallet password in cleartext. +The account passphrase is requested: -# Listing accounts and checking balances - -### Listing your current accounts - -From the command line, call the CLI with: - -``` -$ geth account list -Account #0: {5afdd78bdacb56ab1dad28741ea2a0e47fe41331} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-27.437847599Z--5afdd78bdacb56ab1dad28741ea2a0e47fe41331 -Account #1: {9acb9ff906641a434803efb474c96a837756287f} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-52.180688336Z--9acb9ff906641a434803efb474c96a837756287f -``` - -to list your accounts in order of creation. - -**Note**: -This order can change if you copy keyfiles from other nodes, so make sure you either do not rely on indexes or make sure if you copy keys you check and update your account indexes in your scripts. - -When using the console: -``` -> eth.accounts -["0x5afdd78bdacb56ab1dad28741ea2a0e47fe41331", "0x9acb9ff906641a434803efb474c96a837756287f"] -``` - -or via RPC: -``` -# Request -$ curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":1}' -H 'Content-type: application/json' http://127.0.0.1:8545 - -# Result -{ - "id":1, - "jsonrpc": "2.0", - "result": ["0x5afdd78bdacb56ab1dad28741ea2a0e47fe41331", "0x9acb9ff906641a434803efb474c96a837756287f"] -} -``` - -If you want to use an account non-interactively, you need to unlock it. You can do this on -the command line with the `--unlock` option which takes a comma separated list of accounts -(in hex or index) as argument so you can unlock the accounts programmatically for one -session. This is useful if you want to use your account from Dapps via RPC. `--unlock ` -will unlock the first account. This is useful when you created your account -programmatically, you do not need to know the actual account to unlock it. - -Create account and start node with account unlocked: -``` -geth account new --password <(echo this is not secret!) -geth --password <(echo this is not secret!) --unlock primary --rpccorsdomain localhost --verbosity 6 2>> geth.log -``` - -Instead of the account address, you can use integer indexes which refers to the address -position in the account listing (and corresponds to order of creation) - -The command line allows you to unlock multiple accounts. In this case the argument to -unlock is a comma delimited list of accounts addresses or indexes. - -``` -geth --unlock "0x407d73d8a49eeb85d32cf465507dd71d507100c1,0,5,e470b1a7d2c9c5c6f03bbaa8fa20db6d404a0c32" -``` - -If this construction is used non-interactively, your password file will need to contain -the respective passwords for the accounts in question, one per line. - -On the console you can also unlock accounts (one at a time) for a duration (in seconds). - -``` -personal.unlockAccount(address, "password", 300) -``` - -Note that we do NOT recommend using the password argument here, since the console history -is logged, so you may compromise your account. You have been warned. - -### Checking account balances - -To check your the etherbase account balance: -``` -> web3.fromWei(eth.getBalance(eth.coinbase), "ether") -6.5 -``` - -Print all balances with a JavaScript function: -``` -function checkAllBalances() { - var totalBal = 0; - for (var acctNum in eth.accounts) { - var acct = eth.accounts[acctNum]; - var acctBal = web3.fromWei(eth.getBalance(acct), "ether"); - totalBal += parseFloat(acctBal); - console.log(" eth.accounts[" + acctNum + "]: \t" + acct + " \tbalance: " + acctBal + " ether"); - } - console.log(" Total balance: " + totalBal + " ether"); -}; -``` -That can then be executed with: -``` -> checkAllBalances(); - eth.accounts[0]: 0xd1ade25ccd3d550a7eb532ac759cac7be09c2719 balance: 63.11848 ether - eth.accounts[1]: 0xda65665fc30803cb1fb7e6d86691e20b1826dee0 balance: 0 ether - eth.accounts[2]: 0xe470b1a7d2c9c5c6f03bbaa8fa20db6d404a0c32 balance: 1 ether - eth.accounts[3]: 0xf4dd5c3794f1fd0cdc0327a83aa472609c806e99 balance: 6 ether -``` - -Since this function will disappear after restarting geth, it can be helpful to store -commonly used functions to be recalled later. The -[loadScript](../interface/javascript-console) -function makes this very easy. - -First, save the `checkAllBalances()` function definition to a file on your computer. For -example, `/Users/username/gethload.js`. Then load the file from the interactive console: - -``` -> loadScript("/Users/username/gethload.js") +```terminal +Unlock account 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b +Passphrase: true ``` -The file will modify your JavaScript environment as if you has typed the commands -manually. Feel free to experiment! +This unlocked account can now be used to sign and send transactions. it is also possible to pass the passphrase as an argument to `personal.unlockAccount()` along with a duration after which the accout will automatically re-lock (in seconds), as follows: + +```shell +personal.unlockAccount(eth.accounts[1], "passphrase", 60) +``` + +This unlocks the account for 60 seconds. However, this is not recommended because the command history is logged by the Javascript console which could compromise the security of the account. An unlocked account can be manually re-locked using `personal.lockAccount()`, passing the address as the sole argument. + + +### Unlocking for transactions + +Sending transactions from the Javascript console also requires the sender account to be unlocked. There are two ways to send transactions: `eth.sendTransaction` and `personal.sendTransaction`. The difference between these two functions is that `eth.sendTransaction` requires the account to be unlocked globally, at the node level (i.e., by unlocking it on the command line at the start of the Geth session). On the other hand, `personal.sendTransaction` takes a passphrase argument that unlocks the account temporarily in order to sign the transaction, then locks it again immediately afterwards. For example, to send 5 ether between two accounts in the keystore: + +```shell +var tx = {from: eth.accounts[1], to: eth.accounts[2], value: web3.toWei(5, "ether")} + +# this requires global account unlock for eth.accounts[1] +eth.sendTransaction(tx) + +# this unlocks eth.accounts[1] temporarily just to send the transaction +personal.sendTransaction(tx, "password") +``` + +## Summary + +This page has demonstrated how to use Geth's built-in account management tools, both on the command line and in the Javascript console. Accounts are stored encrypted by a password. It is critical that the account passwords and the keystore directory are safely and securely backed up. diff --git a/content/docs/fundamentals/mining.md b/content/docs/fundamentals/mining.md new file mode 100644 index 0000000000..d2d91f9cf7 --- /dev/null +++ b/content/docs/fundamentals/mining.md @@ -0,0 +1,208 @@ +--- +title: Mining +sort_key: F +--- + + +The Ethereum blockchain grows when nodes add blocks and distribute them to their peers. Nodes +that add blocks are rewarded with ether payouts. This creates competition for the right to add +blocks to the blockchain. This means some mechanism must exist to select a single block for each +position in the blockchain that all nodes can agree upon. The mechanism that currently achieves +this for Ethereum is "proof-of-work" (PoW). This involved computing a certain value that can +only be calculated using repeated random guesses. Only if a node can demonstrate that they have +calculated this value, and therefore expended energy, will their block be accepted by other nodes. +This secures the network. This process of creating blocks and securing them using proof-of-work +is known as "mining". + +Much more information about mining, including details about the specific algorithm ("Ethash") used by +Ethereum nodes is available on +[ethereum.org](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/mining). + + +## Mining and the Merge + +[The Merge](https://ethereum.org/en/upgrades/merge) is an upcoming upgrade to Ethereum that +will swap the existing PoW for a [proof-of-stake (PoS)](https://ethereum.org/en/developers/docs/consensus-mechanisms/pos) consensus mechanism. This marks the end of mining on Ethereum. Instead, nodes can [stake ether](https://ethereum.org/en/staking/solo/#get-started-on-the-staking-launchpad) directly and earn ether rewards by running [validators](https://ethereum.org/en/developers/docs/consensus-mechanisms/pos/#validators). The merge is expected to happen in the second half of 2022. Until then, Ethereum will continue to be secured by PoW miners. It is no longer recommended to purchase new hardware to participate in Ethereum mining because the chances of returning a profit before The Merge are low. + + +## CPU vs GPU + +Participating in Ethereum's PoW mining requires running an algorithm called +["Ethash"](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash). Geth includes +a CPU miner which runs Ethash within the Geth process. This might be useful for mining on some testnets. However, this is CPU mining is not viable on Ethereum Mainnet because CPU miners are easily out-competed by more efficient GPU miners. GPU mining is the recommended method for mining real ether on Ethereum Mainnet, but it is not part of the standard Geth installation. To mine using GPUs an additional piece of third-paty software is required. The recommended GPU mining software is [Ethminer](https://github.com/ethereum-mining/ethminer). + +Regardless of the mining method, the blockchain must be fully synced before mining is started, otherwise the miner will build on an incorrect chain, invalidating the block rewards. + + +## GPU Mining + +### Installing Ethminer + +The Ethminer software can be installed from a downloaded binary or built from source. The relevant downloads +and installation instructions are available from the [Ethminer Github](https://github.com/ethereum-mining/ethminer/#build). Standalone executables are available for Linux, macOS and Windows. + +### Using Ethminer with Geth + + +An account to receive block rewards must first be defined. The address of the account is all that is required to start mining - the mining rewards will be credited to that address. This can be an existing address or one that is newly created by Geth. More detailed instructions on creating and importing accounts are available on the [Account Management](/docs/interface/managing-your-accounts) page. + +The account address can be provided to `--mining.etherbase` when Geth is started. This instructs Geth to direct any block rewards to this address. Once started, Geth will sync the blockchain. If Geth has not connected to this network before, or if the data directory has been deleted, this can take several days. Also, enable HTTP traffic with the `--http` command. + +```shell +geth --http --miner.etherbase 0xC95767AC46EA2A9162F0734651d6cF17e5BfcF10 +``` + +The progress of the blockchain syncing can be monitored by attaching a JavaScript console in another terminal. More detailed information about the console can be found on the [Javascript Console](/docs/interface/javascript-console) page. To attach and open a console: + +```shell +geth attach http://127.0.0.1:8545 +``` + +Then in the console, to check the sync progress: + +```shell +eth.syncing +``` + +If the sync is progressing correctly the output will look similar to the following: + +```terminal +{ + currentBlock: 13891665, + healedBytecodeBytes: 0, + healedBytecodes: 0, + healedTrienodeBytes: 0, + healedTrienodes: 0, + healingBytecode: 0, + healingTrienodes: 0, + highestBlock: 14640000, + startingBlock: 13891665, + syncedAccountBytes: 0, + syncedAccounts: 0, + syncedBytecodeBytes: 0, + syncedBytecodes: 0, + syncedStorage: 0, + syncedStorageBytes: 0 +} +``` + +Once the blockchain is sync'd, mining can begin. In order to begin mining, Ethminer must be run and connected to Geth in a new terminal. OpenCL can be used for a wide range of GPUs, CUDA can be used specifically for Nvidia GPUs: + +```shell +#OpenCL +ethminer -v 9 -G -P http://127.0.0.1:8545 +``` + +```shell +#CUDA +ethminer -v -U -P http://127.0.0.1:8545 +``` + +Ethminer communicates with Geth on port 8545 (Geth's default RPC port) but this can be changed by providing a custom +port to the `http.port` command. The corresponding port must also be configured in Ethminer by providing +`-P http://127.0.0.1:`. This is necessary when multiple instances of Geth/Ethminer will coexist on the same machine. + +If using OpenCL and the default for `ethminer` does not work, specifying the device using the `--opencl--device X` command is a common fix. `X` is an integer `1`, `2`, `3` etc. The Ethminer `-M` (benchmark) command should display something that looks like: + +```terminal +Benchmarking on platform: { "platform": "NVIDIA CUDA", "device": "GeForce GTX 750 Ti", "version": "OpenCL 1.1 CUDA" } + +Benchmarking on platform: { "platform": "Apple", "device": "Intel(R) Xeon(R) CPU E5-1620 v2 @ 3.70GHz", "version": "OpenCL 1.2 " } +``` + +Note that the Geth command `miner.hashrate` only works for CPU mining - it always reports zero for GPU mining. To check the GPU mining hashrate, check the logs `ethminer` displays to its terminal. More verbose logs can be configured using `-v` and a value between 0-9. + +The Ethash algorithm is [memory-hard](https://crypto.stackexchange.com/questions/84002/memory-hard-vs-memory-bound-functions) and requires a large dataset to be loaded into memory. Each GPU requires 4-5 GB of RAM. The error message `Error GPU mining. GPU memory fragmentation?` indicates that there is insufficient memory available. + + +## CPU Mining with Geth + +When Geth is started is is not mining by default. Unless it is specifically instructed to mine, it acts only as a node, not a miner. Geth starts as a (CPU) miner if the `--mine` flag is provided. The `--miner.threads` parameter can +be used to set the number parallel mining threads (defaulting to the total number of processor cores). + +```shell +geth --mine --miner.threads=4 +``` + +CPU mining can also be started and stopped at runtime using the [console](/docs/interface/javascript-console). The command `miner.start` takes an optional parameter for the number of miner threads. + +```js +miner.start(8) + true +miner.stop() + true +``` + +Note that mining for real ether only makes sense if you are in sync with the network (since you mine on top of the consensus block). Therefore the Ethereum blockchain downloader/synchroniser will delay mining until syncing is complete, and after that mining automatically starts unless you cancel your intention with `miner.stop()`. + +Like with GPU mining, an etherbase account must be set. This defaults to the primary account in the keystore but can be set to an alternative address using the `--miner.etherbase` command: + +```shell +geth --miner.etherbase '0xC95767AC46EA2A9162F0734651d6cF17e5BfcF10' --mine +``` +If there is no account available the miner will not start. The Javascript console can also be used to reset the etherbase account at runtime: + +```shell +miner.setEtherbase(eth.accounts[2]) +``` + +Note that your etherbase does not need to be an address of a local account, it just has to be set to an existing one. + +There is an option to add extra data (32 bytes only) to the mined blocks. By convention this is interpreted as a unicode string, so it can be used to add a short vanity tag using `miner.setExtra` in the Javascript console. + +```shell +miner.setExtra("ΞTHΞЯSPHΞЯΞ") +``` + +The console can also be used to check the current hashrate in units H/s (Hash operations per second): + +```shell +eth.hashrate + 712000 +``` + +After some blocks have been mined, the etherbase account balance with be >0. Assuming the etherbase is a local account: + +```shell +eth.getBalance(eth.coinbase).toNumber(); + '34698870000000' +``` + +It is also possible to check which blocks were mined by a particular miner (address) using the following code snippet in the Javascript console: + +```js +function minedBlocks(lastn, addr) { + addrs = []; + if (!addr) { + addr = eth.coinbase + } + limit = eth.blockNumber - lastn + for (i = eth.blockNumber; i >= limit; i--) { + if (eth.getBlock(i).miner == addr) { + addrs.push(i) + } + } + return addrs +} + +// scans the last 1000 blocks and returns the blocknumbers of blocks mined by your coinbase +// (more precisely blocks the mining reward for which is sent to your coinbase). +minedBlocks(1000, eth.coinbase) +[352708, 352655, 352559] + +``` + +The etherbase balance will fluctuate because quite often a mined block may be re-org'd out +of the canonical chain. This means that when the local Geth node includes the mined block +in its own local blockchain the account balance appears higher because the block rewards are +applied. When the node switches to another version of the chain due to information received +from peers, that block may not be included and the block rewards are not applied. + +The logs show locally mined blocks confirmed after 5 blocks. + + +## Summary + +The page describes how to start Geth as a mining node. Mining can be done on CPUs - in which case Geth's built-in +miner can be used - or on GPUs which requires third party software. GPUs are required to mine real ether on Ethereum +Mainnet. It is important to note that Ethereum will swap its consensus mechanism from PoW to PoS in the second half of 2022. This swap, known as "The Merge" will end mining on Ethereum. diff --git a/content/docs/getting_started/getting-started-with-clef.md b/content/docs/getting_started/getting-started-with-clef.md new file mode 100644 index 0000000000..684996f7ed --- /dev/null +++ b/content/docs/getting_started/getting-started-with-clef.md @@ -0,0 +1,597 @@ +--- +title: Geth and Clef +permalink: docs/getting-started/geth-and-clef +sort_key: B +--- + +This page explains how to set up Geth and execute some basic tasks using the command line tools. +In order to use Geth, the software must first be installed. There are several ways Geth can be +installed depending on the operating system and the user's choice of installation method, for example +using a package manager, container or building from source. Instructions for installing Geth can be +found on the ["Install and Build"](install-and-build/installing-geth) pages. The tutorial on this +page assumes Geth and the associated developer tools have been installed successfully. + +This page provides step-by-step instructions covering the fundamentals of using Geth. This +includes generating accounts, joining an Ethereum network, syncing the blockchain and sending ether +between accounts. This tutorial also uses [Clef](/docs/clef/tutorial). Clef is an account management tool +external to Geth itself that allows users to sign transactions. It is developed and maintained by +the Geth team and is intended to eventually replace the account management tool built in to Geth. + +## Prerequisites + +In order to get the most value from the tutorials on this page, the following skills are necessary: + +- Experience using the command line +- Basic knowledge about Ethereum and testnets +- Basic knowledge about HTTP and JavaScript + +Users that need to revisit these fundamentals can find helpful resources relating to the command line +[here][cli], +Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), http +[here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and Javascript [here](https://www.javascript.com/learn). + +{% include note.html content="If Geth was installed from source on Linux, `make` saves the binaries for +Geth and the associated tools in `/build/bin`. To run these programs it is convenient to move them to +the top level project directory (e.g. running `mv ./build/bin/* ./`) from `/go-ethereum`. Then `./` must +be prepended to the commands in the code snippets in order to execute a particular program, e.g. `./geth` +instead of simply `geth`. If the executables are not moved then either navigate to the `bin` directory to +run them (e.g. `cd ./build/bin` and `./geth`) or provide their path (e.g. `./build/bin/geth`). These +instructions can be ignored for other installations." %} + +## Background + +Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. +Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being +managed by a central server. Nodes compete to generate new blocks of transactions to send to its peers +because they are rewarded for doing so in Ethereum's native token, ether (ETH). On receiving a new block, +each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called +a "blockchain". The information provided in each block is used by Geth to update its "state" - the ether +balance of each account on Ethereum. There are two types of account: externally-owned accounts (EOAs) and +contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts +that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, +where the public key is used to derive a unique address for the user and the private key is used to protect +the account and securely sign messages. Therefore, in order to use Ethereum, it is first necessary to generate +an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it with +ether and sending some to another address. + +Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). + +## Step 1: Generating accounts + +There are several methods for generating accounts in Geth. This tutorial demonstrates how to generate accounts +using Clef, as this is considered best practice, largely because it decouples the users' key management from Geth, +making it more modular and flexible. It can also be run from secure USB sticks or virtual machines, offering +security benefits. For convenience, this tutorial will execute Clef on the same computer that will also run Geth, +although more secure options are available (see [here](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/docs/setup.md)). + +An account is a pair of keys (public and private). Clef needs to know where to save these keys to so that they +can be retrieved later. This information is passed to Clef as an argument. This is achieved using the following command: + +```shell +clef newaccount --keystore geth-tutorial/keystore +``` + +The specific function from Clef that generates new accounts is `newaccount` and it accepts a +parameter, `--keystore`, that tells it where to store the newly generated keys. In this +example the keystore location is a new directory that will be created automatically: `geth-tutorial/keystore`. +Clef will return the following result in the terminal: + +```terminal +WARNING! + +Clef is an account management tool. It may, like any software, contain bugs. + +Please take care to +- backup your keystore files, +- verify that the keystore(s) can be opened with your password. + +Clef is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY +without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR +PURPOSE. See the GNU General Public License for more details. + +Enter 'ok' to proceed: +> +``` + +This is important information. The `geth-tutorial/keystore` directory will soon contain a secret +key that can be used to access any funds held in the new account. If it is compromised, the funds +can be stolen. If it is lost, there is no way to retrieve the funds. This tutorial will only use +dummy funds with no real world value, but when these steps are repeated on Ethereum mainnet is +critical that the keystore is kept secure and backed up. + + +Typing `ok` into the terminal and pressing `enter` causes Clef to prompt for a password. +Clef requires a password that is at least 10 characters long, and best practice would be +to use a combination of numbers, characters and special characters. Entering a suitable +password and pressing `enter` returns the following result to the terminal: + +```terminal +----------------------- +DEBUG[02-10|13:46:46.436] FS scan times list="92.081µs" set="12.629µs" diff="2.129µs" +INFO [02-10|13:46:46.592] Your new key was generated address=0xCe8dBA5e4157c2B284d8853afEEea259344C1653 +WARN [02-10|13:46:46.595] Please backup your key file! path=keystore:///.../geth-tutorial/keystore/UTC--2022-02-07T17-19-56.517538000Z--ca57f3b40b42fcce3c37b8d18adbca5260ca72ec +WARN [02-10|13:46:46.595] Please remember your password! +Generated account 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 +``` + +It is important to save the account address and the password somewhere secure. +They will be used again later in this tutorial. Please note that the account address shown +in the code snippets above and later in this tutorials are examples - those generated by followers +of this tutorial will be different. The account generated above can be used as the main account +throughout the remainder of this tutorial. However in order to demonstrate transactions between +accounts it is also necessary to have a second account. A second account can be added to the +same keystore by precisely repeating the previous steps, providing the same password. + +## Step 2: Start Clef + +The previous commands used Clef's `newaccount` function to add new key pairs to the keystore. +Clef uses the private key(s) saved in the keystore is used to sign transactions. In order to do +this, Clef needs to be started and left running while Geth is running simultaneously, so that the +two programs can communicate between one another. + +To start Clef, run the Clef executable passing as arguments the keystore file location, +config directory location and a chain ID. The config directory was automatically created +inside the `geth-tutorial` directory during the previous step. The [chain ID](https://chainlist.org/) +is an integer that defines which Ethereum network to connect to. Ethereum mainnet has chain ID 1. +In this tutorial Chain ID 5 is used which is that of the Goerli testnet. It is very important that +this chain ID parameter is set to 5. The following command starts Clef on Goerli: + +```shell + +clef --keystore geth-tutorial/keystore --configdir geth-tutorial/clef --chainid 5 + +``` + +After running the command above, Clef requests the user to type “ok” to proceed. On typing "ok" and pressing enter, Clef returns the following to the terminal: + +```terminal +INFO [02-10|13:55:30.812] Using CLI as UI-channel +INFO [02-10|13:55:30.946] Loaded 4byte database embeds=146,841 locals=0 local=./4byte-custom.json +WARN [02-10|13:55:30.947] Failed to open master, rules disabled err="failed stat on geth-tutorial/clef/masterseed.json: stat geth-tutorial/clef/masterseed.json: no such file or directory" +INFO [02-10|13:55:30.947] Starting signer chainid=5 keystore=geth-tutorial/keystore light-kdf=false advanced=false +DEBUG[02-10|13:55:30.948] FS scan times list="133.35µs" set="5.692µs" diff="3.262µs" +DEBUG[02-10|13:55:30.970] Ledger support enabled +DEBUG[02-10|13:55:30.973] Trezor support enabled via HID +DEBUG[02-10|13:55:30.976] Trezor support enabled via WebUSB +INFO [02-10|13:55:30.978] Audit logs configured file=audit.log +DEBUG[02-10|13:55:30.981] IPCs registered namespaces=account +INFO [02-10|13:55:30.984] IPC endpoint opened url=geth-tutorial/clef/clef.ipc +------- Signer info ------- +* intapi_version : 7.0.1 +* extapi_version : 6.1.0 +* extapi_http : n/a +* extapi_ipc : geth-tutorial/clef/clef.ipc +``` + +This result indicates that Clef is running. This terminal should be left running for the duration of this +tutorial. If the tutorial is stopped and restarted later Clef must also be restarted by running the previous command. + +## Step 3: Start Geth + +Geth is the Ethereum client that will connect the computer to the Ethereum network. In this tutorial the +network is Goerli, an Ethereum testnet. Testnets are used to test Ethereum client software and smart +contracts in an environment where no real-world value is at risk. To start Geth, run the Geth executable +file passing argument that define the data directory (where Geth should save blockchain data), +signer (points Geth to Clef), the network ID and the sync mode. For this tutorial, snap sync is recommended +(see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). The final argument +passed to Geth is the `--http` flag. This enables the http-rpc server that allows external programs to +interact with Geth by sending it http requests. By default the http server is only exposed locally using +port 8545: `localhost:8545`. + +The following command should be run in a new terminal, separate to the one running Clef: + +```shell +geth --datadir geth-tutorial --signer=geth-tutorial/clef/clef.ipc --goerli --syncmode snap --http +``` + +Running the above command starts Geth. The terminal should rapidly fill with status updates, starting with: + +```terminal +INFO [02-10|13:59:06.649] Starting Geth on goerli testnet... +INFO [02-10|13:59:06.649] Dropping default light client cache provided=1024 updated=128 +INFO [02-10|13:59:06.652] Maximum peer count ETH=50 LES=0 total=50 +INFO [02-10|13:59:06.655] Using external signer url=geth-tutorial/clef/clef.ipc +INFO [02-10|13:59:06.660] Set global gas cap cap=50,000,000 +INFO [02-10|13:59:06.661] Allocated cache and file handles database=/.../geth-tutorial/geth/chaindata cache=64.00MiB handles=5120 +INFO [02-10|13:59:06.855] Persisted trie from memory database nodes=361 size=51.17KiB time="643.54µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B +INFO [02-10|13:59:06.855] Initialised chain configuration config="{ChainID: 5 Homestead: 0 DAO: nil DAOSupport: true EIP150: 0 EIP155: 0 EIP158: 0 Byzantium: 0 Constantinople: 0 Petersburg: 0 Istanbul: 1561651, Muir Glacier: nil, Berlin: 4460644, London: 5062605, Arrow Glacier: nil, MergeFork: nil, Engine: clique}" +INFO [02-10|13:59:06.862] Added trusted checkpoint block=5,799,935 hash=2de018..c32427 +INFO [02-10|13:59:06.863] Loaded most recent local header number=6,340,934 hash=483cf5..858315 td=9,321,576 age=2d9h29m +INFO [02-10|13:59:06.867] Configured checkpoint oracle address=0x18CA0E045F0D772a851BC7e48357Bcaab0a0795D signers=5 threshold=2 +INFO [02-10|13:59:06.867] Gasprice oracle is ignoring threshold set threshold=2 +WARN [02-10|13:59:06.869] Unclean shutdown detected booted=2022-02-08T04:25:08+0100 age=2d9h33m +INFO [02-10|13:59:06.870] Starting peer-to-peer node instance=Geth/v1.10.15-stable/darwin-amd64/go1.17.5 +INFO [02-10|13:59:06.995] New local node record seq=1,644,272,735,880 id=d4ffcd252d322a89 ip=127.0.0.1 udp=30303 tcp=30303 +INFO [02-10|13:59:06.996] Started P2P networking self=enode://4b80ebd341b5308f7a6b61d91aa0ea31bd5fc9e0a6a5483e59fd4ea84e0646b13ecd289e31e00821ccedece0bf4b9189c474371af7393093138f546ac23ef93e@127.0.0.1:30303 +INFO [02-10|13:59:06.997] IPC endpoint opened url=/.../geth-tutorial/geth.ipc +INFO [02-10|13:59:06.998] HTTP server started endpoint=127.0.0.1:8545 prefix= cors= vhosts=localhost +WARN [02-10|13:59:06.998] Light client mode is an experimental feature +WARN [02-10|13:59:06.999] Failed to open wallet url=extapi://geth-tutorial/clef/cle.. err="operation not supported on external signers" +INFO [02-10|13:59:08.793] Block synchronisation started +``` + +This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers it +can request block headers from them, starting at the genesis block for the Goerli blockchain. Geth continues +to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. +This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in +the terminal with the following syntax: + +```terminal +INFO [04-29][15:54:09.238] Looking for peers peercount=2 tried=0 static=0 +INFO [04-29][15:54:19.393] Imported new block headers count=2 elapsed=1.127ms number=996288 hash=09f1e3..718c47 age=13h9m5s +INFO [04-29][15:54:19:656] Imported new block receipts count=698 elapsed=4.464ms number=994566 hash=56dc44..007c93 age=13h9m9s +``` + +These logs indicate that Geth is running as expected. Sending an empty Curl request to the http server +provides a quick way to confirm that this too has been started without any issues. In a third terminal, +the following command can be run: + +```shell +curl http://localhost:8545 +``` + +If there is no error message reported to the terminal, everything is OK. Geth must be running in order for +a user to interact with the Ethereum network. If this terminal is closed down then Geth must be restarted +in a new terminal. Geth can be started and stopped easily, but it must be running for any interaction with +Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. To start it again, +run the previous command `geth --datadir ... ..`. + +{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished you +can't use the node to transfer funds. You can also try doing a [light sync](interface/les) which will be +much quicker but depends on light servers being available to serve your node the data it needs." %} + +## Step 4: Get Testnet Ether + +In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, +ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; +2) receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, +3) having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it +4) can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether to their account. + +The address generated by Clef in Step 1 can be pasted into the Paradigm Multifaucet faucet +[here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of +personhood. The faucets adds ether to the given address on multiple testnets simultaneously, +including Goerli. In the next steps Geth will be used to check that the ether has been sent +to the given address and send some of it to the second address created earlier. + + +## Step 5: Interact with Geth + +For interacting with the blockchain, Geth provides JSON-RPC APIs. +[JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific +tasks by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. +RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded +instructions from locations outside of those managed by Geth. It is possible to interact with Geth +by sending these JSON encoded instructions directly over Geth's exposed http port using tools like Curl. +However, this is somewhat user-unfriendly and error-prone, especially for more complex instructions. +For this reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly +interface for interacting with Geth. One of the most widely used is Web3.js. + +Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in one terminal, a Javascript environment can be opened in another allowing the user to interact with Geth using Web3.js. There are three transport protocols that can be used to connect the Javascript environment to Geth: + +- IPC (Inter-Process Communication): Provides unrestricted access to all APIs, but only works when the console is run on the same host as the geth node. + +- HTTP: By default provides access to the `eth`, `web3` and `net` method namespaces. + +- Websocket: By default provides access to the `eth`, `web3` and `net` method namespaces. + +This tutorial will use the HTTP option. Note that the terminals running Geth and Clef should both still be active. +In a new (third) terminal, the following command can be run to start the console and connect it to Geth +using the exposed http port: + +```shell +geth attach http://127.0.0.1:8545 +``` + +This command causes the terminal to hang because it is waiting for approval from Clef. Approving the request +in the terminal running Clef will lead to the following welcome message being displayed in the Javascript console: + +```terminal +Welcome to the Geth JavaScript console! + +instance: Geth/v1.10.15-stable/darwin-amd64/go1.17.5 +at block: 6354736 (Thu Feb 10 2022 14:01:46 GMT+0100 (WAT)) + modules: eth:1.0 net:1.0 rpc:1.0 web3:1.0 + +To exit, press ctrl-d or type exit +``` + +The console is now active and connected to Geth. It can now be used to interact with the Ethereum (Goerli) network. + + +### List of accounts + +In this tutorial, the accounts are managed using Clef. This means that requesting information about +the accounts requires explicit approval in Clef, which should still be running in its own terminal. +Earlier in this tutorial, two accounts were created using Clef. The following command will display the +addresses of those two accounts and any others that might have been added to the keystore before or since. + +```javascript +eth.accounts +``` + +The console will hang, because Clef is waiting for approval. The following message will be +displayed in the Clef terminal: + +```terminal +-------- List Account request-------------- +A request has been made to list all accounts. +You can select which accounts the caller can see + [x] 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC + URL: keystore:///.../geth-tutorial/keystore/UTC--2022-02-07T17-19-56.517538000Z--ca57f3b40b42fcce3c37b8d18adbca5260ca72ec + [x] 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 + URL: keystore:///.../geth-tutorial/keystore/UTC--2022-02-10T12-46-45.265592000Z--ce8dba5e4157c2b284d8853afeeea259344c1653 +------------------------------------------- +Request context: + NA - ipc - NA + +Additional HTTP header data, provided by the external caller: + User-Agent: "" + Origin: "" +Approve? [y/N]: + +``` + +Entering `y` approves the request from the console. In the terminal running the Javascript console, +the account addresses are now displayed: + +```terminal +["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", "0xce8dba5e4157c2b284d8853afeeea259344c1653"] +``` + +It is also possible for this request to time out if the Clef approval took too long - +in this case simply repeat the request and approval. + + +### Checking account balance. + +Having confirmed that the two addresses created earlier are indeed in the keystore and accessible +through the Javascript console, it is possible to retrieve information about how much ether they own. +The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance of one of +the accounts should be 1 ether and the other should be 0. The following command displays the account +balance in the console: + +```javascript +web3.fromWei(eth.getBalance("0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC"), "ether") +``` + +There are actually two instructions sent in the above command. The inner one is the `getBalance` +function from the `eth` namespace. This takes the account address as its only argument. By default, +this returns the account balance in units of Wei. There are 1018 Wei to one ether. +To present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from +the `web3` namespace. Running this command should provide the following result +(for the account that received faucet funds): + +```terminal +1 +``` + +Repeating the command for the other account should yield: + +```terminal +0 +``` + +### Send ether to another account + +The command `eth.sendTransaction` can be used to send some ether from one address to another. +This command takes three arguments: `from`, `to` and `value`. These define the sender and +recipient addresses (as strings) and the amount of Wei to transfer. It is far less error +prone to enter the transaction value in units of ether rather than Wei, so the value field can +take the return value from the `toWei` function. The following command, run in the Javascript +console, sends 0.1 ether from one of the accounts in the Clef keystore to the other. Note that +the addresses here are examples - the user must replace the address in the `from` field with +the address currently owning 1 ether, and the address in the `to` field with the address +currently holding 0 ether. + +```javascript +eth.sendTransaction({ + from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", + to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", + value: web3.toWei(0.1, "ether") +}) +``` + +Note that submitting this transaction requires approval in Clef. In the Clef terminal, +Clef will prompt for approval and request the account password. If the password is correctly +entered, Geth proceeds with the transaction. The transaction request summary is presented by +Clef in the Clef terminal. This is an opportunity for the sender to review the details and +ensure they are correct. + +```terminal +--------- Transaction request------------- +to: 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 +from: 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC [chksum ok] +value: 10000000000000000 wei +gas: 0x5208 (21000) +maxFeePerGas: 2425000057 wei +maxPriorityFeePerGas: 2424999967 wei +nonce: 0x3 (3) +chainid: 0x5 +Accesslist + +Request context: + NA - ipc - NA + +Additional HTTP header data, provided by the external caller: + User-Agent: "" + Origin: "" +------------------------------------------- +Approve? [y/N]: + +Please enter the password for account 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC + +``` + +After approving the transaction, the following confirmation screen in displayed in +the Clef terminal: + +```terminal +----------------------- +Transaction signed: + { + "type": "0x2", + "nonce": "0x3", + "gasPrice": null, + "maxPriorityFeePerGas": "0x908a901f", + "maxFeePerGas": "0x908a9079", + "gas": "0x5208", + "value": "0x2386f26fc10000", + "input": "0x", + "v": "0x0", + "r": "0x66e5d23ad156e04363e68b986d3a09e879f7fe6c84993cef800bc3b7ba8af072", + "s": "0x647ff82be943ea4738600c831c4a19879f212eb77e32896c05055174045da1bc", + "to": "0xce8dba5e4157c2b284d8853afeeea259344c1653", + "chainId": "0x5", + "accessList": [], + "hash": "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" + } +``` + +In the Javascript console, the transaction hash is displayed. This will be used in the +next section to retrieve the transaction details. + +```terminal +"0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" +``` + +It is also advised to check the account balances using Geth by repeating the instructions from +earlier. At this point in the tutorial, the two accounts in the Clef keystore should have balances +just below 0.9 ether (because 0.1 ether has been transferred out and some small amount paid in +transaction gas) and 0.1 ether. + + +### Checking the transaction hash + +The transaction hash is a unique identifier for this specific transaction that can be used +later to retrieve the transaction details. For example, the transaction details can be +viewed by pasting this hash into the [Goerli block explorer](https://goerli.etherscan.io/). +The same information can also be retrieved directly from the Geth node. The hash returned in +the previous step can be provided as an argument to `eth.getTransaction` to return the +transaction information: + +```javascript +eth.getTransaction("0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb") +``` + +This returns the following response (although the actual values for each field will vary +because they are specific to each transaction): + +```terminal +{ + accessList: [], + blockHash: "0x1c5d3f8dd997b302935391b57dc3e4fffd1fa2088ef2836d51f844f993eb39c4", + blockNumber: 6355150, + chainId: "0x5", + from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", + gas: 21000, + gasPrice: 2425000023, + hash: "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb", + input: "0x", + maxFeePerGas: 2425000057, + maxPriorityFeePerGas: 2424999967, + nonce: 3, + r: "0x66e5d23ad156e04363e68b986d3a09e879f7fe6c84993cef800bc3b7ba8af072", + s: "0x647ff82be943ea4738600c831c4a19879f212eb77e32896c05055174045da1bc", + to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", + transactionIndex: 630, + type: "0x2", + v: "0x0", + value: 10000000000000000 +} +``` + +## Using Curl + +Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. +This library enables the user to send instructions to Geth using a more user-friendly interface +compared to sending raw JSON objects. However, it is also possible for the user to send these +JSON objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP +requests. This part of the tutorial demonstrates how to check account balances and send a +transaction using Curl. + +### Checking account balance + +The command below returns the balance of the given account. This is a HTTP POST request to the +local port 8545. The `-H` flag is for header information. It is used here to define the format +of the incoming payload, which is JSON. The `--data` flag defines the content of the payload, +which is a JSON object. That JSON object contains four fields: `jsonrpc` defines the spec version +for the JSON-RPC API, `method` is the specific function being invoked, `params` are the function +arguments, and `id` is used for ordering transactions. The two arguments passed to `eth_getBalance` +are the account address whose balance to check and the block to query (here `latest` is used to +check the balance in the most recently mined block). + +```shell +curl -X POST http://127.0.0.1:8545 \ + -H "Content-Type: application/json" \ + --data '{"jsonrpc":"2.0", "method":"eth_getBalance", "params":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","latest"], "id":1}' +``` + +A successful call will return a response like the one below: + +```terminal +{"jsonrpc":"2.0","id":1,"result":"0xc7d54951f87f7c0"} +``` + +The balance is in the `result` field in the returned JSON object. However, it is denominated in +Wei and presented as a hexadecimal string. There are many options for converting this value to a +decimal in units of ether, for example by opening a Python console and running: + +```python +0xc7d54951f87f7c0 / 1e18 +``` +This returns the balance in ether: + +```terminal +0.8999684999998321 +``` + +### Checking the account list + +The curl command below returns the list of all accounts. + +```shell +curl -X POST http://127.0.0.1:8545 \ + -H "Content-Type: application/json" \ + --data '{"jsonrpc":"2.0", "method":"eth_accounts","params":[], "id":1}' +``` + +This requires approval in Clef. Once approved, the following information is returned to the terminal: + +```terminal +{"jsonrpc":"2.0","id":1,"result":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec"]} +``` + +### Sending Transactions + +Sending a transaction between accounts can also be achieved using Curl. Notice that the value of the +transaction is a hexadecimal string in units of Wei. To transfer 0.1 ether, it is first necessary to +convert this to Wei by multiplying by 1018 then converting to hex. 0.1 ether is +`"0x16345785d8a0000"` in hex. As before, update the `to` and `from` fields with the addresses in +the Clef keystore. + + +```shell +curl -X POST http://127.0.0.1:8545 \ + -H "Content-Type: application/json" \ + --data '{"jsonrpc":"2.0", "method":"eth_sendTransaction", "params":[{"from": "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","to": "0xce8dba5e4157c2b284d8853afeeea259344c1653","value": "0x16345785d8a0000"}], "id":1}' +``` + +This requires approval in Clef. Once the password for the sender account has been provided, +Clef will return a summary of the transaction details and the terminal that made the Curl +request will display a response containing the transaction hash. + +```terminal +{"jsonrpc":"2.0","id":5,"result":"0xac8b347d70a82805edb85fc136fc2c4e77d31677c2f9e4e7950e0342f0dc7e7c"} +``` + +## Summary + +This tutorial has demonstrated how to generate accounts using Clef, fund them with testnet ether and use +those accounts to interact with Ethereum (Goerli) through a Geth node. Checking account balances, sending +transactions and retrieving transaction details were explained using the web3.js library via the +Geth console and using the JSON-RPC directly using Curl. For more detailed information about Clef, please see +[the Clef docs](/docs/clef/tutorial). + + +[cli]: https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line diff --git a/content/docs/getting_started/index.md b/content/docs/getting_started/index.md index 86b3f3a2ca..448e8eb5aa 100644 --- a/content/docs/getting_started/index.md +++ b/content/docs/getting_started/index.md @@ -4,134 +4,138 @@ permalink: docs/getting-started sort_key: A --- -This page explains how to set up Geth and execute some basic tasks using the command line tools. In order to use Geth, the software must first be installed. There are several ways Geth can be installed depending on the operating system and the user's choice of installation method, for example using a package manager, container or building from source. Instructions for installing Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. The tutorial on this page assumes Geth and the associated developer tools have been installed successfully. +This page explains how to set up Geth and execute some basic tasks using the command line tools. +In order to use Geth, the software must first be installed. There are several ways Geth can be +installed depending on the operating system and the user's choice of installation method, for +example using a package manager, container or building from source. Instructions for installing +Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. +The tutorial on this page assumes Geth and the associated developer tools have been installed successfully. -This page provides step-by-step instructions covering the fundamentals of using Geth. This includes generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. This tutorial also uses [Clef](clef/tutorial). Clef is an account management tool external to Geth itself that allows users to sign transactions. It is developed and maintained by the Geth team and is intended to eventually replace the account management tool built in to Geth. +This page provides step-by-step instructions covering the fundamentals of using Geth. This includes +generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. +It is considered best-practice to use [Clef](/docs/clef/Introduction) for account management - this +is explained in the [Geth with Clef](/docs/getting-started/geth_with_clef) tutorial. In this +introductory tutorial, Geth's built-in account management tools are used instead. + +{:toc} +- this will be removed by the toc ## Prerequisites -In order to get the most value from the tutorials on this page, the following skills are necessary: +In order to get the most value from the tutorials on this page, the following skills are +necessary: - Experience using the command line - Basic knowledge about Ethereum and testnets - Basic knowledge about HTTP and JavaScript -Users that need to revisit these fundamentals can find helpful resources relating to the command line [here](https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line), Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and Javascript [here](https://www.javascript.com/learn). +Users that need to revisit these fundamentals can find helpful resources relating to the command +line [here][cli], Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), +http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and +Javascript [here](https://www.javascript.com/learn). -{% include note.html content="If Geth was installed from source on Linux, `make` saves the binaries for Geth and the associated tools in `/build/bin`. To run these programs it is convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} +{% include note.html content="If Geth was installed from source on Linux, `make` saves the +binaries for Geth and the associated tools in `/build/bin`. To run these programs it is +convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) +from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to +execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not +moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) +or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} ## Background -Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being managed by a central server. Nodes compete to generate new blocks of transactions to send to its peers because they are rewarded for doing so in Ethereum's native token, ether (ETH). On receiving a new block, each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called a "blockchain". The information provided in each block is used by Geth to update its "state" - the ether balance of each account on Ethereum. There are two types of account: externally-owned accounts (EOAs) and contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, where the public key is used to derive a unique address for the user and the private key is used to protect the account and securely sign messages. Therefore, in order to use Ethereum, it is first necessary to generate an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it with ether and sending some to another address. +Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. +Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being +managed by a central server. Nodes compete to generate new blocks of transactions to send to its peers +because they are rewarded for doing so in Ethereum's native token, ether (ETH). On receiving a new block, +each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called +a "blockchain". The information provided in each block is used by Geth to update its "state" - the ether +balance of each account on Ethereum. There are two types of account: externally-owned accounts (EOAs) and +contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts +that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, +where the public key is used to derive a unique address for the user and the private key is used to protect +the account and securely sign messages. Therefore, in order to use Ethereum, it is first necessary to generate +an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it +with ether and sending some to another address. Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). ## Step 1: Generating accounts -There are several methods for generating accounts in Geth. This tutorial demonstrates how to generate accounts using Clef, as this is considered best practice, largely because it decouples the users' key management from Geth, making it more modular and flexible. It can also be run from secure USB sticks or virtual machines, offering security benefits. For convenience, this tutorial will execute Clef on the same computer that will also run Geth, although more secure options are available (see [here](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/docs/setup.md)). - -An account is a pair of keys (public and private). Clef needs to know where to save these keys to so that they can be retrieved later. This information is passed to Clef as an argument. This is achieved using the following command: - -```shell - -clef newaccount --keystore geth-tutorial/keystore +To generate a new account in Geth: +```sh +geth account new ``` -The specific function from Clef that generates new accounts is `newaccount` and it accepts a parameter, `--keystore`, that tells it where to store the newly generated keys. In this example the keystore location is a new directory that will be created automatically: `geth-tutorial/keystore`. Clef will return the following result in the terminal: +This returns a prompt for a password. Once provided, a new account will be created and added to the +default keystore (`/datadir/keystore`). A custom keystore can also be provided by passing `--keystore `. +In this tutorial the keys will be stored in a new data directory `geth-tutorial`. Create that diredctory, then run: + +```sh +geth account new --keystore geth-tutorial/keystore +``` +The following will be returned to the console, confirming the new account has been created and +added to the keystore. ```terminal -WARNING! +Your new account is locked with a password. Please give a password. Do not forget this password. +Password: +Repeat password: -Clef is an account management tool. It may, like any software, contain bugs. +Your new key was generated -Please take care to -- backup your keystore files, -- verify that the keystore(s) can be opened with your password. +Public address of the key: 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC +Path of the secret key file: /home/go-ethereum/geth-tutorial/keystore/UTC--2022-07-25T08-27-59.433905560Z--ca57F3b40B42FCce3c37B8D18aDBca5260ca72EC -Clef is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; -without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR -PURPOSE. See the GNU General Public License for more details. - -Enter 'ok' to proceed: -> +- You can share your public address with anyone. Others need it to interact with you. +- You must NEVER share the secret key with anyone! The key controls access to your funds! +- You must BACKUP your key file! Without the key, it's impossible to access account funds! +- You must REMEMBER your password! Without the password, it's impossible to decrypt the key! ``` -This is important information. The `geth-tutorial/keystore` directory will soon contain a secret key that can be used to access any funds held in the new account. If it is compromised, the funds can be stolen. If it is lost, there is no way to retrieve the funds. This tutorial will only use dummy funds with no real world value, but when these steps are repeated on Ethereum mainnet is critical that the keystore is kept secure and backed up. +It is important to save the account address and the password somewhere secure. They will be used +again later in this tutorial. Please note that the account address shown in the code snippets +above and later in this tutorials are examples - those generated by followers of this tutorial +will be different. The account generated above can be used as the main account throughout the +remainder of this tutorial. However in order to demonstrate transactions between accounts it is +also necessary to have a second account. A second account can be added to the same keystore by +precisely repeating the previous steps, providing the same password. +Notice that the path to the secret key includes a long filename that starts `UTC--`. This is the +name of the file that contains the keys for the new account. It is **extremely important** that +this file stays secure because it contains the secret key used to control access to any funds +associated with the account. The file should be backed up securely along with the password +used to encrypt it. If the file or the password is lost, then so is access to the funds in +the account. If someone else gains access to the keyfile and password, they have access to any +assets in the account. -Typing `ok` into the terminal and pressing `enter` causes Clef to prompt for a password. Clef requires a password that is at least 10 characters long, and best practice would be to use a combination of numbers, characters and special characters. Entering a suitable password and pressing `enter` returns the following result to the terminal: +## Step 2: Start Geth -```terminal ------------------------ -DEBUG[02-10|13:46:46.436] FS scan times list="92.081µs" set="12.629µs" diff="2.129µs" -INFO [02-10|13:46:46.592] Your new key was generated address=0xCe8dBA5e4157c2B284d8853afEEea259344C1653 -WARN [02-10|13:46:46.595] Please backup your key file! path=keystore:///.../geth-tutorial/keystore/UTC--2022-02-07T17-19-56.517538000Z--ca57f3b40b42fcce3c37b8d18adbca5260ca72ec -WARN [02-10|13:46:46.595] Please remember your password! -Generated account 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 -``` +Geth is the Ethereum client that will connect the computer to the Ethereum network. +In this tutorial the network is Goerli, an Ethereum testnet. Testnets are used to test +Ethereum client software and smart contracts in an environment where no real-world value +is at risk. To start Geth, run the Geth executable file passing argument that define the +data directory (where Geth should save blockchain data), the network ID and the sync mode. +For this tutorial, snap sync is recommended +(see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). -It is important to save the account address and the password somewhere secure. They will be used again later in this tutorial. Please note that the account address shown in the code snippets above and later in this tutorials are examples - those generated by followers of this tutorial will be different. The account generated above can be used as the main account throughout the remainder of this tutorial. However in order to demonstrate transactions between accounts it is also necessary to have a second account. A second account can be added to the same keystore by precisely repeating the previous steps, providing the same password. - -## Step 2: Start Clef - -The previous commands used Clef's `newaccount` function to add new key pairs to the keystore. Clef uses the private key(s) saved in the keystore is used to sign transactions. In order to do this, Clef needs to be started and left running while Geth is running simultaneously, so that the two programs can communicate between one another. - -To start Clef, run the Clef executable passing as arguments the keystore file location, config directory location and a chain ID. The config directory was automatically created inside the `geth-tutorial` directory during the previous step. The [chain ID](https://chainlist.org/) is an integer that defines which Ethereum network to connect to. Ethereum mainnet has chain ID 1. In this tutorial Chain ID 5 is used which is that of the Goerli testnet. It is very important that this chain ID parameter is set to 5. The following command starts Clef on Goerli: +The following command should be run in the terminal: ```shell - -clef --keystore geth-tutorial/keystore --configdir geth-tutorial/clef --chainid 5 - +geth --datadir geth-tutorial --goerli --syncmode snap ``` - -After running the command above, Clef requests the user to type “ok” to proceed. On typing "ok" and pressing enter, Clef returns the following to the terminal: - -```terminal -INFO [02-10|13:55:30.812] Using CLI as UI-channel -INFO [02-10|13:55:30.946] Loaded 4byte database embeds=146,841 locals=0 local=./4byte-custom.json -WARN [02-10|13:55:30.947] Failed to open master, rules disabled err="failed stat on geth-tutorial/clef/masterseed.json: stat geth-tutorial/clef/masterseed.json: no such file or directory" -INFO [02-10|13:55:30.947] Starting signer chainid=5 keystore=geth-tutorial/keystore light-kdf=false advanced=false -DEBUG[02-10|13:55:30.948] FS scan times list="133.35µs" set="5.692µs" diff="3.262µs" -DEBUG[02-10|13:55:30.970] Ledger support enabled -DEBUG[02-10|13:55:30.973] Trezor support enabled via HID -DEBUG[02-10|13:55:30.976] Trezor support enabled via WebUSB -INFO [02-10|13:55:30.978] Audit logs configured file=audit.log -DEBUG[02-10|13:55:30.981] IPCs registered namespaces=account -INFO [02-10|13:55:30.984] IPC endpoint opened url=geth-tutorial/clef/clef.ipc -------- Signer info ------- -* intapi_version : 7.0.1 -* extapi_version : 6.1.0 -* extapi_http : n/a -* extapi_ipc : geth-tutorial/clef/clef.ipc -``` - -This result indicates that Clef is running. This terminal should be left running for the duration of this tutorial. If the tutorial is stopped and restarted later Clef must also be restarted by running the previous command. - -## Step 3: Start Geth - -Geth is the Ethereum client that will connect the computer to the Ethereum network. In this tutorial the network is Goerli, an Ethereum testnet. Testnets are used to test Ethereum client software and smart contracts in an environment where no real-world value is at risk. To start Geth, run the Geth executable file passing argument that define the data directory (where Geth should save blockchain data), signer (points Geth to Clef), the network ID and the sync mode. For this tutorial, snap sync is recommended (see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). The final argument passed to Geth is the `--http` flag. This enables the http-rpc server that allows external programs to interact with Geth by sending it http requests. By default the http server is only exposed locally using port 8545: `localhost:8545`. - -The following command should be run in a new terminal, separate to the one running Clef: - -```shell - -geth --datadir geth-tutorial --signer=geth-tutorial/clef/clef.ipc --goerli --syncmode snap --http - -``` - -Running the above command starts Geth. The terminal should rapidly fill with status updates, starting with: +Running the above command starts Geth. The terminal should rapidly fill with status updates that look like the following: ```terminal INFO [02-10|13:59:06.649] Starting Geth on goerli testnet... INFO [02-10|13:59:06.649] Dropping default light client cache provided=1024 updated=128 INFO [02-10|13:59:06.652] Maximum peer count ETH=50 LES=0 total=50 -INFO [02-10|13:59:06.655] Using external signer url=geth-tutorial/clef/clef.ipc INFO [02-10|13:59:06.660] Set global gas cap cap=50,000,000 INFO [02-10|13:59:06.661] Allocated cache and file handles database=/.../geth-tutorial/geth/chaindata cache=64.00MiB handles=5120 INFO [02-10|13:59:06.855] Persisted trie from memory database nodes=361 size=51.17KiB time="643.54µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B -INFO [02-10|13:59:06.855] Initialised chain configuration config="{ChainID: 5 Homestead: 0 DAO: DAOSupport: true EIP150: 0 EIP155: 0 EIP158: 0 Byzantium: 0 Constantinople: 0 Petersburg: 0 Istanbul: 1561651, Muir Glacier: , Berlin: 4460644, London: 5062605, Arrow Glacier: , MergeFork: , Engine: clique}" +INFO [02-10|13:59:06.855] Initialised chain configuration config="{ChainID: 5 Homestead: 0 DAO: nil DAOSupport: true EIP150: 0 EIP155: 0 EIP158: 0 Byzantium: 0 Constantinople: 0 Petersburg: 0 Istanbul: 1561651, Muir Glacier: nil, Berlin: 4460644, London: 5062605, Arrow Glacier: nil, MergeFork: nil, Engine: clique}" INFO [02-10|13:59:06.862] Added trusted checkpoint block=5,799,935 hash=2de018..c32427 INFO [02-10|13:59:06.863] Loaded most recent local header number=6,340,934 hash=483cf5..858315 td=9,321,576 age=2d9h29m INFO [02-10|13:59:06.867] Configured checkpoint oracle address=0x18CA0E045F0D772a851BC7e48357Bcaab0a0795D signers=5 threshold=2 @@ -141,13 +145,15 @@ INFO [02-10|13:59:06.870] Starting peer-to-peer node instance=Geth INFO [02-10|13:59:06.995] New local node record seq=1,644,272,735,880 id=d4ffcd252d322a89 ip=127.0.0.1 udp=30303 tcp=30303 INFO [02-10|13:59:06.996] Started P2P networking self=enode://4b80ebd341b5308f7a6b61d91aa0ea31bd5fc9e0a6a5483e59fd4ea84e0646b13ecd289e31e00821ccedece0bf4b9189c474371af7393093138f546ac23ef93e@127.0.0.1:30303 INFO [02-10|13:59:06.997] IPC endpoint opened url=/.../geth-tutorial/geth.ipc -INFO [02-10|13:59:06.998] HTTP server started endpoint=127.0.0.1:8545 prefix= cors= vhosts=localhost WARN [02-10|13:59:06.998] Light client mode is an experimental feature -WARN [02-10|13:59:06.999] Failed to open wallet url=extapi://geth-tutorial/clef/cle.. err="operation not supported on external signers" INFO [02-10|13:59:08.793] Block synchronisation started ``` -This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers it can request block headers from them, starting at the genesis block for the Goerli blockchain. Geth continues to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in the terminal with the following syntax: +This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers +it can request block headers from them, starting at the genesis block for the Goerli blockchain. +Geth continues to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. +This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in the +terminal with the following syntax: ```terminal @@ -157,51 +163,76 @@ INFO [04-29][15:54:19:656] Imported new block receipts count=698 elapsed=4.46 ``` -These logs indicate that Geth is running as expected. Sending an empty Curl request to the http server provides a quick way to confirm that this too has been started without any issues. In a third terminal, the following command can be run: +These logs indicate that Geth is running as expected. -```shell +If there is no error message reported to the terminal, everything is OK. Geth must be running in +order for a user to interact with the Ethereum network. If this terminal is closed down then Geth +must be restarted again. Geth can be started and stopped easily, but it must be running for any +interaction with Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. +To start it again, run the previous command `geth --datadir ... ..`. -curl http://localhost:8545 +{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished +you can't use the node to transfer funds. You can also try doing a [light sync](interface/les) +which will be much quicker but depends on light servers being available to serve your node the data it needs." %} -``` +## Step 3: Get Testnet Ether -If there is no error message reported to the terminal, everything is OK. Geth must be running in order for a user to interact with the Ethereum network. If this terminal is closed down then Geth must be restarted in a new terminal. Geth can be started and stopped easily, but it must be running for any interaction with Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. To start it again, run the previous command `geth --datadir ... ..`. +In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, +ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; 2) +receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, +having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it +can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether +to their account. -{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished you can't use the node to transfer funds. You can also try doing a [light sync](interface/les) which will be much quicker but depends on light servers being available to serve your node the data it needs." %} - -## Step 4: Get Testnet Ether - -In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; 2) receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether to their account. - -The address generated by Clef in Step 1 can be pasted into the Paradigm Multifaucet faucet [here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of personhood. The faucets adds ether to the given address on multiple testnets simultaneously, including Goerli. In the next steps Geth will be used to check that the ether has been sent to the given address and send some of it to the second address created earlier. +The address generated by `geth account new` can be pasted into the Paradigm Multifaucet faucet +[here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of +personhood. The faucets adds ether to the given address on multiple testnets simultaneously, +including Goerli. In the next steps Geth will be used to check that the ether has been sent to +the given address and send some of it to the second address created earlier. -## Step 5: Interact with Geth via IPC or RPC +## Step 4: Interact with Geth -For interacting with the blockchain, Geth provides JSON-RPC APIs. [JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific tasks by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded instructions from locations outside of those managed by Geth. It is possible to interact with Geth by sending these JSON encoded instructions directly over Geth's exposed http port using tools like Curl. However, this is somewhat user-unfriendly and error-prone, especially for more complex instructions. For this reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly interface for interacting with Geth. One of the most widely used is Web3.js. +For interacting with the blockchain, Geth provides JSON-RPC APIs. +[JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific tasks +by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. +RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded +instructions from locations outside of those managed by Geth. It is possible to interact with Geth +by sending these JSON encoded instructions directly to Geth using tools such as Curl. However, +this is somewhat user-unfriendly and error-prone, especially for more complex instructions. For this +reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly +interface for interacting with Geth. One of the most widely used is Web3.js. -Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in one terminal, a Javascript environment can be opened in another allowing the user to interact with Geth using Web3.js. There are two transport protocols that can be used to connect the Javascript environment to Geth: +Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in +one terminal, a Javascript environment can be opened in another allowing the user to interact with +Geth using Web3.js. There are three transport protocols that can be used to connect the Javascript +environment to Geth: -- IPC (Inter-Process Communication): This provides unrestricted access to all APIs, but only works when the console is run on the same host as the geth node. +- IPC (Inter-Process Communication): Provides unrestricted access to all APIs, but only works when the +- console is run on the same host as the Geth node. -- HTTP: This connection method by default provides access to the `eth`, `web3` and `net` method namespaces. +- HTTP: By default provides access to the `eth`, `web3` and `net` method namespaces. -This tutorial will use the HTTP option. Note that the terminals running Geth and Clef should both still be active. In a new (third) terminal, the following command can be run to start the console and connect it to Geth using the exposed http port: +- Websocket: By default provides access to the `eth`, `web3` and `net` method namespaces. + +This tutorial will use the IPC option. To do this, the path to Geth's `ipc` file must be known. +By default, this is the `datadir`, in this case `geth-tutorial`. In a new terminal, the following +command can be run to start the Javascript console and connect it to Geth using the `geth.ipc` +file from the datadir: ```shell - -geth attach http://127.0.0.1:8545 - +geth attach geth-tutorial/geth.ipc ``` -This command causes the terminal to hang because it is waiting for approval from Clef. Approving the request in the terminal running Clef will lead to the following welcome message being displayed in the Javascript console: +The following welcome message will be displayed in the Javascript console: ```terminal Welcome to the Geth JavaScript console! instance: Geth/v1.10.15-stable/darwin-amd64/go1.17.5 at block: 6354736 (Thu Feb 10 2022 14:01:46 GMT+0100 (WAT)) - modules: eth:1.0 net:1.0 rpc:1.0 web3:1.0 + datadir: /home/go-ethereum/geth-tutorial + modules: admin:1.0 clique:1.0 debug:1.0 eth:1.0 miner:1.0 net:1.0 personal:1.0 rpc:1.0 txpool:1.0 web3:1.0 To exit, press ctrl-d or type exit ``` @@ -211,78 +242,58 @@ The console is now active and connected to Geth. It can now be used to interact ### List of accounts -In this tutorial, the accounts are managed using Clef. This means that requesting information about the accounts requires explicit approval in Clef, which should still be running in its own terminal. Earlier in this tutorial, two accounts were created using Clef. The following command will display the addresses of those two accounts and any others that might have been added to the keystore before or since. +Earlier in this tutorial, at least one account was created using `geth account new`. The following +command will display the addresses of those two accounts and any others that might have been added +to the keystore before or since. ```javascript - eth.accounts - ``` -The console will hang, because Clef is waiting for approval. The following message will be displayed in the Clef terminal: - ```terminal - --------- List Account request-------------- -A request has been made to list all accounts. -You can select which accounts the caller can see - [x] 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC - URL: keystore:///.../geth-tutorial/keystore/UTC--2022-02-07T17-19-56.517538000Z--ca57f3b40b42fcce3c37b8d18adbca5260ca72ec - [x] 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 - URL: keystore:///.../geth-tutorial/keystore/UTC--2022-02-10T12-46-45.265592000Z--ce8dba5e4157c2b284d8853afeeea259344c1653 -------------------------------------------- -Request context: - NA -> ipc -> NA - -Additional HTTP header data, provided by the external caller: - User-Agent: "" - Origin: "" -Approve? [y/N]: -> y - -``` - -Entering `y` approves the request from the console. In the terminal running the Javascript console, the account addresses are now displayed: - -```terminal - ["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", "0xce8dba5e4157c2b284d8853afeeea259344c1653"] - ``` -It is also possible for this request to time out if the Clef approval took too long - in this case simply repeat the request and approval. - ### Checking account balance. -Having confirmed that the two addresses created earlier are indeed in the keystore and accessible through the Javascript console, it is possible to retrieve information about how much ether they own. The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance of one of the accounts should be 1 ether and the other should be 0. The following command displays the account balance in the console: +Having confirmed that the two addresses created earlier are indeed in the keystore and accessible +through the Javascript console, it is possible to retrieve information about how much ether they +own. The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance +of one of the accounts should be 1 ether and the other should be 0. The following command displays +the account balance in the console: ```javascript - web3.fromWei(eth.getBalance("0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC"), "ether") - ``` -There are actually two instructions sent in the above command. The inner one is the `getBalance` function from the `eth` namespace. This takes the account address as its only argument. By default, this returns the account balance in units of Wei. There are 1018 Wei to one ether. To present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from the `web3` namespace. Running this command should provide the following result (for the account that received faucet funds): +There are actually two instructions sent in the above command. The inner one is the `getBalance` +function from the `eth` namespace. This takes the account address as its only argument. By default, +this returns the account balance in units of Wei. There are 1018 Wei to one ether. To +present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from the +`web3` namespace. Running this command should provide the following result (for the account that +received faucet funds): ```terminal - 1 - ``` -Repeating the command for the other account should yield: +Repeating the command for the other new account that was not funded from the faucet should yield: ```terminal - 0 - ``` - ### Send ether to another account -The command `eth.sendTransaction` can be used to send some ether from one address to another. This command takes three arguments: `from`, `to` and `value`. These define the sender and recipient addresses (as strings) and the amount of Wei to transfer. It is far less error prone to enter the transaction value in units of ether rather than Wei, so the value field can take the return value from the `toWei` function. The following command, run in the Javascript console, sends 0.1 ether from one of the accounts in the Clef keystore to the other. Note that the addresses here are examples - the user must replace the address in the `from` field with the address currently owning 1 ether, and the address in the `to` field with the address currently holding 0 ether. +The command `eth.sendTransaction` can be used to send some ether from one address to another. +This command takes three arguments: `from`, `to` and `value`. These define the sender and +recipient addresses (as strings) and the amount of Wei to transfer. It is far less error prone +to enter the transaction value in units of ether rather than Wei, so the value field can take the +return value from the `toWei` function. The following command, run in the Javascript console, +sends 0.1 ether from one of the accounts in the keystore to the other. Note that the addresses +here are examples - the user must replace the address in the `from` field with the address +currently owning 1 ether, and the address in the `to` field with the address currently holding 0 ether. ```javascript eth.sendTransaction({ @@ -292,82 +303,48 @@ eth.sendTransaction({ }) ``` -Note that submitting this transaction requires approval in Clef. In the Clef terminal, Clef will prompt for approval and request the account password. If the password is correctly entered, Geth proceeds with the transaction. The transaction request summary is presented by Clef in the Clef terminal. This is an opportunity for the sender to review the details and ensure they are correct. +This command will return an error message indicating that `authentication is needed: password or unlock`. +This is a security feature that prevents unauthorized access to sensitive account operations. +There are two ways to unlock the account. The first is to start Geth with the account permanently +unlocked (by passing `--unlock
` at startup). This is not recommended because the account +remains unlocked all the time Geth is running, creating a security weakness. Instead, it is better +to temporarily unlock the account for the specific transaction. This requires using the `sendTransaction` +method from the `personal` namespace instead of the `eth` namespace. The password can be provided as a +string in the method call as follows: -```terminal ---------- Transaction request------------- -to: 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 -from: 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC [chksum ok] -value: 10000000000000000 wei -gas: 0x5208 (21000) -maxFeePerGas: 2425000057 wei -maxPriorityFeePerGas: 2424999967 wei -nonce: 0x3 (3) -chainid: 0x5 -Accesslist - -Request context: - NA -> ipc -> NA - -Additional HTTP header data, provided by the external caller: - User-Agent: "" - Origin: "" -------------------------------------------- -Approve? [y/N]: -> y - - -Please enter the password for account 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC -> +```sh +personal.sendTransaction({ + from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", + to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", + value: web3.toWei(0.1, "ether") +}, "password") ``` -After approving the transaction, the following confirmation screen in displayed in the Clef terminal: +In the Javascript console, the transaction hash is displayed. This will be used in the next section +to retrieve the transaction details. ```terminal ------------------------ -Transaction signed: - { - "type": "0x2", - "nonce": "0x3", - "gasPrice": null, - "maxPriorityFeePerGas": "0x908a901f", - "maxFeePerGas": "0x908a9079", - "gas": "0x5208", - "value": "0x2386f26fc10000", - "input": "0x", - "v": "0x0", - "r": "0x66e5d23ad156e04363e68b986d3a09e879f7fe6c84993cef800bc3b7ba8af072", - "s": "0x647ff82be943ea4738600c831c4a19879f212eb77e32896c05055174045da1bc", - "to": "0xce8dba5e4157c2b284d8853afeeea259344c1653", - "chainId": "0x5", - "accessList": [], - "hash": "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" - } - -``` - -In the Javascript console, the transaction hash is displayed. This will be used in the next section to retrieve the transaction details. - -```terminal - "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" - ``` -It is also advised to check the account balances using Geth by repeating the instructions from earlier. At this point in the tutorial, the two accounts in the Clef keystore should have balances just below 0.9 ether (because 0.1 ether has been transferred out and some small amount paid in transaction gas) and 0.1 ether. - +It is also advised to check the account balances using Geth by repeating the instructions from earlier. +At this point in the tutorial, the two accounts in the keystore should have balances just below 0.9 +ether (because 0.1 ether has been transferred out and some small amount paid in transaction gas) and 0.1 ether. ### Checking the transaction hash -The transaction hash is a unique identifier for this specific transaction that can be used later to retrieve the transaction details. For example, the transaction details can be viewed by pasting this hash into the [Goerli block explorer](https://goerli.etherscan.io/). The same information can also be retrieved directly from the Geth node. The hash returned in the previous step can be provided as an argument to `eth.getTransaction` to return the transaction information: +The transaction hash is a unique identifier for this specific transaction that can be used later to +retrieve the transaction details. For example, the transaction details can be viewed by pasting this +hash into the [Goerli block explorer](https://goerli.etherscan.io/). The same information can also +be retrieved directly from the Geth node. The hash returned in the previous step can be provided as +an argument to `eth.getTransaction` to return the transaction information: ```javascript - eth.getTransaction("0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb") - ``` -This returns the following response (although the actual values for each field will vary because they are specific to each transaction): +This returns the following response (although the actual values for each field will vary because they +are specific to each transaction): ```terminal { @@ -393,21 +370,31 @@ This returns the following response (although the actual values for each field w } ``` - ## Using Curl -Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. This library enables the user to send instructions to Geth using a more user-friendly interface compared to sending raw JSON objects. However, it is also possible for the user to send these JSON objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP requests. This part of the tutorial demonstrates how to check account balances and send a transaction using Curl. +Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. +This library enables the user to send instructions to Geth using a more user-friendly interface +compared to sending raw JSON objects. However, it is also possible for the user to send these JSON +objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP requests. +This part of the tutorial demonstrates how to check account balances and send a transaction using Curl. +This requires Geth to expose an HTTP port to listen for requests. This can be configured at startup +by passing the `--http` flag. If no other commands are passed with it, `--http` will expose the +default `localhost:8545` port. ### Checking account balance -The command below returns the balance of the given account. This is a HTTP POST request to the local port 8545. The `-H` flag is for header information. It is used here to define the format of the incoming payload, which is JSON. The `--data` flag defines the content of the payload, which is a JSON object. That JSON object contains four fields: `jsonrpc` defines the spec version for the JSON-RPC API, `method` is the specific function being invoked, `params` are the function arguments, and `id` is used for ordering transactions. The two arguments passed to `eth_getBalance` are the account address whose balance to check and the block to query (here `latest` is used to check the balance in the most recently mined block). +The command below returns the balance of the given account. This is a HTTP POST request to the local +port 8545. The `-H` flag is for header information. It is used here to define the format of the incoming +payload, which is JSON. The `--data` flag defines the content of the payload, which is a JSON object. +That JSON object contains four fields: `jsonrpc` defines the spec version for the JSON-RPC API, `method` +is the specific function being invoked, `params` are the function arguments, and `id` is used for ordering +transactions. The two arguments passed to `eth_getBalance` are the account address whose balance to check +and the block to query (here `latest` is used to check the balance in the most recently mined block). ```shell - curl -X POST http://127.0.0.1:8545 \ -H "Content-Type: application/json" \ --data '{"jsonrpc":"2.0", "method":"eth_getBalance", "params":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","latest"], "id":1}' - ``` A successful call will return a response like the one below: @@ -416,22 +403,19 @@ A successful call will return a response like the one below: {"jsonrpc":"2.0","id":1,"result":"0xc7d54951f87f7c0"} ``` -The balance is in the `result` field in the returned JSON object. However, it is denominated in Wei and presented as a hexadecimal string. There are many options for converting this value to a decimal in units of ether, for example by opening a Python console and running: +The balance is in the `result` field in the returned JSON object. However, it is denominated in Wei and +presented as a hexadecimal string. There are many options for converting this value to a decimal in units +of ether, for example by opening a Python console and running: ```python - 0xc7d54951f87f7c0 / 1e18 - ``` This returns the balance in ether: ```terminal - 0.8999684999998321 - ``` - ### Checking the account list The curl command below returns the list of all accounts. @@ -442,33 +426,27 @@ curl -X POST http://127.0.0.1:8545 \ --data '{"jsonrpc":"2.0", "method":"eth_accounts","params":[], "id":1}' ``` -This requires approval in Clef. Once approved, the following information is returned to the terminal: +The following information is returned to the terminal: ```terminal - {"jsonrpc":"2.0","id":1,"result":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec"]} - ``` ### Sending Transactions -Sending a transaction between accounts can also be achieved using Curl. Notice that the value of the transaction is a hexadecimal string in units of Wei. To transfer 0.1 ether, it is first necessary to convert this to Wei by multiplying by 1018 then converting to hex. 0.1 ether is `"0x16345785d8a0000"` in hex. As before, update the `to` and `from` fields with the addresses in the Clef keystore. - - -```shell -curl -X POST http://127.0.0.1:8545 \ - -H "Content-Type: application/json" \ - --data '{"jsonrpc":"2.0", "method":"eth_sendTransaction", "params":[{"from": "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","to": "0xce8dba5e4157c2b284d8853afeeea259344c1653","value": "0x16345785d8a0000"}], "id":1}' -``` - -This requires approval in Clef. Once the password for the sender account has been provided, Clef will return a summary of the transaction details and the terminal that made the Curl request will display a response containing the transaction hash. - -```terminal - -{"jsonrpc":"2.0","id":5,"result":"0xac8b347d70a82805edb85fc136fc2c4e77d31677c2f9e4e7950e0342f0dc7e7c"} - -``` +It is possible to send transactions using raw curl requests too, but this requires unlocking the sender +account. It is recommended to do this using Clef to manage access to accounts or to use `ipc` instead. The +combination of HTTP and unlocked accounts pose a security risk. ## Summary -This tutorial has demonstrated how to generate accounts using Clef, fund them with testnet ether and use those accounts to interact with Ethereum (Goerli) through a Geth node. Checking account balances, sending transactions and retrieving transaction details were explained using the web3.js library via the Geth console and using the JSON-RPC directly using Curl. +This tutorial has demonstrated how to generate accounts using Geth's built-in account management tool, +fund them with testnet ether and use those accounts to interact with Ethereum (Goerli) through a Geth +node. Checking account balances, sending transactions and retrieving transaction details were explained using +the web3.js library via the Geth console and using the JSON-RPC directly using Curl. Note that this is an +entry-level tutorial designed to help users get familiar with basic Geth processes, we strongly recommend +following this with the [Geth with Clef](/docs/getting-started/geth_with_clef) tutorial which will help to +adopt more secure account management practices than those outlined here. + + +[cli]: https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line diff --git a/content/docs/tools/Clef/Rules.md b/content/docs/tools/Clef/Rules.md index 9441181716..b7a7416cce 100644 --- a/content/docs/tools/Clef/Rules.md +++ b/content/docs/tools/Clef/Rules.md @@ -1,26 +1,58 @@ --- title: Rules -sort_key: B +sort_key: C --- -The `signer` binary contains a ruleset engine, implemented with [OttoVM](https://github.com/robertkrimen/otto) +This page provides a fairly low-level explanation for how rules are implemented in +Clef. It is a good idea to read the [Introduction to Clef](/docs/clef/introduction) +and the [Clef tutorial](/docs/clef/tutorial) before diving in to this page. -It enables usecases like the following: +{:toc} +- this will be removed by the toc + +## Introduction -* I want to auto-approve transactions with contract `CasinoDapp`, with up to `0.05 ether` in value to maximum `1 ether` per 24h period -* I want to auto-approve transaction to contract `EthAlarmClock` with `data`=`0xdeadbeef`, if `value=0`, `gas < 44k` and `gasPrice < 40Gwei` +Rules in Clef are sets of conditions that determine whether a given action can be +approved automatically without requiring manual intervention from the user. This can be +useful for automatically approving transactions between a user's own accounts, or +approving patterns that are commonly used by applications. Automatic signing also +requires Clef to have access to account passwords which is configured independently +of the ruleset. -The two main features that are required for this to work well are; +Rules can define arbitrary conditions such as: -1. Rule Implementation: how to create, manage and interpret rules in a flexible but secure manner -2. Credential managements and credentials; how to provide auto-unlock without exposing keys unnecessarily. +* Auto-approve 10 transactions with contract `CasinoDapp`, with value between `0.05 ether` and + `1 ether` per 24h period. -The section below deals with both of them +* Auto-approve transactions to contract `Uniswapv2` with `value` up to 1 ether, if + `gas < 44k` and `gasPrice < 40Gwei`. + +* Auto-approve signing if the data to be signed contains the string `"approve_me"`. + +* Auto-approve any requests to list accounts in keystore if the request arrives over IPC + +Because the rules are Javascript files they can be customized to implement any arbitrary logic on +the available request data. + +This page will explain how rules are implemented in Clef and how best to manage credentials +when automatic rulesets are enabled. ## Rule Implementation -A ruleset file is implemented as a `js` file. Under the hood, the ruleset-engine is a `SignerUI`, implementing the same methods as the `json-rpc` methods -defined in the UI protocol. Example: + +The ruleset engine acts as a gatekeeper to the command line interface - it auto-approves +any requests that meet the conditions defined in a set of authenticated rule files. This +prevents the user from having to manually approve or reject every request - instead they +can define common patterns in a rule file and abstract that task away to the ruleset engine. +The general architecture is as follows: + +![Clef ruleset logic](/static/images/clef_ruleset.png) + +When Clef receives a request, the ruleset engine evaluates a Javascript file for +each method defined in the internal [UI API docs](/docs/clef/apis). For example the code +snippet below is an example ruleset that calls the function `ApproveTx`. The call to `ApproveTx` +is invoking the `ui_approveTx` [JSON_RPC API endpoint](/docs/clef/apis/#ui-api). Every time an RPC +method is invoked the Javascript code is executed in a freshly instantiated virtual machine. ```js function asBig(str) { @@ -39,7 +71,8 @@ function ApproveTx(req) { return "Approve" } // If we return "Reject", it will be rejected. - // By not returning anything, it will be passed to the next UI, for manual processing + // By not returning anything, the decision to approve/reject + // will be passed to the next UI, for manual processing } // Approve listings if request made from IPC @@ -48,98 +81,165 @@ function ApproveListing(req){ } ``` -Whenever the external API is called (and the ruleset is enabled), the `signer` calls the UI, which is an instance of a ruleset-engine. The ruleset-engine -invokes the corresponding method. In doing so, there are three possible outcomes: +When a request is made via the external API, the logic flow is as follows: -1. JS returns "Approve" - * Auto-approve request -2. JS returns "Reject" - * Auto-reject request -3. Error occurs, or something else is returned - * Pass on to `next` ui: the regular UI channel. +* Request is made to the `signer` binary using external API + +* `signer` calls the UI - in this case the ruleset engine -A more advanced example can be found below, "Example 1: ruleset for a rate-limited window", using `storage` to `Put` and `Get` `string`s by key. +* UI evaluates whether the call conforms to rules in an attested rulefile -* At the time of writing, storage only exists as an ephemeral unencrypted implementation, to be used during testing. +* Assuming the call returns "Approve", request is signed. -### Things to note -The Otto vm has a few [caveats](https://github.com/robertkrimen/otto): +There are five possible outcomes from the ruleset engine that are +handled in different ways: + +| Return value | Action | +| ------------------| ----------------------------------------- | +| "Approve" | Auto-approve request | +| "Reject" | Auto-reject request | +| Anything else | Pass decision to UI for manual approval | + + +There are some additional noteworthy implementation details that are important +for defining rules correctly in `ruleset.js`: -* "use strict" will parse, but does nothing. -* The regular expression engine (re2/regexp) is not fully compatible with the ECMA5 specification. -* Otto targets ES5. ES6 features (eg: Typed Arrays) are not supported. - -Additionally, a few more have been added - -* The rule execution cannot load external javascript files. -* The only preloaded library is [`bignumber.js`](https://github.com/MikeMcl/bignumber.js) version `2.0.3`. This one is fairly old, and is not aligned with the documentation at the github repository. -* Each invocation is made in a fresh virtual machine. This means that you cannot store data in global variables between invocations. This is a deliberate choice -- if you want to store data, use the disk-backed `storage`, since rules should not rely on ephemeral data. -* Javascript API parameters are _always_ an object. This is also a design choice, to ensure that parameters are accessed by _key_ and not by order. This is to prevent mistakes due to missing parameters or parameter changes. -* The JS engine has access to `storage` and `console`. - -#### Security considerations - -##### Security of ruleset - -Some security precautions can be made, such as: - -* Never load `ruleset.js` unless the file is `readonly` (`r-??-??-?`). If the user wishes to modify the ruleset, he must make it writeable and then set back to readonly. - * This is to prevent attacks where files are dropped on the users disk. -* Since we're going to have to have some form of secure storage (not defined in this section), we could also store the `sha3` of the `ruleset.js` file in there. - * If the user wishes to modify the ruleset, he'd then have to perform e.g. `signer --attest /path/to/ruleset --credential ` - -##### Security of implementation - -The drawbacks of this very flexible solution is that the `signer` needs to contain a javascript engine. This is pretty simple to implement, since it's already -implemented for `geth`. There are no known security vulnerabilities in, nor have we had any security-problems with it so far. - -The javascript engine would be an added attack surface; but if the validation of `rulesets` is made good (with hash-based attestation), the actual javascript cannot be considered -an attack surface -- if an attacker can control the ruleset, a much simpler attack would be to implement an "always-approve" rule instead of exploiting the js vm. The only benefit -to be gained from attacking the actual `signer` process from the `js` side would be if it could somehow extract cryptographic keys from memory. - -##### Security in usability - -Javascript is flexible, but also easy to get wrong, especially when users assume that `js` can handle large integers natively. Typical errors -include trying to multiply `gasCost` with `gas` without using `bigint`:s. - -It's unclear whether any other DSL could be more secure; since there's always the possibility of erroneously implementing a rule. +* The code in `ruleset.js` **cannot** load external Javascript files. + +* The Javascript engine can access `storage` and `console` + +* The only preloaded library in the Javascript environment is + `bignumber.js` version `2.0.3`. + +* Each invocation is made in a fresh virtual machine meaning data cannot be + stored in global variables between invocations. + +* Since no global variable storage is available, disk backed `storage` must be + used - rules should not rely on ephemeral data. + +* Javascript API parameters are always objects. This ensures parameters are + accessed by _key_ to avoid misordering errors. + +* Otto VM uses ES5. ES6-specific features (such as Typed Arrays) are not supported. + +* The regular expression engine (re2/regexp) in Otto VM is not fully compatible + with the [ECMA5 specification](https://tc39.es/ecma262/#sec-intro). + +* [Strict mode](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Strict_mode) + is not supported. "Use strict" will parse but it does nothing. ## Credential management -The ability to auto-approve transaction means that the signer needs to have necessary credentials to decrypt keyfiles. These passwords are hereafter called `ksp` (keystore pass). +The ability to auto-approve transaction requires that the signer has +the necessary credentials, i.e. account passwords, to decrypt keyfiles. +These are stored encrypted as follows: -### Example implementation - -Upon startup of the signer, the signer is given a switch: `--seed ` -The `seed` contains a blob of bytes, which is the master seed for the `signer`. +When the `signer` is started it generates a seed that is locked with a +user specified password. The seed is saved to a location that defaults to +`$HOME/.clef/masterseed.json`. The `seed` itself is a blob of bytes. The `signer` uses the `seed` to: -* Generate the `path` where the settings are stored. - * `./settings/1df094eb-c2b1-4689-90dd-790046d38025/vault.dat` - * `./settings/1df094eb-c2b1-4689-90dd-790046d38025/rules.js` -* Generate the encryption password for `vault.dat`. +* Generate the `path` where the configuration and credentials data are stored. + * `$HOME/.clef/790046d38025/config.json` + * `$HOME/.clef/790046d38025/credentials.json` +* Generate the encryption password for the config and credentials files. -The `vault.dat` would be an encrypted container storing the following information: +`config.json` stores the hashes of any attested rulesets. `credentials.json` +stores encrypted account passwords. The masterseed is required to decrypt +these files. The decrypted account passwords can then be used to decrypt keyfiles. -* `ksp` entries -* `sha256` hash of `rules.js` -* Information about pair:ed callers (not yet specified) +## Security -### Security considerations +### The Javascript VM +The downside of the very flexible rule implementation included in Clef is +that the `signer` binary needs to contain a Javascript engine. This is an +additional attack surface. The only viable attack is for an adversary to +somehow extract cryptographic keys from memory during the Javascript VM execution. +The hash-based rule attestation condition means the actual Javascript code +executed by the Javascript engine is not a viable attack surface -- since if the attacker can control the ruleset, a much simpler +attack would be to surreptitiously insert an attested "always-approve" rule +instead of attempting to exploit the Javascript virtual machine. The Javascript +engine is quite simple to implement and there are currently no known security +vulnerabilities, not have there been any security problems identified for the +similar Javascript VM implemented in Geth. -This would leave it up to the user to ensure that the `path/to/masterseed` is handled in a secure way. It's difficult to get around this, although one could -imagine leveraging OS-level keychains where supported. The setup is however in general similar to how ssh-keys are stored in `.ssh/`. +### Writing rules + +Since the user has complete freedom to write custom rules, it is plausible that those rules +could create unintended security vulnerabilities. This can only really be protected by +coding very carefully and trying to test rulesets (e.g. on a private testnet) before +implementing them on a public network. + +Javascript is very flexible but also easy to write incorrectly. For example, users +might assume that javascript can handle large integers natively rather than explicitly +using `bigInt`. This is an error commonly encountered in the Ethereum context when +users attempt to multiply `gas` by `gasCost`. + +It’s unclear whether any other language would be more secure - there is alwas the possibility +of implementing an insecure rule. + +### File security -# Implementation status +### Credential security -This is now implemented (with ephemeral non-encrypted storage for now, so not yet enabled). +Clef implements a secure, encrypted vault for storing sensitive data. This vault is +encrypted using a `masterseed` which the user is responsible for storing and backing +up safely and securely. Since this `masterseed` is used to decrypt the secure vault, +and its security is not handled by Clef, it could represent a security vulnerability +if the user does not implement best practise in keeping it safe. -## Example 1: ruleset for a rate-limited window +The same is also true for keys. Keys are not stored by Clef, they are only accessed +using account passwords that Clef does store in its vault. The keys themselves are stored +in an external `keystore` whose security is the responsibility of the user. If the +keys are compromised, the account is not safe irrespective of the security benefits +derived from Clef. +## Ruleset examples + +Below are some examples of `ruleset.js` files. + +### Example 1: Allow destination + +```js +function ApproveTx(r) { + if (r.transaction.to.toLowerCase() == "0x0000000000000000000000000000000000001337") { + return "Approve" + } + if (r.transaction.to.toLowerCase() == "0x000000000000000000000000000000000000dead") { + return "Reject" + } + // Otherwise goes to manual processing +} +``` + +### Example 2: Allow listing + +```js +function ApproveListing() { + return "Approve" +} +``` + +### Example 3: Approve signing data + +```js +function ApproveSignData(req) { + if (req.address.toLowerCase() == "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3") { + if (req.messages[0].value.indexOf("bazonk") >= 0) { + return "Approve" + } + return "Reject" + } + // Otherwise goes to manual processing +} +``` + + +### Example 4: Rate-limited window ```js function big(str) { @@ -214,24 +314,11 @@ function OnApprovedTx(resp) { } ``` -## Example 2: allow destination +## Summary -```js -function ApproveTx(r) { - if (r.transaction.from.toLowerCase() == "0x0000000000000000000000000000000000001337") { - return "Approve" - } - if (r.transaction.from.toLowerCase() == "0x000000000000000000000000000000000000dead") { - return "Reject" - } - // Otherwise goes to manual processing -} -``` +Rules are sets of conditions encoded in Javascript files that enable certain actions to +be auto-approved by Clef. This page outlined the implementation details and security +considerations that will help to build suitrable ruleset files. See the +[Clef Github](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef) for further reading. -## Example 3: Allow listing -```js -function ApproveListing() { - return "Approve" -} -``` From ef856f842bf3922297a3d5c58b564a68bc3c701e Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 28 Jul 2022 13:23:54 +0100 Subject: [PATCH 010/432] imgs to assets --- .../docs/monitoring => assets}/grafana1.png | Bin .../docs/monitoring => assets}/grafana2.png | Bin .../docs/monitoring => assets}/grafana3.png | Bin .../docs/monitoring => assets}/grafana4.png | Bin .../docs/monitoring => assets}/grafana5.png | Bin .../docs/monitoring => assets}/grafana6.png | Bin .../docs/monitoring => assets}/grafana7.png | Bin .../docs/monitoring => assets}/grafana8.png | Bin content/docs/monitoring/dashboards.md | 16 ++++++++-------- 9 files changed, 8 insertions(+), 8 deletions(-) rename {content/docs/monitoring => assets}/grafana1.png (100%) rename {content/docs/monitoring => assets}/grafana2.png (100%) rename {content/docs/monitoring => assets}/grafana3.png (100%) rename {content/docs/monitoring => assets}/grafana4.png (100%) rename {content/docs/monitoring => assets}/grafana5.png (100%) rename {content/docs/monitoring => assets}/grafana6.png (100%) rename {content/docs/monitoring => assets}/grafana7.png (100%) rename {content/docs/monitoring => assets}/grafana8.png (100%) diff --git a/content/docs/monitoring/grafana1.png b/assets/grafana1.png similarity index 100% rename from content/docs/monitoring/grafana1.png rename to assets/grafana1.png diff --git a/content/docs/monitoring/grafana2.png b/assets/grafana2.png similarity index 100% rename from content/docs/monitoring/grafana2.png rename to assets/grafana2.png diff --git a/content/docs/monitoring/grafana3.png b/assets/grafana3.png similarity index 100% rename from content/docs/monitoring/grafana3.png rename to assets/grafana3.png diff --git a/content/docs/monitoring/grafana4.png b/assets/grafana4.png similarity index 100% rename from content/docs/monitoring/grafana4.png rename to assets/grafana4.png diff --git a/content/docs/monitoring/grafana5.png b/assets/grafana5.png similarity index 100% rename from content/docs/monitoring/grafana5.png rename to assets/grafana5.png diff --git a/content/docs/monitoring/grafana6.png b/assets/grafana6.png similarity index 100% rename from content/docs/monitoring/grafana6.png rename to assets/grafana6.png diff --git a/content/docs/monitoring/grafana7.png b/assets/grafana7.png similarity index 100% rename from content/docs/monitoring/grafana7.png rename to assets/grafana7.png diff --git a/content/docs/monitoring/grafana8.png b/assets/grafana8.png similarity index 100% rename from content/docs/monitoring/grafana8.png rename to assets/grafana8.png diff --git a/content/docs/monitoring/dashboards.md b/content/docs/monitoring/dashboards.md index cef0a02270..76671417a3 100644 --- a/content/docs/monitoring/dashboards.md +++ b/content/docs/monitoring/dashboards.md @@ -130,40 +130,40 @@ When Grafana is up and running, it should be reachable at `localhost:3000`. A br to access a visualization dashboard. The browser will prompt for login credentials (user: `admin` and password: `admin`). When prompted, the default password should be changed and saved. -![](./grafana1.png) +![](assets/grafana1.png) The browser first redirects to the Grafana home page to set up the source data. Click on the configuration icon in the left bar and select "Data sources". -![](./grafana2.png) +![](assets/grafana2.png) There aren't any data sources yet, click on "Add data source" to define one. -![](./grafana3.png) +![](assets/grafana3.png) Select "InfluxDB" and proceed. -![](./grafana4.png) +![](assets/grafana4.png) Data source configuration is pretty straight forward if you are running tools on the same machine. You need to set the InfluxDB address and details for accessing the database. Refer to the picture below. -![](./grafana5.png) +![](assets/grafana5.png) If everything is complete and InfluxDB is reachable, click on "Save and test" and wait for the confirmation to pop up. -![](./grafana6.png) +![](assets/grafana6.png) Grafana is now set up to read data from InfluxDB. Now you need to create a dashboard which will interpret and display it. Dashboards properties are encoded in JSON files which can be created by anybody and easily imported. On the left bar, click on "Create and Import". -![](./grafana7.png) +![](assets/grafana7.png) For a Geth monitoring dashboard, copy the ID of [this dashboard](https://grafana.com/grafana/dashboards/13877/) and paste it in the "Import page" in Grafana. After saving the dashboard, it should look like this: -![](./grafana8.png) +![](assets/grafana8.png) The dashboards can be customized further. Each panel can be edited, moved, removed or added. To learn more about how dashboards work, refer to [Grafana's documentation](https://grafana.com/docs/grafana/latest/dashboards/). From 7f34978b2bba9ed9c29b0d723044dd58ffb678c9 Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 28 Jul 2022 17:00:12 +0100 Subject: [PATCH 011/432] content updates --- content/docs/fundamentals/Backup--restore.md | 29 +- content/docs/fundamentals/cross-compile.md | 167 ------- .../docs/fundamentals/node-architecture.md | 20 +- content/docs/fundamentals/security.md | 34 ++ .../Backup--restore.md | 0 .../Installing-Geth.md | 0 .../docs/getting_started/consensus-clients.md | 70 +-- .../docs/getting_started/getting_started.md | 452 ++++++++++++++++++ content/docs/install_build/Installing-Geth.md | 356 -------------- content/docs/install_build/cross-compile.md | 167 ------- 10 files changed, 529 insertions(+), 766 deletions(-) delete mode 100644 content/docs/fundamentals/cross-compile.md create mode 100644 content/docs/fundamentals/security.md rename content/docs/{install_build => getting_started}/Backup--restore.md (100%) rename content/docs/{fundamentals => getting_started}/Installing-Geth.md (100%) create mode 100644 content/docs/getting_started/getting_started.md delete mode 100644 content/docs/install_build/Installing-Geth.md delete mode 100644 content/docs/install_build/cross-compile.md diff --git a/content/docs/fundamentals/Backup--restore.md b/content/docs/fundamentals/Backup--restore.md index 6d038572d1..1534d360a4 100644 --- a/content/docs/fundamentals/Backup--restore.md +++ b/content/docs/fundamentals/Backup--restore.md @@ -1,34 +1,36 @@ --- title: Backup & Restore -sort_key: C --- -Most important info first: **REMEMBER YOUR PASSWORD** and **BACKUP YOUR KEYSTORE**. +**Keep secure backups of your keystore and password!** ## Data Directory -Everything `geth` persists gets written inside its data directory. The default data -directory locations are platform specific: +All data relating to a specific Geth instance gets written inside a data directory. +The default data directory locations are platform specific: * Mac: `~/Library/Ethereum` * Linux: `~/.ethereum` * Windows: `%LOCALAPPDATA%\Ethereum` Accounts are stored in the `keystore` subdirectory. The contents of this directories -should be transportable between nodes, platforms, implementations (C++, Go, Python). +should be transportable between nodes, platforms, and client implementations. To configure the location of the data directory, the `--datadir` parameter can be specified. See [CLI Options](../interface/command-line-options) for more details. +There may exist multiple data directories for multiple networks (e.g. a separate directory +for Ethereum Mainnet and the Goerli testnet). Each would have subdirectories for their +blockchain data and keystore. -Note the [ethash dag](../interface/mining) is stored at `~/.ethash` (Mac/Linux) or -`%APPDATA%\Ethash` (Windows) so that it can be reused by all clients. You can store this -in a different location by using a symbolic link. +It is important to backup the files in the keystore securely. These files are encrypted +using an account password. This needs to be securely backed up too. There is no way to +decrypt the keys without the password! ## Cleanup Geth's blockchain and state databases can be removed with: -``` +```sh geth removedb ``` @@ -39,14 +41,14 @@ directories that can be re-created on synchronisation and does not touch the key Export the blockchain in binary format with: -``` +```sh geth export ``` Or if you want to back up portions of the chain over time, a first and last block can be specified. For example, to back up the first epoch: -``` +```sh geth export 0 29999 ``` @@ -55,11 +57,8 @@ truncated. Import binary-format blockchain exports with: -``` +```sh geth import ``` -_See https://eth.wiki/en/howto/blockchain-import-and-export-instructions for more info_ - - And finally: **REMEMBER YOUR PASSWORD** and **BACKUP YOUR KEYSTORE** diff --git a/content/docs/fundamentals/cross-compile.md b/content/docs/fundamentals/cross-compile.md deleted file mode 100644 index 55af4e6652..0000000000 --- a/content/docs/fundamentals/cross-compile.md +++ /dev/null @@ -1,167 +0,0 @@ ---- -title: Cross-Compiling Geth -sort_key: C ---- - -**Note: All of these and much more have been merged into the project Makefile. You can -cross build via `make geth--` without needing to know any of these details -from below.** - -Developers usually have a preferred platform that they feel most comfortable working in, -with all the necessary tools, libraries and environments set up for an optimal workflow. -However, there's often need to build for either a different CPU architecture, or an -entirely different operating system; but maintaining a development environment for each -and switching between the them quickly becomes unwieldy. - -Here we present a very simple way to cross compile Ethereum to various operating systems -and architectures using a minimal set of prerequisites and a completely containerized -approach, guaranteeing that your development environment remains clean even after the -complex requirements and mechanisms of a cross compilation. - -The currently supported target platforms are: - - - ARMv7 Android and iOS - - 32 bit, 64 bit and ARMv5 Linux - - 32 bit and 64 bit Mac OSX - - 32 bit and 64 bit Windows - -Please note, that cross compilation does not replace a release build. Although resulting -binaries can usually run perfectly on the desired platform, compiling on a native system -with the specialized tools provided by the official vendor can often result in more a -finely optimized code. - -## Cross compilation environment - -Although the `go-ethereum` project is written in Go, it does include a bit of C code -shared between all implementations to ensure that all perform equally well, including a -dependency to the GNU Multiple Precision Arithmetic Library. Because of these, Go cannot -by itself compile to a different platform than the host. To overcome this limitation, we -will use [`xgo`](https://github.com/karalabe/xgo), a Go cross compiler package based on -Docker containers that has been architected specifically to allow both embedded C snippets -as well as simpler external C dependencies during compilation. - -The `xgo` project has two simple dependencies: Docker (to ensure that the build -environment is completely contained) and Go. On most platforms these should be available -from the official package repositories. For manually installing them, please consult their -install guides at [Docker](https://docs.docker.com/installation/) and -[Go](https://golang.org/doc/install) respectively. This guide assumes that these two -dependencies are met. - -To install and/or update xgo, simply type: - - $ go get -u github.com/karalabe/xgo - -You can test whether `xgo` is functioning correctly by requesting it to cross -compile itself and verifying that all cross compilations succeeded or not. - - $ xgo github.com/karalabe/xgo - ... - - $ ls -al - -rwxr-xr-x 1 root root 2792436 Sep 14 16:45 xgo-android-21-arm - -rwxr-xr-x 1 root root 2353212 Sep 14 16:45 xgo-darwin-386 - -rwxr-xr-x 1 root root 2906128 Sep 14 16:45 xgo-darwin-amd64 - -rwxr-xr-x 1 root root 2388288 Sep 14 16:45 xgo-linux-386 - -rwxr-xr-x 1 root root 2960560 Sep 14 16:45 xgo-linux-amd64 - -rwxr-xr-x 1 root root 2437864 Sep 14 16:45 xgo-linux-arm - -rwxr-xr-x 1 root root 2551808 Sep 14 16:45 xgo-windows-386.exe - -rwxr-xr-x 1 root root 3130368 Sep 14 16:45 xgo-windows-amd64.exe - - -## Building Ethereum - -Cross compiling Ethereum is analogous to the above example, but an additional flags is -required to satisfy the dependencies: - - - `--deps` is used to inject arbitrary C dependency packages and pre-build them - -Injecting the GNU Arithmetic Library dependency and selecting `geth` would be: - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - github.com/ethereum/go-ethereum/cmd/geth - ... - - $ ls -al - -rwxr-xr-x 1 root root 23213372 Sep 14 17:59 geth-android-21-arm - -rwxr-xr-x 1 root root 14373980 Sep 14 17:59 geth-darwin-386 - -rwxr-xr-x 1 root root 17373676 Sep 14 17:59 geth-darwin-amd64 - -rwxr-xr-x 1 root root 21098910 Sep 14 17:59 geth-linux-386 - -rwxr-xr-x 1 root root 25049693 Sep 14 17:59 geth-linux-amd64 - -rwxr-xr-x 1 root root 20578535 Sep 14 17:59 geth-linux-arm - -rwxr-xr-x 1 root root 16351260 Sep 14 17:59 geth-windows-386.exe - -rwxr-xr-x 1 root root 19418071 Sep 14 17:59 geth-windows-amd64.exe - - -As the cross compiler needs to build all the dependencies as well as the main project -itself for each platform, it may take a while for the build to complete (approximately 3-4 -minutes on a Core i7 3770K machine). - -### Fine tuning the build - -By default Go, and inherently `xgo`, checks out and tries to build the master branch of a -source repository. However, more often than not, you'll probably want to build a different -branch from possibly an entirely different remote repository. These can be controlled via -the `--remote` and `--branch` flags. - -To build the `develop` branch of the official `go-ethereum` repository instead of the -default `master` branch, you just need to specify it as an additional command line flag -(`--branch`): - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - --branch=develop \ - github.com/ethereum/go-ethereum/cmd/geth - -Additionally, during development you will most probably want to not only build a custom -branch, but also one originating from your own fork of the repository instead of the -upstream one. This can be done via the `--remote` flag: - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - --remote=https://github.com/karalabe/go-ethereum \ - --branch=rpi-staging \ - github.com/ethereum/go-ethereum/cmd/geth - -By default `xgo` builds binaries for all supported platforms and architectures, with -Android binaries defaulting to the highest released Android NDK platform. To limit the -build targets or compile to a different Android platform, use the `--targets` CLI -parameter. - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - --targets=android-16/arm,windows/* \ - github.com/ethereum/go-ethereum/cmd/geth - -### Building locally - -If you would like to cross compile your local development version, simply specify a local -path (starting with `.` or `/`), and `xgo` will use all local code from `GOPATH`, only -downloading missing dependencies. In such a case of course, the `--branch`, `--remote` and -`--pkg` arguments are no-op: - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - ./cmd/geth - -## Using the Makefile - -Having understood the gist of `xgo` based cross compilation, you do not need to actually -memorize and maintain these commands, as they have been incorporated into the official -[Makefile](https://github.com/ethereum/go-ethereum/blob/master/Makefile) and can be -invoked with a trivial `make` request: - - * `make geth-cross`: Cross compiles to every supported OS and architecture - * `make geth-`: Cross compiles supported architectures of a particular OS (e.g. `linux`) - * `make geth--`: Cross compiles to a specific OS/architecture (e.g. `linux`, `arm`) - -We advise using the `make` based commands opposed to manually invoking `xgo` as we do -maintain the Makefile actively whereas we cannot guarantee that this document will be -always readily updated to latest advancements. - -### Tuning the cross builds - -A few of the `xgo` build options have also been surfaced directly into the Makefile to -allow fine tuning builds to work around either upstream Go issues, or to enable some -fancier mechanics. - - - `make ... GO=`: Use a specific Go runtime (e.g. `1.5.1`, `1.5-develop`, `develop`) - - `make ... MODE=`: Build a specific target type (e.g. `exe`, `c-archive`). - -Please note that these are not yet fully finalized, so they may or may not change in the -future as our code and the Go runtime features change. diff --git a/content/docs/fundamentals/node-architecture.md b/content/docs/fundamentals/node-architecture.md index 9ad8662e1e..4dcf68b005 100644 --- a/content/docs/fundamentals/node-architecture.md +++ b/content/docs/fundamentals/node-architecture.md @@ -3,13 +3,15 @@ Geth is an [execution client](https://ethereum.org/en/developers/docs/nodes-and-clients/#execution-clients). Originally, an execution client alone was enough to run a full Ethereum node. -However, ever since Ethereum turned off proof-of-work and implemented proof-of-stake, -Geth must to be coupled to another piece of software called a -[“consensus client”](https://ethereum.org/en/developers/docs/nodes-and-clients/#consensus-clients). +However, ever since Ethereum turned off [proof-of-work](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/) and implemented [proof-of-stake](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/), +Geth has needed to be coupled to another piece of software called a +[“consensus client”](https://ethereum.org/en/developers/docs/nodes-and-clients/#consensus-clients) in order to +keep track of the Ethereum blockchain. -The execution client is responsible for transaction handling, transaction gossip, state management and -the Ethereum Virtual Machine (EVM). However, Geth is **not** responsible for block building, block gossiping -or handling consensus logic. These are in the remit of the consensus client. +The execution client is responsible for transaction handling, transaction gossip, state management and supporting +the Ethereum Virtual Machine ([EVM])(https://ethereum.org/en/developers/docs/evm/). However, Geth is **not** +responsible for block building, block gossiping or handling consensus logic. These are in the remit of the +consensus client. The relationship between the two Ethereum clients is shown in the schematic below. The two clients each connect to their own respective peer-to-peer (P2P) networks. This is because the execution clients gossip @@ -23,8 +25,8 @@ Geth to be executed. Executing the transactions locally is how the client valida do not violate any Ethereum rules and that the proposed update to Ethereum’s state is correct. Likewise, when the node is selected to be a block producer the consensus client must be able to request bundles of transactions from Geth to include in the new block. This inter-client communication is handled by a local -RPC connection using the engine API which is part of the JSON-RPC API exposed by Geth. - +RPC connection using the [engine API](https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md) +which is exposed internally over port 8551 by default. ## What does Geth do? @@ -43,4 +45,4 @@ In summary, Geth is: - home to the Ethereum Virtual Machine, Ethereum's state and transaction pool. - +Read more about [proof-of-stake](https://ethereum.org/en/developers/docs/consensus-mechanisms/pos/). diff --git a/content/docs/fundamentals/security.md b/content/docs/fundamentals/security.md new file mode 100644 index 0000000000..698d0523e1 --- /dev/null +++ b/content/docs/fundamentals/security.md @@ -0,0 +1,34 @@ +--- +title: Security +root: .. +--- + +## Downloading Geth + +Download Geth using the links on our [Downloads](/downloads) page. The SHA256 hashes of the downloaded files +can be compared to ours to ensure precise consistency with our releases. This protects against malicious code being +inadvertently downloaded from an adversarial source. The same measures should also be taken to download trusted +consensus client software. + +## Networking security + +The local machine's firewall settings should: + +* Block all traffic to `8545`, or whatever custom port has been defined for JSON-RPC requests to the node, except for traffic from explicitly defined trusted machines. +* Allow traffic on `TCP 30303` or whichever custom port has been defined for peer-to-peer communications. This allows the node to connect to peers. +* Allow traffic on `UDP 30303` or whichever custom port has been defined for peer-to-peer communications. This allows node discovery. + +## Account security + +Account security comes down to keeping private keys and account passwords backed up and inaccessible to adversaries. This is something that users take responsibility for. Geth provides an encrypted store for keys that are unlocked using an account password. If the key files or the passwors are lost, the account is impossible to access and the funds are effectively lost forever. If access to the unencrypted keys is obtained by an adversary they gain control of any funds associated with the account. + +Geth has built-in account management tools that are sufficiently secure for most purposes. However, Clef is recommended as an external account management and signing tool. It can be run decoupled from Geth and can even be run on dedicated secure external hardware such as a VM or a secure USB drive. This is considered best practise because the user is required to manually review all actions that touch sensitive data, except where specific predefined rules are implemented. Signing is done locally to Clef rather than giving key access to a node. + +Geth allows account unlocking by passing account passwords at startup. This unlocks the account all the while that Geth is running. This is not allowed when `http` traffic is enabled, even with appropriate firewall setings. The combination of `http` and `-unlock` poses too much of a security risk because an attacker able to access the node over the exposed HTTP port would be able to make JSON-RPC requests to the node from the unlocked account, including sending funds to other addresses. + +**back up your keystore and passwords safely and securely!** + + +## Other security considerations + +Even with a perfectly secure node, users can still be manipulated by attackers into exposing security weaknesses or inadvertently interact with insecure smart contracts. For an overview, please see the Ethereum [security best practise webpage](https://ethereum.org/en/security) and this introduction to [smart contract security](https://ethereum.org/en/developers/docs/smart-contracts/security). \ No newline at end of file diff --git a/content/docs/install_build/Backup--restore.md b/content/docs/getting_started/Backup--restore.md similarity index 100% rename from content/docs/install_build/Backup--restore.md rename to content/docs/getting_started/Backup--restore.md diff --git a/content/docs/fundamentals/Installing-Geth.md b/content/docs/getting_started/Installing-Geth.md similarity index 100% rename from content/docs/fundamentals/Installing-Geth.md rename to content/docs/getting_started/Installing-Geth.md diff --git a/content/docs/getting_started/consensus-clients.md b/content/docs/getting_started/consensus-clients.md index 363997036e..17cb109d0f 100644 --- a/content/docs/getting_started/consensus-clients.md +++ b/content/docs/getting_started/consensus-clients.md @@ -3,19 +3,13 @@ title: Connecting to Consensus Clients sort_key: A3 --- -Geth is an [execution client][ex-client-link]. Historically, an execution client alone has been enough to run a full Ethereum node. -However, Ethereum will soon swap its consensus mechanism from [proof-of-work][pow-link] (PoW) to -[proof-of-stake][pos-link] (PoS) in a transition known as [The Merge](/docs/interface/merge). +Geth is an [execution client][ex-client-link]. Historically, an execution client alone was enough to +run a full Ethereum node. However, ever since Ethereum swapped from [proof-of-work][pow-link] (PoW) to +[proof-of-stake][pos-link] (PoS) based consensus, Geth has needed to be coupled to another piece of +software called a ["consensus client"][con-client-link]. -When that happens, Geth will not be able to track the Ethereum chain on its own. Instead, it will need to -be coupled to another piece of software called a ["consensus client"][con-client-link]. For Geth users that -intend to continue to run full nodes after The Merge, it is sensible to start running a consensus client now, -so that The Merge can happen smoothly. There are five consensus clients available, all of which connect to Geth in the same way. - -This page will outline how Geth can be set up with a consensus client in advance of The Merge (or to interact with an alread-merged testnet). - -{% include note.html content=" It is recommended to practise connecting a consensus client to Geth on a testnet such as Sepolia or Goerli but to -wait until merge-ready releases are available before doing it on Ethereum Mainnet." %} +There are four consensus clients available, all of which connect to Geth in the same way. This page will +outline how Geth can be set up with a consensus client. ## Configuring Geth @@ -33,10 +27,6 @@ The authorization must then be applied to a specific address/port. This is achie `*` to `--authrpc.vhosts` so that incoming requests from virtual hosts are accepted by Geth because it only applies to the port authenticated using `jwtsecret`. -The Merge itself will be triggered using a terminal total difficulty (TTD). The specific value for the TTD has not yet -been decided. When it is decided, Geth needs to know what it is in order to merge successfully. This will most likely be -included in a new release, so Geth will have to be stopped, updated and restarted in advance of The Merge. - A complete command to start Geth so that it can connect to a consensus client looks as follows: ```shell @@ -56,7 +46,8 @@ There are currently four consensus clients that can be run alongside Geth. These [Teku](https://pegasys.tech/teku): written in Java -It is recommended to consider [client diversity][client-div-link] when choosing a consensus client. Instructions for installing each client are provided in the documentation linked in the list above. +It is recommended to consider [client diversity][client-div-link] when choosing a consensus client. +Instructions for installing each client are provided in the documentation linked in the list above. The consensus client must be started with the right port configuration to establish an RPC connection to the local Geth instance. In the example above, `localhost:8551` was authorized @@ -73,49 +64,24 @@ More information on this can be found in the documentation for each consensus cl ## Validators -After The Merge, miners are no longer responsible for securing the Ethereum blockchain. Instead, this becomes the responsibility -of validators that have staked at least 32 ETH into a deposit contract and run validator software. Each of the consensus clients -have their own validator software that is described in detail in their respective documentation. The easiest way to handle -staking and validator key generation is to use the Ethereum Foundation [Staking Launchpad][launchpad-link]. The launchpad is also -available for [Prater][prater-launchpad-link], [Ropsten][ropsten-launchpad-link] and [Kiln][kiln-launchpad-link] testnets. It is -also highly recommended to review the [Merge readiness checklist][checklist-link]. +Validators are responsible for securing the Ethereum blockchain. Validators have staked at least 32 ETH into a +deposit contract and run validator software. Each of the consensus clients have their own validator software that +is described in detail in their respective documentation. The easiest way to handle staking and validator +key generation is to use the Ethereum Foundation [Staking Launchpad][launchpad-link]. The Launchpad guides users +through the process of generating validator keys and connecting the validator to the consensus client. ## Using Geth -After the merge, Geth will follow the head of the chain via its connection to the consensus client. However, Geth is still -the portal for users to send transactions to Ethereum. Overall, Geth will not change very much from a user-perspective. -The Geth Javascript console is still available for this purpose, and the majority of the [JSON-RPC API](/docs/rpc/server) will -remain available via web3js or HTTP requests with commands as json payloads. These options are explained in more detail on the -[Javascript Console page](/docs/interface/javascript-console). The Javascript console can be started using the following command -in a separate terminal (assuming Geth's IPC file is saved in `datadir`): +Geth is the portal for users to send transactions to Ethereum. The Geth Javascript console is available +for this purpose, and the majority of the [JSON-RPC API](/docs/rpc/server) will remain available via web3js +or HTTP requests with commands as json payloads. These options are explained in more detail on the +[Javascript Console page](/docs/interface/javascript-console). The Javascript console can be started +using the following command in a separate terminal (assuming Geth's IPC file is saved in `datadir`): ```shell geth attach datadir/geth.ipc ``` - -## Testnets - -Ethereum Mainnet has not yet undergone The Merge, but some public testnets have. This means that running Geth alone is no longer -enough to interact with merged testnets. This includes two testnets that were purpose built to test The Merge (Kiln, Kintsugi) and -the long-standing public PoW chain, Ropsten, as well as the relatively new testnet Sepolia. If Geth is connected to these merged networks alone it will simply stall when it syncs as far -as the merge block, awaiting information from a consensus client. Therefore, any activity on these testnets requires Geth to be -connected to a consensus client. There are many instructional articles that exlain how to connect to these testnets using Geth in -combination with various consensus clients, for example: - -[Connecting to Kiln using Teku](https://github.com/chrishobcroft/TestingTheMerge/blob/main/geku.md) - -[Connecting to Kiln using Lighthouse](https://github.com/remyroy/ethstaker/blob/main/merge-devnet.md) - -[Connecting to Kiln using Prysm](https://hackmd.io/@prysmaticlabs/B1Q2SluWq) - -[Connecting to Ropsten using Lighthouse](https://github.com/remyroy/ethstaker/blob/main/merge-ropsten.md) - - -The Merge testing will soon progress to merging the Goerli testnet. Once this has happened Geth will require a connection -to a consensus client to work on those networks too. - - ## Summary As The Merge approaches it is important for Geth users to prepare by installing and running a consensus client. Otherwise, Geth will stop diff --git a/content/docs/getting_started/getting_started.md b/content/docs/getting_started/getting_started.md new file mode 100644 index 0000000000..448e8eb5aa --- /dev/null +++ b/content/docs/getting_started/getting_started.md @@ -0,0 +1,452 @@ +--- +title: Getting Started with Geth +permalink: docs/getting-started +sort_key: A +--- + +This page explains how to set up Geth and execute some basic tasks using the command line tools. +In order to use Geth, the software must first be installed. There are several ways Geth can be +installed depending on the operating system and the user's choice of installation method, for +example using a package manager, container or building from source. Instructions for installing +Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. +The tutorial on this page assumes Geth and the associated developer tools have been installed successfully. + +This page provides step-by-step instructions covering the fundamentals of using Geth. This includes +generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. +It is considered best-practice to use [Clef](/docs/clef/Introduction) for account management - this +is explained in the [Geth with Clef](/docs/getting-started/geth_with_clef) tutorial. In this +introductory tutorial, Geth's built-in account management tools are used instead. + +{:toc} +- this will be removed by the toc + +## Prerequisites + +In order to get the most value from the tutorials on this page, the following skills are +necessary: + +- Experience using the command line +- Basic knowledge about Ethereum and testnets +- Basic knowledge about HTTP and JavaScript + +Users that need to revisit these fundamentals can find helpful resources relating to the command +line [here][cli], Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), +http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and +Javascript [here](https://www.javascript.com/learn). + +{% include note.html content="If Geth was installed from source on Linux, `make` saves the +binaries for Geth and the associated tools in `/build/bin`. To run these programs it is +convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) +from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to +execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not +moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) +or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} + +## Background + +Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. +Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being +managed by a central server. Nodes compete to generate new blocks of transactions to send to its peers +because they are rewarded for doing so in Ethereum's native token, ether (ETH). On receiving a new block, +each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called +a "blockchain". The information provided in each block is used by Geth to update its "state" - the ether +balance of each account on Ethereum. There are two types of account: externally-owned accounts (EOAs) and +contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts +that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, +where the public key is used to derive a unique address for the user and the private key is used to protect +the account and securely sign messages. Therefore, in order to use Ethereum, it is first necessary to generate +an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it +with ether and sending some to another address. + +Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). + + +## Step 1: Generating accounts + +To generate a new account in Geth: + +```sh +geth account new +``` + +This returns a prompt for a password. Once provided, a new account will be created and added to the +default keystore (`/datadir/keystore`). A custom keystore can also be provided by passing `--keystore `. +In this tutorial the keys will be stored in a new data directory `geth-tutorial`. Create that diredctory, then run: + +```sh +geth account new --keystore geth-tutorial/keystore +``` +The following will be returned to the console, confirming the new account has been created and +added to the keystore. + +```terminal +Your new account is locked with a password. Please give a password. Do not forget this password. +Password: +Repeat password: + +Your new key was generated + +Public address of the key: 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC +Path of the secret key file: /home/go-ethereum/geth-tutorial/keystore/UTC--2022-07-25T08-27-59.433905560Z--ca57F3b40B42FCce3c37B8D18aDBca5260ca72EC + +- You can share your public address with anyone. Others need it to interact with you. +- You must NEVER share the secret key with anyone! The key controls access to your funds! +- You must BACKUP your key file! Without the key, it's impossible to access account funds! +- You must REMEMBER your password! Without the password, it's impossible to decrypt the key! +``` + +It is important to save the account address and the password somewhere secure. They will be used +again later in this tutorial. Please note that the account address shown in the code snippets +above and later in this tutorials are examples - those generated by followers of this tutorial +will be different. The account generated above can be used as the main account throughout the +remainder of this tutorial. However in order to demonstrate transactions between accounts it is +also necessary to have a second account. A second account can be added to the same keystore by +precisely repeating the previous steps, providing the same password. + +Notice that the path to the secret key includes a long filename that starts `UTC--`. This is the +name of the file that contains the keys for the new account. It is **extremely important** that +this file stays secure because it contains the secret key used to control access to any funds +associated with the account. The file should be backed up securely along with the password +used to encrypt it. If the file or the password is lost, then so is access to the funds in +the account. If someone else gains access to the keyfile and password, they have access to any +assets in the account. + +## Step 2: Start Geth + +Geth is the Ethereum client that will connect the computer to the Ethereum network. +In this tutorial the network is Goerli, an Ethereum testnet. Testnets are used to test +Ethereum client software and smart contracts in an environment where no real-world value +is at risk. To start Geth, run the Geth executable file passing argument that define the +data directory (where Geth should save blockchain data), the network ID and the sync mode. +For this tutorial, snap sync is recommended +(see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). + +The following command should be run in the terminal: + +```shell +geth --datadir geth-tutorial --goerli --syncmode snap +``` +Running the above command starts Geth. The terminal should rapidly fill with status updates that look like the following: + +```terminal +INFO [02-10|13:59:06.649] Starting Geth on goerli testnet... +INFO [02-10|13:59:06.649] Dropping default light client cache provided=1024 updated=128 +INFO [02-10|13:59:06.652] Maximum peer count ETH=50 LES=0 total=50 +INFO [02-10|13:59:06.660] Set global gas cap cap=50,000,000 +INFO [02-10|13:59:06.661] Allocated cache and file handles database=/.../geth-tutorial/geth/chaindata cache=64.00MiB handles=5120 +INFO [02-10|13:59:06.855] Persisted trie from memory database nodes=361 size=51.17KiB time="643.54µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B +INFO [02-10|13:59:06.855] Initialised chain configuration config="{ChainID: 5 Homestead: 0 DAO: nil DAOSupport: true EIP150: 0 EIP155: 0 EIP158: 0 Byzantium: 0 Constantinople: 0 Petersburg: 0 Istanbul: 1561651, Muir Glacier: nil, Berlin: 4460644, London: 5062605, Arrow Glacier: nil, MergeFork: nil, Engine: clique}" +INFO [02-10|13:59:06.862] Added trusted checkpoint block=5,799,935 hash=2de018..c32427 +INFO [02-10|13:59:06.863] Loaded most recent local header number=6,340,934 hash=483cf5..858315 td=9,321,576 age=2d9h29m +INFO [02-10|13:59:06.867] Configured checkpoint oracle address=0x18CA0E045F0D772a851BC7e48357Bcaab0a0795D signers=5 threshold=2 +INFO [02-10|13:59:06.867] Gasprice oracle is ignoring threshold set threshold=2 +WARN [02-10|13:59:06.869] Unclean shutdown detected booted=2022-02-08T04:25:08+0100 age=2d9h33m +INFO [02-10|13:59:06.870] Starting peer-to-peer node instance=Geth/v1.10.15-stable/darwin-amd64/go1.17.5 +INFO [02-10|13:59:06.995] New local node record seq=1,644,272,735,880 id=d4ffcd252d322a89 ip=127.0.0.1 udp=30303 tcp=30303 +INFO [02-10|13:59:06.996] Started P2P networking self=enode://4b80ebd341b5308f7a6b61d91aa0ea31bd5fc9e0a6a5483e59fd4ea84e0646b13ecd289e31e00821ccedece0bf4b9189c474371af7393093138f546ac23ef93e@127.0.0.1:30303 +INFO [02-10|13:59:06.997] IPC endpoint opened url=/.../geth-tutorial/geth.ipc +WARN [02-10|13:59:06.998] Light client mode is an experimental feature +INFO [02-10|13:59:08.793] Block synchronisation started +``` + +This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers +it can request block headers from them, starting at the genesis block for the Goerli blockchain. +Geth continues to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. +This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in the +terminal with the following syntax: + +```terminal + +INFO [04-29][15:54:09.238] Looking for peers peercount=2 tried=0 static=0 +INFO [04-29][15:54:19.393] Imported new block headers count=2 elapsed=1.127ms number=996288 hash=09f1e3..718c47 age=13h9m5s +INFO [04-29][15:54:19:656] Imported new block receipts count=698 elapsed=4.464ms number=994566 hash=56dc44..007c93 age=13h9m9s + +``` + +These logs indicate that Geth is running as expected. + +If there is no error message reported to the terminal, everything is OK. Geth must be running in +order for a user to interact with the Ethereum network. If this terminal is closed down then Geth +must be restarted again. Geth can be started and stopped easily, but it must be running for any +interaction with Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. +To start it again, run the previous command `geth --datadir ... ..`. + +{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished +you can't use the node to transfer funds. You can also try doing a [light sync](interface/les) +which will be much quicker but depends on light servers being available to serve your node the data it needs." %} + +## Step 3: Get Testnet Ether + +In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, +ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; 2) +receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, +having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it +can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether +to their account. + +The address generated by `geth account new` can be pasted into the Paradigm Multifaucet faucet +[here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of +personhood. The faucets adds ether to the given address on multiple testnets simultaneously, +including Goerli. In the next steps Geth will be used to check that the ether has been sent to +the given address and send some of it to the second address created earlier. + + +## Step 4: Interact with Geth + +For interacting with the blockchain, Geth provides JSON-RPC APIs. +[JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific tasks +by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. +RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded +instructions from locations outside of those managed by Geth. It is possible to interact with Geth +by sending these JSON encoded instructions directly to Geth using tools such as Curl. However, +this is somewhat user-unfriendly and error-prone, especially for more complex instructions. For this +reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly +interface for interacting with Geth. One of the most widely used is Web3.js. + +Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in +one terminal, a Javascript environment can be opened in another allowing the user to interact with +Geth using Web3.js. There are three transport protocols that can be used to connect the Javascript +environment to Geth: + +- IPC (Inter-Process Communication): Provides unrestricted access to all APIs, but only works when the +- console is run on the same host as the Geth node. + +- HTTP: By default provides access to the `eth`, `web3` and `net` method namespaces. + +- Websocket: By default provides access to the `eth`, `web3` and `net` method namespaces. + +This tutorial will use the IPC option. To do this, the path to Geth's `ipc` file must be known. +By default, this is the `datadir`, in this case `geth-tutorial`. In a new terminal, the following +command can be run to start the Javascript console and connect it to Geth using the `geth.ipc` +file from the datadir: + +```shell +geth attach geth-tutorial/geth.ipc +``` + +The following welcome message will be displayed in the Javascript console: + +```terminal +Welcome to the Geth JavaScript console! + +instance: Geth/v1.10.15-stable/darwin-amd64/go1.17.5 +at block: 6354736 (Thu Feb 10 2022 14:01:46 GMT+0100 (WAT)) + datadir: /home/go-ethereum/geth-tutorial + modules: admin:1.0 clique:1.0 debug:1.0 eth:1.0 miner:1.0 net:1.0 personal:1.0 rpc:1.0 txpool:1.0 web3:1.0 + +To exit, press ctrl-d or type exit +``` + +The console is now active and connected to Geth. It can now be used to interact with the Ethereum (Goerli) network. + + +### List of accounts + +Earlier in this tutorial, at least one account was created using `geth account new`. The following +command will display the addresses of those two accounts and any others that might have been added +to the keystore before or since. + +```javascript +eth.accounts +``` + +```terminal +["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", "0xce8dba5e4157c2b284d8853afeeea259344c1653"] +``` + + +### Checking account balance. + +Having confirmed that the two addresses created earlier are indeed in the keystore and accessible +through the Javascript console, it is possible to retrieve information about how much ether they +own. The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance +of one of the accounts should be 1 ether and the other should be 0. The following command displays +the account balance in the console: + +```javascript +web3.fromWei(eth.getBalance("0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC"), "ether") +``` + +There are actually two instructions sent in the above command. The inner one is the `getBalance` +function from the `eth` namespace. This takes the account address as its only argument. By default, +this returns the account balance in units of Wei. There are 1018 Wei to one ether. To +present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from the +`web3` namespace. Running this command should provide the following result (for the account that +received faucet funds): + +```terminal +1 +``` + +Repeating the command for the other new account that was not funded from the faucet should yield: + +```terminal +0 +``` + +### Send ether to another account + +The command `eth.sendTransaction` can be used to send some ether from one address to another. +This command takes three arguments: `from`, `to` and `value`. These define the sender and +recipient addresses (as strings) and the amount of Wei to transfer. It is far less error prone +to enter the transaction value in units of ether rather than Wei, so the value field can take the +return value from the `toWei` function. The following command, run in the Javascript console, +sends 0.1 ether from one of the accounts in the keystore to the other. Note that the addresses +here are examples - the user must replace the address in the `from` field with the address +currently owning 1 ether, and the address in the `to` field with the address currently holding 0 ether. + +```javascript +eth.sendTransaction({ + from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", + to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", + value: web3.toWei(0.1, "ether") +}) +``` + +This command will return an error message indicating that `authentication is needed: password or unlock`. +This is a security feature that prevents unauthorized access to sensitive account operations. +There are two ways to unlock the account. The first is to start Geth with the account permanently +unlocked (by passing `--unlock
` at startup). This is not recommended because the account +remains unlocked all the time Geth is running, creating a security weakness. Instead, it is better +to temporarily unlock the account for the specific transaction. This requires using the `sendTransaction` +method from the `personal` namespace instead of the `eth` namespace. The password can be provided as a +string in the method call as follows: + +```sh +personal.sendTransaction({ + from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", + to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", + value: web3.toWei(0.1, "ether") +}, "password") +``` + +In the Javascript console, the transaction hash is displayed. This will be used in the next section +to retrieve the transaction details. + +```terminal +"0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" +``` + +It is also advised to check the account balances using Geth by repeating the instructions from earlier. +At this point in the tutorial, the two accounts in the keystore should have balances just below 0.9 +ether (because 0.1 ether has been transferred out and some small amount paid in transaction gas) and 0.1 ether. + +### Checking the transaction hash + +The transaction hash is a unique identifier for this specific transaction that can be used later to +retrieve the transaction details. For example, the transaction details can be viewed by pasting this +hash into the [Goerli block explorer](https://goerli.etherscan.io/). The same information can also +be retrieved directly from the Geth node. The hash returned in the previous step can be provided as +an argument to `eth.getTransaction` to return the transaction information: + +```javascript +eth.getTransaction("0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb") +``` + +This returns the following response (although the actual values for each field will vary because they +are specific to each transaction): + +```terminal +{ + accessList: [], + blockHash: "0x1c5d3f8dd997b302935391b57dc3e4fffd1fa2088ef2836d51f844f993eb39c4", + blockNumber: 6355150, + chainId: "0x5", + from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", + gas: 21000, + gasPrice: 2425000023, + hash: "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb", + input: "0x", + maxFeePerGas: 2425000057, + maxPriorityFeePerGas: 2424999967, + nonce: 3, + r: "0x66e5d23ad156e04363e68b986d3a09e879f7fe6c84993cef800bc3b7ba8af072", + s: "0x647ff82be943ea4738600c831c4a19879f212eb77e32896c05055174045da1bc", + to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", + transactionIndex: 630, + type: "0x2", + v: "0x0", + value: 10000000000000000 +} +``` + +## Using Curl + +Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. +This library enables the user to send instructions to Geth using a more user-friendly interface +compared to sending raw JSON objects. However, it is also possible for the user to send these JSON +objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP requests. +This part of the tutorial demonstrates how to check account balances and send a transaction using Curl. +This requires Geth to expose an HTTP port to listen for requests. This can be configured at startup +by passing the `--http` flag. If no other commands are passed with it, `--http` will expose the +default `localhost:8545` port. + +### Checking account balance + +The command below returns the balance of the given account. This is a HTTP POST request to the local +port 8545. The `-H` flag is for header information. It is used here to define the format of the incoming +payload, which is JSON. The `--data` flag defines the content of the payload, which is a JSON object. +That JSON object contains four fields: `jsonrpc` defines the spec version for the JSON-RPC API, `method` +is the specific function being invoked, `params` are the function arguments, and `id` is used for ordering +transactions. The two arguments passed to `eth_getBalance` are the account address whose balance to check +and the block to query (here `latest` is used to check the balance in the most recently mined block). + +```shell +curl -X POST http://127.0.0.1:8545 \ + -H "Content-Type: application/json" \ + --data '{"jsonrpc":"2.0", "method":"eth_getBalance", "params":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","latest"], "id":1}' +``` + +A successful call will return a response like the one below: + +```terminal +{"jsonrpc":"2.0","id":1,"result":"0xc7d54951f87f7c0"} +``` + +The balance is in the `result` field in the returned JSON object. However, it is denominated in Wei and +presented as a hexadecimal string. There are many options for converting this value to a decimal in units +of ether, for example by opening a Python console and running: + +```python +0xc7d54951f87f7c0 / 1e18 +``` +This returns the balance in ether: + +```terminal +0.8999684999998321 +``` + +### Checking the account list + +The curl command below returns the list of all accounts. + +```shell +curl -X POST http://127.0.0.1:8545 \ + -H "Content-Type: application/json" \ + --data '{"jsonrpc":"2.0", "method":"eth_accounts","params":[], "id":1}' +``` + +The following information is returned to the terminal: + +```terminal +{"jsonrpc":"2.0","id":1,"result":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec"]} +``` + +### Sending Transactions + +It is possible to send transactions using raw curl requests too, but this requires unlocking the sender +account. It is recommended to do this using Clef to manage access to accounts or to use `ipc` instead. The +combination of HTTP and unlocked accounts pose a security risk. + +## Summary + +This tutorial has demonstrated how to generate accounts using Geth's built-in account management tool, +fund them with testnet ether and use those accounts to interact with Ethereum (Goerli) through a Geth +node. Checking account balances, sending transactions and retrieving transaction details were explained using +the web3.js library via the Geth console and using the JSON-RPC directly using Curl. Note that this is an +entry-level tutorial designed to help users get familiar with basic Geth processes, we strongly recommend +following this with the [Geth with Clef](/docs/getting-started/geth_with_clef) tutorial which will help to +adopt more secure account management practices than those outlined here. + + +[cli]: https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line diff --git a/content/docs/install_build/Installing-Geth.md b/content/docs/install_build/Installing-Geth.md deleted file mode 100644 index f82d577cca..0000000000 --- a/content/docs/install_build/Installing-Geth.md +++ /dev/null @@ -1,356 +0,0 @@ ---- -title: Installing Geth -sort_key: A ---- - -There are several ways to install Geth, including via a package manager, downloading a pre-built bundle, running as a docker container or building from downloaded source code. On this page the various installation options are explained for several major operating systems. Users prioritizing ease of installation should choose to use a package manager or prebuilt bundle. Users prioritizing customization should build from source. It is important to run the latest version of Geth because each release includes bugfixes and improvement over the previous versions. The stable releases are recommended for most users because they have been fully tested. A list of stable releases can be found [here][geth-releases]. Instructions for updating existing Geth installations are also provided in each section. - - -{:toc} - -- this will be removed by the toc - -## Package managers - -### MacOS via Homebrew - -The easiest way to install go-ethereum is to use the Geth Homebrew tap. The first step is to check that Homebrew is installed. The following command should return a version number. - -```shell -brew -v -``` - -If a version number is returned, then Homebrew is installed. If not, Homebrew can be installed by following the instructions [here][brew]. With Homebrew installed, the following commands add the Geth tap and install Geth: - - -```shell -brew tap ethereum/ethereum -brew install ethereum -``` - -The previous command installs the latest stable release. Developers that wish to install the most up-to-date version can install the Geth repository's master branch by adding the `--devel` parameter to the install command: - -```shell -brew install ethereum --devel -``` - -These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. - -Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: - -```shell -brew update -brew upgrade -brew reinstall ethereum -``` - -When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. - - -### Ubuntu via PPAs - -The easiest way to install Geth on Ubuntu-based distributions is with the built-in launchpad PPAs (Personal Package Archives). A single PPA repository is provided, containing stable and development releases for Ubuntu versions `xenial`, `trusty`, `impish`, `focal`, `bionic`. - -The following command enables the launchpad repository: - -```shell -sudo add-apt-repository -y ppa:ethereum/ethereum -``` - -Then, to install the stable version of go-ethereum: - -```shell -sudo apt-get update -sudo apt-get install ethereum -``` - -Or, alternatively the develop version: - -```shell -sudo apt-get update -sudo apt-get install ethereum-unstable -``` - -These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. - - -Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: - -```shell -sudo apt-get update -sudo apt-get install ethereum -sudo apt-get upgrade geth -``` - -When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. - - -### Windows - -The easiest way to install Geth is to download a pre-compiled binary from the [downloads][geth-dl] page. The page provides an installer as well as a zip file containing the Geth source code. The install wizard offers the user the option to install Geth, or Geth and the developer tools. The installer adds `geth` to the system's `PATH` automatically. The zip file contains the command `.exe` files that can be run from the command prompt. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. - -Updating an existing Geth installation can be achieved by stopping the node, downloading and installing the latest version following the instructions above. When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. - -### FreeBSD via pkg - -Geth can be installed on FreeBSD using the package manager `pkg`. The following command downloads and installs Geth: - -```shell -pkg install go-ethereum -``` - -These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. - -The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. - - -Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: - -```shell -pkg upgrade -``` - -When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. - - -### FreeBSD via ports - -Installing Geth using ports, simply requires navigating to the `net-p2p/go-ethereum` ports directory and running `make install` as root: - -```shell -cd /usr/ports/net-p2p/go-ethereum -make install -``` - -These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. - -The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. - - -Updating an existing Geth installation can be achieved by stopping the node and running the following command: - -```shell -portsnap fetch -``` - -When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. - -### Arch Linux via pacman - -The Geth package is available from the [community repo][geth-archlinux]. It can be installed by running: - -```shell -pacman -S geth -``` - -These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/bin/`. - -The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. - -Updating an existing Geth installation can be achieved by stopping the node and running the following command: - -```shell -sudo pacman -Sy -``` - -When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. - -## Standalone bundle - -Stable releases and development builds are provided as standalone bundles. These are useful for users who: a) wish to install a specific version of Geth (e.g., for reproducible environments); b) wish to install on machines without internet access (e.g. air-gapped computers); or c) wish to avoid automatic updates and instead prefer to manually install software. - -The following standalone bundles are available: - -- 32bit, 64bit, ARMv5, ARMv6, ARMv7 and ARM64 archives (`.tar.gz`) on Linux -- 64bit archives (`.tar.gz`) on macOS -- 32bit and 64bit archives (`.zip`) and installers (`.exe`) on Windows - - -Some archives contain only Geth, while other archives containing Geth and the various developer tools (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`). More information about these executables is available at the [`README`][geth-readme-exe]. - -The standalone bundles can be downloaded from the [Geth Downloads][geth-dl] page. To update an existing installation, download and manually install the latest version. - -## Docker container - -A Docker image with recent snapshot builds from our `develop` branch is maintained on DockerHub to support users who prefer to run containerized processes. There four different Docker images available for running the latest stable or development versions of Geth. - -- `ethereum/client-go:latest` is the latest development version of Geth (default) -- `ethereum/client-go:stable` is the latest stable version of Geth -- `ethereum/client-go:{version}` is the stable version of Geth at a specific version number -- `ethereum/client-go:release-{version}` is the latest stable version of Geth at a specific version family - -Pulling an image and starting a node is achieved by running these commands: - -```shell -docker pull ethereum/client-go -docker run -it -p 30303:30303 ethereum/client-go -``` - -There are also four different Docker images for running the latest stable or development versions of miscellaneous Ethereum tools. - -- `ethereum/client-go:alltools-latest` is the latest development version of the Ethereum tools -- `ethereum/client-go:alltools-stable` is the latest stable version of the Ethereum tools -- `ethereum/client-go:alltools-{version}` is the stable version of the Ethereum tools at a specific version number -- `ethereum/client-go:alltools-release-{version}` is the latest stable version of the Ethereum tools at a specific version family - -The image has the following ports automatically exposed: - -- `8545` TCP, used by the HTTP based JSON RPC API -- `8546` TCP, used by the WebSocket based JSON RPC API -- `8547` TCP, used by the GraphQL API -- `30303` TCP and UDP, used by the P2P protocol running the network - - -**Note:** if you are running an Ethereum client inside a Docker container, you should mount a data volume as the client's data directory (located at `/root/.ethereum` inside the container) to ensure that downloaded data is preserved between restarts and/or container life-cycles. - - -Updating Geth to the latest version simply requires stopping the container, pulling the latest version from Docker and running it: - -```shell -docker stop ethereum/client-go -docker pull ethereum/client-go:latest -docker run -it -p 30303:30303 ethereum/client-go -``` - -## Build from source code - -### Most Linux systems and macOS - -Geth is written in [Go][go], so building from source code requires the most recent version of Go to be installed. Instructions for installing Go are available at the [Go installation page][go-install] and necessary bundles can be downloaded from the [Go download page][go-dl]. - -With Go installed, Geth can be downloaded into a `GOPATH` workspace via: - - -```shell -go get -d github.com/ethereum/go-ethereum -``` - -You can also install specific versions via: - -```shell -go get -d github.com/ethereum/go-ethereum@v1.9.21 -``` - - -The above commands do not build any executables. To do that you can either build one specifically: - -```shell -go install github.com/ethereum/go-ethereum/cmd/geth -``` - - -Alternatively, the following command, run in the project root directory (`ethereum/go-ethereum`) in the GO workspace, builds the entire project and installs Geth and all the developer tools: - - -```shell -go install ./... -``` - -For macOS users, errors related to macOS header files are usually fixed by installing XCode Command Line Tools with `xcode-select --install`. -Another common error is: `go: cannot use path@version syntax in GOPATH mode`. This and other similar errors can often be fixed by enabling gomodules using `export GO111MODULE=on`. - -Updating an existing Geth installation can be achieved using `go get`: - -```shell -go get -u github.com/ethereum/go-ethereum -``` - - -### Windows - -The Chocolatey package manager provides an easy way to install the required build tools. Chocolatey can be installed by following these [instructions][chocolatey]. Then, to install the build tool the following commands can be run in an Administrator command prompt: - - -``` -C:\Windows\system32> choco install git -C:\Windows\system32> choco install golang -C:\Windows\system32> choco install mingw -``` - -Installing these packages sets up the path environment variables. To get the new path a new command prompt must be opened. To install Geth, a Go workspace directory must first be created, then the Geth source code can be created and built. - -``` -C:\Users\xxx> mkdir src\github.com\ethereum -C:\Users\xxx> git clone https://github.com/ethereum/go-ethereum src\github.com\ethereum\go-ethereum -C:\Users\xxx> cd src\github.com\ethereum\go-ethereum -C:\Users\xxx\src\github.com\ethereum\go-ethereum> go get -u -v golang.org/x/net/context -C:\Users\xxx\src\github.com\ethereum\go-ethereum> go install -v ./cmd/... -``` - -### FreeBSD - -To build Geth from source code on FreeBSD, the Geth Github repository can be cloned into a local directory. - - -```shell -git clone https://github.com/ethereum/go-ethereum -``` - -Then, the Go compiler can be used to build Geth: - -```shell -pkg install go -``` - - -If the Go version currently installed is >= 1.5, Geth can be built using the following command: - -```shell -cd go-ethereum -make geth -``` - -If the installed Go version is < 1.5 (quarterly packages, for example), the following command can be used instead: - -```shell -cd go-ethereum -CC=clang make geth -``` - -To start the node, the followijng command can be run: - -```shell -build/bin/geth -``` - -### Building without a Go workflow - -Geth can also be built without using Go workspaces. In this case, the repository should be cloned to a local repository. Then, the command -`make geth` configures everything for a temporary build and cleans up afterwards. This method of building only works on UNIX-like operating systems, and a Go installation is still required. - -```shell -git clone https://github.com/ethereum/go-ethereum.git -cd go-ethereum -make geth -``` - -These commands create a Geth executable file in the `go-ethereum/build/bin` folder that can be moved and run from another directory if required. The binary is standalone and doesn't require any additional files. - -To update an existing Geth installation simply stop the node, navigate to the project root directory and pull the latest version from the Geth Github repository. then rebuild and restart the node. - -```shell -cd go-ethereum -git pull -make geth -``` - -Additionally all the developer tools provided with Geth (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`) can be compiled by running `make all`. More information about these tools can be found [here][geth-readme-exe]. - -Instructions for cross-compiling to another architecture are available in the [cross-compilation guide](./cross-compile). - -To build a stable release, e.g. v1.9.21, the command `git checkout v1.9.21` retrieves that specific version. Executing that command before running `make geth` switches Geth to a stable branch. - - - -[brew]: https://brew.sh/ -[go]: https://golang.org/ -[go-dl]: https://golang.org/dl/ -[go-install]: https://golang.org/doc/install -[chocolatey]: https://chocolatey.org -[geth-releases]: https://github.com/ethereum/go-ethereum/releases -[geth-readme-exe]: https://github.com/ethereum/go-ethereum#executables -[geth-cl-options]: https://geth.ethereum.org/docs/interface/command-line-options -[geth-archlinux]: https://www.archlinux.org/packages/community/x86_64/geth/ -[geth-dl]: ../../downloads/ - - diff --git a/content/docs/install_build/cross-compile.md b/content/docs/install_build/cross-compile.md deleted file mode 100644 index 55af4e6652..0000000000 --- a/content/docs/install_build/cross-compile.md +++ /dev/null @@ -1,167 +0,0 @@ ---- -title: Cross-Compiling Geth -sort_key: C ---- - -**Note: All of these and much more have been merged into the project Makefile. You can -cross build via `make geth--` without needing to know any of these details -from below.** - -Developers usually have a preferred platform that they feel most comfortable working in, -with all the necessary tools, libraries and environments set up for an optimal workflow. -However, there's often need to build for either a different CPU architecture, or an -entirely different operating system; but maintaining a development environment for each -and switching between the them quickly becomes unwieldy. - -Here we present a very simple way to cross compile Ethereum to various operating systems -and architectures using a minimal set of prerequisites and a completely containerized -approach, guaranteeing that your development environment remains clean even after the -complex requirements and mechanisms of a cross compilation. - -The currently supported target platforms are: - - - ARMv7 Android and iOS - - 32 bit, 64 bit and ARMv5 Linux - - 32 bit and 64 bit Mac OSX - - 32 bit and 64 bit Windows - -Please note, that cross compilation does not replace a release build. Although resulting -binaries can usually run perfectly on the desired platform, compiling on a native system -with the specialized tools provided by the official vendor can often result in more a -finely optimized code. - -## Cross compilation environment - -Although the `go-ethereum` project is written in Go, it does include a bit of C code -shared between all implementations to ensure that all perform equally well, including a -dependency to the GNU Multiple Precision Arithmetic Library. Because of these, Go cannot -by itself compile to a different platform than the host. To overcome this limitation, we -will use [`xgo`](https://github.com/karalabe/xgo), a Go cross compiler package based on -Docker containers that has been architected specifically to allow both embedded C snippets -as well as simpler external C dependencies during compilation. - -The `xgo` project has two simple dependencies: Docker (to ensure that the build -environment is completely contained) and Go. On most platforms these should be available -from the official package repositories. For manually installing them, please consult their -install guides at [Docker](https://docs.docker.com/installation/) and -[Go](https://golang.org/doc/install) respectively. This guide assumes that these two -dependencies are met. - -To install and/or update xgo, simply type: - - $ go get -u github.com/karalabe/xgo - -You can test whether `xgo` is functioning correctly by requesting it to cross -compile itself and verifying that all cross compilations succeeded or not. - - $ xgo github.com/karalabe/xgo - ... - - $ ls -al - -rwxr-xr-x 1 root root 2792436 Sep 14 16:45 xgo-android-21-arm - -rwxr-xr-x 1 root root 2353212 Sep 14 16:45 xgo-darwin-386 - -rwxr-xr-x 1 root root 2906128 Sep 14 16:45 xgo-darwin-amd64 - -rwxr-xr-x 1 root root 2388288 Sep 14 16:45 xgo-linux-386 - -rwxr-xr-x 1 root root 2960560 Sep 14 16:45 xgo-linux-amd64 - -rwxr-xr-x 1 root root 2437864 Sep 14 16:45 xgo-linux-arm - -rwxr-xr-x 1 root root 2551808 Sep 14 16:45 xgo-windows-386.exe - -rwxr-xr-x 1 root root 3130368 Sep 14 16:45 xgo-windows-amd64.exe - - -## Building Ethereum - -Cross compiling Ethereum is analogous to the above example, but an additional flags is -required to satisfy the dependencies: - - - `--deps` is used to inject arbitrary C dependency packages and pre-build them - -Injecting the GNU Arithmetic Library dependency and selecting `geth` would be: - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - github.com/ethereum/go-ethereum/cmd/geth - ... - - $ ls -al - -rwxr-xr-x 1 root root 23213372 Sep 14 17:59 geth-android-21-arm - -rwxr-xr-x 1 root root 14373980 Sep 14 17:59 geth-darwin-386 - -rwxr-xr-x 1 root root 17373676 Sep 14 17:59 geth-darwin-amd64 - -rwxr-xr-x 1 root root 21098910 Sep 14 17:59 geth-linux-386 - -rwxr-xr-x 1 root root 25049693 Sep 14 17:59 geth-linux-amd64 - -rwxr-xr-x 1 root root 20578535 Sep 14 17:59 geth-linux-arm - -rwxr-xr-x 1 root root 16351260 Sep 14 17:59 geth-windows-386.exe - -rwxr-xr-x 1 root root 19418071 Sep 14 17:59 geth-windows-amd64.exe - - -As the cross compiler needs to build all the dependencies as well as the main project -itself for each platform, it may take a while for the build to complete (approximately 3-4 -minutes on a Core i7 3770K machine). - -### Fine tuning the build - -By default Go, and inherently `xgo`, checks out and tries to build the master branch of a -source repository. However, more often than not, you'll probably want to build a different -branch from possibly an entirely different remote repository. These can be controlled via -the `--remote` and `--branch` flags. - -To build the `develop` branch of the official `go-ethereum` repository instead of the -default `master` branch, you just need to specify it as an additional command line flag -(`--branch`): - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - --branch=develop \ - github.com/ethereum/go-ethereum/cmd/geth - -Additionally, during development you will most probably want to not only build a custom -branch, but also one originating from your own fork of the repository instead of the -upstream one. This can be done via the `--remote` flag: - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - --remote=https://github.com/karalabe/go-ethereum \ - --branch=rpi-staging \ - github.com/ethereum/go-ethereum/cmd/geth - -By default `xgo` builds binaries for all supported platforms and architectures, with -Android binaries defaulting to the highest released Android NDK platform. To limit the -build targets or compile to a different Android platform, use the `--targets` CLI -parameter. - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - --targets=android-16/arm,windows/* \ - github.com/ethereum/go-ethereum/cmd/geth - -### Building locally - -If you would like to cross compile your local development version, simply specify a local -path (starting with `.` or `/`), and `xgo` will use all local code from `GOPATH`, only -downloading missing dependencies. In such a case of course, the `--branch`, `--remote` and -`--pkg` arguments are no-op: - - $ xgo --deps=https://gmplib.org/download/gmp/gmp-6.0.0a.tar.bz2 \ - ./cmd/geth - -## Using the Makefile - -Having understood the gist of `xgo` based cross compilation, you do not need to actually -memorize and maintain these commands, as they have been incorporated into the official -[Makefile](https://github.com/ethereum/go-ethereum/blob/master/Makefile) and can be -invoked with a trivial `make` request: - - * `make geth-cross`: Cross compiles to every supported OS and architecture - * `make geth-`: Cross compiles supported architectures of a particular OS (e.g. `linux`) - * `make geth--`: Cross compiles to a specific OS/architecture (e.g. `linux`, `arm`) - -We advise using the `make` based commands opposed to manually invoking `xgo` as we do -maintain the Makefile actively whereas we cannot guarantee that this document will be -always readily updated to latest advancements. - -### Tuning the cross builds - -A few of the `xgo` build options have also been surfaced directly into the Makefile to -allow fine tuning builds to work around either upstream Go issues, or to enable some -fancier mechanics. - - - `make ... GO=`: Use a specific Go runtime (e.g. `1.5.1`, `1.5-develop`, `develop`) - - `make ... MODE=`: Build a specific target type (e.g. `exe`, `c-archive`). - -Please note that these are not yet fully finalized, so they may or may not change in the -future as our code and the Go runtime features change. From edd22c6eab791f8bd2d3039812c37ee2337df90e Mon Sep 17 00:00:00 2001 From: Sam Richards Date: Thu, 28 Jul 2022 12:57:05 -0700 Subject: [PATCH 012/432] Remove nested /downloads folder --- content/downloads/{downloads => }/index.md | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename content/downloads/{downloads => }/index.md (100%) diff --git a/content/downloads/downloads/index.md b/content/downloads/index.md similarity index 100% rename from content/downloads/downloads/index.md rename to content/downloads/index.md From a93245d4e4b833da82851609e61104ebc2b053e6 Mon Sep 17 00:00:00 2001 From: Sam Richards Date: Thu, 28 Jul 2022 13:04:07 -0700 Subject: [PATCH 013/432] Convert /downloads to a page --- content/{downloads/index.md => downloads.md} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename content/{downloads/index.md => downloads.md} (100%) diff --git a/content/downloads/index.md b/content/downloads.md similarity index 100% rename from content/downloads/index.md rename to content/downloads.md From e32c01579fa8e0a6e50bbb1785e6990b4d573f4a Mon Sep 17 00:00:00 2001 From: Joe Date: Fri, 29 Jul 2022 09:48:04 +0100 Subject: [PATCH 014/432] content updates --- .../geth-developer/built-in-tracers.md | 112 ++++++++++++++++++ .../docs/getting_started/consensus-clients.md | 17 +-- .../getting-started-with-clef.md | 63 +++++----- .../docs/getting_started/getting_started.md | 47 +++++--- .../interacting_with_geth/RPC/ns-debug.md | 3 +- .../interacting_with_geth/RPC/ns-personal.md | 3 +- content/homepage.md | 3 + 7 files changed, 194 insertions(+), 54 deletions(-) create mode 100644 content/docs/developers/geth-developer/built-in-tracers.md diff --git a/content/docs/developers/geth-developer/built-in-tracers.md b/content/docs/developers/geth-developer/built-in-tracers.md new file mode 100644 index 0000000000..08ae63b3a9 --- /dev/null +++ b/content/docs/developers/geth-developer/built-in-tracers.md @@ -0,0 +1,112 @@ +--- +title: Built-in tracers +sort_key: C +--- + +Geth comes bundled with a choice of tracers ready for usage through the [tracing API](/docs/rpc/ns-debug). Some of them are implemented natively in Go, and others in JS. In this page a summary of each of these will be outlined. They have to be specified by name when sending a request. The only exception is the opcode logger (otherwise known as struct logger) which is the default tracer for all the methods and cannot be specified by name. + +* TOC +{:toc} + +## Struct logger + +Struct logger or opcode logger is a native Go tracer which executes a transaction and emits the opcode and execution context at every step. This is the tracer that will be used when no name is passed to the API, e.g. `debug.traceTransaction()`. The following information is emitted at each step: + +| field | type | description | +|------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------| +| pc | uint64 | program counter | +| op | byte | opcode to be executed | +| gas | uint64 | remaining gas | +| gasCost | uint64 | cost for executing op | +| memory | []byte | EVM memory. Enabled via `enableMemory` | +| memSize | int | Size of memory | +| stack | []uint256 | EVM stack. Disabled via `disableStack` | +| returnData | []byte | Last call's return data. Enabled via `enableReturnData` | +| storage | map[hash]hash | Storage slots of current contract read from and written to. Only emitted for `SLOAD` and `SSTORE`. Disabled via `disableStorage` | +| depth | int | Current call depth | +| refund | uint64 | Refund counter | +| error | string | Error message if any | + +Note that the fields `memory`, `stack`, `returnData`, and `storage` have dynamic size and depending on the exact transaction they could grow large in size. This is specially true for `memory` which could blow up the trace size. It is recommended to keep them disabled unless they are explicitly required for a given use-case. + +## Native tracers + +The following tracers are implement in Go and as such have offer good performance. They are selected by their name when invoking a tracing API method, e.g. `debug.traceTransaction(, { tracer: 'callTracer' })`. + +### 4byteTracer + +Solidity contract functions are [addressed](https://docs.soliditylang.org/en/develop/abi-spec.html#function-selector) by the first four four byte of the Keccak-256 hash of their signature. Therefore when calling the function of a contract, the caller must send this function selector as well as the ABI-encoded arguments as call data. + +The `4byteTracer` collects the function selectors of every function executed in the lifetime of a transaction, along with the size of the supplied call data. The result is a `map[string]int` where the keys are `SELECTOR-CALLDATASIZE` and the values are number of occurances of this key. E.g.: + +```terminal +> debug.traceTransaction( "0x214e597e35da083692f5386141e69f47e973b2c56e7a8073b1ea08fd7571e9de", {tracer: "4byteTracer"}) +{ + "0x27dc297e-128": 1, + "0x38cc4831-0": 2, + "0x524f3889-96": 1, + "0xadf59f99-288": 1, + "0xc281d19e-0": 1 +} +``` + +### callTracer + +The `callTracer` tracks all the call frames executed during a transaction, including depth 0. The result will be a nested list of call frames, resembling how EVM works. They form a tree with the top-level call at root and sub-calls as children of the higher levels. Each call frame has the following fields: + +| field | type | description | +|---------|-------------|-------------------------------------------| +| type | string | CALL or CREATE | +| from | string | address | +| to | string | address | +| value | string | hex-encoded amount of value transfer | +| gas | string | hex-encoded gas provided for call | +| gasUsed | string | hex-encoded gas used during call | +| input | string | call data | +| output | string | return data | +| error | string | error, if any | +| calls | []callframe | list of sub-calls | + +Things to note about the call tracer: + +- Calls to precompiles are also included in the result +- In case a frame reverts, the field `output` will contain the raw return data, unlike [revertReasonTracer](#revertreasontracer) which parses the data and returns the revert message + +### noopTracer + +This tracer is noop. It returns an empty object and is only meant for testing the setup. + +### prestateTracer + +Executing a transaction requires the prior state, including account of sender and recipient, contracts that are called during execution, etc. The `prestateTracer` replays the tx and tracks every part of state that is touched. This is similar to the concept of a [stateless witness](https://ethresear.ch/t/the-stateless-client-concept/172), the difference being this tracer doesn't return any cryptographic proof, rather only the trie leaves. The result is an object. The keys are addresses of accounts. The value is an object with the following fields: + +| field | type | description | +|---------|-------------------|-------------------------------| +| balance | string | balance in Wei | +| nonce | uint64 | nonce | +| code | string | hex-encoded bytecode | +| storage | map[string]string | storage slots of the contract | + +### revertReasonTracer + +The `revertReasonTracer` is useful for analyzing failed transactions. The return value is: + +- In case the transaction reverted: reason of the revert as returned by the Solidity contract +- Error message for any other failure + +Example: + +```terminal +> debug.traceTransaction('0x97695ffb034be7e1faeb372a564bb951ba4ebf4fee4caff2f9d1702497bb2b8b', { tracer: 'revertReasonTracer' }) +"execution reverted: tokensMintedPerAddress exceed MAX_TOKENS_MINTED_PER_ADDRESS" +``` + +## JS tracers + +The following are a list of tracers written in JS that come as part of Geth: + +- `bigramTracer`: Counts the opcode bigrams, i.e. how many times 2 opcodes were executed one after the other +- `evmdisTracer`: Returns sufficient information from a trace to perform [evmdis](https://github.com/Arachnid/evmdis)-style disassembly +- `opcountTracer` Counts the total number of opcodes executed +- `trigramTracer`: Counts the opcode trigrams +- `unigramTracer`: Counts the occurances of each opcode diff --git a/content/docs/getting_started/consensus-clients.md b/content/docs/getting_started/consensus-clients.md index 17cb109d0f..f57bc4e26f 100644 --- a/content/docs/getting_started/consensus-clients.md +++ b/content/docs/getting_started/consensus-clients.md @@ -8,8 +8,8 @@ run a full Ethereum node. However, ever since Ethereum swapped from [proof-of-wo [proof-of-stake][pos-link] (PoS) based consensus, Geth has needed to be coupled to another piece of software called a ["consensus client"][con-client-link]. -There are four consensus clients available, all of which connect to Geth in the same way. This page will -outline how Geth can be set up with a consensus client. +There are five consensus clients available, all of which connect to Geth in the same way. +This page will outline how Geth can be set up with a consensus client to form a complete Ethereum node. ## Configuring Geth @@ -45,6 +45,8 @@ There are currently four consensus clients that can be run alongside Geth. These [Prysm](https://docs.prylabs.network/docs/getting-started/): written in Go [Teku](https://pegasys.tech/teku): written in Java + +[Lodestar](https://lodestar.chainsafe.io/): written in Typescript It is recommended to consider [client diversity][client-div-link] when choosing a consensus client. Instructions for installing each client are provided in the documentation linked in the list above. @@ -59,8 +61,8 @@ Each consensus client has a command similar to `--jwt-secret` that takes the fil be consistent with the `--authrpc.jwtsecret` path provided to Geth. The consensus clients all expose a [Beacon API][beacon-api-link] that can be used to check the status -of the Beacon client or download blocks and consensus data by sending requests using tools such as [Curl](https://curl.se). -More information on this can be found in the documentation for each consensus client. +of the Beacon client or download blocks and consensus data by sending requests using tools such as +[Curl](https://curl.se). More information on this can be found in the documentation for each consensus client. ## Validators @@ -84,10 +86,9 @@ geth attach datadir/geth.ipc ## Summary -As The Merge approaches it is important for Geth users to prepare by installing and running a consensus client. Otherwise, Geth will stop -following the head of the chain immediately after The Merge. There are five consensus clients to choose from. This page provided an overview -of how to choose a consensus client and configure Geth to connect to it. This pre-emptive action will protect against disruption to users as a -result of The Merge. +Now that Ethereum has implemented proof-of-stake, Geth users are required to install and run a consensus client. +Otherwise, Geth will not be able to track the head of the chain. There are five consensus clients to choose from. +This page provided an overview of how to choose a consensus client and configure Geth to connect to it. [pow-link]:https://ethereum.org/en/developers/docs/consensus-mechanisms/pow diff --git a/content/docs/getting_started/getting-started-with-clef.md b/content/docs/getting_started/getting-started-with-clef.md index 684996f7ed..37078b7a2e 100644 --- a/content/docs/getting_started/getting-started-with-clef.md +++ b/content/docs/getting_started/getting-started-with-clef.md @@ -6,10 +6,13 @@ sort_key: B This page explains how to set up Geth and execute some basic tasks using the command line tools. In order to use Geth, the software must first be installed. There are several ways Geth can be -installed depending on the operating system and the user's choice of installation method, for example -using a package manager, container or building from source. Instructions for installing Geth can be -found on the ["Install and Build"](install-and-build/installing-geth) pages. The tutorial on this -page assumes Geth and the associated developer tools have been installed successfully. +installed depending on the operating system and the user's choice of installation method, for +example using a package manager, container or building from source. Instructions for installing +Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. Geth +also needs to be connected to a consensus client in order to function as an Ethereum node. +The tutorial on this page assumes Geth and a consensus client have been installed successfully and +that a firewall has been configured to block external traffic to the JSON-RPC port `8545` see +[Security](/content/docs/fundamentals/security.md). This page provides step-by-step instructions covering the fundamentals of using Geth. This includes generating accounts, joining an Ethereum network, syncing the blockchain and sending ether @@ -19,40 +22,46 @@ the Geth team and is intended to eventually replace the account management tool ## Prerequisites -In order to get the most value from the tutorials on this page, the following skills are necessary: +In order to get the most value from the tutorials on this page, the following skills are +necessary: - Experience using the command line - Basic knowledge about Ethereum and testnets - Basic knowledge about HTTP and JavaScript +- Basic knowledge of node architecture and consensus clients -Users that need to revisit these fundamentals can find helpful resources relating to the command line -[here][cli], -Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), http -[here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and Javascript [here](https://www.javascript.com/learn). +Users that need to revisit these fundamentals can find helpful resources relating to the command +line [here][cli], Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), +http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and +Javascript [here](https://www.javascript.com/learn). Information on node architecture can be found +[here](/content/docs/fundamentals/node-architecture.md) and our guide for configuring Geth to connect to a +consensus client is [here](/content/docs/getting_started/consensus-clients.md). -{% include note.html content="If Geth was installed from source on Linux, `make` saves the binaries for -Geth and the associated tools in `/build/bin`. To run these programs it is convenient to move them to -the top level project directory (e.g. running `mv ./build/bin/* ./`) from `/go-ethereum`. Then `./` must -be prepended to the commands in the code snippets in order to execute a particular program, e.g. `./geth` -instead of simply `geth`. If the executables are not moved then either navigate to the `bin` directory to -run them (e.g. `cd ./build/bin` and `./geth`) or provide their path (e.g. `./build/bin/geth`). These -instructions can be ignored for other installations." %} +{% include note.html content="If Geth was installed from source on Linux, `make` saves the +binaries for Geth and the associated tools in `/build/bin`. To run these programs it is +convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) +from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to +execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not +moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) +or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} ## Background Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being -managed by a central server. Nodes compete to generate new blocks of transactions to send to its peers -because they are rewarded for doing so in Ethereum's native token, ether (ETH). On receiving a new block, -each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called -a "blockchain". The information provided in each block is used by Geth to update its "state" - the ether -balance of each account on Ethereum. There are two types of account: externally-owned accounts (EOAs) and -contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts -that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, -where the public key is used to derive a unique address for the user and the private key is used to protect -the account and securely sign messages. Therefore, in order to use Ethereum, it is first necessary to generate -an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it with -ether and sending some to another address. +managed by a central server. Every 12 seconds one node is randomly selected to generate a new block +containing a list of transactions that nodes receiving the block should execute. This "block proposer" node +sends the new block to its peers. On receiving a new block, each node checks that it is valid and adds +it to their database. The sequence of discrete blocks is called a "blockchain". + +The information provided in each block is used by Geth to update its "state" - the ether +balance of each account on Ethereum and the data stored by each smart contract. There are two types of account: +externally-owned accounts (EOAs) and contract accounts. Contract accounts execute contract code when they +receive transactions. EOAs are accounts that users manage locally in order to sign and submit transactions. +Each EOA is a public-private key pair, where the public key is used to derive a unique address for the user and +the private key is used to protect the account and securely sign messages. Therefore, in order to use Ethereum, +it is first necessary to generate an EOA (hereafter, "account"). This tutorial will guide the user through +creating an account, funding it with ether and sending some to another address. Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). diff --git a/content/docs/getting_started/getting_started.md b/content/docs/getting_started/getting_started.md index 448e8eb5aa..7f9c8f6647 100644 --- a/content/docs/getting_started/getting_started.md +++ b/content/docs/getting_started/getting_started.md @@ -8,14 +8,22 @@ This page explains how to set up Geth and execute some basic tasks using the com In order to use Geth, the software must first be installed. There are several ways Geth can be installed depending on the operating system and the user's choice of installation method, for example using a package manager, container or building from source. Instructions for installing -Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. -The tutorial on this page assumes Geth and the associated developer tools have been installed successfully. +Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. Geth +also needs to be connected to a consensus client in order to function as an Ethereum node. +The tutorial on this page assumes Geth and a consensus client have been installed successfully and +that a firewall has been configured to block external traffic to the JSON-RPC port `8545` see +[Security](/content/docs/fundamentals/security.md). This page provides step-by-step instructions covering the fundamentals of using Geth. This includes generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. -It is considered best-practice to use [Clef](/docs/clef/Introduction) for account management - this -is explained in the [Geth with Clef](/docs/getting-started/geth_with_clef) tutorial. In this -introductory tutorial, Geth's built-in account management tools are used instead. +This page uses Geth's built in account management tool. This is the simplest method for creating and accessing +accounts in Geth, is sufficiently secure for many purposes and provides a good entry point for undersatanding +some of the basic Geth workflows. However, Geth also comes bundled with an external signer and account management +tool called [Clef](/tools/Clef/introduction). It is best practise to use Clef instead of Geth's built-in account +management tools because Clef is decoupled from Geth and can be run in a separate, secure environment. +This page should be used as an initial entry point into basic Geth and readers should plan to advance from this +page to [Getting started with Geth and Clef](/content/docs/getting_started/getting-started-with-clef.md). +Eventually, Clef is intended to replace Geth's built-in account management tools. {:toc} - this will be removed by the toc @@ -28,11 +36,14 @@ necessary: - Experience using the command line - Basic knowledge about Ethereum and testnets - Basic knowledge about HTTP and JavaScript +- Basic knowledge of node architecture and consensus clients Users that need to revisit these fundamentals can find helpful resources relating to the command line [here][cli], Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and -Javascript [here](https://www.javascript.com/learn). +Javascript [here](https://www.javascript.com/learn). Information on node architecture can be found +[here](/content/docs/fundamentals/node-architecture.md) and our guide for configuring Geth to connect to a +consensus client is [here](/content/docs/getting_started/consensus-clients.md). {% include note.html content="If Geth was installed from source on Linux, `make` saves the binaries for Geth and the associated tools in `/build/bin`. To run these programs it is @@ -46,17 +57,19 @@ or provide their path (e.g. `./build/bin/geth`). These instructions can be ignor Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being -managed by a central server. Nodes compete to generate new blocks of transactions to send to its peers -because they are rewarded for doing so in Ethereum's native token, ether (ETH). On receiving a new block, -each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called -a "blockchain". The information provided in each block is used by Geth to update its "state" - the ether -balance of each account on Ethereum. There are two types of account: externally-owned accounts (EOAs) and -contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts -that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, -where the public key is used to derive a unique address for the user and the private key is used to protect -the account and securely sign messages. Therefore, in order to use Ethereum, it is first necessary to generate -an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it -with ether and sending some to another address. +managed by a central server. Every 12 seconds one node is randomly selected to generate a new block +containing a list of transactions that nodes receiving the block should execute. This "block proposer" node +sends the new block to its peers. On receiving a new block, each node checks that it is valid and adds +it to their database. The sequence of discrete blocks is called a "blockchain". + +The information provided in each block is used by Geth to update its "state" - the ether +balance of each account on Ethereum and the data stored by each smart contract. There are two types of account: +externally-owned accounts (EOAs) and contract accounts. Contract accounts execute contract code when they +receive transactions. EOAs are accounts that users manage locally in order to sign and submit transactions. +Each EOA is a public-private key pair, where the public key is used to derive a unique address for the user and +the private key is used to protect the account and securely sign messages. Therefore, in order to use Ethereum, +it is first necessary to generate an EOA (hereafter, "account"). This tutorial will guide the user through +creating an account, funding it with ether and sending some to another address. Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). diff --git a/content/docs/interacting_with_geth/RPC/ns-debug.md b/content/docs/interacting_with_geth/RPC/ns-debug.md index 57640283d0..2fed88c96b 100644 --- a/content/docs/interacting_with_geth/RPC/ns-debug.md +++ b/content/docs/interacting_with_geth/RPC/ns-debug.md @@ -753,7 +753,7 @@ Specifying the `tracer` option in the second argument enables JavaScript-based t `log` has the following fields: - `op`: Object, an OpCode object representing the current opcode - - `stack`: array[big.Int], the EVM execution stack + - `stack`: Object, a structure representing the EVM execution stack - `memory`: Object, a structure representing the contract's memory space - `contract`: Object, an object representing the account executing the current operation @@ -945,3 +945,4 @@ Writes a goroutine blocking profile to the given file. |:--------|-----------------------------------------------------------| | Console | `debug.writeMutexProfile(file)` | | RPC | `{"method": "debug_writeMutexProfile", "params": [file]}` | + diff --git a/content/docs/interacting_with_geth/RPC/ns-personal.md b/content/docs/interacting_with_geth/RPC/ns-personal.md index c3086ccb50..436471b773 100644 --- a/content/docs/interacting_with_geth/RPC/ns-personal.md +++ b/content/docs/interacting_with_geth/RPC/ns-personal.md @@ -207,7 +207,7 @@ undefined ### personal_sign The sign method calculates an Ethereum specific signature with: -`sign(keccak256("\x19Ethereum Signed Message:\n" + len(message) + message)))`. +`sign(keccak256("\x19Ethereum Signed Message:\n" + len(message) + message))`. By adding a prefix to the message makes the calculated signature recognisable as an Ethereum specific signature. This prevents misuse where a malicious DApp can sign arbitrary data (e.g. transaction) and use the signature to impersonate the victim. @@ -253,3 +253,4 @@ SignTransaction will create a transaction from the given arguments and tries to > personal.ecRecover("0xdeadbeaf", "0xa3f20717a250c2b0b729b7e5becbff67fdaef7e0699da4de7ca5895b02a170a12d887fd3b17bfdce3481f10bea41f45ba9f709d39ce8325427b57afcfc994cee1b") "0x9b2055d370f73ec7d8a03e965129118dc8f5bf83" ``` + diff --git a/content/homepage.md b/content/homepage.md index eb6ec09174..eb2254aa34 100644 --- a/content/homepage.md +++ b/content/homepage.md @@ -16,6 +16,8 @@ of smart contracts and contains an embedded computer known as the *Ethereum Virt Running Geth alongside a consensus client turns a computer into an Ethereum node. + + ## What is Ethereum? Ethereum is a technology for building apps and organizations, holding assets, transacting and @@ -37,3 +39,4 @@ using your Geth instance. + From 67892d6c845480cae3036a37e3b0cef4d23ad453 Mon Sep 17 00:00:00 2001 From: Joe Date: Fri, 29 Jul 2022 10:17:06 +0100 Subject: [PATCH 015/432] add page on abigen and placeholder for puppeth --- content/docs/tools/abigen/index.md | 151 ++++++++++++++++++++++++++++ content/docs/tools/puppeth/index.md | 8 ++ 2 files changed, 159 insertions(+) create mode 100644 content/docs/tools/abigen/index.md create mode 100644 content/docs/tools/puppeth/index.md diff --git a/content/docs/tools/abigen/index.md b/content/docs/tools/abigen/index.md new file mode 100644 index 0000000000..d8c64a730d --- /dev/null +++ b/content/docs/tools/abigen/index.md @@ -0,0 +1,151 @@ +--- +title: Home +root: .. +--- + +Abigen is a binfing-generator for easily interacting with Ethereum using Go. +Abigen creates easy-to-use, type-safe Go packages from Ethereum smart contract definitions known +as ABIs. This abstracts away a lot of the complexity of handling smart contract deployment +and interaction in Go native applications such as encoding and decoding smart contracts into +EVM bytecode. Abigen comes bundled with Geth. A full Geth installation includes the abigen binary. +Abigen can also be built independently by navigating to `go-ethereum/cmd/abigen` and running +`go build`, or equivalently: + +``` +$ cd $GOPATH/src/github.com/ethereum/go-ethereum +$ go build ./cmd/abigen +``` + +## What is an ABI? + +Ethereum smart contracts have a schema that defines its functions and return types in the form +of a JSON file. This JSON file is known as an *Application Binary Interface*, or ABI. The ABI +acts as a specification for precisely how to encode data sent to a contract and how to +decode the data the contract sends back. The ABI is the only essential piece of information required to +generate Go bindings. Go developers can then use the bindings to interact with the contract +from their Go application without having to deal directly with data encoding and decoding. +An ABI is generated when a contract is compiled. + + +### Generating the bindings + +To demonstrate the binding generator a contract is required. The contract `Storage.sol` implements two +very simple functions: `store` updates a user-defined `uint256` to the contract's storage, and `retrieve` +displays the value stored in the contract to the user. The Solidity code is as follows: + +```solidity +// SPDX-License-Identifier: GPL-3.0 + +pragma solidity >0.7.0 < 0.9.0; +/** +* @title Storage +* @dev store or retrieve variable value +*/ + +contract Storage { + + uint256 value; + + function store(uint256 number) public{ + value = number; + } + + function retrieve() public view returns (uint256){ + return value; + } +} +``` + +This contract can be pasted into a text file and saved as `Storage.sol`. + +The following code snippet shows how an ABI can be generated for `Storage.sol` +using the Solidity compiler `solc`. + +```shell +solc --abi Storage.sol -o build +``` + +The ABI can also be generated in other ways such as using the `compile` commands in development +frameworks such as [Truffle][truffle-link], [Hardhat][hardhat-link] and [Brownie][brownie-link] +or in the online IDE [Remix][remix-link]. ABIs for existing +verified contracts can be downloaded from [Etherscan](etherscan.io). + + +The ABI for `Storage.sol` (`Storage.abi`) looks as follows: + +```json +[{"inputs":[],"name":"retrieve","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"number","type":"uint256"}],"name":"store","outputs":[],"stateMutability":"nonpayable","type":"function"}] +``` + +The contract binding can then be generated by passing the ABI to `abigen` as follows: + +``` +$ abigen --abi Storage.abi --pkg main --type Storage --out Storage.go +``` + +Where the flags are: + + * `--abi`: Mandatory path to the contract ABI to bind to + * `--pkg`: Mandatory Go package name to place the Go code into + * `--type`: Optional Go type name to assign to the binding struct + * `--out`: Optional output path for the generated Go source file (not set = stdout) + +This will generate a type-safe Go binding for the Storage contract. The generated code will +look something like the snippet below, the full version of which can be viewed +[here](https://gist.github.com/jmcook1186/a78e59d203bb54b06e1b81f2cda79d93). + +```go +// Code generated - DO NOT EDIT. +// This file is a generated binding and any manual changes will be lost. + +package main + +import ( + "errors" + "math/big" + "strings" + + ethereum "github.com/ethereum/go-ethereum" + "github.com/ethereum/go-ethereum/accounts/abi" + "github.com/ethereum/go-ethereum/accounts/abi/bind" + "github.com/ethereum/go-ethereum/common" + "github.com/ethereum/go-ethereum/core/types" + "github.com/ethereum/go-ethereum/event" +) + +// Reference imports to suppress errors if they are not otherwise used. +var ( + _ = errors.New + _ = big.NewInt + _ = strings.NewReader + _ = ethereum.NotFound + _ = bind.Bind + _ = common.Big1 + _ = types.BloomLookup + _ = event.NewSubscription +) + +// StorageMetaData contains all meta data concerning the Storage contract. +var StorageMetaData = &bind.MetaData{ + ABI: "[{\"inputs\":[],\"name\":\"retrieve\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"number\",\"type\":\"uint256\"}],\"name\":\"store\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}]", +} + +// StorageABI is the input ABI used to generate the binding from. +// Deprecated: Use StorageMetaData.ABI instead. +var StorageABI = StorageMetaData.ABI + +// Storage is an auto generated Go binding around an Ethereum contract. +type Storage struct { + StorageCaller // Read-only binding to the contract + StorageTransactor // Write-only binding to the contract + StorageFilterer // Log filterer for contract events +} +... + +``` + +`Storage.go` contains all the bindings required to interact with `Storage.sol` from a Go application. + +For instructions on how to deploy this contract to Ethereum from a Go native application read our +[Go bindings page](/content/docs/developers/dapp-developer/native.md). To browse the Abigen source code +visit the Geth [Github repository](https://github.com/ethereum/go-ethereum/tree/master/cmd/abigen). \ No newline at end of file diff --git a/content/docs/tools/puppeth/index.md b/content/docs/tools/puppeth/index.md new file mode 100644 index 0000000000..73856b26f6 --- /dev/null +++ b/content/docs/tools/puppeth/index.md @@ -0,0 +1,8 @@ +--- +title: puppeth +--- + +Puppeth is a tool for quickly spinning up private development networks. + + +[Github repository](https://github.com/ethereum/go-ethereum/tree/master/cmd/puppeth) \ No newline at end of file From 45550ace2c6798c1d3cb0a26702554f2b6e29609 Mon Sep 17 00:00:00 2001 From: Joe Date: Fri, 29 Jul 2022 10:34:01 +0100 Subject: [PATCH 016/432] rm mining.md, update account and CLI pages --- .../docs/fundamentals/Command-Line-Options.md | 12 +- .../fundamentals/Managing-your-accounts.md | 258 ---------- .../docs/fundamentals/account-management.md | 340 +++++++++++++ content/docs/fundamentals/mining.md | 208 -------- content/docs/getting_started/index.md | 452 ------------------ 5 files changed, 351 insertions(+), 919 deletions(-) delete mode 100644 content/docs/fundamentals/Managing-your-accounts.md create mode 100644 content/docs/fundamentals/account-management.md delete mode 100644 content/docs/fundamentals/mining.md delete mode 100644 content/docs/getting_started/index.md diff --git a/content/docs/fundamentals/Command-Line-Options.md b/content/docs/fundamentals/Command-Line-Options.md index 46a29354c7..c0c610948b 100644 --- a/content/docs/fundamentals/Command-Line-Options.md +++ b/content/docs/fundamentals/Command-Line-Options.md @@ -3,8 +3,18 @@ title: Command-line Options sort_key: A --- +Geth is primarily controlled using the command line. Geth is started using the `geth` command. +Geth is stopped by pressing `ctrl-c`. There are then many combinations of commands that configure +precisely how geth will run. These commands are displayed below. The same information can be +obtained at any time from your Geth instance by running + +```sh +geth --help +``` + +## Commands + ``` -$ geth --help NAME: geth - the go-ethereum command line interface diff --git a/content/docs/fundamentals/Managing-your-accounts.md b/content/docs/fundamentals/Managing-your-accounts.md deleted file mode 100644 index 1df734593d..0000000000 --- a/content/docs/fundamentals/Managing-your-accounts.md +++ /dev/null @@ -1,258 +0,0 @@ ---- -title: Account Management -sort_key: C ---- - -It is recommended to use the external key manager Clef for interacting with Geth because it can be run from secure external devices and has additional security benefits such as the ability to sign transactions according to custom rules. Instructions for setting up and using Clef can be found on the [Clef page](../clef/tutorial). However, Geth also has its own built-in account management tools that are more convenient and secure enough for many use-cases. This page will describe how to manage accounts using Geth's built in tools. The command line is considered first and then managing accounts from the Javascript console is considered in a [separate section](#accounts-in-the-javascript-console). - - -## Account command - -Interacting with accounts is achieved using Geth's `account` command: - -``` -geth account [options...] [arguments...] -``` - -The account command enables the user to create new accounts, list existing accounts, import private keys into a new account, update key formats and update the passwords that lock each account. In interactive mode, the user is prompted for passwords in the console when the `account` functions are invoked, whereas in non-interactive mode passwords to unlock accounts are saved to text files whose path is passed to Geth at startup. Non-interactive mode is only intended for use on private networks or known safe environments. - -The `account` subcommands are: - -``` -COMMANDS: - list Print summary of existing accounts - new Create a new account - update Update an existing account - import Import a private key into a new account -``` - -Information about the subcommands can be displayed in the terminal using `geth account --help`. For example, for the `list` subcommand: - -``` -$ geth account list --help -list [command options] [arguments...] - -Print a short summary of all accounts - -OPTIONS: - --datadir "/home/.ethereum" Data directory for the databases and keystore - --keystore Directory for the keystore (default = inside the datadir) -``` - - -## Creating new accounts - -New accounts can be created using `account new`. This generates a new key pair and adds them to the `keystore` directory in the `datadir`. To create a new account in the default data directory: - - -```shell -$ geth account new -``` - -This returns the following to the terminal: - -```terminal -Your new account is locked with a password. Please give a password. Do not forget this password. -Passphrase: -Repeat Passphrase: -Address: {168bc315a2ee09042d83d7c5811b533620531f67} -``` - -It is critical to backup the account password safely and securely as it cannot be retrieved or reset. - -{% include note.html content=" If the password provided on account creation is lost or forgotten, there is no way to retrive it and the account will simply stay locked forever. The password MUST be backed up safely and securely! **IT IS CRITICAL TO BACKUP THE KEYSTORE AND REMEMBER PASSWORDS**" %} - -The newly generated key files can be viewed in `/keystore/`. The file naming format is `UTC----
` where `date` is the date and time of key creation formatted according to [UTC 8601](https://www.iso.org/iso-8601-date-and-time-format.html) with zero time offset and seconds precise to eight decimal places. `address` is the 40 hexadecimal characters that make up the account address without a leading `0x`, for example: - -`UTC--2022-05-19T12-34-36.47413510Z--0b85e5a13e118466159b1e1b6a4234e5f9f784bb` - - -## Listing Accounts - -Listing all existing accounts is achieved using the `account list` command. If the keystore is located anywhere other than the default location its path should be included with the `keystore` flag. For example, if the datadir is `some-dir`: - -```shell -geth account list --keystore some-dir/keystore -``` - -This command returns the following to the terminal for a keystore with two files: - -```terminal -Account 0: {5afdd78bdacb56ab1dad28741ea2a0e47fe41331} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-27.437847599Z--5afdd78bdacb56ab1dad28741ea2a0e47fe41331 -Account 1: {9acb9ff906641a434803efb474c96a837756287f} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-52.180688336Z--9acb9ff906641a434803efb474c96a837756287f -``` - -The ordering of accounts when they are listed is lexicographic, but is effectively chronological based on time of creation due to the timestamp in the file name. It is safe to transfer the entire `keystore` directory or individual key files between Ethereum nodes. This is important because when accounts are added from other nodes the order of accounts in the keystore may change. It is therefore important not to rely on account indexes in scripts or code snippets. - - -## Importing accounts - -### Import a keyfile - -It is also possible to create a new account by importing a private key. For example, a user might already have some ether at an address they created using a browser wallet and now wish to use a new Geth node to interact with their funds. In this case, the private key can be exported from the browser wallet and imported into Geth. Geth requires the private key to be stored as a file which contains the private key as unencrypted canonical elliptic curve bytes encoded into hex (i.e. plain text key without leading 0x). The new account is then saved in encrypted format, protected by a passphrase the user provides on request. As always, this passphrase must be securely and safely backed up - there is no way to retrieve or reset it if it is forgotten! - -```shell -$ geth account import --datadir /some-dir ./keyfile -``` - -The following information will be displayed in the terminal, indicating a successful import: - -```terminal -Please enter a passphrase now. -Passphrase: -Repeat Passphrase: -Address: {7f444580bfef4b9bc7e14eb7fb2a029336b07c9d} -``` - -This import/export process is not necessary for transferring accounts between Geth instances because the key files can simply be copied directly from one keystore to another. - -It is also possible to import an account in non-interactive mode by saving the account password as plaintext in a `.txt` file and passing its path with the `--password` flag on startup. - -```shell -geth account import --password path/password.txt path/keyfile -``` -In this case, it is important to ensure the password file is not readable by anyone but the intended user. This can be achieved by changing the file permissions. On Linux, the following commands update the file permissions so only the current user has access: - -```shell -chmod 700 /path/to/password -cat > /path/to/password - -``` - -### Import a presale wallet - -Assuming the password is known, importing a presale wallet is very easy. The `wallet import` commands are used, passing the path to the wallet. - -```shell -geth wallet import /path/presale.wallet -``` - - -## Updating accounts - -The `account update` subcommand is used to unlock an account and migrate it to the newest format. This is useful for accounts that may have been created in a format that has since been deprecated. The same command can be used to update the account password. The current password and account address are needed in order to update the account, as follows: - -```shell -geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b -``` - -The following will be returned to the terminal: - -```terminal -Unlocking account a94f5374fce5edbc8e2a8697c15331677e6ebf0b | Attempt 1/3 -Passphrase: -0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b -Account 'a94f5374fce5edbc8e2a8697c15331677e6ebf0b' unlocked. -Please give a new password. Do not forget this password. -Passphrase: -Repeat Passphrase: -0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b -``` - -Alternatively, in non-interactive mode the path to a password file containing the account password in unencrypted plaintext can be passed with the `--password` flag: - -```shell -geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b --password path/password.txt -``` - -Updating the account replaces the original file with a new one - this means the original file is no longer available after it has been updated. - - -## Unlocking accounts - -In Geth, accounts are locked unless they are explicitly unlocked. If an account is intended to be used by apps connecting to Geth via RPC then it can be unlocked in non-interactive mode by passing the `--unlock` flag with a comma-separated list of account addresses (or keystore indexes) to unlock. This unlocks the accounts for one session only. Including the `--unlock` flag without any account addresses defaults to unlocking the first account in the keystore. - -```shell -geth --unlock 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b -``` - -Geth will start and prompt the user to input the account password in the terminal. Alternatively, the user can provide a password as a text file and pass its path to `--password`: - -```shell -geth --unlock 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b --password path/password.txt -``` - -{% include note.html content=" By default, account **unlocking is forbidden when HTTP or Websocket access is enabled** (i.e. by passing `--http` or `ws` flag). This is because an attacker that manages to access the node via the externally-exposed HTTP/WS port can then control the unlocked account. It is possible to force account unlock by including the `--allow-insecure-unlock` flag but this is unsafe and **not recommended** except for expert users that completely understand how it can be used safely. This is not a hypothetical risk: **there are bots that continually scan for http-enabled Ethereum nodes to attack**" %} - - -## Accounts in the Javascript console - -Account management can also be achieved in the Javascript console attached to a running Geth instance. Assuming Geth is already running, in a new terminal attach a Javascript console using the `geth.ipc` file. This file can be found in the data directory. Assuming the data directory is named `data` the console can be started using: - -```shell -geth attach data/geth.ipc -``` - -### New accounts - -New accounts can be generated using the Javascript console using `personal.newAccount()`. A new password is requested in the console and successful account creation is confirmed by the new account address being displayed. - -```shell -personal.newAccount() -``` - -Accounts can also be created by importing private keys directly in the Javascript console. The private key is passed as an unencrypted hex-encoded string to `personal.importRawKey()` along with a passphrase that will be used to encrypt the key. A new key file will be generated from the private key and saved to the keystore. - -```shell -personal.importRawKey("hexstringkey", "password") -``` - -### Listing accounts - -The `accounts` function in the `eth` namespace can be used to list the accounts that currently exist in the keystore.: - -``` -eth.accounts -``` - -or alternatively the same is achieved using: - -``` -personal.listAccounts -``` - -This returns an array of account addresses to the terminal. - - -### Unlocking accounts - -To unlock an account, the `personal.unlockAccount` function can be used: - -``` -personal.unlockAccount(eth.accounts[1]) -``` - -The account passphrase is requested: - -```terminal -Unlock account 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b -Passphrase: -true -``` - -This unlocked account can now be used to sign and send transactions. it is also possible to pass the passphrase as an argument to `personal.unlockAccount()` along with a duration after which the accout will automatically re-lock (in seconds), as follows: - -```shell -personal.unlockAccount(eth.accounts[1], "passphrase", 60) -``` - -This unlocks the account for 60 seconds. However, this is not recommended because the command history is logged by the Javascript console which could compromise the security of the account. An unlocked account can be manually re-locked using `personal.lockAccount()`, passing the address as the sole argument. - - -### Unlocking for transactions - -Sending transactions from the Javascript console also requires the sender account to be unlocked. There are two ways to send transactions: `eth.sendTransaction` and `personal.sendTransaction`. The difference between these two functions is that `eth.sendTransaction` requires the account to be unlocked globally, at the node level (i.e., by unlocking it on the command line at the start of the Geth session). On the other hand, `personal.sendTransaction` takes a passphrase argument that unlocks the account temporarily in order to sign the transaction, then locks it again immediately afterwards. For example, to send 5 ether between two accounts in the keystore: - -```shell -var tx = {from: eth.accounts[1], to: eth.accounts[2], value: web3.toWei(5, "ether")} - -# this requires global account unlock for eth.accounts[1] -eth.sendTransaction(tx) - -# this unlocks eth.accounts[1] temporarily just to send the transaction -personal.sendTransaction(tx, "password") -``` - -## Summary - -This page has demonstrated how to use Geth's built-in account management tools, both on the command line and in the Javascript console. Accounts are stored encrypted by a password. It is critical that the account passwords and the keystore directory are safely and securely backed up. diff --git a/content/docs/fundamentals/account-management.md b/content/docs/fundamentals/account-management.md new file mode 100644 index 0000000000..b38ee22293 --- /dev/null +++ b/content/docs/fundamentals/account-management.md @@ -0,0 +1,340 @@ +--- +title: Account Management +sort_key: C +--- + +The recommended practise for managing accounts in Geth is to use Clef. However, Geth also has its own, convenient +account management tools. Eventually, these built in tools will be deprecated in favour of using Clef as the +default account manager. This page describes account management using Geth's built-in tools. It is recommended to +also visit the following pages that explain how to use Clef. + +- [Getting started with Clef](/content/docs/getting_started/getting-started-with-clef.md) +- [Introduction to Clef](/content/docs/tools/Clef/Introduction.md) +- [Clef tutorial](/content/docs/tools/Clef/Tutorial.md) + + +## Account command + +Geth's `account` command is used to interact with accounts: + +``` +geth account [options...] [arguments...] +``` + +The account command enables the user to create new accounts, list existing +accounts, import private keys into a new account, update key formats and update +the passwords that lock each account. In interactive mode, the user is prompted +for passwords in the console when the `account` functions are invoked, whereas +in non-interactive mode passwords to unlock accounts are saved to text files +whose path is passed to Geth at startup. Non-interactive mode is only intended +for use on private networks or known safe environments. + +The `account` subcommands are: + +``` +COMMANDS: + list Print summary of existing accounts + new Create a new account + update Update an existing account + import Import a private key into a new account +``` + +Information about the subcommands can be displayed in the terminal using +`geth account --help`. For example, for the `list` subcommand: + +``` +$ geth account list --help +list [command options] [arguments...] + +Print a short summary of all accounts + +OPTIONS: + --datadir "/home/.ethereum" Data directory for the databases and keystore + --keystore Directory for the keystore (default = inside the datadir) +``` + + +## Creating new accounts + +New accounts can be created using `account new`. This generates a new key +pair and adds them to the `keystore` directory in the `datadir`. To +create a new account in the default data directory: + + +```shell +$ geth account new +``` + +This returns the following to the terminal: + +```terminal +Your new account is locked with a password. Please give a password. Do not forget this password. +Passphrase: +Repeat Passphrase: +Address: {168bc315a2ee09042d83d7c5811b533620531f67} +``` + +It is critical to backup the account password safely and securely as it cannot +be retrieved or reset. + +{% include note.html content=" If the password provided on account creation is lost +or forgotten, there is no way to retrive it and the account will simply stay locked +forever. The password MUST be backed up safely and securely! +**IT IS CRITICAL TO BACKUP THE KEYSTORE AND REMEMBER PASSWORDS**" %} + +The newly generated key files can be viewed in `/keystore/`. The file naming +format is `UTC----
` where `date` is the date and time of key creation +formatted according to [UTC 8601](https://www.iso.org/iso-8601-date-and-time-format.html) +with zero time offset and seconds precise to eight decimal places. `address` is the 40 +hexadecimal characters that make up the account address without a leading `0x`, for example: + +`UTC--2022-05-19T12-34-36.47413510Z--0b85e5a13e118466159b1e1b6a4234e5f9f784bb` + + +## Listing Accounts + +Listing all existing accounts is achieved using the `account list` command. If the +keystore is located anywhere other than the default location its path should be +included with the `keystore` flag. For example, if the datadir is `some-dir`: + +```shell +geth account list --keystore some-dir/keystore +``` + +This command returns the following to the terminal for a keystore with two files: + +```terminal +Account 0: {5afdd78bdacb56ab1dad28741ea2a0e47fe41331} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-27.437847599Z--5afdd78bdacb56ab1dad28741ea2a0e47fe41331 +Account 1: {9acb9ff906641a434803efb474c96a837756287f} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-52.180688336Z--9acb9ff906641a434803efb474c96a837756287f +``` + +The ordering of accounts when they are listed is lexicographic, but is effectively +chronological based on time of creation due to the timestamp in the file name. It is +safe to transfer the entire `keystore` directory or individual key files between +Ethereum nodes. This is important because when accounts are added from other nodes +the order of accounts in the keystore may change. It is therefore important not to +rely on account indexes in scripts or code snippets. + + +## Importing accounts + +### Import a keyfile + +It is also possible to create a new account by importing a private key. For example, +a user might already have some ether at an address they created using a browser wallet +and now wish to use a new Geth node to interact with their funds. In this case, the +private key can be exported from the browser wallet and imported into Geth. Geth requires +the private key to be stored as a file which contains the private key as unencrypted +canonical elliptic curve bytes encoded into hex (i.e. plain text key without leading 0x). +The new account is then saved in encrypted format, protected by a passphrase the user +provides on request. As always, this passphrase must be securely and safely backed +up - there is no way to retrieve or reset it if it is forgotten! + +```shell +$ geth account import --datadir /some-dir ./keyfile +``` + +The following information will be displayed in the terminal, indicating a successful import: + +```terminal +Please enter a passphrase now. +Passphrase: +Repeat Passphrase: +Address: {7f444580bfef4b9bc7e14eb7fb2a029336b07c9d} +``` + +This import/export process is not necessary for transferring accounts between Geth +instances because the key files can simply be copied directly from one keystore to another. + +It is also possible to import an account in non-interactive mode by saving the account +password as plaintext in a `.txt` file and passing its path with the `--password` flag +on startup. + +```shell +geth account import --password path/password.txt path/keyfile +``` +In this case, it is important to ensure the password file is not readable by anyone but +the intended user. This can be achieved by changing the file permissions. On Linux, the +following commands update the file permissions so only the current user has access: + +```shell +chmod 700 /path/to/password +cat > /path/to/password + +``` + +### Import a presale wallet + +Assuming the password is known, importing a presale wallet is very easy. The `wallet import` +commands are used, passing the path to the wallet. + +```shell +geth wallet import /path/presale.wallet +``` + + +## Updating accounts + +The `account update` subcommand is used to unlock an account and migrate it to the newest +format. This is useful for accounts that may have been created in a format that has since +been deprecated. The same command can be used to update the account password. The current +password and account address are needed in order to update the account, as follows: + +```shell +geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b +``` + +The following will be returned to the terminal: + +```terminal +Unlocking account a94f5374fce5edbc8e2a8697c15331677e6ebf0b | Attempt 1/3 +Passphrase: +0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b +Account 'a94f5374fce5edbc8e2a8697c15331677e6ebf0b' unlocked. +Please give a new password. Do not forget this password. +Passphrase: +Repeat Passphrase: +0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b +``` + +Alternatively, in non-interactive mode the path to a password file containing the account +password in unencrypted plaintext can be passed with the `--password` flag: + +```shell +geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b --password path/password.txt +``` + +Updating the account replaces the original file with a new one - this means the original +file is no longer available after it has been updated. + + +## Unlocking accounts + +In Geth, accounts are locked unless they are explicitly unlocked. If an account is intended +to be used by apps connecting to Geth via RPC then it can be unlocked in non-interactive +mode by passing the `--unlock` flag with a comma-separated list of account addresses +(or keystore indexes) to unlock. This unlocks the accounts for one session only. Including +the `--unlock` flag without any account addresses defaults to unlocking the first account +in the keystore. + +```shell +geth --unlock 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b +``` + +Geth will start and prompt the user to input the account password in the terminal. +Alternatively, the user can provide a password as a text file and pass its path to `--password`: + +```shell +geth --unlock 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b --password path/password.txt +``` + +{% include note.html content=" By default, +account **unlocking is forbidden when HTTP or Websocket access is enabled** (i.e. by +passing `--http` or `ws` flag). This is because an attacker that manages to access +the node via the externally-exposed HTTP/WS port can then control the unlocked account. +It is possible to force account unlock by including the `--allow-insecure-unlock` +flag but this is unsafe and **not recommended** except for expert users that completely +understand how it can be used safely. This is not a hypothetical risk: +**there are bots that continually scan for http-enabled Ethereum nodes to attack**" %} + + +## Accounts in the Javascript console + +Account management can also be achieved in the Javascript console attached to a +running Geth instance. Assuming Geth is already running, in a new terminal attach +a Javascript console using the `geth.ipc` file. This file can be found in the data +directory. Assuming the data directory is named `data` the console can be started using: + +```shell +geth attach data/geth.ipc +``` + +### New accounts + +New accounts can be generated using the Javascript console using `personal.newAccount()`. +A new password is requested in the console and successful account creation is confirmed +by the new account address being displayed. + +```shell +personal.newAccount() +``` + +Accounts can also be created by importing private keys directly in the Javascript console. +The private key is passed as an unencrypted hex-encoded string to `personal.importRawKey()` +along with a passphrase that will be used to encrypt the key. A new key file will be +generated from the private key and saved to the keystore. + +```shell +personal.importRawKey("hexstringkey", "password") +``` + +### Listing accounts + +The `accounts` function in the `eth` namespace can be used to list the accounts that +currently exist in the keystore.: + +``` +eth.accounts +``` +or alternatively the same is achieved using: + +``` +personal.listAccounts +``` +This returns an array of account addresses to the terminal. + +### Unlocking accounts + +To unlock an account, the `personal.unlockAccount` function can be used: + +``` +personal.unlockAccount(eth.accounts[1]) +``` + +The account passphrase is requested: + +```terminal +Unlock account 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b +Passphrase: +true +``` + +This unlocked account can now be used to sign and send transactions. it is also possible to +pass the passphrase as an argument to `personal.unlockAccount()` along with a duration +after which the accout will automatically re-lock (in seconds), as follows: + +```shell +personal.unlockAccount(eth.accounts[1], "passphrase", 60) +``` + +This unlocks the account for 60 seconds. However, this is not recommended because the +command history is logged by the Javascript console which could compromise the security +of the account. An unlocked account can be manually re-locked using `personal.lockAccount()`, +passing the address as the sole argument. + + +### Unlocking for transactions + +Sending transactions from the Javascript console also requires the sender account to be +unlocked. There are two ways to send transactions: `eth.sendTransaction` and `personal.sendTransaction`. +The difference between these two functions is that `eth.sendTransaction` requires the account to be +unlocked globally, at the node level (i.e., by unlocking it on the command line at the start of +the Geth session). On the other hand, `personal.sendTransaction` takes a passphrase argument +that unlocks the account temporarily in order to sign the transaction, then locks it again +immediately afterwards. For example, to send 5 ether between two accounts in the keystore: + +```shell +var tx = {from: eth.accounts[1], to: eth.accounts[2], value: web3.toWei(5, "ether")} + +# this requires global account unlock for eth.accounts[1] +eth.sendTransaction(tx) + +# this unlocks eth.accounts[1] temporarily just to send the transaction +personal.sendTransaction(tx, "password") +``` + +## Summary + +This page has demonstrated how to use Geth's built-in account management tools, both on the +command line and in the Javascript console. Accounts are stored encrypted by a password. +It is critical that the account passwords and the keystore directory are safely and securely backed up. diff --git a/content/docs/fundamentals/mining.md b/content/docs/fundamentals/mining.md deleted file mode 100644 index d2d91f9cf7..0000000000 --- a/content/docs/fundamentals/mining.md +++ /dev/null @@ -1,208 +0,0 @@ ---- -title: Mining -sort_key: F ---- - - -The Ethereum blockchain grows when nodes add blocks and distribute them to their peers. Nodes -that add blocks are rewarded with ether payouts. This creates competition for the right to add -blocks to the blockchain. This means some mechanism must exist to select a single block for each -position in the blockchain that all nodes can agree upon. The mechanism that currently achieves -this for Ethereum is "proof-of-work" (PoW). This involved computing a certain value that can -only be calculated using repeated random guesses. Only if a node can demonstrate that they have -calculated this value, and therefore expended energy, will their block be accepted by other nodes. -This secures the network. This process of creating blocks and securing them using proof-of-work -is known as "mining". - -Much more information about mining, including details about the specific algorithm ("Ethash") used by -Ethereum nodes is available on -[ethereum.org](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/mining). - - -## Mining and the Merge - -[The Merge](https://ethereum.org/en/upgrades/merge) is an upcoming upgrade to Ethereum that -will swap the existing PoW for a [proof-of-stake (PoS)](https://ethereum.org/en/developers/docs/consensus-mechanisms/pos) consensus mechanism. This marks the end of mining on Ethereum. Instead, nodes can [stake ether](https://ethereum.org/en/staking/solo/#get-started-on-the-staking-launchpad) directly and earn ether rewards by running [validators](https://ethereum.org/en/developers/docs/consensus-mechanisms/pos/#validators). The merge is expected to happen in the second half of 2022. Until then, Ethereum will continue to be secured by PoW miners. It is no longer recommended to purchase new hardware to participate in Ethereum mining because the chances of returning a profit before The Merge are low. - - -## CPU vs GPU - -Participating in Ethereum's PoW mining requires running an algorithm called -["Ethash"](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash). Geth includes -a CPU miner which runs Ethash within the Geth process. This might be useful for mining on some testnets. However, this is CPU mining is not viable on Ethereum Mainnet because CPU miners are easily out-competed by more efficient GPU miners. GPU mining is the recommended method for mining real ether on Ethereum Mainnet, but it is not part of the standard Geth installation. To mine using GPUs an additional piece of third-paty software is required. The recommended GPU mining software is [Ethminer](https://github.com/ethereum-mining/ethminer). - -Regardless of the mining method, the blockchain must be fully synced before mining is started, otherwise the miner will build on an incorrect chain, invalidating the block rewards. - - -## GPU Mining - -### Installing Ethminer - -The Ethminer software can be installed from a downloaded binary or built from source. The relevant downloads -and installation instructions are available from the [Ethminer Github](https://github.com/ethereum-mining/ethminer/#build). Standalone executables are available for Linux, macOS and Windows. - -### Using Ethminer with Geth - - -An account to receive block rewards must first be defined. The address of the account is all that is required to start mining - the mining rewards will be credited to that address. This can be an existing address or one that is newly created by Geth. More detailed instructions on creating and importing accounts are available on the [Account Management](/docs/interface/managing-your-accounts) page. - -The account address can be provided to `--mining.etherbase` when Geth is started. This instructs Geth to direct any block rewards to this address. Once started, Geth will sync the blockchain. If Geth has not connected to this network before, or if the data directory has been deleted, this can take several days. Also, enable HTTP traffic with the `--http` command. - -```shell -geth --http --miner.etherbase 0xC95767AC46EA2A9162F0734651d6cF17e5BfcF10 -``` - -The progress of the blockchain syncing can be monitored by attaching a JavaScript console in another terminal. More detailed information about the console can be found on the [Javascript Console](/docs/interface/javascript-console) page. To attach and open a console: - -```shell -geth attach http://127.0.0.1:8545 -``` - -Then in the console, to check the sync progress: - -```shell -eth.syncing -``` - -If the sync is progressing correctly the output will look similar to the following: - -```terminal -{ - currentBlock: 13891665, - healedBytecodeBytes: 0, - healedBytecodes: 0, - healedTrienodeBytes: 0, - healedTrienodes: 0, - healingBytecode: 0, - healingTrienodes: 0, - highestBlock: 14640000, - startingBlock: 13891665, - syncedAccountBytes: 0, - syncedAccounts: 0, - syncedBytecodeBytes: 0, - syncedBytecodes: 0, - syncedStorage: 0, - syncedStorageBytes: 0 -} -``` - -Once the blockchain is sync'd, mining can begin. In order to begin mining, Ethminer must be run and connected to Geth in a new terminal. OpenCL can be used for a wide range of GPUs, CUDA can be used specifically for Nvidia GPUs: - -```shell -#OpenCL -ethminer -v 9 -G -P http://127.0.0.1:8545 -``` - -```shell -#CUDA -ethminer -v -U -P http://127.0.0.1:8545 -``` - -Ethminer communicates with Geth on port 8545 (Geth's default RPC port) but this can be changed by providing a custom -port to the `http.port` command. The corresponding port must also be configured in Ethminer by providing -`-P http://127.0.0.1:`. This is necessary when multiple instances of Geth/Ethminer will coexist on the same machine. - -If using OpenCL and the default for `ethminer` does not work, specifying the device using the `--opencl--device X` command is a common fix. `X` is an integer `1`, `2`, `3` etc. The Ethminer `-M` (benchmark) command should display something that looks like: - -```terminal -Benchmarking on platform: { "platform": "NVIDIA CUDA", "device": "GeForce GTX 750 Ti", "version": "OpenCL 1.1 CUDA" } - -Benchmarking on platform: { "platform": "Apple", "device": "Intel(R) Xeon(R) CPU E5-1620 v2 @ 3.70GHz", "version": "OpenCL 1.2 " } -``` - -Note that the Geth command `miner.hashrate` only works for CPU mining - it always reports zero for GPU mining. To check the GPU mining hashrate, check the logs `ethminer` displays to its terminal. More verbose logs can be configured using `-v` and a value between 0-9. - -The Ethash algorithm is [memory-hard](https://crypto.stackexchange.com/questions/84002/memory-hard-vs-memory-bound-functions) and requires a large dataset to be loaded into memory. Each GPU requires 4-5 GB of RAM. The error message `Error GPU mining. GPU memory fragmentation?` indicates that there is insufficient memory available. - - -## CPU Mining with Geth - -When Geth is started is is not mining by default. Unless it is specifically instructed to mine, it acts only as a node, not a miner. Geth starts as a (CPU) miner if the `--mine` flag is provided. The `--miner.threads` parameter can -be used to set the number parallel mining threads (defaulting to the total number of processor cores). - -```shell -geth --mine --miner.threads=4 -``` - -CPU mining can also be started and stopped at runtime using the [console](/docs/interface/javascript-console). The command `miner.start` takes an optional parameter for the number of miner threads. - -```js -miner.start(8) - true -miner.stop() - true -``` - -Note that mining for real ether only makes sense if you are in sync with the network (since you mine on top of the consensus block). Therefore the Ethereum blockchain downloader/synchroniser will delay mining until syncing is complete, and after that mining automatically starts unless you cancel your intention with `miner.stop()`. - -Like with GPU mining, an etherbase account must be set. This defaults to the primary account in the keystore but can be set to an alternative address using the `--miner.etherbase` command: - -```shell -geth --miner.etherbase '0xC95767AC46EA2A9162F0734651d6cF17e5BfcF10' --mine -``` -If there is no account available the miner will not start. The Javascript console can also be used to reset the etherbase account at runtime: - -```shell -miner.setEtherbase(eth.accounts[2]) -``` - -Note that your etherbase does not need to be an address of a local account, it just has to be set to an existing one. - -There is an option to add extra data (32 bytes only) to the mined blocks. By convention this is interpreted as a unicode string, so it can be used to add a short vanity tag using `miner.setExtra` in the Javascript console. - -```shell -miner.setExtra("ΞTHΞЯSPHΞЯΞ") -``` - -The console can also be used to check the current hashrate in units H/s (Hash operations per second): - -```shell -eth.hashrate - 712000 -``` - -After some blocks have been mined, the etherbase account balance with be >0. Assuming the etherbase is a local account: - -```shell -eth.getBalance(eth.coinbase).toNumber(); - '34698870000000' -``` - -It is also possible to check which blocks were mined by a particular miner (address) using the following code snippet in the Javascript console: - -```js -function minedBlocks(lastn, addr) { - addrs = []; - if (!addr) { - addr = eth.coinbase - } - limit = eth.blockNumber - lastn - for (i = eth.blockNumber; i >= limit; i--) { - if (eth.getBlock(i).miner == addr) { - addrs.push(i) - } - } - return addrs -} - -// scans the last 1000 blocks and returns the blocknumbers of blocks mined by your coinbase -// (more precisely blocks the mining reward for which is sent to your coinbase). -minedBlocks(1000, eth.coinbase) -[352708, 352655, 352559] - -``` - -The etherbase balance will fluctuate because quite often a mined block may be re-org'd out -of the canonical chain. This means that when the local Geth node includes the mined block -in its own local blockchain the account balance appears higher because the block rewards are -applied. When the node switches to another version of the chain due to information received -from peers, that block may not be included and the block rewards are not applied. - -The logs show locally mined blocks confirmed after 5 blocks. - - -## Summary - -The page describes how to start Geth as a mining node. Mining can be done on CPUs - in which case Geth's built-in -miner can be used - or on GPUs which requires third party software. GPUs are required to mine real ether on Ethereum -Mainnet. It is important to note that Ethereum will swap its consensus mechanism from PoW to PoS in the second half of 2022. This swap, known as "The Merge" will end mining on Ethereum. diff --git a/content/docs/getting_started/index.md b/content/docs/getting_started/index.md deleted file mode 100644 index 448e8eb5aa..0000000000 --- a/content/docs/getting_started/index.md +++ /dev/null @@ -1,452 +0,0 @@ ---- -title: Getting Started with Geth -permalink: docs/getting-started -sort_key: A ---- - -This page explains how to set up Geth and execute some basic tasks using the command line tools. -In order to use Geth, the software must first be installed. There are several ways Geth can be -installed depending on the operating system and the user's choice of installation method, for -example using a package manager, container or building from source. Instructions for installing -Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. -The tutorial on this page assumes Geth and the associated developer tools have been installed successfully. - -This page provides step-by-step instructions covering the fundamentals of using Geth. This includes -generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. -It is considered best-practice to use [Clef](/docs/clef/Introduction) for account management - this -is explained in the [Geth with Clef](/docs/getting-started/geth_with_clef) tutorial. In this -introductory tutorial, Geth's built-in account management tools are used instead. - -{:toc} -- this will be removed by the toc - -## Prerequisites - -In order to get the most value from the tutorials on this page, the following skills are -necessary: - -- Experience using the command line -- Basic knowledge about Ethereum and testnets -- Basic knowledge about HTTP and JavaScript - -Users that need to revisit these fundamentals can find helpful resources relating to the command -line [here][cli], Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), -http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and -Javascript [here](https://www.javascript.com/learn). - -{% include note.html content="If Geth was installed from source on Linux, `make` saves the -binaries for Geth and the associated tools in `/build/bin`. To run these programs it is -convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) -from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to -execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not -moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) -or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} - -## Background - -Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. -Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being -managed by a central server. Nodes compete to generate new blocks of transactions to send to its peers -because they are rewarded for doing so in Ethereum's native token, ether (ETH). On receiving a new block, -each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called -a "blockchain". The information provided in each block is used by Geth to update its "state" - the ether -balance of each account on Ethereum. There are two types of account: externally-owned accounts (EOAs) and -contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts -that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, -where the public key is used to derive a unique address for the user and the private key is used to protect -the account and securely sign messages. Therefore, in order to use Ethereum, it is first necessary to generate -an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it -with ether and sending some to another address. - -Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). - - -## Step 1: Generating accounts - -To generate a new account in Geth: - -```sh -geth account new -``` - -This returns a prompt for a password. Once provided, a new account will be created and added to the -default keystore (`/datadir/keystore`). A custom keystore can also be provided by passing `--keystore `. -In this tutorial the keys will be stored in a new data directory `geth-tutorial`. Create that diredctory, then run: - -```sh -geth account new --keystore geth-tutorial/keystore -``` -The following will be returned to the console, confirming the new account has been created and -added to the keystore. - -```terminal -Your new account is locked with a password. Please give a password. Do not forget this password. -Password: -Repeat password: - -Your new key was generated - -Public address of the key: 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC -Path of the secret key file: /home/go-ethereum/geth-tutorial/keystore/UTC--2022-07-25T08-27-59.433905560Z--ca57F3b40B42FCce3c37B8D18aDBca5260ca72EC - -- You can share your public address with anyone. Others need it to interact with you. -- You must NEVER share the secret key with anyone! The key controls access to your funds! -- You must BACKUP your key file! Without the key, it's impossible to access account funds! -- You must REMEMBER your password! Without the password, it's impossible to decrypt the key! -``` - -It is important to save the account address and the password somewhere secure. They will be used -again later in this tutorial. Please note that the account address shown in the code snippets -above and later in this tutorials are examples - those generated by followers of this tutorial -will be different. The account generated above can be used as the main account throughout the -remainder of this tutorial. However in order to demonstrate transactions between accounts it is -also necessary to have a second account. A second account can be added to the same keystore by -precisely repeating the previous steps, providing the same password. - -Notice that the path to the secret key includes a long filename that starts `UTC--`. This is the -name of the file that contains the keys for the new account. It is **extremely important** that -this file stays secure because it contains the secret key used to control access to any funds -associated with the account. The file should be backed up securely along with the password -used to encrypt it. If the file or the password is lost, then so is access to the funds in -the account. If someone else gains access to the keyfile and password, they have access to any -assets in the account. - -## Step 2: Start Geth - -Geth is the Ethereum client that will connect the computer to the Ethereum network. -In this tutorial the network is Goerli, an Ethereum testnet. Testnets are used to test -Ethereum client software and smart contracts in an environment where no real-world value -is at risk. To start Geth, run the Geth executable file passing argument that define the -data directory (where Geth should save blockchain data), the network ID and the sync mode. -For this tutorial, snap sync is recommended -(see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). - -The following command should be run in the terminal: - -```shell -geth --datadir geth-tutorial --goerli --syncmode snap -``` -Running the above command starts Geth. The terminal should rapidly fill with status updates that look like the following: - -```terminal -INFO [02-10|13:59:06.649] Starting Geth on goerli testnet... -INFO [02-10|13:59:06.649] Dropping default light client cache provided=1024 updated=128 -INFO [02-10|13:59:06.652] Maximum peer count ETH=50 LES=0 total=50 -INFO [02-10|13:59:06.660] Set global gas cap cap=50,000,000 -INFO [02-10|13:59:06.661] Allocated cache and file handles database=/.../geth-tutorial/geth/chaindata cache=64.00MiB handles=5120 -INFO [02-10|13:59:06.855] Persisted trie from memory database nodes=361 size=51.17KiB time="643.54µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B -INFO [02-10|13:59:06.855] Initialised chain configuration config="{ChainID: 5 Homestead: 0 DAO: nil DAOSupport: true EIP150: 0 EIP155: 0 EIP158: 0 Byzantium: 0 Constantinople: 0 Petersburg: 0 Istanbul: 1561651, Muir Glacier: nil, Berlin: 4460644, London: 5062605, Arrow Glacier: nil, MergeFork: nil, Engine: clique}" -INFO [02-10|13:59:06.862] Added trusted checkpoint block=5,799,935 hash=2de018..c32427 -INFO [02-10|13:59:06.863] Loaded most recent local header number=6,340,934 hash=483cf5..858315 td=9,321,576 age=2d9h29m -INFO [02-10|13:59:06.867] Configured checkpoint oracle address=0x18CA0E045F0D772a851BC7e48357Bcaab0a0795D signers=5 threshold=2 -INFO [02-10|13:59:06.867] Gasprice oracle is ignoring threshold set threshold=2 -WARN [02-10|13:59:06.869] Unclean shutdown detected booted=2022-02-08T04:25:08+0100 age=2d9h33m -INFO [02-10|13:59:06.870] Starting peer-to-peer node instance=Geth/v1.10.15-stable/darwin-amd64/go1.17.5 -INFO [02-10|13:59:06.995] New local node record seq=1,644,272,735,880 id=d4ffcd252d322a89 ip=127.0.0.1 udp=30303 tcp=30303 -INFO [02-10|13:59:06.996] Started P2P networking self=enode://4b80ebd341b5308f7a6b61d91aa0ea31bd5fc9e0a6a5483e59fd4ea84e0646b13ecd289e31e00821ccedece0bf4b9189c474371af7393093138f546ac23ef93e@127.0.0.1:30303 -INFO [02-10|13:59:06.997] IPC endpoint opened url=/.../geth-tutorial/geth.ipc -WARN [02-10|13:59:06.998] Light client mode is an experimental feature -INFO [02-10|13:59:08.793] Block synchronisation started -``` - -This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers -it can request block headers from them, starting at the genesis block for the Goerli blockchain. -Geth continues to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. -This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in the -terminal with the following syntax: - -```terminal - -INFO [04-29][15:54:09.238] Looking for peers peercount=2 tried=0 static=0 -INFO [04-29][15:54:19.393] Imported new block headers count=2 elapsed=1.127ms number=996288 hash=09f1e3..718c47 age=13h9m5s -INFO [04-29][15:54:19:656] Imported new block receipts count=698 elapsed=4.464ms number=994566 hash=56dc44..007c93 age=13h9m9s - -``` - -These logs indicate that Geth is running as expected. - -If there is no error message reported to the terminal, everything is OK. Geth must be running in -order for a user to interact with the Ethereum network. If this terminal is closed down then Geth -must be restarted again. Geth can be started and stopped easily, but it must be running for any -interaction with Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. -To start it again, run the previous command `geth --datadir ... ..`. - -{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished -you can't use the node to transfer funds. You can also try doing a [light sync](interface/les) -which will be much quicker but depends on light servers being available to serve your node the data it needs." %} - -## Step 3: Get Testnet Ether - -In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, -ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; 2) -receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, -having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it -can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether -to their account. - -The address generated by `geth account new` can be pasted into the Paradigm Multifaucet faucet -[here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of -personhood. The faucets adds ether to the given address on multiple testnets simultaneously, -including Goerli. In the next steps Geth will be used to check that the ether has been sent to -the given address and send some of it to the second address created earlier. - - -## Step 4: Interact with Geth - -For interacting with the blockchain, Geth provides JSON-RPC APIs. -[JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific tasks -by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. -RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded -instructions from locations outside of those managed by Geth. It is possible to interact with Geth -by sending these JSON encoded instructions directly to Geth using tools such as Curl. However, -this is somewhat user-unfriendly and error-prone, especially for more complex instructions. For this -reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly -interface for interacting with Geth. One of the most widely used is Web3.js. - -Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in -one terminal, a Javascript environment can be opened in another allowing the user to interact with -Geth using Web3.js. There are three transport protocols that can be used to connect the Javascript -environment to Geth: - -- IPC (Inter-Process Communication): Provides unrestricted access to all APIs, but only works when the -- console is run on the same host as the Geth node. - -- HTTP: By default provides access to the `eth`, `web3` and `net` method namespaces. - -- Websocket: By default provides access to the `eth`, `web3` and `net` method namespaces. - -This tutorial will use the IPC option. To do this, the path to Geth's `ipc` file must be known. -By default, this is the `datadir`, in this case `geth-tutorial`. In a new terminal, the following -command can be run to start the Javascript console and connect it to Geth using the `geth.ipc` -file from the datadir: - -```shell -geth attach geth-tutorial/geth.ipc -``` - -The following welcome message will be displayed in the Javascript console: - -```terminal -Welcome to the Geth JavaScript console! - -instance: Geth/v1.10.15-stable/darwin-amd64/go1.17.5 -at block: 6354736 (Thu Feb 10 2022 14:01:46 GMT+0100 (WAT)) - datadir: /home/go-ethereum/geth-tutorial - modules: admin:1.0 clique:1.0 debug:1.0 eth:1.0 miner:1.0 net:1.0 personal:1.0 rpc:1.0 txpool:1.0 web3:1.0 - -To exit, press ctrl-d or type exit -``` - -The console is now active and connected to Geth. It can now be used to interact with the Ethereum (Goerli) network. - - -### List of accounts - -Earlier in this tutorial, at least one account was created using `geth account new`. The following -command will display the addresses of those two accounts and any others that might have been added -to the keystore before or since. - -```javascript -eth.accounts -``` - -```terminal -["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", "0xce8dba5e4157c2b284d8853afeeea259344c1653"] -``` - - -### Checking account balance. - -Having confirmed that the two addresses created earlier are indeed in the keystore and accessible -through the Javascript console, it is possible to retrieve information about how much ether they -own. The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance -of one of the accounts should be 1 ether and the other should be 0. The following command displays -the account balance in the console: - -```javascript -web3.fromWei(eth.getBalance("0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC"), "ether") -``` - -There are actually two instructions sent in the above command. The inner one is the `getBalance` -function from the `eth` namespace. This takes the account address as its only argument. By default, -this returns the account balance in units of Wei. There are 1018 Wei to one ether. To -present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from the -`web3` namespace. Running this command should provide the following result (for the account that -received faucet funds): - -```terminal -1 -``` - -Repeating the command for the other new account that was not funded from the faucet should yield: - -```terminal -0 -``` - -### Send ether to another account - -The command `eth.sendTransaction` can be used to send some ether from one address to another. -This command takes three arguments: `from`, `to` and `value`. These define the sender and -recipient addresses (as strings) and the amount of Wei to transfer. It is far less error prone -to enter the transaction value in units of ether rather than Wei, so the value field can take the -return value from the `toWei` function. The following command, run in the Javascript console, -sends 0.1 ether from one of the accounts in the keystore to the other. Note that the addresses -here are examples - the user must replace the address in the `from` field with the address -currently owning 1 ether, and the address in the `to` field with the address currently holding 0 ether. - -```javascript -eth.sendTransaction({ - from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", - to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", - value: web3.toWei(0.1, "ether") -}) -``` - -This command will return an error message indicating that `authentication is needed: password or unlock`. -This is a security feature that prevents unauthorized access to sensitive account operations. -There are two ways to unlock the account. The first is to start Geth with the account permanently -unlocked (by passing `--unlock
` at startup). This is not recommended because the account -remains unlocked all the time Geth is running, creating a security weakness. Instead, it is better -to temporarily unlock the account for the specific transaction. This requires using the `sendTransaction` -method from the `personal` namespace instead of the `eth` namespace. The password can be provided as a -string in the method call as follows: - -```sh -personal.sendTransaction({ - from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", - to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", - value: web3.toWei(0.1, "ether") -}, "password") -``` - -In the Javascript console, the transaction hash is displayed. This will be used in the next section -to retrieve the transaction details. - -```terminal -"0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" -``` - -It is also advised to check the account balances using Geth by repeating the instructions from earlier. -At this point in the tutorial, the two accounts in the keystore should have balances just below 0.9 -ether (because 0.1 ether has been transferred out and some small amount paid in transaction gas) and 0.1 ether. - -### Checking the transaction hash - -The transaction hash is a unique identifier for this specific transaction that can be used later to -retrieve the transaction details. For example, the transaction details can be viewed by pasting this -hash into the [Goerli block explorer](https://goerli.etherscan.io/). The same information can also -be retrieved directly from the Geth node. The hash returned in the previous step can be provided as -an argument to `eth.getTransaction` to return the transaction information: - -```javascript -eth.getTransaction("0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb") -``` - -This returns the following response (although the actual values for each field will vary because they -are specific to each transaction): - -```terminal -{ - accessList: [], - blockHash: "0x1c5d3f8dd997b302935391b57dc3e4fffd1fa2088ef2836d51f844f993eb39c4", - blockNumber: 6355150, - chainId: "0x5", - from: "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", - gas: 21000, - gasPrice: 2425000023, - hash: "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb", - input: "0x", - maxFeePerGas: 2425000057, - maxPriorityFeePerGas: 2424999967, - nonce: 3, - r: "0x66e5d23ad156e04363e68b986d3a09e879f7fe6c84993cef800bc3b7ba8af072", - s: "0x647ff82be943ea4738600c831c4a19879f212eb77e32896c05055174045da1bc", - to: "0xce8dba5e4157c2b284d8853afeeea259344c1653", - transactionIndex: 630, - type: "0x2", - v: "0x0", - value: 10000000000000000 -} -``` - -## Using Curl - -Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. -This library enables the user to send instructions to Geth using a more user-friendly interface -compared to sending raw JSON objects. However, it is also possible for the user to send these JSON -objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP requests. -This part of the tutorial demonstrates how to check account balances and send a transaction using Curl. -This requires Geth to expose an HTTP port to listen for requests. This can be configured at startup -by passing the `--http` flag. If no other commands are passed with it, `--http` will expose the -default `localhost:8545` port. - -### Checking account balance - -The command below returns the balance of the given account. This is a HTTP POST request to the local -port 8545. The `-H` flag is for header information. It is used here to define the format of the incoming -payload, which is JSON. The `--data` flag defines the content of the payload, which is a JSON object. -That JSON object contains four fields: `jsonrpc` defines the spec version for the JSON-RPC API, `method` -is the specific function being invoked, `params` are the function arguments, and `id` is used for ordering -transactions. The two arguments passed to `eth_getBalance` are the account address whose balance to check -and the block to query (here `latest` is used to check the balance in the most recently mined block). - -```shell -curl -X POST http://127.0.0.1:8545 \ - -H "Content-Type: application/json" \ - --data '{"jsonrpc":"2.0", "method":"eth_getBalance", "params":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","latest"], "id":1}' -``` - -A successful call will return a response like the one below: - -```terminal -{"jsonrpc":"2.0","id":1,"result":"0xc7d54951f87f7c0"} -``` - -The balance is in the `result` field in the returned JSON object. However, it is denominated in Wei and -presented as a hexadecimal string. There are many options for converting this value to a decimal in units -of ether, for example by opening a Python console and running: - -```python -0xc7d54951f87f7c0 / 1e18 -``` -This returns the balance in ether: - -```terminal -0.8999684999998321 -``` - -### Checking the account list - -The curl command below returns the list of all accounts. - -```shell -curl -X POST http://127.0.0.1:8545 \ - -H "Content-Type: application/json" \ - --data '{"jsonrpc":"2.0", "method":"eth_accounts","params":[], "id":1}' -``` - -The following information is returned to the terminal: - -```terminal -{"jsonrpc":"2.0","id":1,"result":["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec"]} -``` - -### Sending Transactions - -It is possible to send transactions using raw curl requests too, but this requires unlocking the sender -account. It is recommended to do this using Clef to manage access to accounts or to use `ipc` instead. The -combination of HTTP and unlocked accounts pose a security risk. - -## Summary - -This tutorial has demonstrated how to generate accounts using Geth's built-in account management tool, -fund them with testnet ether and use those accounts to interact with Ethereum (Goerli) through a Geth -node. Checking account balances, sending transactions and retrieving transaction details were explained using -the web3.js library via the Geth console and using the JSON-RPC directly using Curl. Note that this is an -entry-level tutorial designed to help users get familiar with basic Geth processes, we strongly recommend -following this with the [Geth with Clef](/docs/getting-started/geth_with_clef) tutorial which will help to -adopt more secure account management practices than those outlined here. - - -[cli]: https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line From 28572eb110b5637b772c902321891bf096574c0c Mon Sep 17 00:00:00 2001 From: Joe Date: Fri, 29 Jul 2022 11:04:46 +0100 Subject: [PATCH 017/432] move contributing.md and update dev guide --- .../{geth-developer => }/contributing.md | 11 ++++ .../developers/geth-developer/devguide.md | 64 ++++++------------- .../docs/fundamentals/node-architecture.md | 4 ++ content/docs/tools/abigen/index.md | 2 +- 4 files changed, 35 insertions(+), 46 deletions(-) rename content/docs/developers/{geth-developer => }/contributing.md (74%) diff --git a/content/docs/developers/geth-developer/contributing.md b/content/docs/developers/contributing.md similarity index 74% rename from content/docs/developers/geth-developer/contributing.md rename to content/docs/developers/contributing.md index f01d2c1a59..d07ecd0726 100644 --- a/content/docs/developers/geth-developer/contributing.md +++ b/content/docs/developers/contributing.md @@ -22,6 +22,17 @@ Please make sure your contributions adhere to our coding guidelines: E.g. "eth, rpc: make trace configs optional" +Pull requests generally need to be based on and opened against the `master` branch, +unless by explicit agreement because the work is contributing to some more complex +feature branch. + +All pull requests will be reviewed according to the +[Code Review guidelines](/content/docs/developers/geth-developer/Code-Review-Guidelines.md). + +We encourage an early pull request approach, meaning pull requests are created as early +as possible even without the completed fix/feature. This will let core devs and other +volunteers know you picked up an issue. These early PRs should indicate 'in progress' status. + ## Contributing to the Geth website The Geth website is hosted separately from Geth itself. The contribution guidelines are the same. Please diff --git a/content/docs/developers/geth-developer/devguide.md b/content/docs/developers/geth-developer/devguide.md index 171016a486..f5c21a6121 100644 --- a/content/docs/developers/geth-developer/devguide.md +++ b/content/docs/developers/geth-developer/devguide.md @@ -3,50 +3,25 @@ title: Developer Guide sort_key: A --- -**NOTE: These instructions are for people who want to contribute Go source code changes. -If you just want to run ethereum, use the regular [Installation Instructions][install-guide].** +This document is the entry point for developers who wish to work on Geth. +Developers are people who are interested to build, develop, debug, submit +a bug report or pull request or otherwise contribute to the Geth source code. -This document is the entry point for developers of the Go implementation of Ethereum. -Developers here refer to the hands-on: who are interested in build, develop, debug, submit -a bug report or pull request or contribute code to go-ethereum. - -## Contributing - -Thank you for considering to help out with the source code! We welcome contributions from -anyone on the internet, and are grateful for even the smallest of fixes! - -GitHub is used to track issues and contribute code, suggestions, feature requests or -documentation. - -If you'd like to contribute to go-ethereum, please fork, fix, commit and send a pull -request (PR) for the maintainers to review and merge into the main code base. If you wish -to submit more complex changes though, please check up with the core devs in the -go-ethereum [Discord Server][discord]. to ensure those changes are in line with the -general philosophy of the project and/or get some early feedback. This can reduce your -effort as well as speeding up our review and merge procedures. - -PRs need to be based on and opened against the `master` branch (unless by explicit -agreement, you contribute to a complex feature branch). - -Your PR will be reviewed according to the [Code Review guidelines][code-review]. - -We encourage a PR early approach, meaning you create the PR the earliest even without the -fix/feature. This will let core devs and other volunteers know you picked up an issue. -These early PRs should indicate 'in progress' status. +Please see [Contributing](/content/docs/developers/contributing.md) for the +GHeth contribution guidelines. ## Building and Testing -We assume that you have Go installed. Please use Go version 1.13 or later. We use the go +Developers should use a recent version of Go for building and testing. We use the go toolchain for development, which you can get from the [Go downloads page][go-install]. -go-ethereum is a Go module, and uses the [Go modules system][go-modules] to manage +Geth is a Go module, and uses the [Go modules system][go-modules] to manage dependencies. Using `GOPATH` is not required to build go-ethereum. ### Building Executables Switch to the go-ethereum repository root directory. - -You can build all code using the go tool, placing the resulting binary in `$GOPATH/bin`. +All code can be built using the go tool, placing the resulting binary in `$GOPATH/bin`. ```text go install -v ./... @@ -58,8 +33,7 @@ go-ethereum exectuables can be built individually. To build just geth, use: go install -v ./cmd/geth ``` -If you want to compile geth for an architecture that differs from your host, please -consult our [cross compilation guide][cross-compile]. +Cross compilation is not recommended, please build Geth for the host architecture. ### Testing @@ -75,8 +49,8 @@ Running an individual test: go test -v ./eth -run TestMethod ``` -**Note**: here all tests with prefix _TestMethod_ will be run, so if you got TestMethod, -TestMethod1, then both tests will run. +**Note**: here all tests with prefix _TestMethod_ will be run, so if TestMethod and +TestMethod1 both exist then both tests will run. Running benchmarks, eg.: @@ -89,14 +63,14 @@ For more information, see the [go test flags][testflag] documentation. ### Getting Stack Traces If `geth` is started with the `--pprof` option, a debugging HTTP server is made available -on port 6060. You can bring up to see the heap, -running routines etc. By clicking "full goroutine stack dump" you can generate a trace +on port 6060. Navigating to displays the heap, +running routines etc. By clicking "full goroutine stack dump" a trace can be generated that is useful for debugging. -Note that if you run multiple instances of `geth`, this port will only work for the first -instance that was launched. If you want to generate stacktraces for these other instances, -you need to start them up choosing an alternative pprof port. Make sure you are -redirecting stderr to a logfile. +Note that if multiple instances of Geth exist, port `6060` will only work for the first +instance that was launched. To generate stacktraces for other instances, +they should be started up with alternative pprof ports. Ensure `stderr` is being +redirected to a logfile. ``` geth -port=30300 -verbosity 5 --pprof --pprof.port 6060 2>> /tmp/00.glog @@ -104,8 +78,8 @@ geth -port=30301 -verbosity 5 --pprof --pprof.port 6061 2>> /tmp/01.glog geth -port=30302 -verbosity 5 --pprof --pprof.port 6062 2>> /tmp/02.glog ``` -Alternatively if you want to kill the clients (in case they hang or stalled syncing, etc) -and have the stacktrace too, you can use the `-QUIT` signal with `kill`: +Alternatively to kill the clients (in case they hang or stalled syncing, etc) +and have the stacktrace too, use the `-QUIT` signal with `kill`: ``` killall -QUIT geth diff --git a/content/docs/fundamentals/node-architecture.md b/content/docs/fundamentals/node-architecture.md index 4dcf68b005..94e55f4ca8 100644 --- a/content/docs/fundamentals/node-architecture.md +++ b/content/docs/fundamentals/node-architecture.md @@ -1,3 +1,7 @@ +--- +title: Node architecture +root: .. +--- ## Node architecture diff --git a/content/docs/tools/abigen/index.md b/content/docs/tools/abigen/index.md index d8c64a730d..494597f862 100644 --- a/content/docs/tools/abigen/index.md +++ b/content/docs/tools/abigen/index.md @@ -1,5 +1,5 @@ --- -title: Home +title: Abigen root: .. --- From 0a4aa8add5ebbd2e8cdd894d1996512c813989dd Mon Sep 17 00:00:00 2001 From: Joe Date: Fri, 29 Jul 2022 11:24:42 +0100 Subject: [PATCH 018/432] refine code review and contribution guidelines --- content/docs/developers/contributing.md | 2 +- .../{Code-Review-Guidelines.md => code-review-guidelines.md} | 5 ++++- 2 files changed, 5 insertions(+), 2 deletions(-) rename content/docs/developers/geth-developer/{Code-Review-Guidelines.md => code-review-guidelines.md} (97%) diff --git a/content/docs/developers/contributing.md b/content/docs/developers/contributing.md index d07ecd0726..44d4a9a33f 100644 --- a/content/docs/developers/contributing.md +++ b/content/docs/developers/contributing.md @@ -27,7 +27,7 @@ unless by explicit agreement because the work is contributing to some more compl feature branch. All pull requests will be reviewed according to the -[Code Review guidelines](/content/docs/developers/geth-developer/Code-Review-Guidelines.md). +[Code Review guidelines](/content/docs/developers/geth-developer/code-review-guidelines.md). We encourage an early pull request approach, meaning pull requests are created as early as possible even without the completed fix/feature. This will let core devs and other diff --git a/content/docs/developers/geth-developer/Code-Review-Guidelines.md b/content/docs/developers/geth-developer/code-review-guidelines.md similarity index 97% rename from content/docs/developers/geth-developer/Code-Review-Guidelines.md rename to content/docs/developers/geth-developer/code-review-guidelines.md index cfe6ae85d3..e19da73f90 100644 --- a/content/docs/developers/geth-developer/Code-Review-Guidelines.md +++ b/content/docs/developers/geth-developer/code-review-guidelines.md @@ -3,7 +3,7 @@ title: Code Review Guidelines sort_key: B --- -The only way to get code into go-ethereum is to send a pull request. Those pull requests +The only way to get code into Geth is to submit a pull request (PR). Those pull requests need to be reviewed by someone. This document is a guide that explains our expectations around PRs for both authors and reviewers. @@ -11,9 +11,12 @@ around PRs for both authors and reviewers. * The **author** of a pull request is the entity who wrote the diff and submitted it to GitHub. + * The **team** consists of people with commit rights on the go-ethereum repository. + * The **reviewer** is the person assigned to review the diff. The reviewer must be a team member. + * The **code owner** is the person responsible for the subsystem being modified by the PR. ## The Process From 46bc4df1b46b49927a29ab7316d77c3d56af3dc3 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 2 Aug 2022 12:57:54 +0100 Subject: [PATCH 019/432] add devp2p page, update devguide + mobile --- .../docs/developers/dapp-developer/mobile.md | 5 - .../developers/geth-developer/devguide.md | 8 +- content/docs/tools/devp2p/index.md | 171 ++++++++++++++++++ 3 files changed, 175 insertions(+), 9 deletions(-) create mode 100644 content/docs/tools/devp2p/index.md diff --git a/content/docs/developers/dapp-developer/mobile.md b/content/docs/developers/dapp-developer/mobile.md index 6eb3111e9a..0de0d40933 100644 --- a/content/docs/developers/dapp-developer/mobile.md +++ b/content/docs/developers/dapp-developer/mobile.md @@ -336,11 +336,6 @@ let tx = GethNewTransaction(1, to, GethNewBigInt(0), GethNewBigInt(0), GethNe let chain = GethNewBigInt(1) // Chain identifier of the main net ``` -*Although Swift usually rewrites `NSError` returns to throws, this particular -instance seems to have been missed for some reason (possibly due to it being a -constructor). It will be fixed in a later version of the iOS bindings when the appropriate -fixes are implemented upstream in the `gomobile` project.* - The transaction `tx` can now be signed using the authorization methods described above: ```swift diff --git a/content/docs/developers/geth-developer/devguide.md b/content/docs/developers/geth-developer/devguide.md index f5c21a6121..6df219959c 100644 --- a/content/docs/developers/geth-developer/devguide.md +++ b/content/docs/developers/geth-developer/devguide.md @@ -1,5 +1,5 @@ --- -title: Developer Guide +title: Getting Started sort_key: A --- @@ -8,7 +8,7 @@ Developers are people who are interested to build, develop, debug, submit a bug report or pull request or otherwise contribute to the Geth source code. Please see [Contributing](/content/docs/developers/contributing.md) for the -GHeth contribution guidelines. +Geth contribution guidelines. ## Building and Testing @@ -60,9 +60,9 @@ go test -v -bench . -run BenchmarkJoin For more information, see the [go test flags][testflag] documentation. -### Getting Stack Traces +### Stack Traces -If `geth` is started with the `--pprof` option, a debugging HTTP server is made available +If Geth is started with the `--pprof` option, a debugging HTTP server is made available on port 6060. Navigating to displays the heap, running routines etc. By clicking "full goroutine stack dump" a trace can be generated that is useful for debugging. diff --git a/content/docs/tools/devp2p/index.md b/content/docs/tools/devp2p/index.md new file mode 100644 index 0000000000..2237be183d --- /dev/null +++ b/content/docs/tools/devp2p/index.md @@ -0,0 +1,171 @@ +--- +title: devp2p +--- + +[DevP2P](https://github.com/ethereum/devp2p) is a set of network protocols that form the +Ethereum peer-to-peer network. The DevP2P specifications define precisely how nodes +should find each other and communicate. Geth implements the DevP2P specifications in Go. + +The DevP2P stack includes the low-level peer-to-peer protocols that define discovery and +secure sessions between nodes such as: + +[Ethereum Node Records](https://github.com/ethereum/devp2p/blob/master/enr.md): A standard format for connectivity information for a node +[Discovery protocol](https://github.com/ethereum/devp2p/blob/master/discv4.md): Defines how nodes find each other. +[RLPx protocol](https://github.com/ethereum/devp2p/blob/master/rlpx.md): Defines a TCP based transport system for communication between nodes. + +DevP2P also includes the RLPx-based application level protocols including: + +[Ethereum Wire Protocol](https://github.com/ethereum/devp2p/blob/master/caps/eth.md): facilitates exchange of blockchain data between peers +[Ethereum Snapshot Protocol](https://github.com/ethereum/devp2p/blob/master/caps/snap.md): enables exchange of snapshots between peers +[Light Ethereum Subprotocol](https://github.com/ethereum/devp2p/blob/master/caps/les.md): protocol used by light clients + +To debug and develop these networking components, Geth includes a command line tool called `devp2p`. + +This page will outline some of `devp2p`s built-in tools. + +### ENR Decoding + +Ethereum Node Records can be decoded, verified and displayed to the terminal using `enrdump`. It takes the ENR in its encoded form, which +is the base64 encoding of its RLP representation. A decoded human-readable text representation is displayed. + +Use `devp2p enrdump ` to verify and display an Ethereum Node Record. + +Read more on [Ethereum Node Records](https://ethereum.org/en/developers/docs/networking-layer/network-addresses/#enr) or browse the [specs](https://github.com/ethereum/devp2p/blob/591edbd36eb57280384d07373a818c00bddf3b31/enr.md). + +### Node Key Management + +The `devp2p key ...` command family deals with node key files. + +Run `devp2p key generate mynode.key` to create a new node key in the `mynode.key` file. + +Run `devp2p key to-enode mynode.key -ip 127.0.0.1 -tcp 30303` to create an enode:// URL +corresponding to the given node key and address information. + +### Maintaining DNS Discovery Node Lists + +The devp2p command can create and publish DNS discovery node lists. + +Run `devp2p dns sign ` to update the signature of a DNS discovery tree. + +Run `devp2p dns sync ` to download a complete DNS discovery tree. + +Run `devp2p dns to-cloudflare ` to publish a tree to CloudFlare DNS. + +Run `devp2p dns to-route53 ` to publish a tree to Amazon Route53. + +More information about these commands can be found in the [DNS Discovery Setup Guide][dns-tutorial]. + +### Node Set Utilities + +There are several commands for working with JSON node set files. These files are generated +by the discovery crawlers and DNS client commands. Node sets also used as the input of the +DNS deployer commands. + +Run `devp2p nodeset info ` to display statistics of a node set. + +Run `devp2p nodeset filter ` to write a new, filtered node +set to standard output. The following filters are supported: + +- `-limit ` limits the output set to N entries, taking the top N nodes by score +- `-ip ` filters nodes by IP subnet +- `-min-age ` filters nodes by 'first seen' time +- `-eth-network ` filters nodes by "eth" ENR entry +- `-les-server` filters nodes by LES server support +- `-snap` filters nodes by snap protocol support + +For example, given a node set in `nodes.json`, you could create a filtered set containing +up to 20 eth mainnet nodes which also support snap sync using this command: + +```sh +devp2p nodeset filter nodes.json -eth-network mainnet -snap -limit 20 +``` + +### Discovery v4 Utilities + +The `devp2p discv4 ...` command family deals with the [Node Discovery v4][discv4] +protocol. + +Run `devp2p discv4 ping ` to ping a node. + +Run `devp2p discv4 resolve ` to find the most recent node record of a node in +the DHT. + +Run `devp2p discv4 crawl ` to create or update a JSON node set. + +### Discovery v5 Utilities + +The `devp2p discv5 ...` command family deals with the [Node Discovery v5][discv5] +protocol. This protocol is currently under active development. + +Run `devp2p discv5 ping ` to ping a node. + +Run `devp2p discv5 resolve ` to find the most recent node record of a node in +the discv5 DHT. + +Run `devp2p discv5 listen` to run a Discovery v5 node. + +Run `devp2p discv5 crawl ` to create or update a JSON node set containing +discv5 nodes. + +### Discovery Test Suites + +The devp2p command also contains interactive test suites for Discovery v4 and Discovery +v5. To run these tests a networking environment must be set up with two separate UDP listening +addresses are available on the same machine. The two listening addresses must also be routed such +that they are able to reach the node you want to test. + +For example, to run the test on the local host when the node under test is +also on the local host, assign two IP addresses (or a larger range) to the +loopback interface. On macOS, this can be done by executing the following command: + +```sh +sudo ifconfig lo0 add 127.0.0.2 +``` + +Either test suite can then be run as follows: + +1. Start the node under test first, ensuring that it won't talk to the Internet (i.e. disable bootstrapping). An easy way to prevent +unintended connections to the global DHT is listening on `127.0.0.1`. + +2. Get the ENR of the node and store it in the `NODE` environment variable. + +3. Start the test by running `devp2p discv5 test -listen1 127.0.0.1 -listen2 127.0.0.2 $NODE`. + +### Eth Protocol Test Suite + +The Eth Protocol test suite is a conformance test suite for the [eth protocol][eth]. + +To run the eth protocol test suite, the node needs to be initialized as follows: + +1. initialize the geth node with the `genesis.json` file contained in the `testdata` directory + +2. import the `halfchain.rlp` file in the `testdata` directory + +3. run geth with the following flags: + +```sh +geth --datadir --nodiscover --nat=none --networkid 19763 --verbosity 5 +``` + +Then, run the following command, replacing `` with the enode of the geth node: + +```sh +devp2p rlpx eth-test cmd/devp2p/internal/ethtest/testdata/chain.rlp cmd/devp2p/internal/ethtest/testdata/genesis.json +``` + +Repeat the above process (re-initialising the node) in order to run the Eth Protocol test suite again. + +#### Eth66 Test Suite + +The Eth66 test suite is also a conformance test suite for the eth 66 protocol version specifically. +To run the eth66 protocol test suite, initialize a geth node as described above and run the following command, +replacing `` with the enode of the geth node: + +```sh +devp2p rlpx eth66-test cmd/devp2p/internal/ethtest/testdata/chain.rlp cmd/devp2p/internal/ethtest/testdata/genesis.json +``` + +[eth]: https://github.com/ethereum/devp2p/blob/master/caps/eth.md +[dns-tutorial]: https://geth.ethereum.org/docs/developers/dns-discovery-setup +[discv4]: https://github.com/ethereum/devp2p/tree/master/discv4.md +[discv5]: https://github.com/ethereum/devp2p/tree/master/discv5/discv5.md \ No newline at end of file From 660687c2d8302a684360fb42b952ed0531c612c9 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 2 Aug 2022 13:33:36 +0100 Subject: [PATCH 020/432] update dev-mode and add images to /assets --- assets/remix-compiler.png | Bin 0 -> 73775 bytes assets/remix-deploy.png | Bin 0 -> 69730 bytes assets/remix-func.png | Bin 0 -> 36977 bytes assets/remix.png | Bin 0 -> 278597 bytes .../developers/geth-developer/dev-mode.md | 63 +++--------------- 5 files changed, 8 insertions(+), 55 deletions(-) create mode 100644 assets/remix-compiler.png create mode 100644 assets/remix-deploy.png create mode 100644 assets/remix-func.png create mode 100644 assets/remix.png diff --git a/assets/remix-compiler.png b/assets/remix-compiler.png new file mode 100644 index 0000000000000000000000000000000000000000..8c9255711b1df39dceddd84d774a32c3d996ab99 GIT binary patch literal 73775 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∈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

GmIy{t+bDT_qt&z+|4Gw;xrlwu}y3lSJ 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 literal 0 HcmV?d00001 diff --git a/assets/remix-deploy.png b/assets/remix-deploy.png new file mode 100644 index 0000000000000000000000000000000000000000..cea10898bf5e080efae00ac5d3c8755beb565edd GIT binary patch literal 69730 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 bUtA#W$QF15G2f&>z&`~U73p$GlfeH6JuuTv literal 0 HcmV?d00001 diff --git a/assets/remix-func.png b/assets/remix-func.png new file mode 100644 index 0000000000000000000000000000000000000000..797e66517745c2911e0e6af82e5b11fa44bd1412 GIT binary patch literal 36977 zcmeFYWl&vB(>A&Z?(Qx@g1fs1cL>4V-Q8V-1h)VoxCeJha3{C~cXv38-1lSe`RY`? zRpEz4a>yE2j^O z6qxT5eJYnz3g0PFfMr&JYnr~iybxXxKb!2-MwCo1IW{~-(Q~YNs2n|2>Ir7W%#9ta zE{yTscrF>+Jzb4DQJ>-+3r>4?G&gRJLE2STTrl`FD`kxl_a6{{Xw~z1axC!D#AhRK z(;JIfa4J|k5&XUb^`x6JQl2sT>dPo*_qHE)IdzJAt28|X>69VOn<>h$#Okq*Kx{rCd6KLTqbO+oZF*RiT1_UbKiWrT<6gg zJsTOzeH8a;+LSRjNRT9^v_K}fI&pHCs~VAaic!b);FiCNÐt%kfPUY+EC!4|KYQ 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 literal 0 HcmV?d00001 diff --git a/assets/remix.png b/assets/remix.png new file mode 100644 index 0000000000000000000000000000000000000000..bff8c709dede222dd9b36fb65688649da6fd260f GIT binary patch literal 278597 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"+V1#Y-dmTB7#^IJ88{x#O?jAm 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�l&eBkQ>>XMoA8>VT!9p;A%DUgk}0s^g)y?DzNo|Rb{JnXyZqz){%ZtGNi5^M`@W$0*nCmi z2{^_tT3a0se?K_Egn^kCYo4G=A(0kg)av+YoDXGloHe(nSZOfW>%wb(VcxP4J99{9uKAYht_HxD5gt@ z%a69?;_Kwsr=qv$HGbI8H!9HUP5F$tCWYfokY5oJ_=>u{Pvqyvy9I{sDKe)r|DM7E z64)LFXm;KE2s6dv`1$j%k}h>59DXehi0j=<<8}V;BkA;B3m6l9hxc!uj2=0~{k><& zWyxeFF*-m^Q6y}f6(zUlg*I>Cl7K{-9Md7jrw81{gENE1=aIBj)Qp z<$o_IdETq3agF1)6OR(y6X%}>zC0F=MNFz%9TASuCT#st&nKVr-<~wh?G-q46i7s6 zIR7CluY6^B-F>cD(BiC{&w;(Mnis#&27Pen7o9w`1MJ>)s8m1^Ko3+A;;xB~=nFjy zBBdQVdwbZp6$>-Jjm(bJj1+Jf&C(!~@$RARjcV%MbG(p01346VTCM$6jzVm)6tSHW zwzfB+>f5xDjM~;C@(2p0aYDyLC&^RDZ1n?F5Bwnuo-+&fr@y*s^u*gwqCjDx)zgt$ zeN;1a_G0y6vEg7;m%3VZ{BT2^`rEy_H&_Wn1cO%|T>10RfKl}Pf{BUY;VLU?DYYwu zf)Mwcw|W;+LxS~R=Eb!(DZ2gnCL79P@BU&ENqS@{a2#)LC9TjcrXyKKSs+L*}JmRr$eO z>^)4PcmG=YZSBfDxhi&_M^`9ipP3EM^hQuTJ{n=swZU5c5p5_NcOkIqfahSnZj`zu zzsmU`DeEnH_^HXpJ*(Yp3)EagWA+|Vbt#tMq%2jVyRQp~$C)uOjmLZ<#PcsArghpi z^Wg=DB@orq+m)JA%81i>-~RX^wJbJ|g0D!pgtUCra|ib-&Q-u~`j_XwYqdVt*8XvM ze(Ei>{~K|)^c|g`U?6ZdpknYGe~lCSYHTM?9MlT7C-=U|re0v+iR|$^nAG=vpt%YL zBB)N)=lp(J_D{XbwpJSoI|;TpRxWn*F+@{Y&{<7(&OBQyQ%H|m^qSIJ8SIn{7}bZEsByN1OafV(%GU zNKAU$~ru+ zFdpu=>MHxx@>Bane!4l%%YNH+q)c@db23_XE8mEdpekaZnC?}zTC@}Pj*uh_Hm*0y zOwd|Op<*moq2sgYcZ}%qU(*XtQ+h>{TSwp9mz~~yAV-+l4`p6I8TRTA1*W~N%dhPl zKkZ^*m@6Bai6OF%3W-BdNlUHB{LB-yUGzmoQjYIcAFeG_Sr!-_tX;>nOpaP>!lrs0 zey0;(m4;mtm+bNE4xf68`&tnx-5KY_Y5UZ2a&6ou zJC2jdl%|X&zR&(Ga<}Ky2wtBomsVdDS5_Wf88|@aJ-7cfND*nxFh^IhhU>IP_EhS* zSy`)}^Q(;Z6XPG9(vx(3jAD$^h=T0Xl25avUqEr*G9|�Uu+h2X$RT!IFbvy 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

gLna)e%cIq_rzyq7SZk?!K)Hu%O2 z=9UqzYVQOpL!Lk`fME^+5EWI;57CB$ptYrSq<9)inr&tK?tX)yuwZ9pspU9X8Da$y zHw>aAS}BGLe0!zsQHsEmhBFAkvzO$_E60yVN(8(+gXo5HZ;!5W8og6YPCLZ)yu7>| zBn(I$ox<7K2}g%KJ3$Opx0uIfvjnN4lAPWhdC}I+38|qG@xK1diFp51i@yO-!=z2cH8>q=gLicVniaE`};Mzx{5=?!!dGtvb|ExEMeX& zh5BpJTXlkPTi~ZF9Ex7&Tsd&Sdz>`_;)=l~_G8g667^h{O$>#Zv-+zyRu^dX zmphGe>VI^(427miU(dO_<)pQ#jnT;i{~~E7o_CwCnt(UUP^Xb-UaACpD4?zGB6fCm zZgzXSTMK#B+lfrV1_d7<%`7jkgNZ;a1Z@oUlTFfDVdl!GM7^5TZZ{*mPZ9(hOUVS~ zIaNi)8W6yu1^BHpkKg5Qxr5Kk&sW9ZC1kvu>x@Z}7qeGab?UU*myuAN$A*L$0^APS z_>n8aTta7Dm=#wO8TtW5C>Y}}T)fJppunR1l6A>wetcqBGx05Hu)$;otJGTP-txQOtA-BoMknmnzZAXqB({gf(Xit8H;);fxhwWRsCm=YU;2hWKYc4OJH(}TVqieP+^C}#o4yyZ zhuv9km2a|s#=~;yUx@3^&pJP4`5#>Ge^5ha-ak>Ue@+GJ=3KM?2Rb|iIKqE}=0+Ef z_x+p8X$J_*y)AzJ2VivHdEQ__``<}Fe$1}zBNXWW@%6U%kN*XLrJ4UB75@5U+|M_H zc&`13HapL;JhuI(Yy0zKZ+n^Z{_9v3#6R6e|Ks=ReE6ReIInVxW~TZdUpnu$PYu|V zBBVsrwYaM3vv4+1?=gpRJoYx>ChKNqT~CN)3* z0gPR&gq|`$I!Pkojj${#E$vC; zOfRFOEr4J(`r(lKQdDoutf0+XEyQdFy2T%&P7+-&u|tI=ldS&=tn$H=<=sy|+{DFA z%NH3GRGe*vSWHSvxoeCi;MEv8kJAN=;INoL#4t^!~hj`b? z<~vJWUs8t+ZR~7Opa_0WJoVYoj6cXqV#Op(Mk_|2+)+ zB~XY=CO=O}*+7V%(%pCxPP|R)@=QfxUCnD z=qCAFN6A7}!vIitolc!_{wRO)qw7sER{EA!(VD#1F~g3YJ9NJ;j^FxWeJ{Su%VX^u zuyJeUL$!=K=alwj<>fWHIE)j1DGT0jO`{{^ggO3F?H<6Lc$IPg=$1odS{NX zJWb&svZ_}A)X~=~>B9HJ(ykE9*3i#QH(%|Hfx1gML=FD=)OTl+Qmj+I6`9CP87vh5c=v9LDVr?7Q_i zF!joaXKmnRxy$(77?S(eoTtq&;i*xj>r>!RbO zPxds1hm)i}_=}>8jh--#WW0KHBCjwv5~YoDXsaOhb!rxskNBuTZxxRlC_N!vEN=z; zwg30}y>y-I&^H(g9sRGnUw0Nm6rOiYZ@2gN_ve?D=|#uHfPIukFOf(lO7h9*MO>ze zlv@G|4K`nx+0R|u8B?pw3&<%xVoHnt+D z$2Y0eyqX#{M#c$f6GPzFHV#LGaQa-Qu_B`WOF9x#RYm+(o3@2Ul{Xq1l%OR$WmztJ zW3}opvP1?;hPjBXZ}HX20Xvik0YO2Py(O-_JjlKX!>LAN8a1v8a-!nQANSUx9UGj`8=fbvCKwk#k=E@hV0O<{K_Ww#s_9ny93h3R&Esbd6oN_JG= z+PZ>9-9v-fl(SPtI@CubX0@y^QY{u7`}+Hr&-~3ehCMfoWY-}ef_Op-n9$`{h&du5 z*9_{f7L0WgyJy9bNGU;S0loD!o0Fms@J6f6BliV%_RH_v7bl~prq|V5Oh`Sz1e$FK zbr(8&mZyAx#+rwQ#pB#2ECuC}Jiu;cX5O713pug2Og!aIUTt<+JFTFg!53xoVHubX z=!d}SPOM*yfk6Xk2wedBLHS}?iV=ePi-pB7URFx2D(ayad5tsRX#Donr}<%0^z-Mr0ALF# z?8Q;Hws;YMgGpJ5BHi4gT-`QCHMi{X)ZEGmvZ7$WFX7S`BWMdTbmAr&Cg$Vd1R+Q5 zsd6IB^Yie`)NXNhPPU3T@ICv_;2C0 zVgoi+8CrgqKsBv|6JkJlMYdAdlERk}^v@;8N+D@=wO*l7{wcKI-R{P-+}x_=_7!T; z(TqOc6gpORc4yz}y1I_JODgTZ4OM%uM8`;Kr1<-obyG{+5#h5QRma$eWCbV}S=9*R z>%L%Pch&N)Na7-OeSvh5yxj1l6l@JYhH``dEFwEPK2BBkCA~Su~qGP?D|4q3! zzV)k-v@a(ql)fjvRt-Wqmh<+DKY9Qd%lA9eGc#T7NhEhlVS@WgB>UVz4Jz`DYXhsd zj~6+eVU%s@2cHZ|F@^NL^a^>`I?&KUQ))7jh0E3dQ^Wogy=#&@d8c43-Xp9{JorgH`bA2Otm z(9r=Hqy*s~;sV~TzwGxOH-z?0>$uvjq`EF(jiVvrQ~I5B{kG{@=%M=1r9AB~Cr~dE zvFvm}e25qWtkUc@vA~sDTgxdSEI^fh=CSDE?U?=l=WZ z!w(OiTi;pOtND5Ve$~{m-^;zbwbAp0K5pwGsbAxyk2(FB3{hoqsYV`f`b-W_U~Y6R+S$1d)DvAJtdm>&Ym?Gr4rHkwQ1@a3TqFH zAEq9lW1^Ii=6l1FNG3&T^^@&teQi>fLYL2|011GXKo0ISpNmeEmUzYW7}0E0d8d%} zt_}>O?Ht0%pLLu3BtYW|yE9v(qovVX>jAC}>i|nbk4<|Z!c3GGzm(C)d(imRtgYKQ z-WEaN@~+nhcXWjw**K5h)MVu0;#xq=B>=j2JSq}aRqh~ZaH!S}%}R{Sh~lTSEGID@ zKQ3v5y$SS+T7qOg4yOmBtg>F`i2rB-W*=Q3B!(`#(NM4graA;g6|lj{Pij4nPk1|y zU-(_MG#2O~>#25!sN$Y?yy9ZIAF@RTzqy`c}}LhlKs%7E(GlpX7N$VI|0c)VtK^sW)ta#SQJtIhXR=XIJ&dpNFxxeeMe(KfB7= zoz0o>2(WfoJ1R0*!|(Kgi$p_DDIcGkh?rCuz`4(S91B`rT0-6>{u~`0o%8*L?|~CQ z_BjkJ$HAk}^&@AHDYhp8z6F8X$rBv;Rw+Ae8MiPzhz-ZxP+F#R%%Q5Ut};JVz8)s@ z8ngIC9$NZmJTwU6blL8xPD8WBgt3Wr^E;w=4GntPXonD zqhiin*1mZ6ldFRhtu$}Zug!wBnsn)T5&S{(SphDek^T59&rxhE{v7a*#+?2pz+uQF zd+L_WJJLAX)2D5;+uudV`)I%*Uc973ysN7o_U;zT#k(_E2_+cvDx!~w6q4XYB`j=~ zkSS!ybW*$hNf%7b{cD-9b9NDVU$?!X@X^;^W{22xZO*~L@gAW#e6)`|C6XlT1(>Ql()og*4UK~D9jAH!4RkaoR!Fh~o5X!iLcgzlk<0|4Q}m6e`| zbl;2R(gs-T7>CRs3=E~j0@EVgJT9NJN2fsvfVs-M?JC=!-o}K4gxtAv$FiJ3ecGqm zsC}*>ciQ3}Bz=%^;%rW*k;${2Gd&IDX=_ir(ev)u#-=v+D#!70tDBK6EiHWb0G5?W zpd%`gmV`(cg@o2jLP|=#W!{wxOiwx^CubVBvH}K4UlR$hEp)Vw$iBw>#p|`4 zUSBBiQbgC)A))*c6c(-^za@S$EagF9*6{Iyt+7Sjp^SFAC{%7xYZbL+WWhC8L%U5C3yZFrr)+@V0`euc!BwP~*RI1B3BIEro1`hPonkFXf|#{I`;# zB#BR$h6_MBvbHW;RF&s^v-=*TBH+sH3XSmX4%DKsRbhxZayy@#`UZV&vnq>mJ7je_eYE@ifhWp^xYGz58eDw@{3QPdq8pxeWFn)56kxRQsup>D>Mt+^mQ{3TjG=@4Npme- zuF7+IscBCI>VL||u^}y?xtrR0#A`e2<$DvX8Zh^}xcKW->@TH;@am+*C$O!p_SCu1 z3E2<6F{EP>CZ;JKLg|=8ef^@SC}qTNoN;1;E9zUp!FB!79j7SQW5*7iGJj=WB>0-~ z#EE>6tDJ&u7!F#4@TMo!yDjKcM zboNgzw;O%z!#QMMJ$PVIXi%(T)qWBh${U`ecth8lK*1}QzqY-8{e>RRB)xiE89bhf zDr>7iYkZH>ceaYA3IoY~1ukuk;uKwfyI)5`E-fZzGR+*BQ-q!Cf|n>b?F-W2^T#}m z=g*%HdQtcgk>#=Fz@SE!m&cB5t;lk}*Y1B0wT^{2Ywy5Fnljf;*%|J1lL(l!qySs% zl9Uh$hBmLF_%*EC6Lo272VE4#w6>Osm%jt4)%Eyrl5e_c{Y!mZ%eRS%OpKir42cVX zDCEM0Vvullh0mQ>P`-65(XqxM3MdRPk*d?TvYN6a`FME|!qY>_4Sy?KZ-c7g}?-&W)O3L@8j$>w^T#J_wa=DJgFUk0p z>C%vDS$?IT?p=kF6{*uRu^-zSQ~0c~i4VqpfWVKxU>?(+BFd$exnR^1Cxr%k7)TE( z&NWQZqZ&bct47|1qfLLkae=BVMg75~L0KqUFlpLEs|WZS7q=7l1t^H1)e5Wne3=TK%Iv9b`wVlDSyJ-fdG=O^Ig!q4u*p{@BQ<{L@|M#3khvdjw%4r z9=W2tBee5Z3syiu|4B3xaa*pqrx zW|o_?$|R0#>*eKTy*_Vi}l{Zm6@^@qT<<;9CjQzab=t2Q{}*YBijB_cC2K1c)U z2o3Y=Pj?y0FGyns4c|EuKMmlf_;|BF-lgchQ_?x+;pv&1dVYbBSPEv$0Q&KOyYbD) zi@MU$_QR4Ka@1UkKeS#jEOgQjq0lJiZ!RYpxti@cstMtJzIIC$YQpF{cgEL%)~L9q zcM7+5049W5QmOArni<~by1EUh5kHh=EHVgn=scC1Nf8@wA)cUeESXvKz^JWe-spvAn zsF0BCNl}B0PoFk{DbX=D&QHd!m**A8D2&ZH4Z73d4Vp&hW6n&<=Ex;K_KO#%gwCAN zhMujZRaVjlS#s)JH6ocaIZ6*DbkXkKo$9AimsNsd>QbiG%ydykM|M1XqOgt zqaLY`+!BVsr^HVuA;k-3?KZTeacAqz8+s8VuPB;+_2osYe0(7i8noIwW=`Ejs-mI; zbK$=?O?(af{&Z3PFE${MEyXZ0%jeA1pm&DsfOD=GRs3P-da03pkac%F@ts-cmsFI0 z?FcO4Ufgighfl!k`nmXh@A6f-rJ@Jax5xaDq-_GA69e|c+*x1qi;AKF0lj(iW5#M` zQIW>P#FS&s(i$`waG#*%**cNahC6a0_wS_Vo)y)1a$3lM_%1F<1Yd)zFCjzslaxUglV4IYB%&$K zdG+c$K-lxxELDofY#Osrr&HZ0Z!KAJu^lrTa&2`WOvI3GIG7h3C5_L|@CM`~;ntUs z4hS(DmMM4TAwJBW3YB)TqwL zvXwQw^^I+MhiXjJ-S%6ZCp5Ni0rAwo`kf_scaIOUUd=kS6}OW2-2$9l9@zGg*I>zY z)?$7Cs|0t|r+^;v4L($#WN2lT>@Xx|xIyBfH=y_@2G)^jgoRYYi|G+zwVCDY0Z zR4%au7+#|5kME=4K~y+MSd#`2#^V}kVQ!{}+(3a;j2goS5pxzRW%EQ0BNp zs@w6J_S?_}ZK5P#3Jln}-=WmG=-9{8RBs_>*Y%1Q;-(IwdFF6LA#^#!!r`2HWmo<} zqy7o7Gj45dRoz;js|~G7XQnC6LZQIHBr#4>-W}qKfl(i=uIT;7b-QaFNHkgq=P>@vbKb?o8-(7^* zt)&|w`;k*EFq|W%C@*hn?zj7p2K~o2Tj*M4tA#M6{EhuAGEB?Km9_2~%+Ab6+wyWl z1(cl33Ca--6*TCJ9V?dBmX~R#heT$AKhZ*{WbnnvVF7M4sA+@Wci zwlNx@ucmf1y^IBS_v;L~>EjjCh&k#l!x05{)3EQy#2V0kRO;4^opWwWd)Z>dCAQY$ z%FmlC6CkO5QP<})@HzzYH(U!1iH;r42B}YALw(P9$<93IL}GRK8b6}ul$yR|{QSH+ zBNOAt`W_w6kxIiSr-lnSVh_)#$BgWn_TznQetqqi!>awcQ~Xur8?)UrZ7-wp`b|mX zBgddBo`JltWimuhgNj2G+Bkmym1T=k5<8idfx;lO?%n&TPgfs=N$5_`x~=`gn0_pE zvtw`c_uKD_z2??pY1INsR)IK(VZ%@wWmm~|#tK{U(-a*grAkxp30|7OFngj^U*pni z2`AGSXl~_4)^{`5H!zAi*!je70>a7{73}T-RTDmiU3Y&3t&g^**|Tu=9rvMy^mJ)R z_yDW`#oYJ#voo@Tg`J%yBOdXiAeEXvSlg^0;rLwVq@Di})$SYMZ#*|Qr_vFZjj?lb z0XwLg!BVRbq08Rf)e(QOJzp932o^>yh`Aq8Jj%qGwX<13}RzDWfb%RpAaCYk3!~=RHo1Jw|UEVq}nlUot(W9CE z?ay!UWk+jntUg^PjG5e(MCYtZfomwaH!n}HyliJ@2jWQAr6G63$%~zE)f7Pu;598~fPt6K68DD`K~(Jvw#< zKtidsxd#t|1^6UQ0o1c~+M0d4v0c!C%ai1U?JxFr7xp?XrP%2sG11yO_i0^oJUOqp z=!46cf$8=}ax3yWJ2P`5JA_f*!7RR%FA29kzM{>I4kX5HImhT z2q7+7-Dpmw+e@!{XZB3-)Xx^jLd-uX9F?1Qz62#Tl#vrOTA5vQ-@fzO=H@}wHP~+f z&EmIj-~Js+A6t9(qQtNCUYnHx)?%#UBG!XPr6lVWw0+{*(&a}+M~i|R4?^?MJgQ*! ziLx*=1Eb*2X+xk8wV)yam>otmEXo-OP>D^6KMp?Z_gmt$eE37i*H~tMpwyXjCs(uV~3_I2+;doHWe1aXoh3A>J{8eU!Q`#gf9h^w76er#eKBOFQ)B{K{LC!`lfds;vl|re#X#myW_N2ZGGF-`GMX}cw@ygHwMxWc zpv2Iz+!(ZIFmF@uWG7vJ92c)yMj;bx@!_V?^V3)ikGzKBITlTdxzHU&}X!-<2%?%wq&wWC#E z$K|mVWUxa5phR=QaX=UWb;38dzj@OQdY$FHXOGNp7cMEDXAVx=-M#uU__W*VsY54z zHcnrGzxRk^DrZ9F^Da#uwY$K62B!6%ljBRp=oJB5U)!87wq12mYcovQl$F8J_7Yk; z+#e(k9>6EAnWP+oA*jfV7cUYH<>rNRMuL-E;~~yS8>+usSa`UWmR51co7L5@!*vfL zLPKM0;#t`feUy7~^XFb>spSgTjM#vS+Qw-4QaI)O05&n~W6s%z;V-8;%PS;QB2q?dwb8QKK^m+uiHVZnq2v?#OL^(0}8z zMyPVNZ`V!H)6{$hP@N>MJu60d{W7k~xyDTc`X3&f=14~Q+ZBL;K$EPEMyJTg@_WFZ zD!$>SeoKd-+T#L&<8lls3cTZh;B{a6`Y^%6vgP9^!tG0C_O~lxY6on0Qib#f=La`Q z(C}e>g&0{`acT?!n`JSEnnqcHf%~AN8}1^+78!77yWNE841(QOsgqOYNWfnI3CDVF zZdO*-?yZGAqeBdHbz>!?JM#fB3bG5jI;Ha62r^TIqyVhPkD}=}3-ClKdnBFqON-d6)je{GqofNxJ%HK#; z+|2B*>Da3h6H7~<_eSO-3u-;OSZrx{N`a28%Bzy8cCA~tJ{*%@NYf)eGH!+mZEka%dWw8n zPqv27)adJ_(+!OuK&D`t)Gq@)>8tnm?^F&ua>!H!v}}2OTf8cAR-i`*JYB(SvU$Q? zP_*cZqM{-z^M>kRZrrTA`i(o+B7ve}LDdfB5X+d39y=x|!mGye(vaYsrmkN!a_N%G zu3us3lT*{4{!;=df;)nnyWZB$p=+Y+^cc@fJ;Ugqm+rR=l-4ZEnk-dZlwSkjmBE_q zYtU=x4Bm}x&1_59L!viZ`d8bW{EhppI&#L1vd_GKA1x=U3|n$jn>GArlL9*CkF<%# z7pWz1>gY|HU^d+IbDV1r9@=uc^r6=xBP+{yzf*B>@-tF_VQKYL8ULcQPh)M9W0M70 z>ZQ3kb1)!IhYuVIA)`lpda4|JJpwXde=3L1i>YKvQA!ZdZt&WnC`89j&)SucJe+*` z?mhnom=}aGenrI~8NcsTUoTQwp$~P&3d-j_Eh}Z&V~nvc$b!dlOm2B` z{K&8Ln%dpMU@+b~<4QhN=V!dL6MlH5BVNKd;_`L{55P+XrFT2DV4{&gAh>_w>yMNc z$OVzD-c4+dppfUtlFMjm)wPEQRsi@`&sPwcI5=)>#j63 z(4FMsDryWq2-L$_g*r_bU@I$>SFH8k({dcF=BSV_H2(6wq#@FAI9fnNLJ=rCO%09m zK~ho6jJwaZk4uM3gjE-6>XaNeKBBMzy0e36+xIsGh2x6I@9!kZyY2X}{Px?lT=@Fi zeE`%8S*quO&m`WwX-mh{swGi3Gc(g}@1C3vtDc96c8-rk$QAog_S z)t6)1&WfNePvC4ld&m+Laq;tKd&C)87&AY85{B?glHc}}PHGpZnVjiq!rQLNI1H{@ zg68<6t1-N;`sRv3Vq(~O!z`Pgiyi)|bNWTo%M&-&*4NISlQi8t@DNC*u3VRto{Ka8 z#e+B{il6?P$)uzlBE%d6$gPCU+3 znmveJ8fYVu$+=k5fE~s{blug;%1srG4oxSgqV+jaVQA=_YZbQcC=$t`r>pyhNkmZJ z1(6G0OKXz}MKkXXNws}`t7mIVpslVHo5P16%l80J^38SA!@`A-=(B|$>5b*2mM}$& zM%%;#ZMAgR9^Ss1HDZEMiPuXNrWdwa1IOWipkAE$l2#+*Kl`Y|Zho{*d4=u?*gt1& zZ~rV!J=FWz9T6QZ%TI50i3L`w52Y~07FY@xr|fy%nj7yXL3Jkif~-b?kWN+e;Nl-w zF@CZ>H=14$Cfp_}_`J9DFf}czrFt6SZEM8D#G=uf5L4vw_%iD$ zWv)D56VDXTwC=2~>92ih3=tQV(%{DZo+N|0^)!}k^}`8tW%}G%RK-m?<&a}+Q7Pze zbAldoMj_~*jdidQ!{N=u1&@ffZeAgA&-u$py?Nc9rr4&Wg&2SQ<`fkG?<*RYm#RSY zQ`i6T<7*xp{RU-QJDV;DxU?NDs)ljk+}qci*ww7V&u8C6a@s@F9weR0sl4)XeNtIX zc16W6A}E62dyhj0f624&x+9HJhcPwEmv=RTbpb^L0&e*AIfzMu#@`N~1^X-t^f-e7 zW)U9x^Mu=PRU_};zg%Csw(33_Jr0HO>Y&0-`h3;GPnI2RS|00{F&nEnC9c^XbJUOg zfqf)Wx;}bSwh-l;GTGMJ2j}?BU8b+oS<820zWX5^#`BGcWCE&T<&>YTeioU0@yOw$ zS~rZcBBP=h+1c}G?P+gfUoAG;*51B?vJf#gc6-OC^)7bjr4u<#4NYuNJ@w7mEByJe z;|8a4x$ku>7Au1xKY;P(Od>HxpvY}Aw9mC_Smt%Wg4{-pMVjZO4;l<+Z3qNXTRRd~ zrsE*84IO$!ZkSJ`wfoDLz;mY6IrSkM8q>NmEc&D(a%`QK@y768Ab{FX{o_2#x3wQ1 zMnIj$&CN}l^Buhx_bf4|^%UEsgnj$`pU1y!p90y8)S~j}PVJfZ^=k|P zdvzH6j^KgK#L&l&d$_jWd19!mh@ItFh4erELb>;4@tl8~NbL6{3`t?zofOYxW%IU{ z2#>xdDviF5ahH2A!E*S{SLff%1Kxf54e&uwEM9PNaS083)S0Wp|EnFg9hxH7Hxx78 zhQAN!tg&ot*6Ls=_Kn5AOI!_=vuB{3Z|fve$Nx-8@Xvim7iYw}ODzmz1U=_cnN!@1 z%WLxsjYl*8(I(FudITuFYJ6`LoDm#MG!FjD_#-YX9T|doLq7lT@87fUlb1&TrkGle z*3)$O=l}lv6K$P!S~0oyzuY%wEVO@+i|$)wsIurn|KCoiw4dF6YjNrN4+mRh=!v{; z{o|*yQfzLPfi|a@i1@QFYf7QM7t7M9gVXjSmJ|1Gby?)JC^PQqGEtC*HpbwLmXuEn;EdwoU#$ygfB5?V_vg zvUQ#Jc6_rP-d^JHY;GxZdB99CwO6sc^NqIo7o_ z{e-J@Uw3!G{zL09apg9$3GQ~fWzNN7Vx=b;8M*7ld%H$p;Pt2i;{h}r9{cbu{FNK~%5vG%pV`6Yq$y;S* z3*WE!dgy-_j)H_7oliV_;WXl>pYA~**V<|DnH$_p^YQV;P9B9@ACHG?v z@?Zz7$AWe9=2x#ij}bwoWqcceuDwu%%dUU^NZ(W0jYeUkH`f7xi1S}B4T$NP=_RbO z0qU%JuK!tke^P&uGu=T9@;upY1`9PCIN0kVOSi6g zWdU$q9a~$fNW|0I%!24Q*QKFQyLAint`!FlQjzF@tBi~!7=Rj!wd>v4P{@Hf^6$5{ z09@2j1TB!<)O1&npeXuPw2j-{ zX{)qN@dl7;b+)tvWGGq^Q+b%oLM0%#jNpN3>vXR+vWd3Nt!o6zfpir#tJSo5NT^*f zU%r?Q(CfT(E5(dr8NUBgc7#s#O{)9zbEXA4s9|rz$nKttz*?t=hCl8LA&n#~QeVDw z!@JKMNy;zOvokIYJ@RDjL%??w%EqpzFW%;aJ%wPA6 z2e#}Gl;TIr3d!qw>X&;av(?NG;x|AyZ8X);TYt3T+9N!|3Gp#YDbsNUU3E`Y_ zJoV?J6B4qsYpEEAk?kTVS3Vr=r`5Iqqr(`S+EhDINQUo*^vbf|q@gC^CWH#4OY=3k z)l6kzk+bszJI0kcy-fnv^aG?PsKfKc7w8ok9DH;^*-Yy}Yifo=A3f5(J?7Vz5St!r zN;QVkPHoHg3v97q>r^L*fQmKg3^z9vvQ;BfTZh;^C%{oWGRw(tWrG(Hu+zV%1Mi|A z%>wMtFK33=I*@{#MFBtqZIB))h(0mmr9jc@Ppyq5l1zpl_yRtmqJ5B!P+=R zoxP~LXk=3=W$IOWdbY__^Srt1vVEbkXC3W3vJ1QKNofvE;Tvn)E2CZe8SJ}XUd;aH zQN=G@1?w49bV3W%MpLKioh?B;+>EvLb+Rhj#{gjSE=V6b^}>!{TKqF+2H7Ykv6XU%uREI_P~23$Tusw!?$X0{4@Fz zIAcXi`OZbOcXzImH9A@ZX=-{84wECKZ^Zv8HWq!hwZ#3)Th5f3t&O?$%PIQPv2zmi ze{OEJ;A!38K6fIy&THv@$9Q11qdjAn^2(F!{;%&FW=WOmJ!3utEp@nn2_ zX=DcMgcPq4<9@bgy#z^F7zD| zzUnPu)iG*otP+>S3ZP#D;r1r|^M8ZjUCAno$Fx%FZ4Eid!8kf9fgjMAB&lDoB9dQs zzr9k|q3IXtKB1B?+^X&8SB)-{kP$RGopw5}N>eDib#n&YJL^GnC!$kf5)`w&!=IJ< z_U+*w=o+z{4D|FLON0-Mn2pT10_FvlnyW)@qr}{vCTNBbYO!qm?)wuY?852mHE(Mb zA9)h$^xf$9+hhK6DKat&T6O*%otS&+r{CmSJJr2fU(XjrX=ZhP`7NmkBr-Zd8n4^A z?zXKzh)xdJeVEXGg7f#&YM(As>HEAdn%9elhmD{EW?69O|9CqeYaRuW26l9TP3IIP z6Bc9^zFkt!&NWSk8I!efu03h4f9K?e%x?q)y+fPt-xuiHV{pX=93Xbme+t(C#J~DB zKX*9^`lZyL_Xq8i6kdIII+91(Y1E-@@4M3uME6OWZdTTFP801^1oukav6d+oI{t*u z!hI8o%)gXwCw3@+tGWfVQHjM%J)A*0ZO(Yk0|X8ysBJ|7ys@pkh$F|=duzy_e}@20 z4la_YO^;N#l%$xFGd#UvVNO2aUN!8q0>W<4v`tJfofRGJ5y`EpQZ+8KCqAT`+9`2* zcl8}B3kwn2-xakf8^_uu=TLK0iDQG9@M!$gkq9*@dh@}EHbBSLW=luAJ3F6&%X}uh z7&Rzzve#Fk5|)dl?-p-W{`)%Z+xs&RE_zS718~SHbDLnp3MpF8X@UR!*%*tVKgQg% zhrNSu$liLWWMksk53?J zM}SEZ5L9GGe$_@%W_6VwW}g`R@{B)loZS^%C)eGu$JW=^!BsaPO(ZxC{JR(#nQR)s zhhe$7i0rgG8K5>TFUb*n@Q`KcKwq!BcQ=KNlckoQTZV~MOk~6#t&?e`z`S0Xe5}~oZ&v>m&MP=*Lt2FU%qt=KY3W= z!KS~B*inE^N4h-RF`hPNsc5&m*=NsxAu65(A1Fj5tEkj1uX7^2ZAEKr6wQ-NUyY+G zDjsN{Je-|1AurPKq2@UcArX<`EfYJ{QsLI_p-Q)fimmQK14p}6X8-l!X!yTqp+c(l zln2M9*ZS|?y@PsYwN+lS+)o(Mk}SL6wq**eMI=e?>j`4y<$9hGGP~O`pZ2A|z`&|n zHOE%MZK-P6|9fD8zNBfVV|VW!ZzY}z=^)%BQsSI+;JPFEt%Ay~&qTSHE9=2ez`u-^@Dk>Z5k2+#e z&3GP#=%N4@h%ga*-AoXSJLXO<0u4 zwPBI}sVJAcut9&7g^O$NWn#c{Ev?We2^I5kUHiVgeVdA2U;12}4qzmO=oIIC4vZXf ztNjM#_DmPZ^N}`#FJ#X3T9*#E?_t@TDov*F#}L{oc)XH8t_{rI>j3EqSo-|MJxJ@cENNA{E0UBio&S2#8MMjy zg@tS3iVBR3val~eCS$9<0C427=lWnB0gwrhC}cAKGYF6p>On0zF)>MbX_c&RKF-^4 zy(#ClbuF1}3rO2|IaNYZJO{?ySDu_Y3xjn4_}b17c@sPed-!`L@76bloMbzZPNn)_ zOetWV_vi>+=!8cVX8MbNig)?$B#Jk{Jcg6n%`Ny*RJ&*5APnFM%5kfLTA8{Q(?$c5 z(&y?l(fkm>8lNW6Jl1OEH7auR$ghXyn*)mIfBjVx+~7A{EUstJD;m8{{UlqMHuegK zqP*bY<>Q%wy&k$ITA$iF*mXew>;{QBTr1rvviq7XiGwShG|)6T$%mXB#DRQr8m1Q& z!68a(?@Ha*JL5DM5jLUYkgpCH?8t5=I*Em|%jX>6we%s+!0vJ1E>tF}PfRdcTU*}* zo=pmc%g#2&<0Sxt7L{9KL^*6cIJq&K+qt-ybo7vS8cq-BAE-*}a6Q@Kb{}V608@-v zn-M^#SMSALbU1Q&i9XZ1GyHEH3Zi(UwVB=B?Wx+^CJV0^Sy-~dR=*uy>FqVu(}*yC zzYR-7YTUJQl}ahH-k~0CX=?+fA{dG$ywj*7QrA9~G`IEe72GB8V!>N$Rfejn^nuTv z)To~tI8n@m?>APD)d7ubD6Qq(R9eAXG`m)ssDl@X-RQ2I{K~HFN*!RS3}?ZN-)%A@ zr)DS5f7i)L=(6xo(LE8U2EgVai_`m?3m6=OPm~srI@*f$N|u(E8gT)D@yDYL3SgXa zV(Qe#E``*_EY-Y%A?e#W1fW@KwwFik`p6P3t!?_YWWl3HkHS2UBFWP))eYb0S-mqi zr;qnu>3Cz?Cqq*-lXfWIn$1VXIQhAGcyvJ*_TjC;Z~=clgpPD-ljLYdVF-bui3e$?74Ebi>`C z(V2ijD3_afw8o&xVILk5v10n7a#Ou`;>l6kM0efIwp&wf|6vb1f5j|Ny0B=$ zeb_JK)Rq;#$9ya=Zu-|kBST@|K#*eFl@_JODry9eX znaO9{_3ARP3WIn`h0hjshVXB~p@ku{M%JVDn+jtVhT6Ioae837uc;Zx17rBtl#n4d z79YSBMLO~_3NPFmdD|=4;Zv(x)Ucz@l|Yntr40ndw9{9ON(t9xJvn0QFTBWw#VfoTyAd+}zRQbx_>eZi;=MB^E72MyZU$|_3wQyoM5Rj!hpn(V&Kq^2@7aDF z&+ri(I{bUKE9p*Mjz%pK`8PyNa&D&p^)CS{}w9L?FJ_kLd@FWpKXv?Z#RxO?I zB|C1^REM4@EuO7NIKR5ZZ{Jb?u!Juc6>UHD_f5Tqb9IPsY}lrtqf{6j8tlDD5gRzT zxUf<5dQf1&ZW;Fap#}KrK#fY=B#r#qnKm_Tf=gNo96X%x^m8@eZs{JMtOl65IesA# zhSIsk`+H3(8OY2Qi$UVi+wsm)h%`hNA_7Ux^ zz7_1(dCiD?5+*&oM4u(CmxWxX(b3!=u8r56s@`|D@Mi`!;e%Lb=t8F^Cg z^()8pM^Sh~f-1WZ2YN))RDZZ+Mdtz#6M)9a6x2(d(~L1@wOp?A?0MB2o0qq2$~adW z7DPLCdRlMi+p*$PI@8pM5O%_LVE4;zG&aJ~JYI2=Cn`jEY^B#=?^xyN-13AFYqI%d z8As&qaVp*)&&6)qt@d;&#s`xLrcD0|sAvxKOl$HSBVD@8tQJ4SFKVS8+eY(|y!!CJ zT~5kx83#X7xVVFi{&hUmz}|Os@+$w)PBoOx%(4359U8V6`>qW)g`FXnZtwM#INPwL z2wNZ~pj`l!r#<75+8T#AoU+RJCeIA2r3L&d=VdQVN@CNrj-^qtlwn}b2t2!@km-8||b7Q0zWU@lj=i3-EdfO26Hdtg-+ z6CX4ifI1}ESz3D42RHmC8?47=EwDi{!i(u*b8;)q>QfW|0`YMO!yTI{w6L;tN%jQ! z6Y|qYR4yF$1P9PO6pD=l;t`HFD>S;VF*+zDr8KRrZQoj?@1J^Ke*3K7h|W12+;G#% z0`9&Rk;^|L&fTyh^v2PAHrs4aJYtHzlxL=#V?KOOz@#*US=Bw2P`AfJv*%1(Ixhza zLSAMFhxgp{`FlcP+zjJ>XcGmrnAy@H>A&b)d;M-I_7`dYcL~aAZ4o8-R~Eb3!A zFco4Qx76}8(*XHLUh6#5h?rPID;pZT%4Q>D`h!G_>VW~>wchh!s%!l&vWJy)eq@cr zEDHM?i@(r-tb~JvD5ic%2{3!TXpw2IdH3ls<*h!O+M^EvReguhDG&sHf5%J2v<(C< zhm(pflfCs#*@|{||EVHVVWp?12h0ZygGP^V3Jt98ji6GV zc5XQP$yot`NV@$r!CLyy>4LKX7!1#1ruTyN;~Uh%<@wRwbisi{C2{^2YXI!>4feCf zVqR1i4&NGvKuDwUuSQhJWi@#-4j2J~$YZf2v1s?*gQiLfPaKXM+|q$iUI0e~McK!| zmGa`dymgTOE1GNQ=_*4G0?8_;!1CHvWAW91n!/geth.ipc ``` The Javascript terminal will open with the following welcome message: ```terminal - Welcome to the Geth Javascript console! instance: Geth/v1.10.18-unstable-8d84a701-20220503/linux-amd64/go.1.18.1 @@ -98,52 +87,41 @@ at block: 0 (Thu Jan 01 1970 01:00:00 GMT+0100 (BST)) To exit, press ctrl-d or type exit > - ``` -In the [Getting Started](/docs/getting-started/) tutorial it was explained that using the external signing and account management tool, Clef, was best practise for generating and securing user accounts. However, for simplicity this tutorial will use Geth's built-in account management. First, the existing accounts can be displayed using `eth.accounts`: +For simplicity this tutorial uses Geth's built-in account management. First, the existing accounts can be displayed using `eth.accounts`: ```shell - eth.accounts - ``` An array containing a single address will be displayed in the terminal, despite no accounts having yet been explicitly created. This is the "coinbase" account. The coinbase address is the recipient of the total amount of ether created at the local network genesis. Querying the ether balance of the coinbase account will return a very large number. The coinbase account can be invoked as `eth.accounts[0]` or as `eth.coinbase`: ```terminal - > eth.coinbase==eth.accounts[0] true - ``` The following command can be used to query the balance. The return value is in units of Wei, which is divided by 118 to give units of ether. This can be done explicitly or by calling the `web3.FromWei()` function: ```shell - eth.getBalance(eth.coinbase)/1e18 // or web3.fromWei(eth.getBalance(eth.coinbase)) - ``` Using `web3.fromWei()` is less error prone because the correct multiplier is built in. These commands both return the following: ```terminal - 1.157920892373162e+59 - ``` A new account can be created and some of the ether from the coinbase transferred across to it. A new account is generated using the `newAccount` function in the `personal` namespace: ```shell - personal.newAccount() - ``` The terminal will display a request for a password, twice. Once provided, a new account will be created and its address printed to the terminal. The account creation is also logged in the Geth terminal, including the location of the keyfile in the keystore. It is a good idea to back up the password somewhere at this point. If this were an account on a live network, intended to own assets of real-world value, it would be critical to back up the account password and the keystore in a secure manner. @@ -151,23 +129,18 @@ The terminal will display a request for a password, twice. Once provided, a new To reconfirm the account creation, running `eth.accounts` in the Javascript console should display an array containing two account addresses, one being the coinbase and the other being the newly generated address. The following command transfers 50 ETH from the coinbase to the new account: ```shell - eth.sendTransaction({from: eth.coinbase, to: eth.accounts[1], value: web3.toWei(50, "ether")}) - ``` A transaction hash will be returned to the console. This transaction hash will also be displayed in the logs in the Geth console, followed by logs confirming that a new block was mined (remember in the local development network blocks are mined when transactions are pending). The transaction details can be displayed in the Javascript console by passing the transaction hash to `eth.getTransaction()`: ```shell - eth.getTransaction("0x62044d2cab405388891ee6d53747817f34c0f00341cde548c0ce9834e9718f27") - ``` The transaction details are displayed as follows: ```terminal - { accessList: [], blockHash: "0xdef68762539ebfb247e31d749acc26ab5df3163aabf9d450b6001c200d17da8a", @@ -189,8 +162,6 @@ The transaction details are displayed as follows: v: "0x0", value: 50000000000000000000 } - - ``` Now that the user account is funded with ether, a contract can be created ready to deploy to the Geth node. @@ -200,9 +171,7 @@ Now that the user account is funded with ether, a contract can be created ready This tutorial will make use of a classic example smart contract, `Storage.sol`. This contract exposes two public functions, one to add a value to the contract storage and one to view the stored value. The contract, written in Solidity, is provided below: - ```Solidity - pragma solidity >=0.7.0; contract Storage{ @@ -220,28 +189,25 @@ contract Storage{ } } - ``` Solidity is a high-level language that makes code executable by the Ethereum virtual machine (EVM) readable to humans. This means that there is an intermediate step between writing code in Solidity and deploying it to Ethereum. This step is called "compilation" and it converts human-readable code into EVM-executable byte-code. This byte-code is then included in a transaction sent from the Geth node during contract deployment. This can all be done directly from the Geth Javascript console; however this tutorial uses an online IDE called Remix to handle the compilation and deployment of the contract to the local Geth node. - ## Compile and deploy using Remix In a web browser, open . This opens an online smart contract development environment. On the left-hand side of the screen there is a side-bar menu that toggles between several toolboxes that are displayed in a vertical panel. On the right hand side of the screen there is an editor and a terminal. This layout is similar to the default layout of many other IDEs such as [VSCode](https://code.visualstudio.com/). The contract defined in the previous section, `Storage.sol` is already available in the `Contracts` directory in Remix. It can be opened and reviewed in the editor. -![Remix](/static/images/remix.png) - +![Remix](/assets/remix.png) The Solidity logo is present as an icon in the Remix side-bar. Clicking this icon opens the Solidity compiler wizard. This can be used to compile `Storage.sol` ready. With `Solidity.sol` open in the editor window, simply click the `Compile 1_Storage.sol` button. A green tick will appear next to the Solidity icon to confirm that the contract has compiled successfully. This means the contract bytecode is available. -![Remix-compiler](/static/images/remix-compiler.png) +![Remix-compiler](assets/remix-compiler.png) Below the Solidity icon is a fourth icon that includes the Ethereum logo. Clicking this opens the Deploy menu. In this menu, Remix can be configured to connect to the local Geth node. In the drop-down menu labelled `ENVIRONMENT`, select `Injected Web3`. This will open an information pop-up with instructions for configuring Geth - these can be ignored as they were completed earlier in this tutorial. However, at the bottom of this pop-up is a box labelled `Web3 Provider Endpoint`. This should be set to Geth's 8545 port on `localhost` (`127.0.0.1:8545`). Click OK. The `ACCOUNT` field should automatically populate with the address of the account created earlier using the Geth Javascript console. -![Remix-deploy](/static/images/remix-deploy.png) +![Remix-deploy](assets/remix-deploy.png) To deploy `Storage.sol`, click `DEPLOY`. @@ -250,13 +216,11 @@ The following logs in the Geth terminal confirm that the contract was successful ```terminal - INFO [05-09|12:27:09.680] Setting new local account address=0x7Aa16266Ba3d309e3cb278B452b1A6307E52Fb62 INFO [05-09|12:27:09.680] Submitted contract creation hash=0xbf2d2d1c393a882ffb6c90e6d1713906fd799651ae683237223b897d4781c4f2 from=0x7Aa16266Ba3d309e3cb278B452b1A6307E52Fb62 nonce=1 contract=0x4aA11DdfD817dD70e9FF2A2bf9c0306e8EC450d3 value=0 INFO [05-09|12:27:09.681] Commit new sealing work number=2 sealhash=845a53..f22818 uncles=0 txs=1 gas=125,677 fees=0.0003141925 elapsed="335.991µs" INFO [05-09|12:27:09.681] Successfully sealed new block number=2 sealhash=845a53..f22818 hash=e927bc..f2c8ed elapsed="703.415µs" INFO [05-09|12:27:09.681] 🔨 mined potential block number=2 hash=e927bc..f2c8ed - ``` ## Interact with contract using Remix @@ -265,23 +229,20 @@ The contract is now deployed on a local testnet version of the Etheruem blockcha After deploying the contract in Remix, the `Deployed Contracts` tab in the sidebar automatically populates with the public functions exposed by `Storage.sol`. To send a value to the contract storage, type a number in the field adjacent to the `store` button, then click the button. -![Remix-func](/static/images/remix-func.png) +![Remix-func](/assets/remix-func.png) In the Geth terminal, the following logs confirm that the transaction was successful (the actual values will vary from the example below): ```terminal - INFO [05-09|13:41:58.644] Submitted transaction hash=0xfa3cd8df6841c5d3706d3bacfb881d2b985d0b55bdba440f1fdafa4ed5b5cc31 from=0x7Aa16266Ba3d309e3cb278B452b1A6307E52Fb62 nonce=2 recipient=0x4aA11DdfD817dD70e9FF2A2bf9c0306e8EC450d3 value=0 INFO [05-09|13:41:58.644] Commit new sealing work number=3 sealhash=5442e3..f49739 uncles=0 txs=1 gas=43724 fees=0.00010931 elapsed="334.446µs" INFO [05-09|13:41:58.645] Successfully sealed new block number=3 sealhash=5442e3..f49739 hash=c076c8..eeee77 elapsed="581.374µs" INFO [05-09|13:41:58.645] 🔨 mined potential block number=3 hash=c076c8..eeee77 - ``` The transaction hash can be used to retrieve the transaction details using the Geth Javascript console, which will return the following information: ```terminal - { accessList: [], blockHash: "0xc076c88200618f4cbbfb4fe7c3eb8d93566724755acc6c4e9a355cc090eeee77", @@ -303,26 +264,20 @@ The transaction hash can be used to retrieve the transaction details using the G v: "0x1", value: 0 } - ``` The `from` address is the account that sent the transaction, the `to` address is the deployment address of the contract. The value entered into Remix is now in storage at that contract address. This can be retrieved using Remix by calling the `retrieve` function - to do this simply click the `retrieve` button. Alternatively, it can be retrieved using `web3.getStorageAt` using the Geth Javascript console. The following command returns the value in the contract storage (replace the given address with the correct one displayed in the Geth logs). ```shell - web3.eth.getStorageAt("0x407d73d8a49eeb85d32cf465507dd71d507100c1", 0) - ``` This returns a value that looks like the following: ```terminal - "0x000000000000000000000000000000000000000000000000000000000000000038" - ``` - The returned value is a left-padded hexadecimal value. For example, the return value `0x000000000000000000000000000000000000000000000000000000000000000038` corresponds to a value of `56` entered as a uint256 to Remix. After converting from hexadecimal string to decimal number the returned value should be equal to that provided to Remix in the previous step. ## Reusing --datadir @@ -330,9 +285,7 @@ The returned value is a left-padded hexadecimal value. For example, the return v This tutorial used an ephemeral blockchain that is completely destroyed and started afresh during each dev-mode session. However, it is also possible to create persistent blockchain and account data that can be reused across multiple sessions. This is done by providing the `--datadir` flag and a directory name when starting Geth in dev-mode. ```shell - geth --datadir dev-chain --dev --http --http.api personal,web3,eth,net --http.corsdomain "remix.ethereum.org" - ``` ## Re-using accounts From fc9edf08ca6bafc942c41f01a6862e600c2c02c1 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 2 Aug 2022 13:51:18 +0100 Subject: [PATCH 021/432] migrate vulnerability list --- vulnerabilities/vulnerabilities.json | 170 +++++++++++++++++++ vulnerabilities/vulnerabilities.json.minisig | 4 + vulnerabilities/vulnerabilities.md | 113 ++++++++++++ 3 files changed, 287 insertions(+) create mode 100644 vulnerabilities/vulnerabilities.json create mode 100644 vulnerabilities/vulnerabilities.json.minisig create mode 100644 vulnerabilities/vulnerabilities.md diff --git a/vulnerabilities/vulnerabilities.json b/vulnerabilities/vulnerabilities.json new file mode 100644 index 0000000000..bee0e66dd8 --- /dev/null +++ b/vulnerabilities/vulnerabilities.json @@ -0,0 +1,170 @@ +[ + { + "name": "CorruptedDAG", + "uid": "GETH-2020-01", + "summary": "Mining nodes will generate erroneous PoW on epochs > `385`.", + "description": "A mining flaw could cause miners to erroneously calculate PoW, due to an index overflow, if DAG size is exceeding the maximum 32 bit unsigned value.\n\nThis occurred on the ETC chain on 2020-11-06. This is likely to trigger for ETH mainnet around block `11550000`/epoch `385`, slated to occur early January 2021.\n\nThis issue is relevant only for miners, non-mining nodes are unaffected, since non-mining nodes use a smaller verification cache instead of a full DAG.", + "links": [ + "https://github.com/ethereum/go-ethereum/pull/21793", + "https://blog.ethereum.org/2020/11/12/geth_security_release/", + "https://github.com/ethereum/go-ethereum/commit/567d41d9363706b4b13ce0903804e8acf214af49", + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-v592-xf75-856p" + ], + "introduced": "v1.6.0", + "fixed": "v1.9.24", + "published": "2020-11-12", + "severity": "Medium", + "CVE": "CVE-2020-26240", + "check": "Geth\\/v1\\.(6|7|8)\\..*|Geth\\/v1\\.9\\.\\d-.*|Geth\\/v1\\.9\\.1.*|Geth\\/v1\\.9\\.2(0|1|2|3)-.*" + }, + { + "name": "Denial of service due to Go CVE-2020-28362", + "uid": "GETH-2020-02", + "summary": "A denial-of-service issue can be used to crash Geth nodes during block processing, due to an underlying bug in Go (CVE-2020-28362) versions < `1.15.5`, or `<1.14.12`", + "description": "The DoS issue can be used to crash all Geth nodes during block processing, the effects of which would be that a major part of the Ethereum network went offline.\n\nOutside of Go-Ethereum, the issue is most likely relevant for all forks of Geth (such as TurboGeth or ETC’s core-geth) which is built with versions of Go which contains the vulnerability.", + "links": [ + "https://blog.ethereum.org/2020/11/12/geth_security_release/", + "https://groups.google.com/g/golang-announce/c/NpBGTTmKzpM", + "https://github.com/golang/go/issues/42552", + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-m6gx-rhvj-fh52" + ], + "introduced": "v0.0.0", + "fixed": "v1.9.24", + "published": "2020-11-12", + "severity": "Critical", + "CVE": "CVE-2020-28362", + "check": "Geth.*\\/go1\\.(11(.*)|12(.*)|13(.*)|14|14\\.(\\d|10|11|)|15|15\\.[0-4])$" + }, + { + "name": "ShallowCopy", + "uid": "GETH-2020-03", + "summary": "A consensus flaw in Geth, related to `datacopy` precompile", + "description": "Geth erroneously performed a 'shallow' copy when the precompiled `datacopy` (at `0x00...04`) was invoked. An attacker could deploy a contract that uses the shallow copy to corrupt the contents of the `RETURNDATA`, thus causing a consensus failure.", + "links": [ + "https://blog.ethereum.org/2020/11/12/geth_security_release/", + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-69v6-xc2j-r2jf" + ], + "introduced": "v1.9.7", + "fixed": "v1.9.17", + "published": "2020-11-12", + "severity": "Critical", + "CVE": "CVE-2020-26241", + "check": "Geth\\/v1\\.9\\.(7|8|9|10|11|12|13|14|15|16).*$" + }, + { + "name": "Geth DoS via MULMOD", + "uid": "GETH-2020-04", + "summary": "A denial-of-service issue can be used to crash Geth nodes during block processing", + "description": "Affected versions suffer from a vulnerability which can be exploited through the `MULMOD` operation, by specifying a modulo of `0`: `mulmod(a,b,0)`, causing a `panic` in the underlying library. \nThe crash was in the `uint256` library, where a buffer [underflowed](https://github.com/holiman/uint256/blob/4ce82e695c10ddad57215bdbeafb68b8c5df2c30/uint256.go#L442).\n\n\tif `d == 0`, `dLen` remains `0`\n\nand https://github.com/holiman/uint256/blob/4ce82e695c10ddad57215bdbeafb68b8c5df2c30/uint256.go#L451 will try to access index `[-1]`.\n\nThe `uint256` library was first merged in this [commit](https://github.com/ethereum/go-ethereum/commit/cf6674539c589f80031f3371a71c6a80addbe454), on 2020-06-08. \nExploiting this vulnerabilty would cause all vulnerable nodes to drop off the network. \n\nThe issue was brought to our attention through a [bug report](https://github.com/ethereum/go-ethereum/issues/21367), showing a `panic` occurring on sync from genesis on the Ropsten network.\n \nIt was estimated that the least obvious way to fix this would be to merge the fix into `uint256`, make a new release of that library and then update the geth-dependency.\n", + "links": [ + "https://blog.ethereum.org/2020/11/12/geth_security_release/", + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-jm5c-rv3w-w83m", + "https://github.com/holiman/uint256/releases/tag/v1.1.1", + "https://github.com/holiman/uint256/pull/80", + "https://github.com/ethereum/go-ethereum/pull/21368" + ], + "introduced": "v1.9.16", + "fixed": "v1.9.18", + "published": "2020-11-12", + "severity": "Critical", + "CVE": "CVE-2020-26242", + "check": "Geth\\/v1\\.9.(16|17).*$" + }, + { + "name": "LES Server DoS via GetProofsV2", + "uid": "GETH-2020-05", + "summary": "A DoS vulnerability can make a LES server crash.", + "description": "A DoS vulnerability can make a LES server crash via malicious GetProofsV2 request from a connected LES client.\n\nThe vulnerability was patched in #21896.\n\nThis vulnerability only concern users explicitly running geth as a light server", + "links": [ + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-r33q-22hv-j29q", + "https://github.com/ethereum/go-ethereum/pull/21896" + ], + "introduced": "v1.8.0", + "fixed": "v1.9.25", + "published": "2020-12-10", + "severity": "Medium", + "CVE": "CVE-2020-26264", + "check": "(Geth\\/v1\\.8\\.*)|(Geth\\/v1\\.9\\.\\d-.*)|(Geth\\/v1\\.9\\.1\\d-.*)|(Geth\\/v1\\.9\\.(20|21|22|23|24)-.*)$" + }, + { + "name": "SELFDESTRUCT-recreate consensus flaw", + "uid": "GETH-2020-06", + "introduced": "v1.9.4", + "fixed": "v1.9.20", + "summary": "A consensus-vulnerability in Geth could cause a chain split, where vulnerable versions refuse to accept the canonical chain.", + "description": "A flaw was repoted at 2020-08-11 by John Youngseok Yang (Software Platform Lab), where a particular sequence of transactions could cause a consensus failure.\n\n- Tx 1:\n - `sender` invokes `caller`.\n - `caller` invokes `0xaa`. `0xaa` has 3 wei, does a self-destruct-to-self\n - `caller` does a `1 wei` -call to `0xaa`, who thereby has 1 wei (the code in `0xaa` still executed, since the tx is still ongoing, but doesn't redo the selfdestruct, it takes a different path if callvalue is non-zero)\n\n-Tx 2:\n - `sender` does a 5-wei call to 0xaa. No exec (since no code). \n\nIn geth, the result would be that `0xaa` had `6 wei`, whereas OE reported (correctly) `5` wei. Furthermore, in geth, if the second tx was not executed, the `0xaa` would be destructed, resulting in `0 wei`. Thus obviously wrong. \n\nIt was determined that the root cause was this [commit](https://github.com/ethereum/go-ethereum/commit/223b950944f494a5b4e0957fd9f92c48b09037ad) from [this PR](https://github.com/ethereum/go-ethereum/pull/19953). The semantics of `createObject` was subtly changd, into returning a non-nil object (with `deleted=true`) where it previously did not if the account had been destructed. This return value caused the new object to inherit the old `balance`.\n", + "links": [ + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-xw37-57qp-9mm4" + ], + "published": "2020-12-10", + "severity": "High", + "CVE": "CVE-2020-26265", + "check": "(Geth\\/v1\\.9\\.(4|5|6|7|8|9)-.*)|(Geth\\/v1\\.9\\.1\\d-.*)$" + }, + { + "name": "Not ready for London upgrade", + "uid": "GETH-2021-01", + "summary": "The client is not ready for the 'London' technical upgrade, and will deviate from the canonical chain when the London upgrade occurs (at block '12965000' around August 4, 2021.", + "description": "At (or around) August 4, Ethereum will undergo a technical upgrade called 'London'. Clients not upgraded will fail to progress on the canonical chain.", + "links": [ + "https://github.com/ethereum/eth1.0-specs/blob/master/network-upgrades/mainnet-upgrades/london.md", + "https://notes.ethereum.org/@timbeiko/ropsten-postmortem" + ], + "introduced": "v1.10.1", + "fixed": "v1.10.6", + "published": "2021-07-22", + "severity": "High", + "check": "(Geth\\/v1\\.10\\.(1|2|3|4|5)-.*)$" + }, + { + "name": "RETURNDATA corruption via datacopy", + "uid": "GETH-2021-02", + "summary": "A consensus-flaw in the Geth EVM could cause a node to deviate from the canonical chain.", + "description": "A memory-corruption bug within the EVM can cause a consensus error, where vulnerable nodes obtain a different `stateRoot` when processing a maliciously crafted transaction. This, in turn, would lead to the chain being split: mainnet splitting in two forks.\n\nAll Geth versions supporting the London hard fork are vulnerable (the bug is older than London), so all users should update.\n\nThis bug was exploited on Mainnet at block 13107518.\n\nCredits for the discovery go to @guidovranken (working for Sentnl during an audit of the Telos EVM) and reported via bounty@ethereum.org.", + "links": [ + "https://github.com/ethereum/go-ethereum/blob/master/docs/postmortems/2021-08-22-split-postmortem.md", + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-9856-9gg9-qcmq", + "https://github.com/ethereum/go-ethereum/releases/tag/v1.10.8" + ], + "introduced": "v1.10.0", + "fixed": "v1.10.8", + "published": "2021-08-24", + "severity": "High", + "CVE": "CVE-2021-39137", + "check": "(Geth\\/v1\\.10\\.(0|1|2|3|4|5|6|7)-.*)$" + }, + { + "name": "DoS via malicious `snap/1` request", + "uid": "GETH-2021-03", + "summary": "A vulnerable node is susceptible to crash when processing a maliciously crafted message from a peer, via the snap/1 protocol. The crash can be triggered by sending a malicious snap/1 GetTrieNodes package.", + "description": "The `snap/1` protocol handler contains two vulnerabilities related to the `GetTrieNodes` packet, which can be exploited to crash the node. Full details are available at the Github security [advisory](https://github.com/ethereum/go-ethereum/security/advisories/GHSA-59hh-656j-3p7v)", + "links": [ + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-59hh-656j-3p7v", + "https://geth.ethereum.org/docs/vulnerabilities/vulnerabilities", + "https://github.com/ethereum/go-ethereum/pull/23657" + ], + "introduced": "v1.10.0", + "fixed": "v1.10.9", + "published": "2021-10-24", + "severity": "Medium", + "CVE": "CVE-2021-41173", + "check": "(Geth\\/v1\\.10\\.(0|1|2|3|4|5|6|7|8)-.*)$" + }, + { + "name": "DoS via malicious p2p message", + "uid": "GETH-2022-01", + "summary": "A vulnerable node can crash via p2p messages sent from an attacker node, if running with non-default log options.", + "description": "A vulnerable node, if configured to use high verbosity logging, can be made to crash when handling specially crafted p2p messages sent from an attacker node. Full details are available at the Github security [advisory](https://github.com/ethereum/go-ethereum/security/advisories/GHSA-wjxw-gh3m-7pm5)", + "links": [ + "https://github.com/ethereum/go-ethereum/security/advisories/GHSA-wjxw-gh3m-7pm5", + "https://geth.ethereum.org/docs/vulnerabilities/vulnerabilities", + "https://github.com/ethereum/go-ethereum/pull/24507" + ], + "introduced": "v1.10.0", + "fixed": "v1.10.17", + "published": "2022-05-11", + "severity": "Low", + "CVE": "CVE-2022-29177", + "check": "(Geth\\/v1\\.10\\.(0|1|2|3|4|5|6|7|8|9|10|11|12|13|14|15|16)-.*)$" + } +] diff --git a/vulnerabilities/vulnerabilities.json.minisig b/vulnerabilities/vulnerabilities.json.minisig new file mode 100644 index 0000000000..414b24def8 --- /dev/null +++ b/vulnerabilities/vulnerabilities.json.minisig @@ -0,0 +1,4 @@ +untrusted comment: signature from minisign secret key +RWQk7Lo5TQgd+9DjD2nXoabMy0BkWSuMiePPOQ9rXlwzvjhRGzEtwPDK3YupbRT9/OmyykFLGHCzWTRKVtVfYqFHL07m0DOOnww= +trusted comment: timestamp:1652258428 file:vulnerabilities.json +jtud9mtIiBRWA+krlBf1WCHgRzkcuzeoe9YLjLfHLEUQosbs+Ru1oaxx+nhxmjKdSRFwhPy1yoV5j9+rw55yCg== diff --git a/vulnerabilities/vulnerabilities.md b/vulnerabilities/vulnerabilities.md new file mode 100644 index 0000000000..07d7baf86d --- /dev/null +++ b/vulnerabilities/vulnerabilities.md @@ -0,0 +1,113 @@ +--- +title: Vulnerability disclosure +sort_key: A +--- + +## About disclosures + +In the software world, it is expected for security vulnerabilities to be immediately +announced, thus giving operators an opportunity to take protective measure against +attackers. + +Vulnerabilies typically take two forms: + +1. Vulnerabilies that, if exploited, would harm the software operator. In the case of + go-ethereum, examples would be: + - A bug that would allow remote reading or writing of OS files, or + - Remote command execution, or + - Bugs that would leak cryptographic keys +2. Vulnerabilies that, if exploited, would harm the Ethereum mainnet. In the case of + go-ethereum, examples would be: + - Consensus vulnerabilities, which would cause a chain split, + - Denial-of-service during block processing, whereby a malicious transaction could cause the geth-portion of the network to crash. + - Denial-of-service via p2p networking, whereby portions of the network could be made + inaccessible due to crashes or resource consumption. + +In most cases so far, vulnerabilities in `geth` have been of the second type, where the +health of the network is a concern, rather than individual node operators. For such +issues, we reserve the right to silently patch and ship fixes in new releases. + +### Why silent patches + +In the case of Ethereum, it takes a lot of time (weeks, months) to get node operators to +update even to a scheduled hard fork. If we were to highlight that a release contains +important consensus or DoS fixes, there is always a risk of someone trying to beat node +operators to the punch, and exploit the vulnerability. Delaying a potential attack +sufficiently to make the majority of node operators immune may be worth the temporary loss +of transparency. + +The primary goal for the Geth team is the health of the Ethereum network as a whole, and +the decision whether or not to publish details about a serious vulnerability boils down to +minimizing the risk and/or impact of discovery and exploitation. + +At certain times, it's better to remain silent. This practice is also followed by other +projects such as +[Monero](https://www.getmonero.org/2017/05/17/disclosure-of-a-major-bug-in-cryptonote-based-currencies.html), +[ZCash](https://electriccoin.co/blog/zcash-counterfeiting-vulnerability-successfully-remediated/) +and +[Bitcoin](https://www.coindesk.com/the-latest-bitcoin-bug-was-so-bad-developers-kept-its-full-details-a-secret). + +### Public transparency + +As of November 2020, our policy going forward is: + +- If we silently fix a vulnerability and include the fix in release `X`, then, +- After 4-8 weeks, we will disclose that `X` contained a security-fix. +- After an additional 4-8 weeks, we will publish the details about the vulnerability. + +We hope that this provides sufficient balance between transparency versus the need for +secrecy, and aids node operators and downstream projects in keeping up to date with what +versions to run on their infrastructure. + +In keeping with this policy, we have taken inspiration from [Solidity bug disclosure](https://solidity.readthedocs.io/en/develop/bugs.html) - see below. + +## Disclosed vulnerabilities + +In this folder, you can find a JSON-formatted list +([`vulnerabilities.json`](vulnerabilities.json)) of some of the known security-relevant +vulnerabilities concerning `geth`. + +As of `geth` version `1.9.25`, geth has a built-in command to check whether it is affected +by any publically disclosed vulnerability, using the command `geth version-check`. This +command will fetch the latest json file (and the accompanying +[signature-file](vulnerabilities.json.minisig), and cross-check the data against it's own +version number. + +The file itself is hosted in the Github repository, on the `gh-pages`-branch. The list was +started in November 2020, and covers mainly `v1.9.7` and forward. + +The JSON file of known vulnerabilities below is a list of objects, one for each +vulnerability, with the following keys: + +- `name` + - Unique name given to the vulnerability. +- `uid` + - Unique identifier of the vulnerability. Format `GETH--` +- `summary` + - Short description of the vulnerability. +- `description` + - Detailed description of the vulnerability. +- `links` + - List of relevant URLs with more detailed information (optional). +- `introduced` + - The first published Geth version that contained the vulnerability (optional). +- `fixed` + - The first published Geth version that did not contain the vulnerability anymore. +- `published` + - The date at which the vulnerability became known publicly (optional). +- `severity` + - Severity of the vulnerability: `low`, `medium`, `high`, `critical`. + - Takes into account the severity of impact and likelihood of exploitation. +- `check` + - This field contains a regular expression, which can be used against the reported `web3_clientVersion` of a node. If the check + matches, the node is with a high likelyhood affected by the vulnerability. +- `CVE` + - The assigned `CVE` identifier, if available (optional) + +### What about Github security advisories + +We prefer to not rely on Github as the only/primary publishing protocol for security +advisories, but we plan to use the Github-advisory process as a second channel for +disseminating vulnerability-information. + +Advisories published via Github can be accessed [here](https://github.com/ethereum/go-ethereum/security/advisories?state=published). From 007549d6f9514db4096e13a6ad10f745647b6c56 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 2 Aug 2022 14:07:22 +0100 Subject: [PATCH 022/432] update vulnerabilities and code-review-guidelines --- .../geth-developer/code-review-guidelines.md | 7 ++++--- .../geth-developer/vulnerabilities.md | 21 +++++++------------ 2 files changed, 12 insertions(+), 16 deletions(-) diff --git a/content/docs/developers/geth-developer/code-review-guidelines.md b/content/docs/developers/geth-developer/code-review-guidelines.md index e19da73f90..bdb4e12ab7 100644 --- a/content/docs/developers/geth-developer/code-review-guidelines.md +++ b/content/docs/developers/geth-developer/code-review-guidelines.md @@ -89,8 +89,8 @@ issue notices, e.g. "Fixes #42353". ### Special Situations And How To Deal With Them -As a reviewer, you may find yourself in one of the sitations below. Here's how to deal -with those: +Reviewers may find themselves in one of the sitations below. Here's how to deal +with them: * The author doesn't follow up: ping them after a while (i.e. after a few days). If there is no further response, close the PR or complete the work yourself. @@ -100,7 +100,8 @@ with those: submit the refactoring as an independent PR, or at least as an independent commit in the same PR. -* Author keeps rejecting your feedback: reviewers have authority to reject any change for technical reasons. If you're unsure, ask the team for a second opinion. You may close the PR if no consensus can be reached. +* Author keeps rejecting feedback: reviewers have authority to reject any change for technical reasons. +If you're unsure, ask the team for a second opinion. The PR can be closed if no consensus can be reached. [effgo]: https://golang.org/doc/effective_go.html [revcomment]: https://github.com/golang/go/wiki/CodeReviewComments diff --git a/content/docs/developers/geth-developer/vulnerabilities.md b/content/docs/developers/geth-developer/vulnerabilities.md index 07d7baf86d..05165b4be9 100644 --- a/content/docs/developers/geth-developer/vulnerabilities.md +++ b/content/docs/developers/geth-developer/vulnerabilities.md @@ -3,8 +3,6 @@ title: Vulnerability disclosure sort_key: A --- -## About disclosures - In the software world, it is expected for security vulnerabilities to be immediately announced, thus giving operators an opportunity to take protective measure against attackers. @@ -12,18 +10,18 @@ attackers. Vulnerabilies typically take two forms: 1. Vulnerabilies that, if exploited, would harm the software operator. In the case of - go-ethereum, examples would be: + Geth, examples would be: - A bug that would allow remote reading or writing of OS files, or - Remote command execution, or - Bugs that would leak cryptographic keys 2. Vulnerabilies that, if exploited, would harm the Ethereum mainnet. In the case of - go-ethereum, examples would be: + Geth, examples would be: - Consensus vulnerabilities, which would cause a chain split, - Denial-of-service during block processing, whereby a malicious transaction could cause the geth-portion of the network to crash. - Denial-of-service via p2p networking, whereby portions of the network could be made inaccessible due to crashes or resource consumption. -In most cases so far, vulnerabilities in `geth` have been of the second type, where the +In most cases so far, vulnerabilities in Geth have been of the second type, where the health of the network is a concern, rather than individual node operators. For such issues, we reserve the right to silently patch and ship fixes in new releases. @@ -63,18 +61,15 @@ In keeping with this policy, we have taken inspiration from [Solidity bug disclo ## Disclosed vulnerabilities -In this folder, you can find a JSON-formatted list -([`vulnerabilities.json`](vulnerabilities.json)) of some of the known security-relevant -vulnerabilities concerning `geth`. +On the Geth Github can find a JSON-formatted list ([`vulnerabilities.json`](vulnerabilities.json)) +of some of the known security-relevant vulnerabilities concerning Geth. -As of `geth` version `1.9.25`, geth has a built-in command to check whether it is affected -by any publically disclosed vulnerability, using the command `geth version-check`. This -command will fetch the latest json file (and the accompanying +As of version `1.9.25`, Geth has a built-in command to check whether it is affected by any publically disclosed vulnerability, +using the command `geth version-check`. This command will fetch the latest json file (and the accompanying [signature-file](vulnerabilities.json.minisig), and cross-check the data against it's own version number. -The file itself is hosted in the Github repository, on the `gh-pages`-branch. The list was -started in November 2020, and covers mainly `v1.9.7` and forward. +The list of vulnerabilities was started in November 2020, and covers mainly `v1.9.7` and forward. The JSON file of known vulnerabilities below is a list of objects, one for each vulnerability, with the following keys: From 22c4b6ce45763d88909f0a82e415f22b476b2a72 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 2 Aug 2022 14:24:47 +0100 Subject: [PATCH 023/432] minor changes --- .../docs/developers/geth-developer/dns-discovery-setup.md | 8 ++++---- content/docs/tools/abigen/index.md | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/content/docs/developers/geth-developer/dns-discovery-setup.md b/content/docs/developers/geth-developer/dns-discovery-setup.md index 715838eea8..d13a4bf8cf 100644 --- a/content/docs/developers/geth-developer/dns-discovery-setup.md +++ b/content/docs/developers/geth-developer/dns-discovery-setup.md @@ -5,16 +5,16 @@ sort_key: C This document explains how to set up an [EIP 1459][dns-eip] node list using the devp2p developer tool. The focus of this guide is creating a public list for the Ethereum mainnet -and public testnets, but you may also find this helpful if you want to set up DNS-based -discovery for a private network. +and public testnets, but it may also be helpful for setting up DNS-based discovery for a +private network. DNS-based node lists can serve as a fallback option when connectivity to the discovery DHT -is unavailable. In this guide, we'll create node lists by crawling the discovery DHT, then +is unavailable. In this guide, node lists will be created by crawling the discovery DHT, then publishing the resulting node sets under chosen DNS names. ### Installing the devp2p command -cmd/devp2p is a developer utility and is not included in the Geth distribution. You can +`cmd/devp2p` is a developer utility and is not included in the Geth distribution. You can install this command using `go get`: ```shell diff --git a/content/docs/tools/abigen/index.md b/content/docs/tools/abigen/index.md index 494597f862..d6a6017ace 100644 --- a/content/docs/tools/abigen/index.md +++ b/content/docs/tools/abigen/index.md @@ -3,7 +3,7 @@ title: Abigen root: .. --- -Abigen is a binfing-generator for easily interacting with Ethereum using Go. +Abigen is a binding-generator for easily interacting with Ethereum using Go. Abigen creates easy-to-use, type-safe Go packages from Ethereum smart contract definitions known as ABIs. This abstracts away a lot of the complexity of handling smart contract deployment and interaction in Go native applications such as encoding and decoding smart contracts into From dd6d413947f3030d6160c3beccf9268e2e9de77d Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 3 Aug 2022 15:12:39 +0100 Subject: [PATCH 024/432] update links in api docs --- .../docs/interacting_with_geth/RPC/graphql.md | 12 +++--- .../interacting_with_geth/RPC/ns-admin.md | 12 ++---- .../interacting_with_geth/RPC/ns-debug.md | 38 ++++++++----------- content/docs/monitoring/ethstats.md | 33 ++++++++++++++-- 4 files changed, 56 insertions(+), 39 deletions(-) diff --git a/content/docs/interacting_with_geth/RPC/graphql.md b/content/docs/interacting_with_geth/RPC/graphql.md index 8cb82f4ebb..1abf0a9853 100644 --- a/content/docs/interacting_with_geth/RPC/graphql.md +++ b/content/docs/interacting_with_geth/RPC/graphql.md @@ -5,13 +5,13 @@ sort_key: C In addition to the [JSON-RPC APIs](../rpc/server), Geth supports the GraphQL API as specified by [EIP-1767](eip-1767). GraphQL lets you specify which fields of an objects you need as part of the query, eliminating the extra load on the client for filling in fields which are not needed. It also allows for combining several traditional JSON-RPC requests into one query which translates into less overhead and more performance. -The GraphQL endpoint piggybacks on the HTTP transport used by JSON-RPC. Hence you'll have to enable and configure the relevant `--http` flags, and the `--graphql` flag itself: +The GraphQL endpoint piggybacks on the HTTP transport used by JSON-RPC. Hence the relevant `--http` flags and the `--graphql` flag should be passed to Geth: ```bash geth --http --graphql ``` -Now you can start querying against `http://localhost:8545/graphql`. To change the port, you'll need to provide `--http.port`, e.g.: +Now queries can be raised against `http://localhost:8545/graphql`. To change the port, provide a custom port number to `--http.port`, e.g.: ```bash geth --http --http.port 9545 --graphql @@ -19,7 +19,7 @@ geth --http --http.port 9545 --graphql ### GraphiQL -An easy way to get started right away and try out queries is the GraphiQL interface shipped with Geth. To open it visit `http://localhost:8545/graphql/ui`. To see how this works let's read the sender, recipient and value of all transactions in block number 6000000. Try this out in GraphiQL: +An easy way to try out queries is the GraphiQL interface shipped with Geth. To open it visit `http://localhost:8545/graphql/ui`. To see how this works let's read the sender, recipient and value of all transactions in block number 6000000. In GraphiQL: ```graphql query txInfo { @@ -31,9 +31,9 @@ GraphiQL also provides a way to explore the schema Geth provides to help you for ### Query -Reading out data from Geth is the biggest use-case for GraphQL. However after trying out queries in the UI you may want to do it programmatically. You can consult the official [docs](graphql-code) to find bindings for your language. Or use your favorite tool for sending HTTP requests. For sake of completeness we briefly touch on two approaches here. First via cURL, and second via a JS script. +Reading out data from Geth is the biggest use-case for GraphQL. In addition to using the UI queries can also be sent programmatically. The official GraphQL[docs](graphql-code) explain how to find bindings for many languages, or send http requests from the terminal using tools such as Curl. -Here's how you'd get the latest block's number via cURL. Note the use of a JSON object for the data section: +For example, the code snippet below shows how to obtain the latest block number using Curl. Note the use of a JSON object for the data section: ```bash ❯ curl -X POST http://localhost:8545/graphql -H "Content-Type: application/json" --data '{ "query": "query { block { number } }" }' @@ -46,7 +46,7 @@ Alternatively store the JSON-ified query in a file (let's call it `block-num.que ❯ curl -X POST http://localhost:8545/graphql -H "Content-Type: application/json" --data '@block-num.query' ``` -Executing a simple query in JS looks like the following. Here we're using the lightweight library `graphql-request` to perform the request. Note the use of variables instead of hardcoding the block number in the query: +Executing a simple query in JS looks as follows. Here the lightweight library `graphql-request` is used to perform the request. Note the use of variables instead of hardcoding the block number in the query: ```javascript const { request, gql } = require('graphql-request') diff --git a/content/docs/interacting_with_geth/RPC/ns-admin.md b/content/docs/interacting_with_geth/RPC/ns-admin.md index fc15227b55..a545a226d9 100644 --- a/content/docs/interacting_with_geth/RPC/ns-admin.md +++ b/content/docs/interacting_with_geth/RPC/ns-admin.md @@ -3,12 +3,8 @@ title: admin Namespace sort_key: C --- -The `admin` API gives you access to several non-standard RPC methods, which will allow you to have -a fine grained control over your Geth instance, including but not limited to network peer and RPC -endpoint management. +The `admin` API gives access to several non-standard RPC methods, which allows fine grained control over a Geth instance, including but not limited to network peer and RPC endpoint management. -* TOC -{:toc} ### admin_addPeer @@ -16,7 +12,7 @@ The `addPeer` administrative method requests adding a new remote node to the lis nodes. The node will try to maintain connectivity to these nodes at all times, reconnecting every once in a while if the remote connection goes down. -The method accepts a single argument, the [`enode`](https://github.com/ethereum/wiki/wiki/enode-url-format) +The method accepts a single argument, the [`enode`](https://ethereum.org/en/developers/docs/networking-layer/network-addresses/#enode) URL of the remote peer to start tracking and returns a `BOOL` indicating whether the peer was accepted for tracking or some error occurred. @@ -91,7 +87,7 @@ It returns a boolean indicating whether the operation succeeded. The `nodeInfo` administrative property can be queried for all the information known about the running Geth node at the networking granularity. These include general information about the node itself as a -participant of the [ÐΞVp2p](https://github.com/ethereum/wiki/wiki/%C3%90%CE%9EVp2p-Wire-Protocol) P2P +participant of the [ÐΞVp2p](https://github.com/ethereum/devp2p/blob/master/caps/eth.md) P2P overlay protocol, as well as specialized information added by each of the running application protocols (e.g. `eth`, `les`, `shh`, `bzz`). @@ -141,7 +137,7 @@ The type of events emitted by the server are as follows: The `peers` administrative property can be queried for all the information known about the connected remote nodes at the networking granularity. These include general information about the nodes themselves -as participants of the [ÐΞVp2p](https://github.com/ethereum/wiki/wiki/%C3%90%CE%9EVp2p-Wire-Protocol) +as participants of the [ÐΞVp2p](https://github.com/ethereum/devp2p/blob/master/caps/eth.md) P2P overlay protocol, as well as specialized information added by each of the running application protocols (e.g. `eth`, `les`, `shh`, `bzz`). diff --git a/content/docs/interacting_with_geth/RPC/ns-debug.md b/content/docs/interacting_with_geth/RPC/ns-debug.md index 2fed88c96b..f9cbfe0d7b 100644 --- a/content/docs/interacting_with_geth/RPC/ns-debug.md +++ b/content/docs/interacting_with_geth/RPC/ns-debug.md @@ -3,11 +3,8 @@ title: debug Namespace sort_key: C --- -The `debug` API gives you access to several non-standard RPC methods, which will allow you -to inspect, debug and set certain debugging flags during runtime. +The `debug` API gives access to several non-standard RPC methods, which allow inspection, debugging and setting certain debugging flags during runtime. -* TOC -{:toc} ### debug_accountRange @@ -228,7 +225,7 @@ Retrieves and returns the RLP encoded block by number. | Console | `debug.getBlockRlp(number, [options])` | | RPC | `{"method": "debug_getBlockRlp", "params": [number]}` | -References: [RLP](https://github.com/ethereum/wiki/wiki/RLP) +References: [RLP](https://ethereum.org/en/developers/docs/data-structures-and-encoding/rlp/#top) ### debug_getHeaderRlp @@ -365,7 +362,7 @@ collection. ### debug_setHead Sets the current head of the local chain by block number. **Note**, this is a -destructive action and may severely damage your chain. Use with *extreme* caution. +destructive action and may severely damage the chain. Use with *extreme* caution. | Client | Method invocation | |:--------|---------------------------------------------------| @@ -374,7 +371,7 @@ destructive action and may severely damage your chain. Use with *extreme* cautio | RPC | `{"method": "debug_setHead", "params": [number]}` | References: -[Ethash](https://eth.wiki/en/concepts/ethash/ethash) +[Ethash](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash) ### debug_setMutexProfileFraction @@ -516,7 +513,7 @@ fail. | RPC | `{"method": "debug_traceBlock", "params": [blockRlp, {}]}` | References: -[RLP](https://github.com/ethereum/wiki/wiki/RLP) +[RLP](https://ethereum.org/en/developers/docs/data-structures-and-encoding/rlp) #### Example @@ -566,7 +563,7 @@ block that is already present in the database. | RPC | `{"method": "debug_traceBlockByNumber", "params": [number, {}]}` | References: -[RLP](https://github.com/ethereum/wiki/wiki/RLP) +[RLP](https://ethereum.org/en/developers/docs/data-structures-and-encoding/rlp) ### debug_traceBlockByHash @@ -580,7 +577,7 @@ block that is already present in the database. | RPC | `{"method": "debug_traceBlockByHash", "params": [hash {}]}` | References: -[RLP](https://github.com/ethereum/wiki/wiki/RLP) +[RLP](https://ethereum.org/en/developers/docs/data-structures-and-encoding/rlp) ### debug_traceBlockFromFile @@ -594,11 +591,11 @@ Similar to [debug_traceBlock](#debug_traceblock), `traceBlockFromFile` accepts a | RPC | `{"method": "debug_traceBlockFromFile", "params": [fileName, {}]}` | References: -[RLP](https://github.com/ethereum/wiki/wiki/RLP) +[RLP](https://ethereum.org/en/developers/docs/data-structures-and-encoding/rlp) ### debug_traceCall -The `debug_traceCall` method lets you run an `eth_call` within the context of the given block execution using the final state of parent block as the base. The first argument (just as in `eth_call`) is a [transaction object](/docs/rpc/objects#transaction-call-object). The block can be specified either by hash or by number as the second argument. A tracer can be specified as a third argument, similar to `debug_traceTransaction`. It returns the same output as `debug_traceTransaction`. +The `debug_traceCall` method enables running an `eth_call` within the context of the given block execution using the final state of parent block as the base. The first argument (just as in `eth_call`) is a [transaction object](/docs/rpc/objects#transaction-call-object). The block can be specified either by hash or by number as the second argument. A tracer can be specified as a third argument, similar to `debug_traceTransaction`. It returns the same output as `debug_traceTransaction`. | Client | Method invocation | |:-------:|-----------------------------------| @@ -689,7 +686,7 @@ as it was executed on the network. It will replay any transaction that may have to this one before it will finally attempt to execute the transaction that corresponds to the given hash. -In addition to the hash of the transaction you may give it a secondary *optional* argument, which +In addition to the hash of the transaction it can take a secondary *optional* argument, which specifies the options for this specific call. The possible options are: * `disableStorage`: `BOOL`. Setting this to true will disable storage capture (default = false). @@ -744,7 +741,7 @@ specifies the options for this specific call. The possible options are: #### JavaScript-based tracing -Specifying the `tracer` option in the second argument enables JavaScript-based tracing. In this mode, `tracer` is interpreted as a JavaScript expression that is expected to evaluate to an object which must expose the `result` and `fault` methods. There exist 3 additional methods, namely: `step`, `enter` and `exit`. You must provide either `step`, or `enter` AND `exit` (i.e. these two must be exposed together). You may expose all three if you choose to do so. +Specifying the `tracer` option in the second argument enables JavaScript-based tracing. In this mode, `tracer` is interpreted as a JavaScript expression that is expected to evaluate to an object which must expose the `result` and `fault` methods. There exist 3 additional methods, namely: `step`, `enter` and `exit`. One of either `step`, or `enter` AND `exit` must be provided(i.e. `enter` and `exit` must be exposed together). All three can be provided together. ##### Step @@ -768,7 +765,7 @@ and the following methods: If error is non-empty, all other fields should be ignored. -For efficiency, the same `log` object is reused on each execution step, updated with current values; make sure to copy values you want to preserve beyond the current call. For instance, this step function will not work: +For efficiency, the same `log` object is reused on each execution step, updated with current values; make sure to copy values that are needed beyond the current call. For instance, this step function will not work: function(log) { this.logs.append(log); @@ -887,30 +884,27 @@ Sets the logging verbosity pattern. #### Examples -If you want to see messages from a particular Go package (directory) +To see messages from a particular Go package (directory) and all subdirectories, use: ``` javascript > debug.vmodule("eth/*=6") ``` -If you want to restrict messages to a particular package (e.g. p2p) +To restrict messages to a particular package (e.g. p2p) but exclude subdirectories, use: ``` javascript > debug.vmodule("p2p=6") ``` -If you want to see log messages from a particular source file, use +To see log messages from a particular source file, use ``` javascript > debug.vmodule("server.go=6") ``` -You can compose these basic patterns. If you want to see all -output from peer.go in a package below eth (eth/peer.go, -eth/downloader/peer.go) as well as output from package p2p -at level <= 5, use: +To see all output from peer.go in a package below eth (eth/peer.go, eth/downloader/peer.go) as well as output from package p2p at level <= 5, use: ``` javascript debug.vmodule("eth/*/peer.go=6,p2p=5") diff --git a/content/docs/monitoring/ethstats.md b/content/docs/monitoring/ethstats.md index bc27d5a171..65b47e6913 100644 --- a/content/docs/monitoring/ethstats.md +++ b/content/docs/monitoring/ethstats.md @@ -38,9 +38,36 @@ Note that the Ethstats dashboard is not a reliable source of information about t network because submitting data to the Ethstats server is voluntary and has to be configured by individual nodes. Therefore, many nodes are omitted from the summary statistics. +## How to use + +To report statistics about the local node to Ethstats, an Ethstats server and Ethstats client both have +to be installed alongside Geth. There are several options for installing Ethstats clients and servers, +each with detailed installation instructions. They all share the common trait that an Ethstats service is +started with a specific URL that can be passed to Geth. + +[EthNetStats "Classic"](https://github.com/ethereum/eth-netstats) +[EthNet Intelligence API](https://github.com/ethereum/eth-net-intelligence-api) +[Goerli Ethstats client](https://github.com/goerli/ethstats-client) +[Goerli Ethstats server](https://github.com/goerli/ethstats-server) + +If enabled, Geth spins up a minimal Ethstats reporting daemon that pushes statistics about the +local node to the Ethstats server. + +To enable this, start Geth with the `ethstats` flag, passing the Ethstats service (nodename:secret@host:port) URL. + +```sh +geth --ethstats node1:secret:127.0.0.1:9000 +``` + +The local node will then report to Ethstats, and the statistics will be displayed in a dashboard that can be +accessed via the web browser. + +## Note on WS_secret + +The `WS_secret` parameter is required for connecting to an Ethstats server. For a local network this can be user-defined +on startup by providing it as an environment variable. However, for Ethereum mainnet and the public testnets predefined +values must be known. Historically these have been made available on Gitter and Skype channels or of a forum, but these are +no longer in use. The user will have to track down existing Ethstats users to request the `WS_secret`. -.. UNFINISHED - -Reporting URL of a ethstats service (nodename:secret@host:port) From 74d3defd9d88a1f8395ff09a90f8e7448666d820 Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 3 Aug 2022 15:57:46 +0100 Subject: [PATCH 025/432] update api text --- README.md | 5 +++++ content/docs/interacting_with_geth/RPC/ns-clique.md | 6 +----- content/docs/interacting_with_geth/RPC/ns-eth.md | 7 ++----- content/docs/interacting_with_geth/RPC/ns-les.md | 2 +- content/docs/interacting_with_geth/RPC/ns-miner.md | 10 +++------- content/docs/interacting_with_geth/RPC/ns-net.md | 2 -- content/docs/interacting_with_geth/RPC/ns-personal.md | 7 ++----- content/docs/interacting_with_geth/RPC/ns-txpool.md | 5 +---- content/docs/interacting_with_geth/RPC/objects.md | 2 +- 9 files changed, 16 insertions(+), 30 deletions(-) diff --git a/README.md b/README.md index 735b089fed..62509f9fe6 100644 --- a/README.md +++ b/README.md @@ -8,3 +8,8 @@ Resources: - some draft figma files for design sketching: https://www.figma.com/file/ekzIgwyeVKLtFSAcnA0Q0D/geth-website?node-id=6%3A31 - content planning notes: https://www.notion.so/efdn/Content-Strategy-3252234338814a749374fa7f11049083 - meeting notes: https://www.notion.so/efdn/Call-notes-46aa0202810a402ebfda07b046761cbd + + +Notes: + +**Dev note**: Remember that the fiules in `vulnerabilities` must be served at the same URLs as they are currently to avoid breaking some Geth functions related to security auditing. \ No newline at end of file diff --git a/content/docs/interacting_with_geth/RPC/ns-clique.md b/content/docs/interacting_with_geth/RPC/ns-clique.md index ac0b09f19f..98c68c5317 100644 --- a/content/docs/interacting_with_geth/RPC/ns-clique.md +++ b/content/docs/interacting_with_geth/RPC/ns-clique.md @@ -3,11 +3,7 @@ title: clique Namespace sort_key: C --- -The `clique` API provides access to the state of the clique consensus engine. You can use -this API to manage signer votes and to check the health of a private network. - -* TOC -{:toc} +The `clique` API provides access to the state of the clique consensus engine. This API cna be used to manage signer votes and to check the health of a private network. ### clique_getSnapshot diff --git a/content/docs/interacting_with_geth/RPC/ns-eth.md b/content/docs/interacting_with_geth/RPC/ns-eth.md index e8589ac56e..fe126eb99d 100644 --- a/content/docs/interacting_with_geth/RPC/ns-eth.md +++ b/content/docs/interacting_with_geth/RPC/ns-eth.md @@ -5,9 +5,6 @@ sort_key: C Geth provides several extensions to the standard "eth" JSON-RPC namespace. -* TOC -{:toc} - ### eth_subscribe, eth_unsubscribe These methods are used for real-time events through subscriptions. See the [subscription @@ -188,8 +185,8 @@ curl --data '{"method":"eth_createAccessList","params":[{"from": "0x8cd02c6cbd83 The method `eth_createAccessList` returns list of addresses and storage keys used by the transaction, plus the gas consumed when the access list is added. -That is, it gives you the list of addresses and storage keys that will be used by that transaction, plus the gas consumed if the access list is included. Like `eth_estimateGas`, this is an estimation; the list could change when the transaction is actually mined. -Adding an `accessList` to your transaction does not necessary result in lower gas usage compared to a transaction without an access list. +That is, it gives the list of addresses and storage keys that will be used by that transaction, plus the gas consumed if the access list is included. Like `eth_estimateGas`, this is an estimation; the list could change when the transaction is actually mined. +Adding an `accessList` to a transaction does not necessary result in lower gas usage compared to a transaction without an access list. Example: ```json diff --git a/content/docs/interacting_with_geth/RPC/ns-les.md b/content/docs/interacting_with_geth/RPC/ns-les.md index 457efc2175..cbc965b832 100644 --- a/content/docs/interacting_with_geth/RPC/ns-les.md +++ b/content/docs/interacting_with_geth/RPC/ns-les.md @@ -3,7 +3,7 @@ title: les Namespace sort_key: C --- -The `les` API allows you to manage LES server settings, including client parameters and payment settings for prioritized clients. It also provides functions to query checkpoint information in both server and client mode. +The `les` API is for managing LES server settings, including client parameters and payment settings for prioritized clients. It also provides functions to query checkpoint information in both server and client mode. * TOC {:toc} diff --git a/content/docs/interacting_with_geth/RPC/ns-miner.md b/content/docs/interacting_with_geth/RPC/ns-miner.md index 303f177b9d..8eea5e8c87 100644 --- a/content/docs/interacting_with_geth/RPC/ns-miner.md +++ b/content/docs/interacting_with_geth/RPC/ns-miner.md @@ -3,15 +3,11 @@ title: miner Namespace sort_key: C --- -The `miner` API allows you to remote control the node's mining operation and set various -mining specific settings. - -* TOC -{:toc} +The `miner` API is **now deprecated** because mining was switched off at the transition to proof-of-stake. It existed to provide remote control the node's mining operation and set various mining specific settings. It is provided here for historical interest! ### miner_getHashrate -Get your hashrate in H/s (Hash operations per second). +Get hashrate in H/s (Hash operations per second). | Client | Method invocation | |:--------|-------------------------------------------------------------| @@ -82,7 +78,7 @@ Sets the etherbase, where mining rewards will go. ### miner_setGasLimit -Sets the gas limit the miner will target when mining. Note: on networks where EIP-1559 is activated, this should be set to twice what you want the gas target (i.e. the effective gas used on average per block) to be. +Sets the gas limit the miner will target when mining. Note: on networks where EIP-1559 is activated, this should be set to twice the gas target (i.e. the effective gas used on average per block) to be. | Client | Method invocation | |:--------|-------------------------------------------------------------| diff --git a/content/docs/interacting_with_geth/RPC/ns-net.md b/content/docs/interacting_with_geth/RPC/ns-net.md index 1a92cabb9d..ad4ee571a3 100644 --- a/content/docs/interacting_with_geth/RPC/ns-net.md +++ b/content/docs/interacting_with_geth/RPC/ns-net.md @@ -5,8 +5,6 @@ sort_key: C The `net` API provides insight about the networking aspect of the client. -* TOC -{:toc} ### net_listening diff --git a/content/docs/interacting_with_geth/RPC/ns-personal.md b/content/docs/interacting_with_geth/RPC/ns-personal.md index 436471b773..6a2d7903fc 100644 --- a/content/docs/interacting_with_geth/RPC/ns-personal.md +++ b/content/docs/interacting_with_geth/RPC/ns-personal.md @@ -5,9 +5,6 @@ sort_key: C The personal API manages private keys in the key store. -* TOC -{:toc} - ### personal_deriveAccount Requests a HD wallet to derive a new account, optionally pinning it for later reuse. @@ -165,7 +162,7 @@ Supplying the passphrase and unlock duration as arguments: true ``` -If you want to type in the passphrase and stil override the default unlock duration, +To type in the passphrase and still override the default unlock duration, pass `null` as the passphrase. ``` @@ -177,7 +174,7 @@ true ### personal_unpair -Deletes a pairing between wallet and geth. +Deletes a pairing between wallet and Geth. | Client | Method invocation | | :--------| ----------------------------------------------------------- | diff --git a/content/docs/interacting_with_geth/RPC/ns-txpool.md b/content/docs/interacting_with_geth/RPC/ns-txpool.md index fc935c77a6..1790ec9dcc 100644 --- a/content/docs/interacting_with_geth/RPC/ns-txpool.md +++ b/content/docs/interacting_with_geth/RPC/ns-txpool.md @@ -3,13 +3,10 @@ title: txpool Namespace sort_key: C --- -The `txpool` API gives you access to several non-standard RPC methods to inspect the contents of the +The `txpool` API gives access to several non-standard RPC methods to inspect the contents of the transaction pool containing all the currently pending transactions as well as the ones queued for future processing. -* TOC -{:toc} - ### txpool_content The `content` inspection property can be queried to list the exact details of all the transactions diff --git a/content/docs/interacting_with_geth/RPC/objects.md b/content/docs/interacting_with_geth/RPC/objects.md index 6331680e39..703270687e 100644 --- a/content/docs/interacting_with_geth/RPC/objects.md +++ b/content/docs/interacting_with_geth/RPC/objects.md @@ -19,7 +19,7 @@ The *transaction call object* contains all the necessary parameters for executin | `maxPriorityFeePerGas` | `Quantity` | <32 | Yes | Maximum tip per gas that's given directly to the miner. Relevant for type-2 transactions. | | `value` | `Quantity` | <32 | Yes | Amount of `wei` to simulate sending along with the transaction. Defaults to `0`. | | `nonce` | `Quantity` | <8 | Yes | Nonce of sender account. | -| `input` | `Binary` | any | Yes | Binary data to send to the target contract. Generally the 4 byte hash of the method signature followed by the ABI encoded parameters. For details please see the [Ethereum Contract ABI](https://github.com/ethereum/wiki/wiki/Ethereum-Contract-ABI). This field was previously called `data`. | +| `input` | `Binary` | any | Yes | Binary data to send to the target contract. Generally the 4 byte hash of the method signature followed by the ABI encoded parameters. For details please see the [Ethereum Contract ABI](https://docs.soliditylang.org/en/v0.7.0/abi-spec.html). This field was previously called `data`. | | `accessList` | `AccessList` | any | Yes | A list of addresses and storage keys that the transaction plans to access. Used in non-legacy, i.e. type 1 and 2 transactions. | | `chainId` | `Quantity` | <32 | Yes | Transaction only valid on networks with this chain ID. Used in non-legacy, i.e. type 1 and 2 transactions. | From 88357ff1b72748553d20efb98541f7fbc4565f60 Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 3 Aug 2022 16:35:35 +0100 Subject: [PATCH 026/432] refine text in 2 namespace pages --- .../docs/interacting_with_geth/RPC/pubsub.md | 173 ++++++++++-------- content/docs/tools/Clef/apis.md | 3 +- 2 files changed, 98 insertions(+), 78 deletions(-) diff --git a/content/docs/interacting_with_geth/RPC/pubsub.md b/content/docs/interacting_with_geth/RPC/pubsub.md index be62f0ac94..007ecfb06d 100644 --- a/content/docs/interacting_with_geth/RPC/pubsub.md +++ b/content/docs/interacting_with_geth/RPC/pubsub.md @@ -3,56 +3,54 @@ title: Real-time Events sort_key: B --- -Geth v1.4 and later support publish / subscribe using JSON-RPC notifications. This allows -clients to wait for events instead of polling for them. +Geth v1.4 and later support publish / subscribe using JSON-RPC notifications. This allows clients to wait for events instead of polling for them. -It works by subscribing to particular events. The node will return a subscription id. For -each event that matches the subscription a notification with relevant data is send -together with the subscription id. +It works by subscribing to particular events. The node will return a subscription id. For each event that matches the subscription a notification with relevant data is send together with the subscription id. Example: - // create subscription - >> {"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} - << {"jsonrpc":"2.0","id":1,"result":"0xcd0c3e8af590364c09d0fa6a1210faf5"} +```sh +// create subscription +{"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} +``` - // incoming notifications - << {"jsonrpc":"2.0","method":"eth_subscription","params":{"subscription":"0xcd0c3e8af590364c09d0fa6a1210faf5","result":{"difficulty":"0xd9263f42a87",<...>, "uncles":[]}}} - << {"jsonrpc":"2.0","method":"eth_subscription","params":{"subscription":"0xcd0c3e8af590364c09d0fa6a1210faf5","result":{"difficulty":"0xd90b1a7ad02", <...>, "uncles":["0x80aacd1ea4c9da32efd8c2cc9ab38f8f70578fcd46a1a4ed73f82f3e0957f936"]}}} +returns - // cancel subscription - >> {"id": 1, "method": "eth_unsubscribe", "params": ["0xcd0c3e8af590364c09d0fa6a1210faf5"]} - << {"jsonrpc":"2.0","id":1,"result":true} +```sh +{"jsonrpc":"2.0","id":1,"result":"0xcd0c3e8af590364c09d0fa6a1210faf5"} +// incoming notifications +{"jsonrpc":"2.0","method":"eth_subscription","params":{"subscription":"0xcd0c3e8af590364c09d0fa6a1210faf5","result":{"difficulty":"0xd9263f42a87",<...>, "uncles":[]}}} +{"jsonrpc":"2.0","method":"eth_subscription","params":{"subscription":"0xcd0c3e8af590364c09d0fa6a1210faf5","result":{"difficulty":"0xd90b1a7ad02", <...>, "uncles":["0x80aacd1ea4c9da32efd8c2cc9ab38f8f70578fcd46a1a4ed73f82f3e0957f936"]}}} +``` +to cancel the subscription: +```sh +// cancel subscription +{"id": 1, "method": "eth_unsubscribe", "params": ["0xcd0c3e8af590364c09d0fa6a1210faf5"]} +{"jsonrpc":"2.0","id":1,"result":true} +``` ### Considerations -1. notifications are sent for current events and not for past events. If your use case - requires you not to miss any notifications then subscriptions are probably not the best - option. -2. subscriptions require a full duplex connection. Geth offers such connections in the - form of WebSocket and IPC (enabled by default). -3. subscriptions are coupled to a connection. If the connection is closed all - subscriptions that are created over this connection are removed. -4. notifications are stored in an internal buffer and sent from this buffer to the client. - If the client is unable to keep up and the number of buffered notifications reaches a - limit (currently 10k) the connection is closed. Keep in mind that subscribing to some - events can cause a flood of notifications, e.g. listening for all logs/blocks when the - node starts to synchronize. +1. Notifications are sent for current events and not for past events. For use cases that depend on not to miss any notifications subscriptions are probably not the best option. +2. Subscriptions require a full duplex connection. Geth offers such connections in the form of WebSocket and IPC (enabled by default). +3. Subscriptions are coupled to a connection. If the connection is closed all subscriptions that are created over this connection are removed. +4. Notifications are stored in an internal buffer and sent from this buffer to the client. If the client is unable to keep up and the number of buffered notifications reaches a limit (currently 10k) the connection is closed. Keep in mind that subscribing to some events can cause a flood of notifications, e.g. listening for all logs/blocks when the node starts to synchronize. ## Create subscription -Subscriptions are created with a regular RPC call with `eth_subscribe` as method and the -subscription name as first parameter. If successful it returns the subscription id. +Subscriptions are created with a regular RPC call with `eth_subscribe` as method and the subscription name as first parameter. If successful it returns the subscription id. ### Parameters -1. subscription name -2. optional arguments +1. Subscription name +2. Optional arguments ### Example - >> {"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} - << {"id": 1, "jsonrpc": "2.0", "result": "0x9cef478923ff08bf67fde6c64013158d"} +```sh +{"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} +{"id": 1, "jsonrpc": "2.0", "result": "0x9cef478923ff08bf67fde6c64013158d"} +``` ## Cancel subscription @@ -65,8 +63,10 @@ was cancelled successful. ### Example - >> {"id": 1, "method": "eth_unsubscribe", "params": ["0x9cef478923ff08bf67fde6c64013158d"]} - << {"jsonrpc":"2.0","id":1,"result":true} +```sh +{"id": 1, "method": "eth_unsubscribe", "params": ["0x9cef478923ff08bf67fde6c64013158d"]} +{"jsonrpc":"2.0","id":1,"result":true} +``` ## Supported Subscriptions @@ -79,32 +79,39 @@ chain. Therefore the subscription can emit multiple headers on the same height. #### Example - >> {"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} - << {"jsonrpc":"2.0","id":2,"result":"0x9ce59a13059e417087c02d3236a0b1cc"} +```sh +{"id": 1, "method": "eth_subscribe", "params": ["newHeads"]} +``` - << { - "jsonrpc": "2.0", - "method": "eth_subscription", - "params": { - "result": { - "difficulty": "0x15d9223a23aa", - "extraData": "0xd983010305844765746887676f312e342e328777696e646f7773", - "gasLimit": "0x47e7c4", - "gasUsed": "0x38658", - "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", - "miner": "0xf8b483dba2c3b7176a3da549ad41a48bb3121069", - "nonce": "0x084149998194cc5f", - "number": "0x1348c9", - "parentHash": "0x7736fab79e05dc611604d22470dadad26f56fe494421b5b333de816ce1f25701", - "receiptRoot": "0x2fab35823ad00c7bb388595cb46652fe7886e00660a01e867824d3dceb1c8d36", - "sha3Uncles": "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347", - "stateRoot": "0xb3346685172db67de536d8765c43c31009d0eb3bd9c501c9be3229203f15f378", - "timestamp": "0x56ffeff8", - "transactionsRoot": "0x0167ffa60e3ebc0b080cdb95f7c0087dd6c0e61413140e39d94d3468d7c9689f" - }, - "subscription": "0x9ce59a13059e417087c02d3236a0b1cc" - } - } +returns + +```sh +{"jsonrpc":"2.0","id":2,"result":"0x9ce59a13059e417087c02d3236a0b1cc"} + +{ + "jsonrpc": "2.0", + "method": "eth_subscription", + "params": { + "result": { + "difficulty": "0x15d9223a23aa", + "extraData": "0xd983010305844765746887676f312e342e328777696e646f7773", + "gasLimit": "0x47e7c4", + "gasUsed": "0x38658", + "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "miner": "0xf8b483dba2c3b7176a3da549ad41a48bb3121069", + "nonce": "0x084149998194cc5f", + "number": "0x1348c9", + "parentHash": "0x7736fab79e05dc611604d22470dadad26f56fe494421b5b333de816ce1f25701", + "receiptRoot": "0x2fab35823ad00c7bb388595cb46652fe7886e00660a01e867824d3dceb1c8d36", + "sha3Uncles": "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347", + "stateRoot": "0xb3346685172db67de536d8765c43c31009d0eb3bd9c501c9be3229203f15f378", + "timestamp": "0x56ffeff8", + "transactionsRoot": "0x0167ffa60e3ebc0b080cdb95f7c0087dd6c0e61413140e39d94d3468d7c9689f" + }, + "subscription": "0x9ce59a13059e417087c02d3236a0b1cc" + } + } +``` ### logs @@ -120,11 +127,15 @@ In case of a chain reorganization previous sent logs that are on the old chain w #### Example +```sh +{"id": 1, "method": "eth_subscribe", "params": ["logs", {"address": "0x8320fe7702b96808f7bbc0d4a888ed1468216cfd", "topics": ["0xd78a0cb8bb633d06981248b816e7bd33c2a35a6089241d099fa519e361cab902"]}]} +``` +returns +```sh +{"jsonrpc":"2.0","id":2,"result":"0x4a8a4c0517381924f9838102c5a4dcb7"} - >> {"id": 1, "method": "eth_subscribe", "params": ["logs", {"address": "0x8320fe7702b96808f7bbc0d4a888ed1468216cfd", "topics": ["0xd78a0cb8bb633d06981248b816e7bd33c2a35a6089241d099fa519e361cab902"]}]} - << {"jsonrpc":"2.0","id":2,"result":"0x4a8a4c0517381924f9838102c5a4dcb7"} - - << {"jsonrpc":"2.0","method":"eth_subscription","params": {"subscription":"0x4a8a4c0517381924f9838102c5a4dcb7","result":{"address":"0x8320fe7702b96808f7bbc0d4a888ed1468216cfd","blockHash":"0x61cdb2a09ab99abf791d474f20c2ea89bf8de2923a2d42bb49944c8c993cbf04","blockNumber":"0x29e87","data":"0x00000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000003","logIndex":"0x0","topics":["0xd78a0cb8bb633d06981248b816e7bd33c2a35a6089241d099fa519e361cab902"],"transactionHash":"0xe044554a0a55067caafd07f8020ab9f2af60bdfe337e395ecd84b4877a3d1ab4","transactionIndex":"0x0"}}} +{"jsonrpc":"2.0","method":"eth_subscription","params": {"subscription":"0x4a8a4c0517381924f9838102c5a4dcb7","result":{"address":"0x8320fe7702b96808f7bbc0d4a888ed1468216cfd","blockHash":"0x61cdb2a09ab99abf791d474f20c2ea89bf8de2923a2d42bb49944c8c993cbf04","blockNumber":"0x29e87","data":"0x00000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000003","logIndex":"0x0","topics":["0xd78a0cb8bb633d06981248b816e7bd33c2a35a6089241d099fa519e361cab902"],"transactionHash":"0xe044554a0a55067caafd07f8020ab9f2af60bdfe337e395ecd84b4877a3d1ab4","transactionIndex":"0x0"}}} +``` ### newPendingTransactions @@ -138,16 +149,23 @@ none #### Example - >> {"id": 1, "method": "eth_subscribe", "params": ["newPendingTransactions"]} - << {"jsonrpc":"2.0","id":2,"result":"0xc3b33aa549fb9a60e95d21862596617c"} - << { - "jsonrpc":"2.0", - "method":"eth_subscription", - "params":{ - "subscription":"0xc3b33aa549fb9a60e95d21862596617c", - "result":"0xd6fdc5cc41a9959e922f30cb772a9aef46f4daea279307bc5f7024edc4ccd7fa" - } - } +```sh +{"id": 1, "method": "eth_subscribe", "params": ["newPendingTransactions"]} +``` + +returns + +```sh +{"jsonrpc":"2.0","id":2,"result":"0xc3b33aa549fb9a60e95d21862596617c"} +{ + "jsonrpc":"2.0", + "method":"eth_subscription", + "params":{ + "subscription":"0xc3b33aa549fb9a60e95d21862596617c", + "result":"0xd6fdc5cc41a9959e922f30cb772a9aef46f4daea279307bc5f7024edc4ccd7fa" + } + } +``` ### syncing @@ -161,8 +179,9 @@ none #### Example - >> {"id": 1, "method": "eth_subscribe", "params": ["syncing"]} - << {"jsonrpc":"2.0","id":2,"result":"0xe2ffeb2703bcf602d42922385829ce96"} - - << {"subscription":"0xe2ffeb2703bcf602d42922385829ce96","result":{"syncing":true,"status":{"startingBlock":674427,"currentBlock":67400,"highestBlock":674432,"pulledStates":0,"knownStates":0}}}} +```sh +{"id": 1, "method": "eth_subscribe", "params": ["syncing"]} +{"jsonrpc":"2.0","id":2,"result":"0xe2ffeb2703bcf602d42922385829ce96"} +{"subscription":"0xe2ffeb2703bcf602d42922385829ce96","result":{"syncing":true,"status":{"startingBlock":674427,"currentBlock":67400,"highestBlock":674432,"pulledStates":0,"knownStates":0}}}} +``` diff --git a/content/docs/tools/Clef/apis.md b/content/docs/tools/Clef/apis.md index d8556e799b..6b0655052c 100644 --- a/content/docs/tools/Clef/apis.md +++ b/content/docs/tools/Clef/apis.md @@ -7,7 +7,7 @@ sort_key: E Clef listens to HTTP requests on `http.addr`:`http.port` (or to IPC on `ipcpath`), with the same JSON-RPC standard as Geth. The messages are expected to be [JSON-RPC 2.0 standard](https://www.jsonrpc.org/specification). -Some of these calls can require user interaction. Clients must be aware that responses may be delayed significantly or may never be received if a user decides to ignore the confirmation request. +Some of these calls can require user interaction in the Clef terminal. Responses may be delayed significantly or may never be received if a user decides to ignore the confirmation request. The External API is **untrusted**: it does not accept credentials, nor does it expect that requests have any authority. @@ -41,6 +41,7 @@ See the [external API changelog](https://github.com/ethereum/go-ethereum/blob/ma ### Encoding + - number: positive integers that are hex encoded - data: hex encoded data - string: ASCII string From b9356e6894f3bdecca011d3ce295a06aa6232661 Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 4 Aug 2022 14:13:39 +0100 Subject: [PATCH 027/432] update clef apis page --- content/docs/tools/Clef/apis.md | 173 +++++++++++++++----------------- 1 file changed, 83 insertions(+), 90 deletions(-) diff --git a/content/docs/tools/Clef/apis.md b/content/docs/tools/Clef/apis.md index 6b0655052c..2963850c04 100644 --- a/content/docs/tools/Clef/apis.md +++ b/content/docs/tools/Clef/apis.md @@ -1,46 +1,24 @@ --- -title: Communication APIs +title: Clef APIs sort_key: E --- -### External API - -Clef listens to HTTP requests on `http.addr`:`http.port` (or to IPC on `ipcpath`), with the same JSON-RPC standard as Geth. The messages are expected to be [JSON-RPC 2.0 standard](https://www.jsonrpc.org/specification). - -Some of these calls can require user interaction in the Clef terminal. Responses may be delayed significantly or may never be received if a user decides to ignore the confirmation request. - -The External API is **untrusted**: it does not accept credentials, nor does it expect that requests have any authority. - -### Internal UI API - -Clef has one native console-based UI, for operation without any standalone tools. However, there is also an API to communicate with an external UI. To enable that UI, the signer needs to be executed with the `--stdio-ui` option, which allocates `stdin` / `stdout` for the UI API. - -An example (insecure) proof-of-concept of has been implemented in `pythonsigner.py`. - -The model is as follows: - -* The user starts the UI app (`pythonsigner.py`). -* The UI app starts `clef` with `--stdio-ui`, and listens to the -process output for confirmation-requests. -* `clef` opens the external HTTP API. -* When the `signer` receives requests, it sends a JSON-RPC request via `stdout`. -* The UI app prompts the user accordingly, and responds to `clef`. -* `clef` signs (or not), and responds to the original request. - -### More resoruces - - -* Changelog for [External API](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/extapi_changelog.md) -* Changelog for [UI API](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/intapi_changelog.md) -* Documentation about [Datatypes](datatypes) +Clef uses two separate APIs. The **external API** is an untrusted set of JSON-RPC methods that can be called by a user. The **internal API** is a set of JSON-RPC methods that can be called by a UI. The UI could be Clef's native command line interface or a custom UI. +{:toc} +- this will be removed by the toc ## External API -See the [external API changelog](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/extapi_changelog.md) for information about changes to this API. +Clef listens to HTTP requests on `http.addr`:`http.port` (or to IPC on `ipcpath`), with the same JSON-RPC standard as Geth. The messages are expected to be [JSON-RPC 2.0 standard](https://www.jsonrpc.org/specification). +Some of these JSON-RPC calls require user interaction in the Clef terminal. Responses may be delayed significantly or may never be received if a user fails to respond to a confirmation request. -### Encoding +The External API is **untrusted**: it does not accept credentials, nor does it expect that requests have any authority. + +See the [external API changelog](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/extapi_changelog.md) for up to date information about changes to this API. + +The External API encoding is as follows: - number: positive integers that are hex encoded - data: hex encoded data @@ -48,21 +26,23 @@ See the [external API changelog](https://github.com/ethereum/go-ethereum/blob/ma All hex encoded values must be prefixed with `0x`. -### account_new +### Methods -#### Create new password protected account +#### account_new + +##### Create new password protected account The signer will generate a new private key, encrypt it according to [web3 keystore spec](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) and store it in the keystore directory. The client is responsible for creating a backup of the keystore. If the keystore is lost there is no method of retrieving lost accounts. -#### Arguments +##### Arguments None -#### Result +##### Result - address [string]: account address that is derived from the generated key -#### Sample call +##### Sample call ```json { "id": 0, @@ -80,20 +60,20 @@ Response } ``` -### account_list +#### account_list -#### List available accounts +##### List available accounts List all accounts that this signer currently manages -#### Arguments +##### Arguments None -#### Result +##### Result - array with account records: - account.address [string]: account address that is derived from the generated key -#### Sample call +##### Sample call ```json { "id": 1, @@ -113,12 +93,12 @@ Response } ``` -### account_signTransaction +#### account_signTransaction -#### Sign transactions +##### Sign transactions Signs a transaction and responds with the signed transaction in RLP-encoded and JSON forms. Supports both legacy and EIP-1559-style transactions. -#### Arguments +##### Arguments 1. transaction object (legacy): - `from` [address]: account to send the transaction from - `to` [address]: receiver account. If omitted or `0x`, will cause contract creation. @@ -140,11 +120,11 @@ Response - The method signature, if present, is to aid decoding the calldata. Should consist of `methodname(paramtype,...)`, e.g. `transfer(uint256,address)`. The signer may use this data to parse the supplied calldata, and show the user. The data, however, is considered totally untrusted, and reliability is not expected. -#### Result +##### Result - raw [data]: signed transaction in RLP encoded form - tx [json]: signed transaction in JSON form -#### Sample call (legacy) +##### Sample call (legacy) ```json { "id": 2, @@ -187,7 +167,7 @@ Response } ``` -#### Sample call (1559) +##### Sample call (1559) ```json { "id": 2, @@ -236,7 +216,7 @@ Response } ``` -#### Sample call with ABI-data +##### Sample call with ABI-data ```json @@ -289,12 +269,12 @@ Bash example: {"jsonrpc":"2.0","id":67,"result":{"raw":"0xf88380018203339407a565b7ed7d7a678680a4c162885bedbb695fe080a44401a6e4000000000000000000000000000000000000000000000000000000000000001226a0223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20ea02aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663","tx":{"nonce":"0x0","gasPrice":"0x1","gas":"0x333","to":"0x07a565b7ed7d7a678680a4c162885bedbb695fe0","value":"0x0","input":"0x4401a6e40000000000000000000000000000000000000000000000000000000000000012","v":"0x26","r":"0x223a7c9bcf5531c99be5ea7082183816eb20cfe0bbc322e97cc5c7f71ab8b20e","s":"0x2aadee6b34b45bb15bc42d9c09de4a6754e7000908da72d48cc7704971491663","hash":"0xeba2df809e7a612a0a0d444ccfa5c839624bdc00dd29e3340d46df3870f8a30e"}}} ``` -### account_signData +#### account_signData -#### Sign data +##### Sign data Signs a chunk of data and returns the calculated signature. -#### Arguments +##### Arguments - content type [string]: type of signed data - `text/validator`: hex data with custom validator defined in a contract - `application/clique`: [clique](https://github.com/ethereum/EIPs/issues/225) headers @@ -302,10 +282,10 @@ Bash example: - account [address]: account to sign with - data [object]: data to sign -#### Result +##### Result - calculated signature [data] -#### Sample call +##### Sample call ```json { "id": 3, @@ -328,19 +308,19 @@ Response } ``` -### account_signTypedData +#### account_signTypedData -#### Sign data +##### Sign data Signs a chunk of structured data conformant to [EIP-712](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-712.md) and returns the calculated signature. -#### Arguments +##### Arguments - account [address]: account to sign with - data [object]: data to sign -#### Result +##### Result - calculated signature [data] -#### Sample call +##### Sample call ```json { "id": 68, @@ -425,20 +405,20 @@ Response } ``` -### account_ecRecover +#### account_ecRecover -#### Recover the signing address +##### Recover the signing address Derive the address from the account that was used to sign data with content type `text/plain` and the signature. -#### Arguments +##### Arguments - data [data]: data that was signed - signature [data]: the signature to verify -#### Result +##### Result - derived account [address] -#### Sample call +##### Sample call ```json { "id": 4, @@ -460,21 +440,21 @@ Response } ``` -### account_version +#### account_version -#### Get external API version +##### Get external API version Get the version of the external API used by Clef. -#### Arguments +##### Arguments None -#### Result +##### Result * external API version [string] -#### Sample call +##### Sample call ```json { "id": 0, @@ -493,28 +473,41 @@ Response } ``` -## UI API -These methods needs to be implemented by a UI listener. +## Internal (UI) API -By starting the signer with the switch `--stdio-ui-test`, the signer will invoke all known methods, and expect the UI to respond with -denials. This can be used during development to ensure that the API is (at least somewhat) correctly implemented. -See `pythonsigner`, which can be invoked via `python3 pythonsigner.py test` to perform the 'denial-handshake-test'. +Clef has one native console-based UI, for operation without any standalone tools. However, there is also an API to communicate with an external UI. To enable that UI, the signer needs to be started with the `--stdio-ui` option, which allocates `stdin` / `stdout` for the UI API. + +The internal API methods need to be implemented by a UI listener. By starting the signer with the switch `--stdio-ui-test`, the signer will invoke all known methods, and expect the UI to respond with denials. This can be used during development to ensure that the API is (at least somewhat) correctly implemented. All methods in this API use object-based parameters, so that there can be no mixup of parameters: each piece of data is accessed by key. +An example (insecure) proof-of-concept external UI has been implemented in [`pythonsigner.py`](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/pythonsigner.py). + +The model is as follows: + +* The user starts the UI app (`pythonsigner.py`). +* The UI app starts `clef` with `--stdio-ui`, and listens to the +process output for confirmation-requests. +* `clef` opens the external HTTP API. +* When the `signer` receives requests, it sends a JSON-RPC request via `stdout`. +* The UI app prompts the user accordingly, and responds to `clef`. +* `clef` signs (or not), and responds to the original request. + See the [ui API changelog](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/intapi_changelog.md) for information about changes to this API. -OBS! A slight deviation from `json` standard is in place: every request and response should be confined to a single line. +**NOTE** A slight deviation from `json` standard is in place: every request and response should be confined to a single line. Whereas the `json` specification allows for linebreaks, linebreaks __should not__ be used in this communication channel, to make things simpler for both parties. -### ApproveTx / `ui_approveTx` +### Methods + +#### ApproveTx / `ui_approveTx` Invoked when there's a transaction for approval. -#### Sample call +##### Sample call Here's a method invocation: ```bash @@ -644,11 +637,11 @@ One which has missing `to`, but with no `data`: } ``` -### ApproveListing / `ui_approveListing` +#### ApproveListing / `ui_approveListing` Invoked when a request for account listing has been made. -#### Sample call +##### Sample call ```json @@ -680,9 +673,9 @@ Invoked when a request for account listing has been made. ``` -### ApproveSignData / `ui_approveSignData` +#### ApproveSignData / `ui_approveSignData` -#### Sample call +##### Sample call ```json { @@ -711,11 +704,11 @@ Invoked when a request for account listing has been made. } ``` -### ApproveNewAccount / `ui_approveNewAccount` +#### ApproveNewAccount / `ui_approveNewAccount` Invoked when a request for creating a new account has been made. -#### Sample call +##### Sample call ```json { @@ -734,11 +727,11 @@ Invoked when a request for creating a new account has been made. } ``` -### ShowInfo / `ui_showInfo` +#### ShowInfo / `ui_showInfo` The UI should show the info (a single message) to the user. Does not expect response. -#### Sample call +##### Sample call ```json { @@ -752,7 +745,7 @@ The UI should show the info (a single message) to the user. Does not expect resp ``` -### ShowError / `ui_showError` +#### ShowError / `ui_showError` The UI should show the error (a single message) to the user. Does not expect response. @@ -769,7 +762,7 @@ The UI should show the error (a single message) to the user. Does not expect res ``` -### OnApprovedTx / `ui_onApprovedTx` +#### OnApprovedTx / `ui_onApprovedTx` `OnApprovedTx` is called when a transaction has been approved and signed. The call contains the return value that will be sent to the external caller. The return value from this method is ignored - the reason for having this callback is to allow the ruleset to keep track of approved transactions. @@ -804,7 +797,7 @@ Example call: } ``` -### OnSignerStartup / `ui_onSignerStartup` +#### OnSignerStartup / `ui_onSignerStartup` This method provides the UI with information about what API version the signer uses (both internal and external) as well as build-info and external API, in k/v-form. @@ -830,7 +823,7 @@ Example call: ``` -### OnInputRequired / `ui_onInputRequired` +#### OnInputRequired / `ui_onInputRequired` Invoked when Clef requires user input (e.g. a password). From 99a756517ad6eb0269b00f82ec6ed0faf380421b Mon Sep 17 00:00:00 2001 From: Joe Date: Mon, 15 Aug 2022 11:44:04 +0100 Subject: [PATCH 028/432] update clef pages --- content/docs/tools/Clef/CliqueSigning.md | 167 ++++++++++++++--------- content/docs/tools/Clef/Setup.md | 41 ++---- content/docs/tools/Clef/datatypes.md | 3 +- 3 files changed, 117 insertions(+), 94 deletions(-) diff --git a/content/docs/tools/Clef/CliqueSigning.md b/content/docs/tools/Clef/CliqueSigning.md index a4e4cf33cc..a227dbbcc8 100644 --- a/content/docs/tools/Clef/CliqueSigning.md +++ b/content/docs/tools/Clef/CliqueSigning.md @@ -1,18 +1,25 @@ --- -title: Clique-signing with Clef -sort_key: C +title:Clique signing --- -The 'classic' way to sign PoA blocks is to use the "unlock"-feature of `geth`. This is a highly dangerous thing to do, because "unlock" is totally un-discriminatory. Meaning: if an account is unlocked and an attacker obtains access to the RPC api, the attacker can have anything signed by that account, without supplying a password. +Clique is a proof-of-authority system where new blocks can be created by authorized ‘signers’ only. The initial set of authorized signers is configured in the genesis block. Signers can be authorized and de-authorized using a voting mechanism, thus allowing the set of signers to change while the blockchain operates. Signing blocks in Clique networks classically uses the "unlock" feature of Geth so that each node is always ready to sign without requiring a user to manually provide authorization. -The idea with `clef` was to remove the `unlock` capability, yet still provide sufficient usability to make it possible to automate some things while maintaining a high level of security. This post will show how to integrate `clef` as a sealer of clique-blocks. +However, using the `--unlock` flag is generally a highly dangerous thing to do because it is indiscriminate, i.e. if an account is unlocked and an attacker obtains access to the RPC api, the attacker can sign anything without supplying a password. -## Part 0: Prepping a Clique network +Clef provides a way to safely circumvent `--unlock` while maintaining a enough automation for the network to be useable. -Feel free to skip this section if you already have a Clique-network. +## Prerequisites -First of all, we'll set up a rudimentary testnet to have something to sign on. We create a new keystore (password `testtesttest`) -``` +It is useful to have basic knowledge of private networks and Clef. These topics are covered on our [private networks](/content/docs/developers/geth-developer/private-network) and [Introduction to Clef](/content/docs/tools/Clef/introduction) pages. + +{:toc} +- this will be removed by the toc + +## Prepping a Clique network + +First of all, set up a rudimentary testnet to have something to sign. Create a new keystore (password `testtesttest`) + +```terminal $ geth account new --datadir ./ddir INFO [06-16|11:10:39.600] Maximum peer count ETH=50 LES=0 total=50 Your new account is locked with a password. Please give a password. Do not forget this password. @@ -30,7 +37,8 @@ Path of the secret key file: ddir/keystore/UTC--2022-06-16T09-10-48.578523828Z-- - You must REMEMBER your password! Without the password, it's impossible to decrypt the key! ``` -And create a genesis with that account as a sealer: +Create a genesis with that account as a sealer: + ```json { "config": { @@ -57,7 +65,9 @@ And create a genesis with that account as a sealer: } } ``` -And init `geth` + +Initiate Geth: + ``` $ geth --datadir ./ddir init genesis.json ... @@ -66,16 +76,16 @@ INFO [06-16|11:14:54.125] Persisted trie from memory database nodes=1 size= INFO [06-16|11:14:54.125] Successfully wrote genesis state database=lightchaindata hash=187412..4deb98 ``` -At this point, we have a Clique network which we can start sealing on. +At this point a Clique network exists with blocks that can be signed. -## Part 1: Prepping Clef +## Prepping Clef -In order to make use of `clef` for signing, we need to do a couple of things. +In order to make use of Clef for signing: -1. Make sure that `clef` knows the password for the keystore. -2. Make sure that `clef` auto-approves clique signing requests. +1. Ensure Clef knows the password for the keystore. +2. Ensure Clef auto-approves clique signing requests. -These two things are independent of each other. First of all, however, we need to `init` clef (for this test I use the password `clefclefclef`) +These two things are independent of each other. First of all, however, Clef must be initiated (for this example the password is `clefclefclef`) ``` $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn init @@ -97,11 +107,11 @@ You should treat 'masterseed.json' with utmost secrecy and make a backup of it! * The master seed does not contain your accounts, those need to be backed up separately! ``` -After this operation, `clef` has it's own vault where it can store secrets and attestations, which we will utilize going forward. +After this operation, `clef` has it's own vault where it can store secrets and attestations. -### Storing passwords in `clef` +## Storing passwords in `clef` -With that done, we can now make `clef` aware of the password. We invoke `setpw

` to store a password for a given address. `clef` asks for the password, and it also asks for the clef master-password, in order to update and store the new secrets inside clef vault. +With that done, Clef can be made aware of the password. To do this `setpw
` is invoked to store a password for a given address. Clef asks for the password, and it also asks for the Clef master-password, in order to update and store the new secrets inside Clef vault. ``` $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn setpw 0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 @@ -113,25 +123,27 @@ Repeat password: Decrypt master seed of clef Password: INFO [06-16|11:27:09.153] Credential store updated set=0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 - ``` -At this point, if we were to use clef as a sealer, we would be forced to manually click Approve for each block, but we would not be required to provide the password. +At this point, if Clef is used as a sealer, each block would require manual approval, but without needing to provide the password. -#### Testing stored password +### Testing stored password -Let's test using the stored password when sealing Clique-blocks. Start `clef` with -``` +To test that the stored password is correct and being properly handled by Clef, first start Clef: + +```sh $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn ``` -And start `geth` with -``` + +then start Geth: + +```sh $ geth --datadir ./ddir --signer ./clef/clef.ipc --mine ``` -Geth will ask what accounts are present, to which we need to manually enter `y` to approve: +Geth will ask what accounts are present - enter `y` to approve: -``` +```terminal -------- List Account request-------------- A request has been made to list all accounts. You can select which accounts the caller can see @@ -139,7 +151,7 @@ You can select which accounts the caller can see URL: keystore:///home/user/tmp/clique_clef/ddir/keystore/UTC--2022-06-16T09-10-48.578523828Z--9cd932f670f7ede5de86f756a6d02548e5899f47 ------------------------------------------- Request context: - NA -> ipc -> NA + NA - ipc - NA Additional HTTP header data, provided by the external caller: User-Agent: "" @@ -149,7 +161,7 @@ Approve? [y/N]: DEBUG[06-16|11:36:42.499] Served account_list reqid=2 duration=3.213768195s ``` -After this, `geth` will start asking `clef` to sign things: +After this, Get will start asking Clef to sign things: ``` -------- Sign data request-------------- @@ -169,17 +181,18 @@ Additional HTTP header data, provided by the external caller: Approve? [y/N]: > y ``` -And indeed, after approving with `y`, we are not required to provide the password -- the signed block is returned to geth: -``` +And indeed, after approving with `y`, the password is not required - the signed block is returned to Geth: + +```terminal INFO [06-16|11:36:46.714] Successfully sealed new block number=1 sealhash=9589ed..662d03 hash=bd20b9..af8b87 elapsed=4.214s ``` -This mode of operation is somewhat unusable, since we'd need to keep "Approving" each block to be sealed. So let's fix that too. +This mode of operation offers quite a poor UX because each block to be sealed requires manual approval. That is fixed in the following section. -### Using rules to approve blocks +## Using rules to approve blocks -The basic idea with clef rules, is to let a piece of javascript take over the Approve/Deny decision. The javascript snippet has access to the same information as the manual operator. +Clef rules allow a piece of Javascript take over the Approve/Deny decision. The Javascript snippet has access to the same information as the manual operator. -Let's try with a simplistic first approach, which approves listing, and spits out the request data for `ApproveListing` +The first approach, which approves listing, and returns the request data for `ApproveListing`, is demonstrated below: ```js function ApproveListing(){ @@ -191,21 +204,28 @@ function ApproveSignData(r){ console.log(JSON.stringify(r)) } ``` -In order to use a certain rule-file, we must first `attest` it. This is to prevent someone from modifying a ruleset-file on disk after creation. -``` +In order to use a certain ruleset, it must first be 'attested'. This is to prevent someone from modifying a ruleset-file on disk after creation. + +```sh $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn attest `sha256sum rules.js | cut -f1` +``` +which returns: + +```terminal Decrypt master seed of clef Password: INFO [06-16|13:49:00.298] Ruleset attestation updated sha256=54aae496c3f0eda063a62c73ee284ca9fae3f43b401da847ef30ea30e85e35d1 ``` -And then we can start clef, pointing out the `rules.js` file. OBS: if you later modify this file, you need to redo the `attest`-step. -``` + +And Clef can be started, pointing out the `rules.js` file. + +```sh $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn --rules ./rules.js ``` -Once `geth` starts asking it to seal blocks, we will now see the data. And from that, we can decide on how to make a rule which allows signing clique headers but nothing else. +Once Geth starts asking Clef to seal blocks, the data will be displayed. From that data, rules can be defined that allow signing clique headers but nothing else. -The actual data that gets passed to the js environment (and which our ruleset spit out to the console) looks like this: +The actual data that gets passed to the js environment (and which the ruleset display in the terminal) looks as follows: ```json { "content_type": "application/x-clique-header", @@ -230,9 +250,9 @@ The actual data that gets passed to the js environment (and which our ruleset sp } ``` -If we wanted our js to be extremely trustless/paranoid, we could (inside the javascript) take the `raw_data` and verify that it's the rlp structure for a clique header: +To create an extremely trustless ruleset, the `raw_data` could be verified to ensure it has the right rlp structure for a Clique header: -``` +```sh echo "+QIUoL0guY+66jZpzZh1wDX4Si/ycX4zD8FQqF/1Apy/r4uHoB3MTejex116q4W1Z7bM1BrTEkUblIp0E/ChQv1A1JNHlAAAAAAAAAAAAAAAAAAAAAAAAAAAoF0xJQr87ifQZc7HdMxcPwk0do8Gy/igUDX+TuoPZv6coFboHxcbzFWm/4NF5pLA+G5bSOAbmWytwAFiL7XjY7QhoFboHxcbzFWm/4NF5pLA+G5bSOAbmWytwAFiL7XjY7QhuQEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAICg3pPDoCEYqsY1qDYgwEKFIRnZXRoiGdvMS4xOC4xhWxpbnV4AAAAAAAAAKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIgAAAAAAAAAAA==" | base64 -d | rlpdump [ bd20b98fbaea3669cd9875c035f84a2ff2717e330fc150a85ff5029cbfaf8b87, @@ -252,7 +272,7 @@ If we wanted our js to be extremely trustless/paranoid, we could (inside the jav 0000000000000000, ] ``` -However, we can also use the `messages`. They do not come from the external caller, but are generated from the `clef` internals: `clef` parsed the incoming request and verified the Clique wellformedness of the content. So we let's just check for such a message: +However, `messages` could also be used. They do not come from the external caller, but are generated from the Clef internals: Clef parsed the incoming request and verified the Clique wellformedness of the content. The following simply checks for such a message: ```js function OnSignerStartup(info){} @@ -273,24 +293,33 @@ function ApproveSignData(r){ return "Reject" } ``` -Attest -``` + +Attest the ruleset: + +```sh $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn attest `sha256sum rules.js | cut -f1` +``` + +returning + +```terminal Decrypt master seed of clef Password: INFO [06-16|14:18:53.476] Ruleset attestation updated sha256=7d5036d22d1cc66599e7050fb1877f4e48b89453678c38eea06e3525996c2379 ``` -Run clef -``` -$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn --rules ./rules.js +Run clef: +```sh +$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn --rules ./rules.js ``` -Run geth -``` +Run Geth: + +```sh $ geth --datadir ./ddir --signer ./clef/clef.ipc --mine ``` -And you should now see `clef` happily signing blocks: -``` +And Clef should now happily sign blocks: + +```terminal DEBUG[06-16|14:20:02.136] Served account_version reqid=1 duration="131.38µs" INFO [06-16|14:20:02.289] Op approved DEBUG[06-16|14:20:02.289] Served account_list reqid=2 duration=4.672441ms @@ -302,18 +331,18 @@ INFO [06-16|14:20:32.823] Op approved DEBUG[06-16|14:20:33.584] Served account_signData reqid=5 duration=766.840681ms ``` -### Further refinements +## Refinements -If an attacker find the clef "external" interface (which would only happen if you start it with `http` enabled) , he +If an attacker find the Clef "external" interface (which would only happen if you start it with `http` enabled), they - cannot make it sign arbitrary transactions, - cannot sign arbitrary data message, -However, he could still make it sign e.g. 1000 versions of a certain block height, making the chain very unstable. +However, they could still make it sign e.g. 1000 versions of a certain block height, making the chain very unstable. -It is possible for rule execution to be stateful -- storing data. In this case, one could for example store what block heights have been sealed, and thus reject sealing a particular block height twice. In other words, we can use these rules to build our own version of an Execution-Layer slashing-db. +It is possible for rule execution to be stateful (i.e. storing data). In this case, one could, for example, store what block heights have been sealed and reject sealing a particular block height twice. In other words, these rules could be used to build a miniature version of an execution layer slashing-db. -We simply split the `clique header 2 [0xae525b65bc7f711bc136f502650039cd6959c3abc28fdf0ebfe2a5f85c92f3b6]` line, and store/check the number, using `storage.get` and `storage.put`: +The `clique header 2 [0xae525b65bc7f711bc136f502650039cd6959c3abc28fdf0ebfe2a5f85c92f3b6]` line is split, and the number stored using `storage.get` and `storage.put`: ```js function OnSignerStartup(info){} @@ -343,7 +372,8 @@ function ApproveSignData(r){ } ``` Running with this ruleset: -``` + +```terminal JS:> number 45 latest 44 INFO [06-16|22:26:43.023] Op approved DEBUG[06-16|22:26:44.305] Served account_signData reqid=3 duration=1.287465394s @@ -351,13 +381,13 @@ JS:> number 46 latest 45 INFO [06-16|22:26:44.313] Op approved DEBUG[06-16|22:26:45.317] Served account_signData reqid=4 duration=1.010612774s ``` -This might be a bit over-the-top, security-wise, and may cause problems, if for some reason a clique-deadlock needs to be resolved by rolling back and continuing on a side-chain. It is mainly meant as a demonstration that rules can use javascript and statefulness to construct very intricate signing logic. +This might be a bit over-the-top, security-wise, and may cause problems if, for some reason, a clique-deadlock needs to be resolved by rolling back and continuing on a side-chain. It is mainly meant as a demonstration that rules can use Javascript and statefulness to construct very intricate signing logic. -### TLDR quick-version +## TLDR quick-version Creation and attestation is a one-off event: -```bash +```sh ## Create the rules-file cat << END > rules.js function OnSignerStartup(info){} @@ -384,10 +414,15 @@ clef --keystore ./ddir/keystore \ --suppress-bootwarn --signersecret ./clefpw \ attest `sha256sum rules.js | cut -f1` ``` -The normal startup command for `clef`: -```bash +The normal startup command for Clef: +```sh clef --keystore ./ddir/keystore \ --configdir ./clef --chainid 15 \ --suppress-bootwarn --signersecret ./clefpw --rules ./rules.js ``` -For `geth`, the only change is to provide `--signer `. + +For Geth, the only change is to provide `--signer `. + +## Summary + +Clef can be used as a signer that automatically seals Clique blocks. This is a much more secure option than unlocking accounts using Geth's built-in account manager. diff --git a/content/docs/tools/Clef/Setup.md b/content/docs/tools/Clef/Setup.md index ded3652eee..205a37a223 100644 --- a/content/docs/tools/Clef/Setup.md +++ b/content/docs/tools/Clef/Setup.md @@ -3,17 +3,17 @@ title: Advanced setup sort_key: D --- +Clef is a signer and account management tool that is external to Geth. This means it can be run as a separate process or even on a separate machine to the one running Geth, for example on secure hardware that is not connected to any external network, or on secure virtual machines. +This page describes how Clef can be used with Qubes OS to provide a more secure setup than a normal laptop. Using Clef with USBArmory hardware is also briefly described. -This document describes how Clef can be used in a more secure manner than executing it from your everyday laptop, -in order to ensure that the keys remain safe in the event that your computer should get compromised. +{:toc} +- this will be removed by the toc ## Qubes OS - ### Background -The Qubes operating system is based around virtual machines (qubes), where a set of virtual machines are configured, typically for -different purposes such as: +The Qubes operating system configures a set of virtual machines for different purposes such as: - personal - Your personal email, browsing etc @@ -28,14 +28,12 @@ A couple of dedicated virtual machines handle externalities: - sys-firewall handles firewall rules - sys-usb handles USB devices, and can map usb-devices to certain qubes. -The goal of this document is to describe how we can set up clef to provide secure transaction -signing from a `vault` vm, to another networked qube which runs Dapps. +The goal of this document is to describe how we can set up Clef to provide secure transaction signing from a `vault` vm, to another networked qube which runs Dapps. ### Setup There are two ways that this can be achieved: integrated via Qubes or integrated via networking. - #### 1. Qubes Integrated Qubes provides a facility for inter-qubes communication via `qrexec`. A qube can request to make a cross-qube RPC request @@ -46,7 +44,7 @@ to another qube. The OS then asks the user if the call is permitted. A policy-file can be created to allow such interaction. On the `target` domain, a service is invoked which can read the `stdin` from the `client` qube. -This is how [Split GPG](https://www.qubes-os.org/doc/split-gpg/) is implemented. We can set up Clef the same way: +This is how [Split GPG](https://www.qubes-os.org/doc/split-gpg/) is implemented. Clef can be set up in the same way: ##### Server @@ -54,8 +52,6 @@ This is how [Split GPG](https://www.qubes-os.org/doc/split-gpg/) is implemented. On the `target` qubes, we need to define the RPC service. -[qubes.Clefsign](qubes.Clefsign): - ```bash #!/bin/bash @@ -80,7 +76,7 @@ It will forward the data received on `stdin` (forwarded by the OS) to Clef's HTT It would have been possible to send data directly to the `/home/user/.clef/.clef.ipc` socket via e.g `nc -U /home/user/.clef/clef.ipc`, but the reason for sending the request -data over `HTTP` instead of `IPC` is that we want the ability to forward `HTTP` headers. +data over `HTTP` instead of `IPC` is for the ability to forward `HTTP` headers. To enable the service: @@ -94,14 +90,9 @@ with minimal requirements. ##### Client - -On the `client` qube, we need to create a listener which will receive the request from the Dapp, and proxy it. - - -[qubes-client.py](qubes-client.py): +On the `client` qube, a listener is required to receive the request from the Dapp, and proxy it. ```python - """ This implements a dispatcher which listens to localhost:8550, and proxies requests via qrexec to the service qubes.EthSign on a target domain @@ -124,13 +115,11 @@ class Dispatcher(http.server.BaseHTTPRequestHandler): with socketserver.TCPServer(("",PORT), Dispatcher) as httpd: print("Serving at port", PORT) httpd.serve_forever() - - ``` #### Testing -To test the flow, if we have set up `debian-work` as the `target`, we can do +To test the flow, with `debian-work` as the `target`: ```bash $ cat newaccnt.json @@ -147,7 +136,7 @@ Followed by a GTK-dialog to approve the operation: ![two](qubes_newaccount-2.png) -To test the full flow, we use the client wrapper. Start it on the `client` qube: +To test the full flow, start the client wrapper on the `client` qube: ``` [user@work qubes]$ python3 qubes-client.py ``` @@ -186,16 +175,14 @@ from other qubes. ![Clef via http](clef_qubes_http.png) - - ## USBArmory The [USB armory](https://inversepath.com/usbarmory) is an open source hardware design with an 800 MHz ARM processor. It is a pocket-size computer. When inserted into a laptop, it identifies itself as a USB network interface, basically adding another network -to your computer. Over this new network interface, you can SSH into the device. +to your computer that can be used to SSH into the device. -Running Clef off a USB armory means that you can use the armory as a very versatile offline computer, which only -ever connects to a local network between your computer and the device itself. +Running Clef off a USB armory means that the armory can be used as a very versatile offline computer, which only +ever connects to a local network between the local computer and the device itself. Needless to say, while this model should be fairly secure against remote attacks, an attacker with physical access to the USB Armory would trivially be able to extract the contents of the device filesystem. diff --git a/content/docs/tools/Clef/datatypes.md b/content/docs/tools/Clef/datatypes.md index bdf8e2782d..fc1499c00f 100644 --- a/content/docs/tools/Clef/datatypes.md +++ b/content/docs/tools/Clef/datatypes.md @@ -5,7 +5,8 @@ sort_key: F ## UI Client interface -These data types are defined in the channel between clef and the UI +These data types are defined in the channel between Clef and the UI + ### SignDataRequest SignDataRequest contains information about a pending request to sign some data. The data to be signed can be of various types, defined by content-type. Clef has done most of the work in canonicalizing and making sense of the data, and it's up to the UI to present the user with the contents of the `message` From 0cb917a9dcc3c59f1cbf05568570defd4c70d834 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 16 Aug 2022 11:33:04 +0100 Subject: [PATCH 029/432] add puppeth page --- content/docs/tools/puppeth/index.md | 167 +++++++++++++++++++++++++++- 1 file changed, 166 insertions(+), 1 deletion(-) diff --git a/content/docs/tools/puppeth/index.md b/content/docs/tools/puppeth/index.md index 73856b26f6..619b0c0e48 100644 --- a/content/docs/tools/puppeth/index.md +++ b/content/docs/tools/puppeth/index.md @@ -2,7 +2,172 @@ title: puppeth --- -Puppeth is a tool for quickly spinning up private development networks. +Puppeth is a tool for quickly spinning up and managing private development networks. Puppeth gives fine-grained control over the network properties including the genesis block, signers, bootnodes, dashboards, etc but abstracts away the complexity of configuring it all manually. +The user is guided through the process by a command line wizard. +Puppeth comes bundled with Geth. The binary for Puppeth is built along with the other command line tools when the user runs `make all`. By default the binaries are saved to `build/bin`. This page demonstrates how to start a private proof-of-authority network with all the nodes running on the local machine. Other configurations are also possible, for example nodes can be spread over multiple (virtual) machines and the consensus mechanism can be proof-of-work. + +## Creating accounts + +To run a Clique network, authorized nodes must seal each block. This requires accounts to exist that can be pre-authorized in the genesis block. These accounts should be created before Puppeth is started. The accounts can be created using Geth's built in account manager as follows: + +```sh +geth account new --datadir NodeId +``` +For each account, replace NodeId with Node 1, 2, 3 etc. This saves the details about each account to a new directory. + +Geth will prompt for a password. Once provided, the public address of the new account and the location of the secret key file is displayed to the terminal. It is a good idea to copy these details down in a text document because they will be needed later. This account generation step should be repeated until the number of accounts is at least equal to the desired number of nodes on the proof-of-authority network plus a few extra that will act as non-sealing nodes. Make sure the account passwords are also securely backed up for each new account. + +See more on the [account management pages](/content/docs/fundamentals/account-management.md). + +## Starting Puppeth + +Starting Puppeth is as easy as running `puppeth` in the terminal: + +```sh +puppeth +``` + +This starts the wizard in the terminal. + +```terminal ++-----------------------------------------------------------+ +| Welcome to puppeth, your Ethereum private network manager | +| | +| This tool lets you create a new Ethereum network down to | +| the genesis block, bootnodes, miners and ethstats servers | +| without the hassle that it would normally entail. | +| | +| Puppeth uses SSH to dial in to remote servers, and builds | +| its network components out of Docker containers using the | +| docker-compose toolset. | ++-----------------------------------------------------------+ + +Please specify a network name to administer (no spaces or hyphens, please) +``` + +The wizard prompts for a network name, in this case it can be called `testnetwork`. Typing `testnetwork` and Enter returns the following: + +```terminal +Sweet, you can set this via --network=testnetwork next time! + +INFO [08-15|12:40:39.643] Administering Ethereum network name=testnetwork +WARN [08-15|12:40:39.643] No previous configurations found path=/home/.puppeth/testnetwork + +What would you like to do? (default = stats) +1. Show network stats +2. Configure new genesis block +3. Track new remote server +4. Deploy network components +``` + +There are four options displayed in the terminal. Select `2. Configure new genesis block` by typing `2` and Enter. The wizard presents the option to start a new genesis block from scratch or to import one. Select `1. Create new genesis block from scratch`. Then choose `Clique - proof-of-authority` when the wizard prompts for a choice of consensus engine, and then, when prompted, a block time in seconds (e.g. 15). + +Next, the wizard prompts for the addresses of accounts that should be authorized to sign blocks. Here, the public addresses of the accoutjs created earlier can be pasted one-by-one. Note that the leading `0x` is preset, so do not repeat it when copy/pasting. Enter each address individually, separating them by pressing Enter (i.e. do not enter a list of addresses). + +In a real network these would not be arbitrary accounts as they are in this demonstration, they would be trusted accounts belonging to specific node operators authorized to seal blocks. + +After determining the sealer accounts, the wizard asks which accounts to prefund with ether. Provide all the sealer account addresses and the additional addresses generated earlier. + +```terminal +Which accounts are allowed to seal? (mandatory at least one) + +> 0xbb70c0073cb20d3b20cec14f2bfbe1b61a5b2bd1 +> 0xbef818cf91f521012020ff1ec17c5e5e929b2bc6 +... + +Which accounts should be pre-funded? (advisable at least one) + +> 0xbb70c0073cb20d3b20cec14f2bfbe1b61a5b2bd1 +> 0xbef818cf91f521012020ff1ec17c5e5e929b2bc6 +``` + +The final prompt is for a network ID. For this tutorial it is fine to skip this by hitting Enter 0 - this causes Puppeth to fallback to its default behaviour which is to randomly generate a network ID. + +Puppeth will then display the following message to the terminal indicating that `testnetwork`'s genesis block has been configured. + +```terminal +INFO [08-15|14:25:09.630] Configured new genesis block +``` + +Puppeth has also returned to the 'start menu' encountered earlier. Now, the second option on the menu has updated toread `2. manage existing genesis`. Selecting that option opens a new menu where the genesis configuration can be modified, removed or exported. Choose `2` again to export the config data as a set of json files to a user-defined directory. + +```terminal +What would you like to do? (default = stats) +1. Shown network status +2. Manage existing genesis +3. Track new remote server +4. Deploy network components + +> 2 + +1. Modify existing configurations +2. Export genesis configurations +3. Remove genesis configurations + +> 2 + +Which folder to save the genesis specs into? (default = current) + Will create testnetwork.json, testnetwork-aleth.json, testnetwork-harmony.json, testnetwork-parity.json + +> /home/testnetwork +``` + +At this point a genesis configuration has been created and backed up. There are a few more componments that are required to start the network. + +## Network components + +Puppeth includes wizards for adding several network components: + +```sh +1. Ethstats - Network monitoring tool +2. Bootnode - Entry point for a network +3. Sealer - Full node minting new blocks +4. Explorer - Chain analysis webservice +5. Faucet - Crypto faucet to give away funds +6. Dashboard - Website listing above web services +``` + +These are all accessed by starting Puppeth and selecting `4. Deploy network components` from the main menu. They should be deployed in the numerical order in which they are listed in the `Network components` submenu. + +### Ethstats + +Ethstats is a network monitoring service. The Ethstats server must already be installed (see [instructions](https://github.com/cubedro/eth-netstats)) and running so that its IP address can be provided to Puppeth. The IP address of each node is also required. The wizard guides the user through providing the IP addresses and ports for Ethstats and the local nodes and setting a password for the Ethstats API. + +### Bootnodes + +Bootnodes are nodes with hardcoded addresses that allow new nodes entering the network to immediately find peers to connect to. This makes peer discovery faster. The wizard guides the user through providing IP addresses for nodes on the network that will be used as bootnodes. + +### Sealer + +The sealer nodes must be specified. These validate the network by sealing blocks. The wizard prompts the user to provide the IP addresses for the sealer nodes along with their keyfiles and unlock passwords. Some additional information is also set for the bootnodes including their gas limit - the higher the gas limit the more work the node has to do to validate each block. To match Ethereum set it to 15,000,000. The gas price can be anything, but since it is a private test network it may as well be small, say 1 GWei. + +Puppeth will display the details of each node in a table in the terminal. + +### Explorer + +For proof-of-work networks a block explorer akin to [etherscan](etherscan.io) can be created using the Puppeth wizard. + +### Faucet + +A faucet is an app that allows accounts to request ether to be sent to them. This can be created easily by following the wizard. The wizard prompts the user for details related to which node will act as a server for the faucet, how much ether to release per request, intervals between releases and some optional security features. + +### Dashboard + +The dashboard wizard pulls together the pieces from the already-defined network components into a single dashboard that can be navigated to in a web browser. The wizard guides the user through the necessary steps. Optionally, the explorer and faucet apps can be deployed here too. + +The dashboard can then be viewed by navigating to the node's ip address and the defined port in a web browser. + +## Starting the network + +Start instances of Geth for each node + +``` +geth --datadir Node1 --port 30301 --bootnodes --networkid -unlock --mine +``` + +## Summary + +Puppeth is a command line wizard that guides a user through the various stages of setting up a private network using proof-of-authority or proof-of-work consensus engine. Various network components can be added that optimize the network or enable network monitoring. [Github repository](https://github.com/ethereum/go-ethereum/tree/master/cmd/puppeth) \ No newline at end of file From 88082b29f7496aeddfb066f7c505c4e461f9d16e Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 16 Aug 2022 12:08:18 +0100 Subject: [PATCH 030/432] markdown formatting --- .../docs/getting_started/consensus-clients.md | 70 +++------------ content/docs/tools/devp2p/index.md | 89 +++++++------------ content/docs/tools/puppeth/index.md | 1 + content/homepage.md | 2 +- 4 files changed, 49 insertions(+), 113 deletions(-) diff --git a/content/docs/getting_started/consensus-clients.md b/content/docs/getting_started/consensus-clients.md index f57bc4e26f..d65907c71f 100644 --- a/content/docs/getting_started/consensus-clients.md +++ b/content/docs/getting_started/consensus-clients.md @@ -1,31 +1,19 @@ --- title: Connecting to Consensus Clients -sort_key: A3 +description: Instructions for connecting Geth to a consensus client --- -Geth is an [execution client][ex-client-link]. Historically, an execution client alone was enough to -run a full Ethereum node. However, ever since Ethereum swapped from [proof-of-work][pow-link] (PoW) to -[proof-of-stake][pos-link] (PoS) based consensus, Geth has needed to be coupled to another piece of -software called a ["consensus client"][con-client-link]. +Geth is an [execution client](https://ethereum.org/en/glossary/#execution-client). Historically, an execution client alone was enough to run a full Ethereum node. However, ever since Ethereum swapped from [proof-of-work](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow) (PoW) to [proof-of-stake](https://ethereum.org/en/developers/docs/consensus-mechanisms/pos) (PoS) based consensus, Geth has needed to be coupled to another piece of software called a ["consensus client"](https://ethereum.org/en/glossary/#consensus-client). -There are five consensus clients available, all of which connect to Geth in the same way. -This page will outline how Geth can be set up with a consensus client to form a complete Ethereum node. +There are five consensus clients available, all of which connect to Geth in the same way. This page will outline how Geth can be set up with a consensus client to form a complete Ethereum node. ## Configuring Geth -Geth can be downloaded and installed according to the instructions on the -[Installing Geth](/docs/install-and-build/installing-geth) page. In order to connect to a consensus client, -Geth must expose a port for the inter-client RPC connection. +Geth can be downloaded and installed according to the instructions on the [Installing Geth](/docs/install-and-build/installing-geth) page. In order to connect to a consensus client, Geth must expose a port for the inter-client RPC connection. -The RPC connection must be authenticated using a `jwtsecret` file. This is created and saved -to `/geth/jwtsecret` by default but can also be created and saved to a custom location or it can be -self-generated and provided to Geth by passing the file path to `--authrpc.jwtsecret`. The `jwtsecret` file -is required by both Geth and the consensus client. +The RPC connection must be authenticated using a `jwtsecret` file. This is created and saved to `/geth/jwtsecret` by default but can also be created and saved to a custom location or it can be self-generated and provided to Geth by passing the file path to `--authrpc.jwtsecret`. The `jwtsecret` file is required by both Geth and the consensus client. -The authorization must then be applied to a specific address/port. This is achievd by passing an address to -`--authrpc.addr` and a port number to `--authrpc.port`. It is also safe to provide either `localhost` or a wildcard -`*` to `--authrpc.vhosts` so that incoming requests from virtual hosts are accepted by Geth because it only -applies to the port authenticated using `jwtsecret`. +The authorization must then be applied to a specific address/port. This is achieved by passing an address to `--authrpc.addr` and a port number to `--authrpc.port`. It is also safe to provide either `localhost` or a wildcard `*` to `--authrpc.vhosts` so that incoming requests from virtual hosts are accepted by Geth because it only applies to the port authenticated using `jwtsecret`. A complete command to start Geth so that it can connect to a consensus client looks as follows: @@ -33,7 +21,6 @@ A complete command to start Geth so that it can connect to a consensus client lo geth --authrpc.addr localhost --authrpc.port 8551 --authrpc.vhosts localhost --authrpc.jwtsecret /tmp/jwtsecret ``` - ## Consensus clients There are currently four consensus clients that can be run alongside Geth. These are: @@ -48,36 +35,21 @@ There are currently four consensus clients that can be run alongside Geth. These [Lodestar](https://lodestar.chainsafe.io/): written in Typescript -It is recommended to consider [client diversity][client-div-link] when choosing a consensus client. -Instructions for installing each client are provided in the documentation linked in the list above. +It is recommended to consider [client diversity](https://ethereum.org/en/developers/docs/nodes-and-clients/client-diversity) when choosing a consensus client. Instructions for installing each client are provided in the documentation linked in the list above. -The consensus client must be started with the right port configuration to establish an RPC connection -to the local Geth instance. In the example above, `localhost:8551` was authorized -for this purpose. The consensus clients all have a command similar to `--http-webprovider` that -takes the exposed Geth port as an argument. +The consensus client must be started with the right port configuration to establish an RPC connection to the local Geth instance. In the example above, `localhost:8551` was authorized for this purpose. The consensus clients all have a command similar to `--http-webprovider` that takes the exposed Geth port as an argument. -The consensus client also needs the path to Geth's `jwt-secret` in order to authenticate the RPC connection between them. -Each consensus client has a command similar to `--jwt-secret` that takes the file path as an argument. This must -be consistent with the `--authrpc.jwtsecret` path provided to Geth. +The consensus client also needs the path to Geth's `jwt-secret` in order to authenticate the RPC connection between them. Each consensus client has a command similar to `--jwt-secret` that takes the file path as an argument. This must be consistent with the `--authrpc.jwtsecret` path provided to Geth. -The consensus clients all expose a [Beacon API][beacon-api-link] that can be used to check the status -of the Beacon client or download blocks and consensus data by sending requests using tools such as -[Curl](https://curl.se). More information on this can be found in the documentation for each consensus client. +The consensus clients all expose a [Beacon API](https://ethereum.github.io/beacon-APIs) that can be used to check the status of the Beacon client or download blocks and consensus data by sending requests using tools such as [Curl](https://curl.se). More information on this can be found in the documentation for each consensus client. ## Validators -Validators are responsible for securing the Ethereum blockchain. Validators have staked at least 32 ETH into a -deposit contract and run validator software. Each of the consensus clients have their own validator software that -is described in detail in their respective documentation. The easiest way to handle staking and validator -key generation is to use the Ethereum Foundation [Staking Launchpad][launchpad-link]. The Launchpad guides users -through the process of generating validator keys and connecting the validator to the consensus client. +Validators are responsible for securing the Ethereum blockchain. Validators have staked at least 32 ETH into a deposit contract and run validator software. Each of the consensus clients have their own validator software that is described in detail in their respective documentation. The easiest way to handle staking and validator key generation is to use the Ethereum Foundation [Staking Launchpad](https://launchpad.ethereum.org/). The Launchpad guides users through the process of generating validator keys and connecting the validator to the consensus client. ## Using Geth -Geth is the portal for users to send transactions to Ethereum. The Geth Javascript console is available -for this purpose, and the majority of the [JSON-RPC API](/docs/rpc/server) will remain available via web3js -or HTTP requests with commands as json payloads. These options are explained in more detail on the -[Javascript Console page](/docs/interface/javascript-console). The Javascript console can be started +Geth is the portal for users to send transactions to Ethereum. The Geth Javascript console is available for this purpose, and the majority of the [JSON-RPC API](/docs/rpc/server) will remain available via web3js or HTTP requests with commands as json payloads. These options are explained in more detail on the [Javascript Console page](/docs/interface/javascript-console). The Javascript console can be started using the following command in a separate terminal (assuming Geth's IPC file is saved in `datadir`): ```shell @@ -86,22 +58,6 @@ geth attach datadir/geth.ipc ## Summary -Now that Ethereum has implemented proof-of-stake, Geth users are required to install and run a consensus client. -Otherwise, Geth will not be able to track the head of the chain. There are five consensus clients to choose from. -This page provided an overview of how to choose a consensus client and configure Geth to connect to it. +Now that Ethereum has implemented proof-of-stake, Geth users are required to install and run a consensus client. Otherwise, Geth will not be able to track the head of the chain. There are five consensus clients to choose from. This page provided an overview of how to choose a consensus client and configure Geth to connect to it. -[pow-link]:https://ethereum.org/en/developers/docs/consensus-mechanisms/pow -[pos-link]:https://ethereum.org/en/developers/docs/consensus-mechanisms/pos -[con-client-link]:https://ethereum.org/en/glossary/#consensus-client -[ex-client-link]:https://ethereum.org/en/glossary/#execution-client -[beacon-api-link]:https://ethereum.github.io/beacon-APIs -[engine-api-link]: https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md -[client-div-link]:https://ethereum.org/en/developers/docs/nodes-and-clients/client-diversity -[execution-clients-link]: https://ethereum.org/en/developers/docs/nodes-and-clients/client-diversity/#execution-clients -[launchpad-link]:https://launchpad.ethereum.org/ -[prater-launchpad-link]:https://prater.launchpad.ethereum.org/ -[kiln-launchpad-link]:https://kiln.launchpad.ethereum.org/ -[ropsten-launchpad-link]:https://ropsten.launchpad.ethereum.org/ -[e-org-link]: https://ethereum.org/en/developers/docs/nodes-and-clients/run-a-node/ -[checklist-link]:https://launchpad.ethereum.org/en/merge-readiness diff --git a/content/docs/tools/devp2p/index.md b/content/docs/tools/devp2p/index.md index 2237be183d..5ecd3283bc 100644 --- a/content/docs/tools/devp2p/index.md +++ b/content/docs/tools/devp2p/index.md @@ -1,23 +1,21 @@ --- title: devp2p +description: introduction to the devp2p peer-to-peer networking tool --- -[DevP2P](https://github.com/ethereum/devp2p) is a set of network protocols that form the -Ethereum peer-to-peer network. The DevP2P specifications define precisely how nodes -should find each other and communicate. Geth implements the DevP2P specifications in Go. +[DevP2P](https://github.com/ethereum/devp2p) is a set of network protocols that form the Ethereum peer-to-peer network. The DevP2P specifications define precisely how nodes should find each other and communicate. Geth implements the DevP2P specifications in Go. -The DevP2P stack includes the low-level peer-to-peer protocols that define discovery and -secure sessions between nodes such as: +The DevP2P stack includes the low-level peer-to-peer protocols that define discovery and secure sessions between nodes such as: -[Ethereum Node Records](https://github.com/ethereum/devp2p/blob/master/enr.md): A standard format for connectivity information for a node -[Discovery protocol](https://github.com/ethereum/devp2p/blob/master/discv4.md): Defines how nodes find each other. -[RLPx protocol](https://github.com/ethereum/devp2p/blob/master/rlpx.md): Defines a TCP based transport system for communication between nodes. +- [Ethereum Node Records](https://github.com/ethereum/devp2p/blob/master/enr.md): A standard format for connectivity information for a node +- [Discovery protocol](https://github.com/ethereum/devp2p/blob/master/discv4.md): Defines how nodes find each other. +- [RLPx protocol](https://github.com/ethereum/devp2p/blob/master/rlpx.md): Defines a TCP based transport system for communication between nodes. DevP2P also includes the RLPx-based application level protocols including: -[Ethereum Wire Protocol](https://github.com/ethereum/devp2p/blob/master/caps/eth.md): facilitates exchange of blockchain data between peers -[Ethereum Snapshot Protocol](https://github.com/ethereum/devp2p/blob/master/caps/snap.md): enables exchange of snapshots between peers -[Light Ethereum Subprotocol](https://github.com/ethereum/devp2p/blob/master/caps/les.md): protocol used by light clients +- [Ethereum Wire Protocol](https://github.com/ethereum/devp2p/blob/master/caps/eth.md): facilitates exchange of blockchain data between peers +- [Ethereum Snapshot Protocol](https://github.com/ethereum/devp2p/blob/master/caps/snap.md): enables exchange of snapshots between peers +- [Light Ethereum Subprotocol](https://github.com/ethereum/devp2p/blob/master/caps/les.md): protocol used by light clients To debug and develop these networking components, Geth includes a command line tool called `devp2p`. @@ -25,8 +23,7 @@ This page will outline some of `devp2p`s built-in tools. ### ENR Decoding -Ethereum Node Records can be decoded, verified and displayed to the terminal using `enrdump`. It takes the ENR in its encoded form, which -is the base64 encoding of its RLP representation. A decoded human-readable text representation is displayed. +Ethereum Node Records can be decoded, verified and displayed to the terminal using `enrdump`. It takes the ENR in its encoded form, which is the base64 encoding of its RLP representation. A decoded human-readable text representation is displayed. Use `devp2p enrdump ` to verify and display an Ethereum Node Record. @@ -38,8 +35,7 @@ The `devp2p key ...` command family deals with node key files. Run `devp2p key generate mynode.key` to create a new node key in the `mynode.key` file. -Run `devp2p key to-enode mynode.key -ip 127.0.0.1 -tcp 30303` to create an enode:// URL -corresponding to the given node key and address information. +Run `devp2p key to-enode mynode.key -ip 127.0.0.1 -tcp 30303` to create an enode:// URL corresponding to the given node key and address information. ### Maintaining DNS Discovery Node Lists @@ -53,28 +49,24 @@ Run `devp2p dns to-cloudflare ` to publish a tree to CloudFlare DNS. Run `devp2p dns to-route53 ` to publish a tree to Amazon Route53. -More information about these commands can be found in the [DNS Discovery Setup Guide][dns-tutorial]. +More information about these commands can be found in the [DNS Discovery Setup Guide](https://geth.ethereum.org/docs/developers/dns-discovery-setup). ### Node Set Utilities -There are several commands for working with JSON node set files. These files are generated -by the discovery crawlers and DNS client commands. Node sets also used as the input of the -DNS deployer commands. +There are several commands for working with JSON node set files. These files are generated by the discovery crawlers and DNS client commands. Node sets also used as the input of the DNS deployer commands. Run `devp2p nodeset info ` to display statistics of a node set. - -Run `devp2p nodeset filter ` to write a new, filtered node -set to standard output. The following filters are supported: - + +Run `devp2p nodeset filter ` to write a new, filtered node set to standard output. The following filters are supported: + - `-limit ` limits the output set to N entries, taking the top N nodes by score - `-ip ` filters nodes by IP subnet - `-min-age ` filters nodes by 'first seen' time - `-eth-network ` filters nodes by "eth" ENR entry - `-les-server` filters nodes by LES server support - `-snap` filters nodes by snap protocol support - -For example, given a node set in `nodes.json`, you could create a filtered set containing -up to 20 eth mainnet nodes which also support snap sync using this command: + +For example, given a node set in `nodes.json`, you could create a filtered set containing up to 20 eth mainnet nodes which also support snap sync using this command: ```sh devp2p nodeset filter nodes.json -eth-network mainnet -snap -limit 20 @@ -82,41 +74,32 @@ devp2p nodeset filter nodes.json -eth-network mainnet -snap -limit 20 ### Discovery v4 Utilities -The `devp2p discv4 ...` command family deals with the [Node Discovery v4][discv4] -protocol. +The `devp2p discv4 ...` command family deals with the [Node Discovery v4](https://github.com/ethereum/devp2p/tree/master/discv4.md) protocol. Run `devp2p discv4 ping ` to ping a node. -Run `devp2p discv4 resolve ` to find the most recent node record of a node in -the DHT. +Run `devp2p discv4 resolve ` to find the most recent node record of a node in the DHT. Run `devp2p discv4 crawl ` to create or update a JSON node set. ### Discovery v5 Utilities -The `devp2p discv5 ...` command family deals with the [Node Discovery v5][discv5] -protocol. This protocol is currently under active development. +The `devp2p discv5 ...` command family deals with the [Node Discovery v5](https://github.com/ethereum/devp2p/tree/master/discv5/discv5.md) protocol. This protocol is currently under active development. Run `devp2p discv5 ping ` to ping a node. -Run `devp2p discv5 resolve ` to find the most recent node record of a node in -the discv5 DHT. +Run `devp2p discv5 resolve ` to find the most recent node record of a node in the discv5 DHT. Run `devp2p discv5 listen` to run a Discovery v5 node. -Run `devp2p discv5 crawl ` to create or update a JSON node set containing -discv5 nodes. +Run `devp2p discv5 crawl ` to create or update a JSON node set containing discv5 nodes. ### Discovery Test Suites -The devp2p command also contains interactive test suites for Discovery v4 and Discovery -v5. To run these tests a networking environment must be set up with two separate UDP listening -addresses are available on the same machine. The two listening addresses must also be routed such +The devp2p command also contains interactive test suites for Discovery v4 and Discovery v5. To run these tests a networking environment must be set up with two separate UDP listening addresses are available on the same machine. The two listening addresses must also be routed such that they are able to reach the node you want to test. -For example, to run the test on the local host when the node under test is -also on the local host, assign two IP addresses (or a larger range) to the -loopback interface. On macOS, this can be done by executing the following command: +For example, to run the test on the local host when the node under test is also on the local host, assign two IP addresses (or a larger range) to the loopback interface. On macOS, this can be done by executing the following command: ```sh sudo ifconfig lo0 add 127.0.0.2 @@ -124,8 +107,7 @@ sudo ifconfig lo0 add 127.0.0.2 Either test suite can then be run as follows: -1. Start the node under test first, ensuring that it won't talk to the Internet (i.e. disable bootstrapping). An easy way to prevent -unintended connections to the global DHT is listening on `127.0.0.1`. +1. Start the node under test first, ensuring that it won't talk to the Internet (i.e. disable bootstrapping). An easy way to prevent unintended connections to the global DHT is listening on `127.0.0.1`. 2. Get the ENR of the node and store it in the `NODE` environment variable. @@ -133,21 +115,21 @@ unintended connections to the global DHT is listening on `127.0.0.1`. ### Eth Protocol Test Suite -The Eth Protocol test suite is a conformance test suite for the [eth protocol][eth]. +The Eth Protocol test suite is a conformance test suite for the [eth protocol](https://github.com/ethereum/devp2p/blob/master/caps/eth.md). To run the eth protocol test suite, the node needs to be initialized as follows: -1. initialize the geth node with the `genesis.json` file contained in the `testdata` directory +1. initialize the Geth node with the `genesis.json` file contained in the `testdata` directory 2. import the `halfchain.rlp` file in the `testdata` directory -3. run geth with the following flags: +3. run Geth with the following flags: ```sh geth --datadir --nodiscover --nat=none --networkid 19763 --verbosity 5 ``` -Then, run the following command, replacing `` with the enode of the geth node: +Then, run the following command, replacing `` with the enode of the Geth node: ```sh devp2p rlpx eth-test cmd/devp2p/internal/ethtest/testdata/chain.rlp cmd/devp2p/internal/ethtest/testdata/genesis.json @@ -157,15 +139,12 @@ Repeat the above process (re-initialising the node) in order to run the Eth Prot #### Eth66 Test Suite -The Eth66 test suite is also a conformance test suite for the eth 66 protocol version specifically. -To run the eth66 protocol test suite, initialize a geth node as described above and run the following command, -replacing `` with the enode of the geth node: +The Eth66 test suite is also a conformance test suite for the eth 66 protocol version specifically. To run the eth66 protocol test suite, initialize a Geth node as described above and run the following command, replacing `` with the enode of the Geth node: ```sh devp2p rlpx eth66-test cmd/devp2p/internal/ethtest/testdata/chain.rlp cmd/devp2p/internal/ethtest/testdata/genesis.json ``` -[eth]: https://github.com/ethereum/devp2p/blob/master/caps/eth.md -[dns-tutorial]: https://geth.ethereum.org/docs/developers/dns-discovery-setup -[discv4]: https://github.com/ethereum/devp2p/tree/master/discv4.md -[discv5]: https://github.com/ethereum/devp2p/tree/master/discv5/discv5.md \ No newline at end of file +## Summary + +This page introduced the DevP2P stack that defines Ethereum's peer-to-peer network and the `devp2p` command line tool that comes bundled with Geth. The `devp2p` tools enables Geth developers to work on the peer-to-peer network. \ No newline at end of file diff --git a/content/docs/tools/puppeth/index.md b/content/docs/tools/puppeth/index.md index 619b0c0e48..7c784d3b07 100644 --- a/content/docs/tools/puppeth/index.md +++ b/content/docs/tools/puppeth/index.md @@ -1,5 +1,6 @@ --- title: puppeth +description: introduction to the private-network boot-strapping tool, Puppeth --- Puppeth is a tool for quickly spinning up and managing private development networks. Puppeth gives fine-grained control over the network properties including the genesis block, signers, bootnodes, dashboards, etc but abstracts away the complexity of configuring it all manually. diff --git a/content/homepage.md b/content/homepage.md index eb2254aa34..02ed13f4e8 100644 --- a/content/homepage.md +++ b/content/homepage.md @@ -1,6 +1,6 @@ --- title: Home -root: .. +description: Geth homepage --- ## What is Geth? From dce6f95be50917fd8e42b4774a185732f28c3b85 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 16 Aug 2022 13:22:32 +0100 Subject: [PATCH 031/432] md formatting and add qubes images --- assets/clef_qubes_http.png | Bin 0 -> 12237 bytes assets/clef_qubes_qrexec.png | Bin 0 -> 17443 bytes assets/clef_sign_flow.png | Bin 0 -> 100271 bytes .../ethstats-mainnet.png | Bin assets/qrexec-example.png | Bin 0 -> 16166 bytes assets/qubes-client.py | 23 ++++ assets/qubes.Clefsign | 16 +++ assets/qubes_newaccount-1.png | Bin 0 -> 22348 bytes assets/qubes_newaccount-2.png | Bin 0 -> 37250 bytes content/docs/monitoring/dashboards.md | 16 +-- content/docs/monitoring/ethstats.md | 2 +- content/docs/tools/Clef/CliqueSigning.md | 17 ++- content/docs/tools/Clef/Introduction.md | 91 +++----------- content/docs/tools/Clef/Rules.md | 118 ++++-------------- content/docs/tools/Clef/datatypes.md | 2 +- 15 files changed, 99 insertions(+), 186 deletions(-) create mode 100644 assets/clef_qubes_http.png create mode 100644 assets/clef_qubes_qrexec.png create mode 100644 assets/clef_sign_flow.png rename {content/docs/monitoring => assets}/ethstats-mainnet.png (100%) create mode 100644 assets/qrexec-example.png create mode 100644 assets/qubes-client.py create mode 100644 assets/qubes.Clefsign create mode 100644 assets/qubes_newaccount-1.png create mode 100644 assets/qubes_newaccount-2.png diff --git a/assets/clef_qubes_http.png b/assets/clef_qubes_http.png new file mode 100644 index 0000000000000000000000000000000000000000..e95ad8da4af6fdd4f628ec4ea741c0b98147f00b GIT binary patch literal 12237 zcmch7XIPU<*Dh8>RNNwP!Jm^Bca`swk(ESJ?i-&1zpt4pJX0nk^JXO@d-w!t^T8Fz=OIQCiyuD6r_H?&2^8lzM!`XUcG}X2<~-%8^VBiU++DfZ zTn`mFs*%d?KWdGQbicF1IEm&Yj%E3^`egf{Vac)!gjt{My{;CPkKfM8POjm_eJ;MT zYBM&(`@Ar`apMO4OgrT4n>TNM!v6E?4D#)pH)oLK+)3Solau!T=mdALrbcM8#F{pgI=kOXhZYf>x>t}q{| zl)fCj@Uzg|SZWrd59+#*TJO>#%sdS(zSIC+QGM`rXixbBgLA1-LCppqs^k?mE+ljhm5v6c(j0!C! zqnhjarOwlSuVnKgqz;XEHsq91@O63n?b7Fhu4-jvWqq@p^pwtd@6BIHcv{|MegO#~ z^oX)s&UHu6wI^fSjR!*F`6-d_mA-d%on0nq{}lI-NS@D9Wy@nJ;@11&X3v0(_%53W*5tIRrON-#J5nsd{3yd(1sp^*s;mh5Pi9 zw$&B6yFA_R61=>;{AE}uub^97wW9i?Z7R99e9KwdRPyVoo!k3UaP7(-N%{%PVBLpOpe$hm%HrwA(Rnf#GaKO6d z9Q|v9ou>Kki?4%KH5nm<^R6Wfs}TY43QX{BbF&-?7D-6LtFc9bJ+F#{ZJKK#*9Nn1 zX=rG8NipxIHS{GdL{qc2IkAXiyWjDo+GL}CH4);C#EU1Z#Z3nNQ_Y*%^*@Ru!*}5D~G337CfT zVVWPPeXSN;MPITD&l$h_;P zrpJ1K>^@XdUL+YBY)rgSqnXe2=CH058rPK#)w=T+HdSu|%jGJ;RP!NKDYbqBqg;IN zFDw+k@zv=Xvh8#nz60HP?l%6;o6XsZt7r4_^N)q>4+>#}3)ngi%ZQ6uu8NI4!Z4Zh zr1Snt!G`vZG4UW~<7ywZmy84_}N+A4`-v6&@xm zdaW4e?+@kVeJ|N#m4>bQmGkTS$&~2U(~E>f&e%K_RNLv-E|G1SnkrxY>P~nLldU{o zvA%opSIFt2deQ{7jCjSuO6Rwx)0U{U@u^6(>4`=!13QgPbEdg3$KdS-(FHTfx|Tmj z%i!)-Jr}+kpV;O6(yo@XIYiJVxvV-@t9LkV$4Y?meHEUpQ>VN>-#^ha1tSrD%vIgD zo4S92VbQ~ygPWW26O1y%tR?2Nb681j-pnMEkiPK$R*Q32pi6=>@#Kc~fKK7u0+j{FN zw9x-A-FOn)vaFiAx*$7*L<}4OKzbL{8`oMAetVWZ10iO*)oAcgHkfvS#ALl^7z^R~ z1*@G{y`^!o=*u1DXvoJ}RBj~km(eQF2YusLy6-rv`Ov1sCNCc!AFFBGC!nZZO-K@% zeC*be65Axn(Qu0%6prrSZee0#I<~OC*fUf;3p?fLHU^EK^gQ+9GvA8j4yy;Ol+2zm zI`ME)_*6W8)L=|`FZDPL?dNg;>eW^v*Pa@UR+(v)I9^fLPCJBVC;T9pi=kmnhlxKe zD00UbrJ(fUC=~jknlf48IBon=&JWY@Rsj5xB)nEUwxBP=ds#*M zIU9@EX&`3=1rs?N_ZJ2R(F@3{uqN>a@gNt7g`DLXQz|;|W1x5`Mf`q!9 zM$0)Oe=>ra)Ua*;=!}_FIG=45ueb=c{xnPgk~59+TJ+mCVnj^%7+tAq1Wi>OFQCsM zuLijUx`6hFJ)cB_BG3yA^n;`M^UC7)7)|0}3PCP64yzuH2I_)}0uZ*NU+)fQ11f;2 zu>I5BfAs(VqLV3=6seKHK~|!G?BU1g;%gRStKC?InYlTyUIkc^BjHcI!{gB?)no~c z`~l9`M~Y^5FK&3lA7#~SZX?z^xITXTXkI#ED?0UyQcy^Ufu6oOQiF2o&vA2pG5HLONxDwO06xo1-nU?U|w{Pcb z7Oum?iL|nee?%t)xfE*dWx~WnMGt1^>aXlYeySY?t1=C15bsI*={u08fs(?%+i}v= z98A9-T7=%8YmcUq`t{OtMSp+F&>7*0n*r~r0kdR>7_P!g1qAND!)2n!#KVUyvX0_CxTV7rcpBuLo?VMkaii%1Q zvRK;m#vOA7O{m#a`mM{s!=+z;t6H5ZO0rU$The{`b75g@k(b!ct%-a7i$AX4z4)F< za$!%~1LNQ@xVKhcZ#O22c~swGf+J4%&d&W2tUo&FnP4&9W)gMV8N`L%8g>xeLD*pK||Vz#7d2yq}-I%7BT{=fP0= zU)C*T_i{9nj7~@$*`VD0SbXgoMRfa%vu>RKRwO5KLKd~^uS)t~`n#}^Dwu&OJ8|H8o^0Z%ahv3ZLlQ>Hl5r2hhr(?=*^x#;Xa6u;N@`aMgR(hu`#0hrJsK-~8k z_a{UDh6W*s#W^JC;I}sZbqE!QaPkK${(1EqPmaX-4MvA^IvjWQ*byAz(`&zw-wayY znTY>^17fzF{xg&_^$m5wgyo?I4_b9$N84{l_$G5}+p}Ttr{rqQUdorII2%TW-y28O zPO*pDU)QSls(ViP@YJ6!+`x(5$oy_DkD!2-Qk2$_;f)cPsDnUq(!YCosyF&=N3u*a zxU6Zve~l?+Vd#N%&d)-)t``q+1^l!>tV94)Vth5X>CJM5EffGH+YvSf9zBHuNr9|~ zV0rlPACHIC{uKOvd(`ef9zhHI-KUC*Z=0sC6pN_pmvbP4DoQ<9`~!#DTp9Uh5wmtkLJi z(c5Wi#y!iud@{YddIY;EDkcVviTOV7jO(m3EbcZJO6msYd^#vSKObu@TUSw0QC>dq zoWHEBY{$RXyp$sFxiEbT3ZO+$!xJN;HJoR&Y+Ovt>({Rp$kChLEABoT8nM^T^afK^ zju{vkIq+Y(l_$-tYHDigU2(8I$mqsJJ+D!31CHPU;~yz5UeG`U($s z4THf*%Wx3M6~u;Ygz0gz+2m-T5EoD4W@~CBaI78?^0Rv`j2A*Tctn$Uq@)h54G3T* z=VC9KwI~gA{4z$b0Eku9)6#2wm|TEltg^$~hyHmy?r|fkEKY;d3t(+HNKb5&cg%8l-z=1U28TrT(h2W^!iAnCnhF< zz+lC4)psW?Q&Env6`ysHYU+9g6 zFGZwJV=J^)Yx4nf{1=Y4_h%i;I(%*aq4*!8#W%!{t*myt+1E}W6;B;j@ja6|G-fM` z6HtbCnU}sT);jIeqia233yJ z<|xQ|VOCaFUERKU0K;E@T|c-u#YP7L_^mB>O!m;~s(o~OOiav+(vfD>FqkCch42>V zQs|XK=Wfl67uso3vQbt0ur6?QFM*PdSHH^fu0+z;5nHfFtkLb}rRU!Y-GHzhz{2mC zzj)yZpX})908?FGcc#z<^7dGEban#sYRNfG5t#Ob9sHs>`yg_AvI^I`Up@x5 zu6H|fCYS>3zf6xpojiy`3Wl(LMkmHiO4u)l0qchw7C&M4?>)bH1aSzk%D8hp92~g_ z#6bv%#F>*-px~2~#09VUa_x+BwSMu?9zv1~*5vh49BSB_UtO(JXK2rVg_Db`rT8zS zS>2lBJZAzuGeAs~`7jdEg7SbcB8o2z-o)HFn)77`=I=-(EuSzXS!D`JfyHr}0)5GBHCoYE`XWyHt2fN>fsxWQm1FB`5PRh3zz`N?fj;@NY^b zWRh||-OmLc+Jy)EKSM&DiKJY;{rcMJ^o5nJTW(zXY>P1xjbgeWr*ehFgi*rLz0`==zxU7qWXJC}!AY z58zFNN~??cj!iMcCcHqM7S4e<`)NWM3UUjbPg*ym;|O?DUTNbYt-K?&|$lwG&!PiAH)NKJs%X zOat1=UFf@pkU{=51t~J5>clwUDBPSLt=>S$Fh{m+a|j_|LqkJKYuH(zHQ)~s(v0PK z=}umkl$5-A^S(Mbr{Gmp+I6Z5z7w`M1irOZzFe1wllM%ZZedYzG3xvG4~BC1T?q*Z zfMxbXmTQQqteyO**x1|tT5@u)caT@3MtGrI+}s5f6`H;$51!2FOK5l^Myb%k@#377AS`k@rr|9! zdt`2vV|IcGy1Kf{?zKBx1G-f;eocKut~uP1B;Jqib9-Q9YI$ z#8^iNBgjPZ@bDm@fi37fMGvR9B)b{D$wDIu*Dp@U`_q;mTx5>3jPRzw70_BUrRJZS zU9NzEz(L3wy=HUc{98N=gyk>Tb~cvJe|OSD1(@$)n0Y^KaBz^>LCv^aHZ3T`S8lCHU>g`>KlBeXe%#rZ8!gav?Um;%;EnWzYAQnhXPmdji z0E8zKAoEL*yWMu;x4#`^A3BOC_S*aUh1BID!V^q$zEjDa7nvVlen(d5CYznVeVN1q z-N(Ki2BxbKZ%L%or>xo8-KgY*k3ts4lQVT;G^kb10?XklbbrMO3y_)d9dlqoIgvl8>&kFhLoU;w7}8P`xs@ zm93i^p`^b@CC%9dtYqeJZJ9|KroB;m|CEi-(C~}laP^R-KYD|JH<&=EQ~f}?9n@m_ zs}tq>B$~DgmgfcX<~VR1lyS6$BkN1y$^pQYvN%*wF+;#H6i!(smOf!gf0I8W3j@3UlU~sS5=F2J+?}VL)qsLHhXiOZE@VGdp^YJ0Qm2K z@Taew?OLr-^X+V5Mrna_*R~A?WHP<2t${?p16bfc?7{sFlryd3b$IRJUrN9D0&G7F z2=UYPdyR8Vz0Oz-tvw5)NG7pkN1NI}_%-Da7~li;t0@X!Sc?ttL9hJ|U}03Gi0W;B zH|Gv)w?#<8yide}obr<;S_w0i`d(uHiSlr(ciHuI^HT%LTK2HiWH#D#Habxv`i|t$F|4Y{up};kEd`@wtD(I) z#QvZYOUj>&CqT0ce-a6YV0V;#ynuc+tuLT+0i;O7!>&+)RBo&EWiUPFVQFCw&TlZA zOPSNJPdTn~xd~Y`AHTGjrC=rq{6jL2&ntVkx^IGPYyML&aL|H$E>@z_ju7Q~Cj%jT zTW0>tJUytFR)Jm2p`_!ZB2L-n#Zy?y`7MtI)UdXxfWv^QpY>tO=KM)+Z1L3V4dDo)2~80{ zshBvt8%RUh^JaIl|EkM2V(%1;q>dbuAvhy_lXp&A0@WZ4N6q&*;Z!ddRC~6JY_&sy z`84w(JX^&5%y&mn2=Js+RdGXt*B>YsK(R(I08yd?$w-3~S$2r5=W`>|P3j+w`?5`m z4^=A>=K%v@IP7+<*p>xGx^*~|pdjliK(C93N;G04tXEvatoOCfcZ?U{1kktr$G}iV zGj#^@ixTD4mSFF~wO~M(vQdvi@xZ<0);HX0Ah!z&bO~+xC@Os#&>A`FQa^E?X+S0| zt@^jmtfuR>DXX#eg!|N$t3`AqOJJ=5#H1;OwU@kxd{f)40zJ#QqdLW6sU?PPaA24_ zpT1{oCS_3`b3Aw=_ZTo-FNixy{6Zp=n^5>-q@z<#yoX=GRvjJkqO-yP1Fo z6pKMxCuUZ$QdYb;Z@hnF{p?HQ1AViR<9!T#L12(9l!go(qX8i)ZYLKD*{0?tyWzt6 zya#BmQiD^@622tSyKdanLp=kvn=l}aNv>X&b$~DF@-27i=-gUAEO?D?QML0Ye($;4 z?4_kO6j*J2I6{iyo5%qLiZy1xVLe|=7z==y7*G&2B-b6zg8a@=aNpu}U!93jDa4#VXslaZF zQ`Xb)B=;t&O+3v8s{RTE)f+qm8o)`41lz2ymKe;a9ys#R879dp=(O2!>}H%)=~qIz z#`C7r-hk{HTK2u*V|lGZ2iG;q#0o(_FeLZx)LbhV)#>A78$CeRf%L~yk&l(K7AGVu zER>^`j4Su*UxuE}a6k|v--f-OCT;cFZ+lbh*1T;h1be z086(FpWP#yPCbSD2be7B^P`W6U*>!#X99y9k{RP*4nRrf5}ASsJMeSYY8jJBzG$T2%~wIbXhQ}FT-fGE|% z$%~nfctw{Px+2|%)jcF+ymrZwBir|XCH)v7R7;2kVi%VyhJdXpoAg&s8Me@zRS($T zz=vkegv`6S;wHyul+SnU#Ec}=toYFL1ngr!JgM8WjSf|Z?enc)m}yK^rH?Z3fD>;wD#%fA7FOHfB4p7$0G zf8h69{q(u&VQ=Z+)e11cq`2RKKDvJI{90+MpPhtTQ4J#Zvnzf>=PIBUqtt|;wD!DX z1HRxaO?Q6Gs)8D?^1|Lpg_!vtm|03afyP~G;_CXsk_<@Hw@%YMZIiDr(%WjRS-p9$ z%G6rS??T){?6r*2Jr>WeKRDs*q<0y9s=AIL0GU?XUfRa-3%{w=4lZJ zqZCH!fC54li%OgziNp#M$2S1(wN+PIt8e5yxPhYu*U8aTsoTh*{C+p6bXz4kfnOjy zEyH-&NV&dcVueqXc*qR5G)~uj^$XY3?DDBw{P=F1gCe(QDaO*R18&;Z_F2tjhGb#d zru;$XeV8(0?G?ogv_(02Q$gO|9GUoli|Z^W{h+PnS0_|1*iNR?kplXidz1BnqXEjXTm3zku))iHRk(cycL#?<&|9?wo){KMd1Z>$O5i{M6FU7-W(a<>y&Y>T^svxpzjhJMMya>l#*Eq;pXv=LfobO4K?zQ?^Njcit&kw_Vh;WI^ihSe18SrB*cCO_ESZuU0Y6j1 zM2E$pPl`toX6Du=qZ=H1`OYhJ`HuF(^<27}<`eI%!Zs4ruv?mAEA9$u>4xBt!Rr|+ zz_#89PJg7y@(F3C{;bWCI#gL^xfin&gBcYU5%D?UBg4vITTgW%G!yrY3%`(Uo$~-H zD^zd4cM1P0aLW`6JhPwaF88<7?J6QYw7XD=Te2FpX1LOP!6@~=BC!hyT&s;r4)qDk z9YBUG8H)3pE@TQU#T2lm7$DrYfx`uykRq?W^*4Tto5QF>HZL_`B%AEqV)wj3<ov8p69GbR1{+5CBLl?4^j z%&PMK?RzDK$0-QUc50i!SdF#3t1z^wp#K!OW*6e^s3IqK5)BfA|9%}7fo#Zse*OFM z->3hsan#`7m;XNfsdlUrs_kA2|MKNSz!?x0-N+bIEgr&d?vgp%3)9a#i<2%o%3Kp?yihta zJ~09G%|JtAU}OXX?p)c~1zuCv(gON0RlK&ebm?SzW@Zz16XdG$^724hxuQaJY7Nw) zsUI>gCHNP2&gT^u)17SC4snfa>+9{kaVBsL^~&W&4ct~#&(5w8@Jxia1J(nU!t@cX zwxUYSK#sc?=@}S+!@DW_sk~f63QAo%w$gk1r4p1^LraVDkiAM)$=OlF)ji$y&g@~I zY~^K+YnuMv*~uX7UDjh+H{Afz37ho47JD-1oe%jDV`JkdPo5|#h3{xpS6725 zI}&+;f&zHrboDZTGyw^{%VB^+if+Hm$f&Qat^MrT4gV6$QlN*V&wZG{z(Bw}Wvywj zU)DMLWXeb66&BLe8-fX34(sjh1^05EX3A3plA+~Xeag$qPM$i2ajgL_e*AcX+ge#z zSon4H>Fs^?aTw4rfN>eZ&O28>%dI;=t7~e?%gHGOaD(LaQPO#HbF-nL0bJArmj-4~ zPPG$5MzhfN7c;T6IDB$)GJOOq1fpF$4X zgGP}n=gtNnN4{MY1$Qdb)6;wX=G<$g+1VB9M0;mj-3v9bfHKS<6-?-|F5lXD>R#*D z|M}?*x`kz|zaMa^v5(9E(YGT4)CT0o8iOfiJF1}!W7EEA;#6nPUQ+GrRmAsZDYdk; zOixd@2B>Rj+>UOSkd%C2;)kK(%L=Q^2v6+-Y+FZ1)P+WjYsZVPfCRz$WIgoUf|vnc z6c8NokFx<6g~J2=mn{dszrXmJm&b`&=8}@C0~Crk5)e2(Kd_DvZjwSB`e{vT@8~E! zBO|vVB^`Eo+1AP`x1gXd#SRjR|K_;rvksV&8O0~XL!lud)+7%=W|EgMN9Gh2spJp5 zrx)P_l1oj1jI=_%5P}WMJjIp#)qoeOk^^Xa=V~b~E-pz)2C!NcC;%Hek$7HQ$1V@^ zS+@wpw-^q-jU&F4%wco=+i;h zxw*TxTfHD`8DpK+tofE!|(u zlKFLp4u*z?o}N3Kbf-S4xf>g&ds=`9VP$po{hK#0fqAbqHZ=iOwPgz+R67Nag&be%^Pp8Q_|erk9nas!ii~V*D&(VxQY#6 z!eE~!U3e$1@*VWd;yz_%1;2j%!p!V}oZOpjr7+n?z9&mOo6Q`@gS#AN~CI z<-bq=XVngJNaS*FeUsANvn;?3_}i`zv|V2qyP8RuI-7w%WP0Rahq wF$sPVE`ELqe*TNUx(@H*|J%UM;f0mC*Z79_Mh$u)Aq)Af{5GfJq1jtc9 zIvk`+i9kZHp#}oE6ZD+(f8Tq)`@Hx0F7RaUti9S^Yi8EWZ)SLYOI_*kfzt=*=;#hB z|9)MQj&4Uf9o=u0`*uJ{i`(r~xa_jNs&+w24$NWRi@A&p6FGWot&mb+Dw=4VByP%+;D9wW81BN%R z-p;%h-({m!BUnL9X}T6Kw)*44i=8YomS?AW1`?t@>{B<=$AZQhmgUHtc*LM}vZKSi zUe?jatz*mUJKMvryhgGno9z#xJ9g~Y0Nq8eeb1gfV^97cee5GWfA;J@Ka|cD_YHJ) zjjq*XzE%*D-)M?nHlPF5h8n9Lq5ex$QB{ub+PK8-* zQhMcl@v=H>42^lh?D)A=92K>gUhXcf)}Knx%{VH6>5sgNAU$c!OP#CIoJ*$PTbXU~ z#bF)W;EP%|Zm*}j_6s{j;KxaLw^SSy+ifI%`SNA23RCSj&e8ZeDzS96TR*AHx24>- z{Ss?af0gq1`UeQP;lsS-;vl$65KY7EgI#k znQBJ0(=PVY5p&BvQyPi-8{__`mo0Qx`AZMWxi=W3_9{%lo~ucH|;2 zl2_T&vo|+zU7o+@3yV`fu9y1Fb;@nA6YC*2fX9cOIq7j2Mf7$VX)$nRkd4UCm|RlQ z_uAR=xmdnsz!Vi`g}QyajmaQ1M1bTcZ|2^)DBaw&ZlUpob%Z+I(>t|cWZoQ3lai9+FbfUgAmJq!Zhms`SYFK9Og^h1 zbKdK<1|l*+(kz0@W4WCPGa7Xw|M>Cl2bq#X>!)X8e_TX#y;o5^Fymsc8jjznW%bj% zru^AIY0!WEtFdh`wNqiYvhwqRfq{~179U&ie%W2`V%hM^4W&XuA*JKx3pm{1=Cuc! znwsyUE#C4_2VAY)U9DZ3l1g8b3q~Gth?SO?_s^|b912NPmueXh^Odiij>}>;YG+#x zW(d3|#b8e2GwYA6oMs)gsYUuXZ?=X-%?`%CeEC@&b(&Ldu|N2AfFe9H-b}FFSf8+7 z3Egtxzem{E+*&q3@HH8=y!0J4da)U0%_w9#z2G(f^jZ&^T8!8na;LX)AlAt(s*N>w z9XzFEzsLXXxDVne%;zNmDWFSTAG2ck+9Ux0Cs;xCAV_yMpss9}&Ed zsb9W9MtjJ27yey@4P<4_x;L`mi0jPa7WI3v*Mj-VeEYcP5Dw{D7`$e4cC_rhqcD@A zwG_h+Qn$SACpPaLxv^9Efw&?`PR^Z=Y+hl}mZMr&Gk?C(vL+QJ`_%k1EDuPHNqst+ z^X#`ox}9&Th->TWK0X>^81H#=wAS;tQ?6&jrsnujsFTqasW(wtRm}O$tYcFm-J1d% z!HnFCD8JK*>In`VlkHMwVWqQU^HYohtP{kZ@t4##997W3S7NT#LXjX!mibVyIOcjQ zS+R^>2F1pbT(_|hd&~z{shf4Sjo5SH<=pCq`)h+){PbQPt0$wK{_$MOU${<}Zf)Q; zfyB-tr!1Vz6>U6lw`5Wp^KPG`>Z|E^FI0W3elb4lw|Pwf?H8z+J7)Uc+pWq}-&}F& zgg0Y)zl=*`UK=}pYS~sSuTsPA&U5A=T%}gYU4pkS%1DO*IZ2t^-iBnM<$<8=%bFJg7m75~YYhs^3tzrV@(W6Jckyg&p@}knN zD{JW~83z}h=Q_@|R=!aAeU#tN>Q(5tUeZNg-UBKm3Bo;bTO8K!x%ilBHqwQAly#ga`-QCDu{bE!*ajWj$r9fu# z*R+fNayn2%;&TM_Moi z%BxTJlI4?y46?qkp4U#*2pVycH?d&cYGhZbo3`a7~p39h|id;dPtf4;I~|xv^##!e2o;y@$ zmc0CNLt=wA%_Yw$Lig08zGQxbBB&`bUI@haFmV46ljd>S zyZAD^WA#MsmQ~$n{rSs{yH_gZFaG8d`)A9rFGq52rosMlg|Ph#;}KsTQG7c@IRf|3 zGzEqHCQufQIxWEn^+HLx2GGbw@gza`?OEcBi*Igpe|z*9dRDB2N$v*VsiqL{Naj>wgu{p3+0%34-V$+TXuiY0r0(f42O)&nxoBpug>w zKL?==22W{&(E9v2=zqV`o^Ow_-BRJ#{QfWdk~mM6ZXOUdPrs!4)qjyA`O8a6kJNLm zx!4xriz=$&=z!;;m8rq+vs9$~juW&bBM{t^>ZZ7k&dyWrwU_Gxk&m~3|GDA$bzAoz zH$1dTQ1JJ4yAG}3@0*vkBQLp>Bi=oIx@Wr-KG=eL?Zu1x{6Zv#mwg_H8{NMBvc~)o zt*1cb=~lw(@^WEep|@<(=g(K2mC_H#03ZF6g7Wo35OAx@dx;P3Cx8pgAh zj+9SEj%;pj3dX2Zl5R+RsxWo*_4U=z2tyA2`0=K7Y-(!CwbU4eGc)e#?d=^L6r{>J z6w63Sl~z^`&UiGgUYJ$i@~#e>bSYh5Uni&_HU0ht?q&Ccn?q+=o3!|6{qVSu|Wg?L{d@Z;prF*KT^~Zu2 z1%+#~X{x9FD66O}Zfu%6mTP7f=<`Q#J%8Yr)yX@no~HR6J2gA2o7Kt9&FxcBSyUu` zbYIDUL)1+jZS7al(dU(q1Dz_!6WT+rRVt=V%*-6#wL?8aG?tQ{4zv*!6$R~v?cl{E zJ*5-(_;bKCOG^#xO|!Il^KO{x>gsA~aXKg&_Yz%nbahRGkT9zFYHCW#J<`F02Z>Xc zB_uL3G8(D%4#mNk!+ZQ2i4hov6DK%}=7>|)_wGG2s~%anXKA^6$0G^_>Ffy`kg46U zv6DTSosGni{8fs4f=B&~Ly~6ZA$diIJpJ<;N!b)V(u$9w;?p*pS2(}n>gOc)4_R3? zGsX*h!@26M^6OXm@TthRl2$^FFO70^$y0Yo8yg!$M^Eg)u$}*BVZt5seDN;yVcU zkxen4BtktSH!d^tqNu1AQou2t9^Via6m)#=a$jFx`?qh^H=mb0#?LX@aeyXAQh(gj z)AQ)jZ$C*pgXJ+YzBxJ}!Pv;iPMAsX#ugAD>@-*Ar%&JR2m|$g{``5UmL$NS0x#KV zD|R|$SQh*JyJ2eEg(G<~i7hHGG3^u8V#MZE4$z%YKwO})>FTEIW)UNo!HRjIXrZPS zQi3IsTvFTgjf}F|Y@RI5%*+gb6%`e&F;oGfznS(SGqb*-f%n3NaQr*#JpIe3L%5Vl z7lT0H(38V8MuLz-=6-&D3JU(JDBzQMgVkYv&%ml7C&_9eQ0(v_y1d;&7`B4K!rqyc zADscSv$Ku3DD{YUFwelMW9909_Vw{Oq8kxcpbN^*x~v^)YHG{N%cLk78JWQT#J-uL zzM0QF^hXXI>Y4HIUVSL}$jqT`^BPDoAjh!cRbrrRtH*raPw@iMU;(%W_C%42!eX(3 z?Y z_=*Uk)$)7o^YpV}DtbqNoRtm?L_%u>daJ+GbvPL$5rxP3IXg_J|KeYFb867R$5y6Gz&|Npo!tFTYvWST%dYY$)L9= z^^rV*#vE&Df({?@^4cccj^Jd-o*;lG#>e+nX1b2GCF@ns8GRcnm`hE#NfTL4I__t# zWIt65Y;lRw#ZFb^zz;cHS5m^5R!ED9iAhTvj`QujD43a*75w6bDv*h)s;aW`F=}Q> ziGFHZZ1ZSIiR3~@W^Qh1SeRLbPoZX}EQ+#rW3FYw?Q3l<#;}l=gX8YV*N~WV2pJip ztj=8hymKNVd8w&Y6K=0n(@J^4jac^UBw6{-?avh!Q%o-UU4hjwyx`|Rz z3D(UD2@XD3i9IXh@eI!`FK=4jl#-gNc0RKH-fL<14?US59R|v1(+G)K|4lKJGP`=S zOFrS%o7a2Dm!s>GFN=*n<*?uTz50lvlJ@T1vou`?hg{t(Xbc0I2fWG6by#1T*uQ_jVNOv&!AX*%B#Edn zV%?flafrOIus~XDvMrQOY=PAaF8l$co{@|)?C;px+^CtlDk}t3GPM<@-`3L7GFa}N z?9q4V1a3ezcg^yrHzYmLYl`@7At%AYgbeKKakBmfSyL+&fz_ z3}%w1y+6Dx6@E09t$2FqAaI7r+p)#6^Oh!PJ#tPl<(4c9QR7wn)Utx$OWXy1{*!EO zTKf7IQ5LhcwG})#dJ27! zYzij|(f62{@sjCNs%8v%M$kt{0R`pX`}#1Wrj-NKH$QyI9#sFwb7^35-0XPaZo~_^ zdykQjy?~#q-9-FwFqBN^Fhb!op(D7>djB}1nH^po zXP(@s_XH`$OscUfEi82Z_D*@MH5uVTcvgP$n{A=FofmAC`J9!GPG_8`b@eeh@7tU| zP6l7iI~fr}uMmCvbMTQg&5Ia0V5+@yR+1=6337y#gw8u7<39OHf1UZz9_Jsx(;{BC z`5DSdT^+R5-yr~8Q}@`d^MlT*Q>V<^BtRnGmXF*|sy#|J%+bxZ50X=lIcFvxEwq&s z+cVp3TWFXgE-x<+EGAn8)Oh){nukY`*Uiq(PU05dg3F~iRg&n2rpyYr^6Sg@BT5#4 zUC8(4o=`q~;3a>pQTaWq({yRRhe#8vk#mCb@~GO-vm_yT!rp`X$qf^c$mFgwd}fhv zUW>bv1ni0J`hyMB!Bx&#&HIboefzt+Q%j>Tw=O&_zaw6hiP(lF#}hPd5^ho&3&5 zSdb&ns~u-*6zb8*(tTc21F|_VQYaVayE+R6ho!CwF`NZG4J4?S$Z=z1PId%4;#2N3KZM-mpFr%ZO_nP#1=&hnF%K0 zRbm8BwU*Q7rve40w{AJLVP#xLUz9AkPjx-_n-h%TlaT1XBV1im^E~l4INVN$SOK3$ zaDhasW0}?C!hslqfg`wbOe=igd>ZyVrj!r+(ZkF>+j8$xy=Ql4XVmN0yj?dmwX|v) z)^5}TSNsky%ccBTX-?8Fj2%J9n0qi-E+r@My1Kq$`p{1!wi2M!n`_^kQyQloWgM_Zp^nn!tj&dT^ls!WRgoYl; z(UrM(^#C~`5ARMQD1VNf?gy6TQkI5Q(XW4S|9+lfj#B8Ems}UukkKFxIUKziyGtn> zYORSfJj$9nI#FJS>*gBiQF?YD`)}L`fETqcF>dZNJaZ%vG&G-LN+t5Pib`YJtU5(- z_)n90^~d?vt$WaS{%A{8;#Mx}cuYsyPf~FITB*Nw^5n@~b3!LE&UsfrkLZAjtjytY zXex^NM^{(Z=EkZ@1Xn0N*!6o2H|g7tOTlX1L+m&qGp?e1kl3I-z|TC(t7=6`Cq?k{ zLCrkXXvX+qX@$X6E)*}B@t8`{hYufq;4QBs?(HU3P56;Xp?;^euF7BC>Xe|&RGuWU zqxmC**s9Of@f^@11x`nEZrgh)3(CK=ytn11La+89PNQ&aFlUZroAQ_V{{DpIWb|_P z-0ZC2g$pI7tAlvFV}9@J*RP*^0^o8uvb&+NQHUA>cAaACZA^C~0_p3EZMHg*{DiZ+ zt4mx`axDb)E-8sMxMl}U!`HZ+Tes>Z3l+c1r7z@UjVu}rOEG;b^ij62dIJ}VH#Kgo)p-c=W zhAZ>!+ab->q`0`={(k;SbrlsBCZ?liefC9nNMM+P_Kx&4#dKTcPb{w|B%FzF?&|Jl z+_&r1&9pUhC#OH{#eDSM-x+P1W^vS-Jml$4b6a@mabxTGXgBO~87->{I7D818<51t1f!IWDWYz`Ri zQ8&eeg?}uP;mzA@_<4DOeXcE)mzOs+slKf&KX^5pxx`q|S=rh;<7S$zjm?FN7vqHQ zK3+3{-tEPWz}V2%)}EI-ES;#1{3N$+lV08OVmC|E+?^Vqlr-xmz4Ot-zM0BHKxUgS zUc7kv^eOBz*ri*tHYikO4<;!lhG*;0i|(n4jyAV6P463|`1ttUeISEGMccvpY!qM! zZnlcV)y%B|q1awN?f;p*ONx+HPZ%2;Ys5~SIuNjCLXf${bm+4kA}%hDB=O4{36vu% z6y;kAVIq)2xsAl2=g;#fe0e-(OkgdzOPdI%ea`H(B@fn&Za9$usIa%sMvj0QTUEch zu}Na^c6H6anO1gz%n*D-KGf+p$v>pEq2U)K!iFHQgna#B(L?fZ0<(;6aL8%jNuYpx z_uk#n%xJIo#rgX9?Ag25!rZ*tbOB7ruv$)a%n58iz!m=VO~u8B_mIVe1%tSwz`_xNYu>gR7@3-k}_BU&E!Mp zBmfssYvqLGnIj>J7J2#|wuO|hQkZU;yI*#ZpHu=mQ(>AM7nj*S@dQ7t=EEBWXJo@2 z;b$SFPoFL&s>j5|F(ZTU;b%7h9~~ak&eR_6kcFXynSd;+2T>dq>KS0LN}LXf;lYnB z?w;d)_!CT`_a*J!vuDZ2Z=M^4!vjJivqIE)#DO1QBtLF_!WeT%3a{4R5$;LX5KnRe zirb?wes{V%oO_%H5@_^D=aQv2~Twf__fdP_nP+6UxGE zM@Ni$#t9kL>ZFIkz=qc1@wL-?=RwNRI19b;7~dyOc~Y|Qs%OE8OwR-zGBqY&IkYW$ z!ZjqWZyVIRetxBg3r!?}iA}rN#vgv&{8cs*L6J#0U#p7U+>K^QMnPx$r;Xw_a3%GVnYGUQV#*{adl@iWx z&1g9!UYdwDa(w>#Ewz!~0Ih@m*tW*I;&~L+%a?gX%}>ypmqzG!&u?AcLp!MCwNhpY zS05txfcyuk%3No?En7K~A0gp(8wH{PLBD`MI6!DHBJJ{D@3xz9&}y>NS_YokK5A$^ zz&9GsxCgqX!Ij$;nSUZN(8WJPumO|+?YIB_x!b?pY)wA^f&V8x|N9F3 zJ=%XRMvCKARR5Wo4w>|@Ze{W8C%@L{G3DS&*TLJKs#B+N11KdL#!ma&1}SN9`!@do zzP`;xH0b?T5e>M4Z@`z^4QMDkt%wF^{oCEIXSByZZ)pQTW6^CipEerw`_I$=mt8k1 zM{p^Bd&#Mk>(!j96qajL>;T5l-xIprRWA|W3`V%Kvop;Ui2!vzvi@DCEvP-UVQhN5 zQJ_HrT!I}xrFuS+l3ZZ;z`|l=VWc)SHPx|_JX%**H$FZNpwC}R(Pk5F22hxIJhrS1 z0HopJVNfPZ%0c(uNB)WBkPvWq2rx8)W()9AqWYLl1St5*$Blk1;q_FdEkGd%XV;Dd zrUKNKLeSIJuCA>WGOLu8mmeg$>@Na51%3b|njOIYBy9M+uNsMgd6yZ<$5KG$%+$&# zDk}1DcYn}da$DXd84l?9c;7gdzt|%s?-~m5j#KrZI2HH104~#MTL=p=)s^GFO&!1n zUtUlE<)^_B$O@ljTZ8dCB$#{DP2&7q#W^xSDIeayKWe6tD6Mnm*u!5Wm2xy34Nz7| zNeL*uU=h^T)+Qs+rsc}5=6M&QZUSVVC=G^eA(HF@K#_^bgG+Itta3h4gk)LoOM-&A zVDf>Td_EEuJu5BkMg$ieb>i{d%E$K}{3SDzZ7vVK>;Cpl6M%kWV}8c~m8<(nGSbp; z+KD^#+Y}lS9c957U&F*qfE5xi;h6jWJ#12Veaz1n3q+>0aVBfvE&fAb{ioFXhpjl0 z_x%za|9SVf=-QT|u=0OPyZ`@!>Tl`wQ}F()K!G}ciRFK$%3PPx#)Bqx$fV51irc#O zy{k|4_RJr(`9&UZjO-HiHJxM{JFqR`K}g`bdRM=D2V7f#kc6MLppOOBtxtgx$T1mw zeT+JIy@0*JF*XuMslP3H@<2`hJIlWqxZUeKVmR;wCu%KqT*mq*`O~UWmMZe-d4IAr zjobfIdTcw{e#(h$>4D&&4WIxnxy2LLeoCId_y}asPFgRtzyER@Hr_98`Tf;CfW~O=-p&($*B0n;<_?TTJ=0{>5`)yuIX}I(x9-UoJXG2V$5fRw>Zo)6 zwYRj&3_1F>slSn%xNF;eL5Dq&p@GfW>WP#+4YH9fH1gw}2{nm zTw*hHnyP;GXg0>{!cT=@Y~nO11PHVU{ceJ&UMy~Ni+iA7#`_HIsp=Rs#BU7J_f!W` z_%uE_6uBsN9F}jNjcxJ|U-*Hn%W&dCc&HDbZJ#awJXWNv<$aVvfXYlTyMH$);q&m* z9gqGfEY~_ly7+{k@w_Z@Z#WbzG2h&#x?c`B+U3`Q`QLB;c0B%i@Q>f|C)v_Gk+iby z%YV7q?(n}=2Xl72*9v%NU|KvbrI(o?M2-f>``~=T=r{ zMMXu7NG15=wlW%tpY-`@M;)gUcr2p1CP>|2gh3g&6N32m0@c55y(7G9$8VT!Flvc~ z+F`X|6pk#C?>TIu(4ggl3l{TZ*=J*Y9b7HBUX0Dn%>e-cF$OG0g-*pZra_xiV_&!Qq-O!pXp@Lrp@xKAM0LYN7FZdKJ6?Gq<4y9x~x zqoUF@Gi~kcgwTv&l!0v%^WCG{=JIDD9_PE@B?UuWJ;Tn%X5X$Ia9Y@0R=jb;fS)06 z<%dftK$PG>>$UHiaI-M;gI!~5>|3%e{BE9C*O(9-kqnl5Qc@Dw`H_()_U-cV^#zX` z7)ot6;6RP(Ro)L?pwT*-*Ki7~TQINo?YepMWH*+@ z)R`lBO~(@Gd2nyva`5q~Aah`$o0hS8gxP0mO_F_TO)4o>AJ9zpmSLXa)avvu(D}9{t-xTHpJAKKc9lFM}rU4c{)^ z?u2S~LUhK1nApyA-h0a=Tx00>tp{4^HLAEpnqh0^=FeWow`6fQD`7V*qA|a+Hg^3yF;=E<3ELQsV3RCE}Y{T zsCa43^vW;Pj1Bvy{mnMr5vNyivcYN>I zH9$om;*h@ch&g5BbGaVWs@|}Bj8x>tqr)}st*k!9OHo}AT!s9yECxyqEg%VHBM#xx z9;n4d9@fUb{HAhLuAuu$|L*XaLAeVXYM9YZakYK2@Q63#th`h0+d*z?S|DT&KPTfX|gBakpn zr<&GFCzczNWWE9OgMN98K;IWa9mF#VNKla@D_scWvGkt3VT;9Rvcc&3Ubgxp_!CD+41uOM5 zMd8p`|6sfZ<&^g)sT9Q3HzObbl?Wzm;%abGRh+T^dltyr7jOvrWL zUt~{*R(|eFwf-5twu?+vs0=3&C0Yba5q|ZX6MJ)(Eyny;D%+GuGcxzoMED_`_Gx+h zj$h-m-K>lq4Mh+i@O25Os(llx@6)AB#<_k*@3YQUQ^MaFnD9hZI%C%!6~|1wZf+qS zW9WXZt62i&N62WEc<50{LpwPR5a{E~lBjF2u#KX=b7pZOj-S6gAs-wb zYcX>{`=nb|MO&}T%H8t)(~t_YTb@I$H7>HDu^J1sIib9_MkL}WBirHu;9h81ZOPz^~ug-Kw}FpA}EE#G}G)xv6*S&C7tw260jwv;P$u63wUSN_wA zby!YopKkg6u_Wk*zV8f7(<`d%r}YGC;*G5ywqGy2jYIu|Sp5w)?R<3Qik#7YDODTm z&`EU&@Vx)E$*V4q@@EUA5PW%v^wZoy5au|8&k$2#w4;S#_P#y|kB_!EkLlH~Z$J%y z(<$mS6D{}?f?2x}R=XhPa#ZklIS5w=jX+z=eLXc$4|8xQsoN^ojcSE}nx|tdl%3a5Sx_C1TSr-Kkxtx}#5#tgfwFhvvJhT`Z-Q0~}1806naZ^jjWc}S5M z^s2DJTWkleE=CuZo~G5DwBYG-lmYsJ(S=>@jEsz!!slE{gGg+&E+ff*KGvX;lxShE z(?V!VL+nlxuI+kl(?iOX*g7$+WMCF@D5jPLD`QqCL^xPx`mslYbMr9Nb{XG6zyV>V z(^B83HeTtz=+ELFD0z>|I^zq0z3^@l#N2EAWh(IozF0PxLL5UoO}h3RZ30<4nxekc*2xJS^1jDAWt&@w(^>C3sba9Y5%E z*Ry#edO8Fmkh9za?aYi1(jt&=S1xRh7XJv!tzi6M>YXxwlz`?WCE_+!DE(xRb4ev! zH6QKq9CqCqNkDskD**~HIMA0FYQ%nZY!G-YVxt|4SY<8f5-LShOlh@FIpT_KGLMlU z(m^+Opsk;T>Ip{(3x^lk2vUSo5vP~ka8zmlU)hTM2BlHTa3{fR^ZKB;vXrR$pM#sF z-OC%)60#Dap-(rVILC{~Y1ghB>z`&;&~c&b5S%nh)7fh?+#4WP!CydKyp8=(io$_f zNxy4{N(}$}7Fl?QNGhe&*N#oOinq+PS*5b|JIS*S*FfH)KSwG$RofE8=(`**vvtzD z?;Y?&&9jh=+184@{9!ZnMg=e?(b0ahigDwJK}>)0){m;Va5JFKsH`s2Ri4GV2s2Y% za|CG@Eoj^l%PQ?h+IOpM*>*$JQey^n81_Doq9(Iiw=p&{)`GBieWpg%YfU)8D6h9b zdUvsSPUhYzYQOIraYv)P9zLhW9K=(KlFLd0a?vgJB?K8-qps||)?}mpX+>}jjXDhB z=P5Qc1PnwKbyyDXZ z4FYIZ(kQ7Hdw+~|@SSHH;4B2kKC$DigkwB7%v@xFw)(Jzq6Ne!v=1z5wNgd*-F8cq zSfZ}ghd3R_zki7%Y%SeT2_c<_aE?|8*2o`iTJ(~=tBhhldZDh>!OM@6U4&B(B6xC9 z3(Uxrmo_se;)`c6fk=5L&v(`X(TuA)XPDk*EZBsD6&3p~WD)IgC^GgXi^kk%0@-r| zN!_h}`M4js8{MCyF1sx{(1g(_SF@Hah1S(%nFvqg z#C>&3V=j~pGwA6z8JGE5CYlXt*NC4>lB0&9r_b^b_U`y?iZAdJn@Yfi(e

>W^cs-?#mXItenZY6gYiNlBTK1l?7OkpEdc1 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 GkN+2l3G_?= literal 0 HcmV?d00001 diff --git a/assets/clef_sign_flow.png b/assets/clef_sign_flow.png new file mode 100644 index 0000000000000000000000000000000000000000..906384cf22d51aeb6bfe32c0c7f1bef9e8e623fa GIT binary patch literal 100271 zcmeFZXFOZ){|B57T5VNz*rTmctyLwl>7;gR@4XWv)SjJcgrfH9FlxmPu@zA>r6eSX zicz~t1QG7j|L^zwO4@6UdJ&Jq1YSDpC`*BKB9#H{i7p*{$7 z9s&ZL{CS!YI3lF3VFLn1f;1l9GYllGPU*yxzomd|C7r=g{&x1?OwF5w$YT}fo*C6e z1V>u$oojty^GPDH=$FB^l+4~Q$NNIbo3jb;-_ye)Z%ZqiB|T<*5XZi0eXt-4-2310 zF9QD}@Gk=YBJeK)|03`&0{bczny);$&@1;LKSZpLz z(~_2EDV>Y`_=xb<1KLJJ%R$G4Vtkj{|G7-%{dmUahK&TtDLSrOutzd2kE}e~l0A$T zgdG3xiNDXKB8>m;0{5R?oIA#^Gxx-j>Nm`?%pJrQvUbP%&&$ZpM|WmfNH*b|8twK;dL@Ank-=jCpu3vPh;&AOCIeQsIP9)t-b=-LZ-vsYPdKGi@ZaW5tT z_ic+O(Wb8Y{mi&^7}4~6?Q3K;m2~Wb9s>xZg36rho;DFw#+Yg({e6f7^)>V9-6j_W ziC)Ea^_~9`+)rA+Pa&_xmqU>Jf&ak2-QzRJMQ2>kTKU=s(gAy9EOMPRvdm4{Uk) zS$c@`Q%q}+F$gqst>C@N!62znt`TjGrhtY^QO3zOg;4HPI!MFOlWs zf@Hlr1@RT9mEid<1D+=ubSaz4kL+v@2vX^AF*IOCcbuh-HMNBJaCiD7X@@ZJ0jt+y}<7$yjW$0yvJ|Kbc81@Ma&Z?O_RsRlb($y zpEln=KT)LtI~hqk#m6W0Qw^9rjQLz+T{3eF1RCJ4r-&)Vee5fkp<$48C!DvTZc)7Hu!YHZZm~0pvKu-C9NVl-SeM)X|5P)k<$r-ch|#1 z0VVxS8<_ZL;?|?aWUJ)SlsbM|X(ZB)Q>OWFCKt?#PhQ2>xPrA{ap&u)HBf~W*jLnc zOqbqYg*hLM0Cd+OCuLlu5@2s`M@&Mhf8UOIor>{JlryDSOHId8`_B|%NO5AjmPz~e zi@jg%3*>Ip=T(K)(UocU^NND+ts+x*1@XeE`u7<(!K9tQPn2zr0Po)NntAL+sEZjyCIMj=!8B z3|YTIFtZVdznaFnMjNcQm=9STc>D|&bHME$Q7jXbwK~3Vq}g=eK~@}bS-8=g30sXk zTTqK2{xlYhkLOtfr)Y&1ypqa|)^bN_jhoR(s^X~l(^;>aQNH>P46w#re+UK0q zQHmb|+vwhJljeJA@z>gsH7zw4J9X=>apNNHy7>l4fDlkyhd*K?)hw&*p{!coU;Lp( zH(F{+n+*u*op6>Sh#n zw6YlSL*?iPBrV)aya7jmXf67!n5Ko#t?@PQpVuNuk#j>Mj_OItD>N@r%&jU`Ijg~; zSHnTPRue)B1KS~%%5zT1$pw#gyYG!egkP`@X76`?S(cjLTdvWx+EC{TN-s*kTEiOn zD`@cCNkI2>StG$0h^8doPrxdM#mOd zajWBVnr|e7<9p3xh;f1tXNNzz@WWJ?hu0b{F208xjEYah+dpWDzSl3W8}r1YJS!8f zJ579iS(qTVkhuF}Sn7H17F$I_E7iQ|f`_A<&81k)!B)lsIlUDZOOmgd&k6;ewm&v} zd>Rkk45nd50(KVy1NIXMtsDDIYD%)=p(ukVYvPz)%G>nWZ!O;&pBf#6t$BGaHCx*d zU01-Q&$4NYYqHzWL7EM9<*z4y6g8Gq8(?T0in~ej$82^!$<_{AvsJ%QiHoA|u2S7u zudw(QY$fx$C|$5JnKutT#h(;82Rqd`zpN*j+&$h;2i;L^Afaqq7@ugCF zb38uyujV0|$di1m5ej#NZ~IK+z7DulD6b&eR=X|FBc`SV%_!E36dpY6IK?Kf%{MIf zS{1yvN~9J`2zQ|)#TO-2sEsXRRby{Z-!B@hu5)t{A7F#~GP^Lj4Zi(*OF>5z^n+UDX%z_dDVkGqbG~|=`L3|gH+f3)VE7bcvi|zR<2+tLe{M@S1Nkw+D%K{0b!~U zvTMSG6=QH04)tVzmFi!;wYN#KAl1uQ$C7Vach>Jr1V;>5U(GUlFuDB0y`rB6j%bp_ zlUrMc;2zGFi$rMUWx_;*jmys2O%*LLt_9kHIhMN`4k-6NZ_0T3Aag24PnvBnW#PD2 z&y2DL0`L3g$0cr2vY$ZJ;4p(Z{;Ws!COIx2GXnmPAUnoG0w#l$3kkHQ-HjH9t>Jvk z3dcRS1AJDq0hcr`Zp8wDywqpURzOV;Qg**&6YS3oYuT9yvT9ZT*}yMeRTYqiftlb0 zT08`|eV*}nj3p=E9%-%a!c3dmmnFzu_w;{e@1UbpgCfOju&?w46Z(Uvg4fdo@J{i< zU>uuqg~s@LizM_6Nxbc5PH*>0rVJ3V!x+`2`JUJ)w);H~>c8G&|0pFU3e^%H;MH!t z^-ez+WD&l7mSrR)I=w(}ATwU2)Eer;3|eR;g7zanbbl6v;0y(V`7KQtUuZtM9e>&$ zWyny<1frb094snfEkte^<%6DV4iV)+<&t)rUB;hQINkpl{Pn|So>DYE^%dr^0yKNz zSIZkO#h!?@Vw_1+NY^SuwV6~#Ia79KNUaQGGhI1-tY~MtLYXOQ)64t@dwjacNgyG^ zK8;3998VgNgT&@pvcKqEP^Geov?OpQqg%Yrbigk2FX!Mz~TcyCsDm`(H1;}=eBKakNM zi#ADL+tS8Q^SIZ}{xU9NQ*8jp-cr9qs5#YL9*upLRCYb1+LX!p#>Z;8J&R3&tsOo| zVLWJt=OXvwDXe=5E9K;vx#$H6#e4C_0>ts+abf+^pExde2YrE5CzR;7#G-g2 z6Ppxw4g}g(w4cP8gPWb28;wBFo0A3{4k?)ai9ol~^e0-Dj#S^XqtH6ikf_+ z8M!TUBcO}IVRhsEmD#C~1pQ`*oaB}kzW#Xg0v#voBP%J00YPYUK^p3Ra}`mM&k)CW zF?%*tofvC^^T)R}h1a3_!N!-Pomf?)@#bILWbTzHqD)wcG0^&OeC-EQyYdhm61T#c zcWLns!6bA?KU-`spnz5}-ZsgjcR+#0Xjh9Ok?Qo6HX z7h=6DXuL(<8wRbcUbN0KdQ}Ly=Z6DZo=7PG9b5y#MQ;}3gKz41I)$_561PkC(K1xI zST%Ic(Gdi)9ax1E^(}>nkKl`8KOP0V-l*xa@we9vIa}@Se~E{;pPw@gc5}o)QCJ*t zqoz)SxBnz9jU{p;c>-nFg3Q%x7Ksh zyEfxZ1xy=@aE_$Z5QmLM{9#l1@hNcCj|nJSP1jb7V7LCX+76LuA=A2W@P0oo^Wl1n zui>R1Kt7x;tWa3+=j)7rFPNp#?9;UIl{liw%H87nn8mdRhAR)&e+|8_;X@va+>9*f z!t5>jF&D-O{&9Rhm-<1oe=#+eKQ^V@8XLx@%~7r`E3F|O;#pqYx}$RiIp>w&8X@42 z&)NIYit75PuKIN9SoRNCzz{mw%OhLx}R~4D~J}GMFBAccIId!jbBwdPo!y22@hUINrlNn2X9KdVy zEyj*N@xVwiz9K9yS1JrDRS3mzwQj61+TTEC<@`h*g$u%KM;WOLMbL#TGJ&rS`ZF%Q z{jt=SOkdd$adY#lViRr>MAk~m0j?`0SXR8m3~Fqym}r$&<`p*Dh1t!@+%+FGZ*1{X zoj{9r?^U^vk}HdCpC|kO@wr9d7jM2MQR>ko$5QE z-+J7gUz~Nf-LF!0x@KV_L=f(#Asj|8qXecc2TvfGUbhGBz#@pbsaK7DPT~Yha|?v; z$q<$ZvRzbbg6<=I`z33wil5LdH1ntUlcOPQ(Q4dcI~K230w3EukRO`#D+fE;I}GYx zg|E$8VxVZ7WLv)_p28~xPeQN$wW`Z99%aYR0vTLX#-k@8ix7t_ z6fqvRpoAu2h-aK$%_B*0o&^`wb6qBBwOw9O!ZG&>2oxw-AT?@zUB~UPL5L||#(BUW zw)(W@yfE?R^0$0Uh65(IitB>jWG8oY+)r(`Vg@UM<&zHEf0_I#zA`a4~upd}^((>7ggDFIxi^`E)0Tnsoh#3m(xPWUNtY zxLG{9;BsmyqyYc%!rRh`*IpY6JB-0zRv_eo+f>X+riS%d`_l1>n>Xw zA;x0B)G%HA`buJ%>P4~v*giX*GepZ9PxqT0qZ**fRkdO)ADv~1iL_bPOWYO& z$Bq5ORoP0&Sg%Z7tGMiVYeyjD(gnpPu;-M^=HW(DLTf8B z;GT!O3$sIw)2U88w$I;mRpU?p#j`Hk#b!SCY_48Y1=W;8_mboJF&_$J{Jih@TDz}Lp_^kUP;$4BDT z$R7k&!gGa;O~kgXO)Vyx5<9+m_5BL|kVv`{S;PTb^Xt0EO;p%}J*_i74cc^nvC#tOuSqq}UMW8mP?W4;*F_mVD?NY6EDXU3%ft)w*BicFT{2KF6-pJB ztlxh-T(vYUg)~Em+8>urX2p&(i7VnJpdHTL!|u~i(fD*BHU6+8ReO7~ z8C7k^sv6~wHMN?oAI`NGA2qM_Fdp!oquSPnrQrDMCTTzsU6iKWK4qMo@$}|T)>Bv2 zl^Zg=Peg8IKSdmtedwuy%i~)l%T#p%BlFmQ>blS z$GT2fy#7#^$@Vy?y~hXe&;5aIF3(Ac(TKXUIAGl?Jj*(s&GFZ|sMvoZBkSc$muz}u zjT9HITx54&^i}V9-XFSN)UOB5lifFS8MrqsT_xq%odi7#LR@~FyXiiCZ}o&AWaxme zZKn%UhCpFz-H9ffhkCd;C3Aa+6=gp_OIL&W$M^^0UaFYelgmQdY9alNS7*Fe?7tv^qwRGsACZwz2e< zEo+@8G9f81w$*Dp*=mlzP-lpz`afGWi!{@mZB|~-)yx)O^j|1_FQcsZg+wTFj_$7^ zMzDP-N84zvIZ8gi3`7&%90s>moFN)1-fSrCpVjiYy=j!oPc^Q6fMWW=X`9&8jMsHh^&K zQho~Htu5i3rUFm)n{l%ffd7S_SxrDCBxH}90?b@sgh?5{ytHxssV`sZc`JAZ$>`k_{2uk9lD4I`zn+GF41qRMf;PynNar13z& z)t#zP+uoUw6vy8PnJ#CZscY_;7{gazo&Wu*7Blx_LUXNLNTc?>t%a|SJ?!$a1;29v z4DT)XJDGu!T;{>U%YbbId6d)CtFq+nPJeMH0I83 z@Rx~KKHR^m2x(R7j7QWjmTtE|9WK{YoB~p^xvHK14su0W>V|abxVD?MKPG+aSI{^0 z$FOrX7rl1uB`$KShTA)!)*be_UY*i~m3i0z(ypT9a;?$SF3k+ZjETd0n4%97-j6q= z$hr5Z%`EYt$I*Tro|_>&mBa^s1T4W{XzSQC66$b9FuBbrFN@i|4hBkBwF8Cdt9ro;(sRYsP|oDYn=#Ho z)gC-<_BVM-0?2->lS~!dEY9SuTh~#AGyKQI*=lFRm4wHz?5BdIE}_BBO%}0=-5fPH z_^R1i-u>mGCM{6w&v2#wYu#%B7XIgW(mSUtHY^m?GlWccc<^zicL$M9HDq>p8GKp| zslKwG!4cKd#u?;s>ioa%ziW%kTwiHHTMN3_Iok*dwNrdDhYmUxctfL40>k}@f3 z1Hj_3_1o_HT7M5U(2DyU^(f?Dn8liBB!X{7O8M9?m*s^@@T;VtfG&^pE$qn7AP2Z z{BAkkp;Tl|*}wbX7vP1Um)z|i)g%P~hPfl3H?bZvtz}Ps9*wx7F@=3M&OvwC$uet9 z$h%bq*Czs~XO}qNi2v2)E*jy?Vj0pKGI8SG(!I5#iKY-64P>Luwru)o{i9E}1eFXZ@m^)?bGcnR@YZ1Oq zx1D0V6l$}Em-qFn$0c*8pcvlAeI6R?u|SM*45@o6-Fxq$W1$y&7v@15@i+}x*x!Z@ zt$Y+t)wJR+SVYSxzRR&Koz1n<#}(hnIYY%+^FxKVTh}@;NzgkKv%)((U{X{0demfC zS`#jf@wJ}#xG5nwufGYlr+9AiDOxDYhO4=acAYDNXPzK>yzTP~T?V3JC&biKek;z_fu>25KgkWP=y_n>hGsH&V>E_`^&CjJ z`X%HuPKt9rk&}_brs$PIXI@Y6v-{T$f{jzB^@iWdS)MIGEOz5J5?>;q!uxKA+%-*V z`03JeRY?%Y+p_!x0^O)Ls_xT)9*rzBR9724awqJc9 zp)G$%GnDg--AS=j?EZ@HQgjq!o!NMs_;3KgVR|$eW-f9UmSttx4 zxA!l=CU*{19$HLgZnVI>1MDiRo~;@zD>^LiYw|&Vem#zcM@H>WGp?s68L?TES10XX zl;Eu8W>M)}ek>#!GQj*r$+@!1F=arc)UG>`a79~e<18r3t@1K#ve42(CK&hTz}+QV z3;bPAM;~5h>#*z#VS!A4;-sfNJ}*2_)@U7kzG%H}ay6zHWQMf!7zAI~;H7+PnAUn3 z?|Z4Cmg{QMJcalt*zAt?_IJ^;eG1_8Q6=?GCam8^t9-*U(H&QZRiw71cZif%$SR#W zt2svf`5luHsyvl2d4{7H@_aImP`tlHfV>m=L4V$W)+n8A>w)g83{TN|?&g$qL`FlG zB~W%iXP`*D=55cXy9OoJhBf+Tql4}*-W99#5Uz|B64*ZtSt&w3Ybbt;@ix{7Q^HfZ zDI-5aN3}(=+|@bSu!NnIpQg~|@Ab;#fnn!Npf6vbq51PM8E7d1G)wJS(dVm2 zu1IN`=nM>=T*32$K;tFTxQfcOC4qkCvd3e2J}LP)(xv0zr2HIcUj^GcL^loWtC5*D$GZE-cwD zJ0pde45pVrKL?u~gt?_lfRRop8+xx8G@V@K&eJv=|V1Zy< zwv~`)VO-WpZj3<&;st7^@KI6|`fuN{5=Q0eb!?zHHP~;X+OR zoodMF_^f*1TF86fJ9$U#ZgeJU2@VdB~A(1b;1?(4mKP^EbQ~p-uA0r2ZUDsO558GB|~P_eGfuW za!9#Wk+fa00(ycL@k|sXn&6Pj)tst$qj;xr<=AJeIg3aPeHjXLM^NAGQ<^7&Ek8-f zjhWemR4)I|)#zccf`GC0MJ42~@v*GNp%P>pY zl!~8DnzOP#enIL50=nK^m%MOH<`Rnt9VW&g{g#b^E5ODQ+>dDc-Q6%F{r-(e0xzs= z?+cn)p#&OFuLr^JV9POn1gvR zItue){+k zsaU`4w6;4vDYY=vGxEU-89uoYVA5KZ7nm1*zu@(~AAlU*B<hJ&Hahzvy(mIYHpUNINm1?Ip zG7^@1zY-q!ZO~6smzS6sbrtkM=Vhub8Q$;L8zOjWcJ0;zTJ5XlcQ1)^qswSGa7w$^FDD zts4QoW9aIz^k`IuWll|gw*K1XVhF}E%f{`4?^=E>`dGRa%JMeKk-{8S0Rr9CLSMC8 zdN|rVI3`JDUdXQ<9gZ>j_)&YR(eKF7GXh=NleF0a6_zz0>9O>g8ucvR-zo+Y zf_}9B>%nfP`ag0fj>zvDh z+9fS|!$96yOpsg?z`LE-hE%)UM-*fJIOvu8t%-9 z#M#xZ%8R&$BHolW7{A%qBDp=4dph9w-Mb@5#N%O}`>xK=oY`$H*JY(4=3AFxVn;l~ z&mq2T*5YoCx@O7a%W37*0JNVBD9FLQJbzs ze_DVv)O+ziz`d6lP!D?8Y049F5Y~IQXjJ=mkF|L7cDfdKufef;%fM%W^e3%CqFvb6 zA}qYHxHltgIr8N$``pHXc?uC|#u5=Cz1P0_-uP7O>?9?5Xw@U^rE%fU@TVL*@eJI) z6;{vMbjy&zTNVZv#^dSdk~s&RDk>X)pcjDd~ z)TcVXA(5iY=Y_P6*3nk2gf_?HWoYQv>V`P8}hJE=ZS-!FsS*9H5{WmdvS3sv5KzQ|F9C<_K>zKy=h z((ge*#5kNrg6oE17T><2(z-p|M1_T7@u{fZ(-2Q?*yR49%G`JbA;eZG+Ps(J>xcs} zIBsq*%ydr~oLw{O`}%Jk(0&X6(gsNGzE37$Fyh>ixK{Okhj?l)II=!_ObXn8`0*uz z-h%#QP-HXzp<1fOAJtww^f~FxEFIb~Kk!0`*Xad9@)pyn`s~*=^JRI(k-&#x-XYyJ zhqpWW0xc|9IF|d0%N?&;j~47>GdNA}ydtF{U$MR%+}EgdCYS+vTH6N80?cT!S)#Pm zkT-Y|Gu-*&LM8&rZEcQyDi9M32ufw{_Y{^&kkjFO0 zJ207QF?BU!=iRwIp$`z{eSX7q^wmkZNp&qQ>9muNs92+3G)F{5tz1OGPlXQ561D~s zXGwsY)ZFjBreF!=thkt9-O*C}*hb9*lK2a^P8It~^#c+Rs>KPC_BNg2300Z4s}V=z z4p8O5XO=@!Ga}2Q7P&v@(4HJX$zV_M=>&6Jk@@P4<$u+A8`#P^dqi3`wR8 zueXWsS<8=7wbp^mApm(UZM}Y8Ifa%(*gv$c*#J``Lemf%&v$c0GdR5DygEb9d8Cr@ zb-RP^lqPoSfmSky@OsN=o!fP}e{jaylEdXCnOPnQz?Z^xuZ_#e^od#NNFfsmj5w9- zy4%`j)w7*I;zqACVD+42ag|_#>~z$`TwRxoG{5Mcvv0j*B4)~s6g4$_PzgT_w`$C^ zxAd(;yd922&xP`bKs11L3<3sr0B`x9F_Q{Ncf;13TaP#*k*^&o0RhIb{Uby(qvoBt& zJ42paPVYSDWJLY8F0IQ;OWMe5;(<*bDT}n)1T4A@mbq>c4#UMy%k4bJOt}!BYcyQk*Kiiwe=i{h+ zeX=NHS}c_>3aMK)VDP*u^UB>QAD$tzGL%Vhn3{Y~NSATV8JFgWRhI_q>krwFweGfU zwvo*VvyDHGEXkep#v}UWMaS3=VG#(+4X>jn@A14XfWmuX-FES>C;QKcl)ikd%%N=C zMBv5q9&-jZ;HcdBzlQP8kTa-qpE>-{ZaVDQPiHRWJ1@$SS{BL?k;V1Rl|kw6Y}FUQ z3nKpv@50>h?_pJ{BELJSjj|RS0$-E#B%4Z$@4eOI55O99bnVvfW})xJZSLhf`hQ*f zrqKAlnAyE5T(bI9=jh!oQ#5?NPPJiGMWY2WP0Rqc9JwX%KTv{P3T>F+wdUj>{p%CP zG)?A*&C^t)lRN^ZoF~`~N|n|tc7ACCc}aWF|9RX?9UW=Ls-g8X%r$Dgf9#bTIe^xH zdxzf1#O|4K=jUXR2wAD|D5hQDqpbYg~%3gOj?;Mc{%VeD|XO$*&0Ctc$=J z|BRT>U2CfI$xG}}T)q)r&H`-P~4CTbDt#)d!X z$^HLx>$}o`C|!=$ULvyy*C)Tc`adTlo&Tm8|7%3PWc^3U0w<{a0sQK!eWN=+L#DDc zMa27Dkq4h(DNoSUHhjw+lhmr4*F0a2f_d-_|AnP3DLJ6YYrun@eM(vAWOhms|1+D_ zQ;p9+aN@&Lzva?7R0$JMn@Zp{SYXTu?LWaq-^mnJ4Xg6|g!Mv-IT+lZWGsd@vH%?{8Gz`<>(_vcl$gINmY>lkYOGX|(5TzU*JW zl;bw(yb)0m(#-;Vmi_mX;tRyeX$VSS{G0sk3x7$qNG?Khq#{tgPO&TeXc%lgYM_n( zGr7G#S816~V(9@Z%u>B_(+PNz79po=n-sqE4|e-?dSsrb z+g3^;%spV_U!mxhs+7^s%0W8RW^{KuoT$AYUm&Ei9>Jib8?CQY0mUX%^@+vXt?<7H zJhD?9h4VI9rp4&y8XR@-4LQZGM0l7@VSE8U0SvKA^y6BzCnvex)|Ni68+?>s{QGr- z=Yud)8oM_PU_s1cCRAurn9=XD0}G`1c1KTF@CO%YAXDoyUJ%nYhH z8_&gZI+ICx04})q58REh#RZ*FSSj?;R41$~6uq7OaNJ{^-b0J=fw5|f-oj78>#WsU zNE_>6UVXISBe=)IZ>W488-)Prp2~=@eCMXnrCd{VTqw^29<4vV-Sj%qs0L4HXM8cu zGZY3d-_CQg7hc$VDUG@K1@Mze-eA&H_C; z9=fiD;dC;(fL_YGrzf#5OUmOV2luMQmWwpi{Yv_(2x zf}I>1x%Lvls;$M)ve2q6Fp3gxFdnJWzX;QQeaGN=XVTU?(X5g3g^xjlXd8kZSoW;9 zo0;xwZat~-^hWlW1nN_&o5pRF;CRCvUx^jvGAQyTejX|F3233hBniu(Tf!om%6t9{ zt54x^=YmZMQPnp7;N%xLKH{zt?|$f-jp(93zjn$7fg0CZX>e{Z=WCq|mG1kC?iCiV zTU@543O(nE*l0=@@$cWLWt-We9|vYGQ0yG;h_L#RzI^7dR=yiXTfYE2 z&eqSB$PUb84BWt`5J<8LSd!7U4*W`%l}Yx!troAjs3tK3IaK3$bFT1M2Ur!>RNQCs zn6G9B2Df+ziJp9*CNbV1qs>Lz`EVBGow>mH$^9X~LAnaO5Cz_Va#c@Ic}?gzzL|+G zmwBbX&qvSCkvyasxxeV0Tr6ICu+;w>P7Ot^^7-W1$#+s|9MMGL115B)3=S9#D2r}n&;i=u@Ez$LWSU&>+V*rcX<{rP0k zv~py@Pr}r)xu%sK&55sK;uC+xyu5o5iLVsvvs)%aFWC&}*;RhKF?`r8)F-V%9Hj;g z20UHg(mjlK4nMK|=me;J4X;;OU0UBQeQ3ygm5}vG_hNGAD6Z#|r&68HSj!H<5{dC( z+sw4&g{F5okLy!Lld#DOg@?YnqkB;bW^00AGPbo%2ghGQZK-8;T2~NJwvo+q_{8(( zjw{YtZkSJ@_W4d;MP-f{{tb?FLfWI^0e4@L|4T>3yQ^Nyxv?v)pLiCBEP9o*6gCQ| zYL*+m6_R@gbeHj*o|UaIZ~zI@)^x@Ppw zc>0+q6jhE4+nL?|TETZ$HslZPE*?TC?)Ki-DW-m7;D)xn)NDQL zj$BLH`8`@^^aEL=+M8)B;GH_FRb?|KUQ=xm`g8hVih}Z=Z{AGXe7N|_NJrh}=y%%g z3qATbTwK6VRthlW2 z;_qNm5`c`$`rgyO0oxYs8f(MNCCXHj?ORzTJlgQA{gLWhmwUU<+NwtjJok zJ2gD2gu6{}J_DRUz1Goc+p|0AU!OeHsDx`|^-kWRSTJzoYn9*Yy1w6E?KC|ab#aC3 z2(q&`B3&eIk~2XB0;D|Yf^|RYrCeKqhk`hvoV;5|Fw~zn_Fl7^zn`sDK^lePLr|A1hS3lU;r)3P}ldAa0@dcF%EKO&*ujZbzudCqs& z<%O+ZyGgzKK6u7VnyglG!gcwStO?SWWxRMoL4TeQU|ZB#XrgsXxHy9YcW5ig3@Nlu z%W@OO59gUvYFrtHGN8qCKM4=cgYLG_nG_dt>-Wt_e10riTz#`GvuH2C51{C6vE>Uv z>#wmbArkkU6P57L5d(}@ASE?DJC!IvJ=h|S(R*s@o0&EXubO6M%& z(4jNbwKLdM(f_Kv}Y;u_W-mx-(^i_=ICmhiwlFuw;AX~pPY3emSy0p zNq#No$^P=x%CXf*8YL$4&GZ-2`?C9g(+2K2!eSI^$F)e3X=8qWbO;Q^@12UoIGXS$J?~#p%O~z;++#<#ezVL` zT&_2mx4v_1cw`G4PJ+voKB|-=aKCA7P7*iK^$n{-?>sMF5uj$yh1J8`wlh}(*UkH; zsOaZUx~02q^c=bKt{r-5{Hn@Vt=w;d&&w+;gf)#OZQv}kY)b~cdJi?f?!wFCE4mM9 zAH8oo&Q7Cm(V01rKaJaf>ZW~jez}Oed4k^Oe-_i_Onib_lfs|v>^l4$Zmdt`Oh}7A zQm!q}Cn(O6FdkCLqIaE-JCo_^Av(*xUf|rhCmk5NFZ-gK+~J6VL&=nYJS&kB6H4=& zn~aGqeiZHF_ovvuzSWZl@9h3DF9Q-e`bp9E+Q6c|%`F21{Vc(}`NyyQZNGn2PZQLEb!K(oVOX5g}`%up#^m(ebYgEB#K5eB}C^ zcJhZ$UW?#lN{DU7ewB#EG}iAIkGZFD!X|0a*+GQ!WDCj6qI$$dPO}nj_xjVqHIMas z;_NUnw7)(}xb?>tHmo6E7o%QV!cRFR68gj}Y1ogifjHP@sh>wVh@iM}I#8p1dKH?x#$ zo!tF}ZhSnNrcX&n!@Gp;q0zz5dQIOJls;MzPL(L`#I7~*2PAz77(_5g@ao-pb%xsC zV07AjaPO8oHQnvARj^edAu8!Pv1@Ulj#uzOjI>8`@jDOCpZS?IPfyie)MhlKqZleh z;j5wLn9ALhZB-fL)BlrmJHP{1b`hON1sK|bYa^43BD`cF;9Zp0<%&1Vkqe2LIWm-P zW$F{OBirknTH#`v7ip3MxAa;6C_1ATjt5xK1Njuj)6LH``Hu~*D$8u{`OaHblja^Y z0`%@(WB7y3^$At#fhy%-Okv#g&RdNJAa*vKeRJ%AZ`jr1*7Aav*+cT<>81P&_nmxC z$fmy0qs}w74XicIYmZwna-Y3#YvN0f#fypzOrI(a9~lLej;_RCfoWT7U3ytqIQIg$ zh&he%t0tAWPlKXH49}FW_x5@iOq?WyvFGF%}0N;P85GSd9nHzuR!mOVlq4%rN zq)1Eoa8fK3?@AM}42_y!9~LW^cv^au999FJfRg(8Wu0QIGG5p0POe~I zP$_(|U{Ta03X6E1%N3ggSOZtF)hpou{y75Zjqg|jcgzuY=~*@IuYM9A3O$67Rg-%> z!gev#xAbloeq#u41kNyP&Cn`L!dEJQci@eWODj8us^NaWc*MWtPJ_u%yn3YR+>$hWJLFBM>J7cHy&orbl# zD3L9?f_4CyQ%~hY?X`xCR1YTK*uA;sbS;90G=9`*izXq3YMVbfSB!emdv{5D-41D4 z)GFYYC=m!wBT$){xXiYBII;?NuQ+< zcfO0W(17w$icIP}V@JWXL+`57U-!S9-hmmltp>b-mWizvb8GtQsoryz#hmFWWu4gU z8cU9H=OZA6^QFgGym_6<_XB8Sqi4(q`xts5Ng4h*Y{w=FsE60u$dCrFJl;>rC5|7= zvx`z+-hC!_<=mZ23sgW9bgwU(h03qa_;J^5L?(_P-xaSS|kaN!N&d$t!XZAar zZd7$<#8QT2q}~*!8S8_Bq_iXrSLi)QYPUyGdN(EALz!o+b3?L*TD73uM6_lhhmiyZ z)-s_y_|xHq@c`SBQ00mgkc<)GPCs&;G?ie)N?Qp8S>)pQf_v+y<3&lQy}!BC3Il;H zcCaK-T^|0NP)$eYsgm1pEg9HK+|C)SpXRLVSERoD{!!na^M@Th9RNuZtG*E#C4E(4 z_B8^>bs#(t;{iUTEuz@T=^3;ZBpvC|A*)%7AGsKdEbWNlC3iO%RwBlRzCL9Pdo+4n zz33x&L;b3CpE$R%ftR>(pQ(E0jO~(wu{*Tj1PHXKq@a`Hie9s|;PW;XU*$RteQ6JH zH_WPa4Miwok4%7FkC9%->;q0(R>Vb35A`xL5ksepYZ{eK#*6V17b;mPk6MLv9pmMe zjklpKY4=5kPupQ4t}Nt5L8ZaZn3XTgv_h9}&j@l4DdD@AFTl}O+?s_v=4dfKcy(6j zi^5U2+$8f{isiM^9D9r0QTOEmK~lMSK(PQ+LcK27Zs=x&FoCV^iCv~TAX!MF7NU3q z>*Zze5$9Pdx;LTZfpFe#ur2l`jx4fOb`qkey!8V@3#>54yFaf0**~Y-EqC*eg<9uW zw^Um1O5xyx%$jH`T?2A&^(t%azVpjm*ElNiQh~INFDjmu&0f%gv-}z3xtmeT zMQ+EME4P*?9w8CM8?N{zox$?N-U1KZpL%(pQMZBQ{;$QPM~LFd_cDG?Gk%a5(6=BCj^G(T-eQ?|DMhLAdg3;=jH$h z>`{&%nj=Ho$ZUmBI!<@H0kdYGQ>G-bsn92P9wjv3HCbYs-t2gn8{8rby#UES;q7=9 zBEtRSDlKbUjsuYM(2cI%c}Mkm6Qf=u04Y9RQbPXf7}8~C>3a8c$RSqFx?tD?V8DdA zZ(5pHuWLOI?~GE*^9btQ&ZHFI*G{qaee!tpIB|8w^`*?FEZ1?a6eJ_4-}30=B^ce~ zet=Klss#A8byo&Zn2PEPZcn$_XnG#()E8m=h{o3(!;{fR_fb`0jzBck;sfP@+}3HP zr~3tJ)#N;j16M)|iyaD?QMqRnp2d8#-2-A#nX44@FUKM^c!7{%yQchAGbYDHe$E`+ z95SLF279bzAS_kAT^MFoYG?ex?>jQE!~uA-LqLwQiFzjGV@^ZR3@1dRfaA1L$D`x# z>-bz|GMo{sgZ%^*QOv!JEfXI;z!$uCc4@!_?cz*;1a;!W1r8{K{jg6OQ@;DK!}9I& zcy5s)(xai@&yi+W>&KdJK=`o=zDJ2CKVjf)CXr;gWcfUCq#{!r0NrKk!0O38+mNPf z4O!#QGe<0S^C5sQ9xI$zY4n?yRK@o1+eehTKy(W2;kSv0gvNYoF11H14Iq=&atwv+ z_~Kpij2|n|39Q6)HBR(LodojlS4i9gFY*e+3oeLERk8p$CfEgLM2@6;P-_c6o1mlA zVT^7Y`5HR3|1A^79}tQ?kuIvRC0nWZeW?DWm`rpP3s5;I3=%UgE^bg5m>{nv>O;8i z51VZi6*0+VbwYapQCcFiIU!}V<9iYX8y+-Z0B>U|6Wz`+KZGU#8s$0?UiCgt-?3(~ zP|KpRpY*~`E44DQVc$M0%(I4**t>}!m@0aXO=D_OToA=p1Yj%ZxHrNE)V3HD7B*r% zAUEJO3;1f~!HWEdsrVE1Q*yUvTHTl0vym)0qMZ#9%ng&kW_HrUoXnpyW7#U1_kmQ$ zS13h|mht%I@#9!iTH!6}1((7VOSRGbNy!<(Az3{{vC20UMDZ_$n=otQ$0zC;yOr-0 zYb(j-a}uLl=3u*fh7FjPuw>Dd;r>fs##r=>Z`=X)X`R~4!KELwj?pL`tyMp~#v_KH zcFk3;jGzbPwxN<-Q|>9$F)rbS+RCREi}FKG*{uaHxzxGgO0rs6p#>^Fre#c62^F8w zZe4ETrqqnHOmB3Lwx|xM``zthvAj;m z1c2O)iR(wXvRehqU)ZXdIlChy&OyXX#`#^v8EBkz)uNarTflZwaX8?%1kEN%yXv;S z&-lbVsm&gaQ@kk!f?l!l=W{IK6ibcjD!06tf{;08a%Fe^Toq{4@b@+uwfv}l#MAz&jYymT9A#SZ5>bpWH8d*f z*wpUWcfZZ zhT>e7ZV$foJnK%3-t6I@jWseU$ubcFk}WT!D=$tNkHQTETsqPeR?D4DpTn|-T3V;K zlH^uIfkgpS*sUw?3UvVXkdnN%+ZBFszreg5Z}ZtZl1x4$W+?FcX9H$m)$VRKexC(0 zuj){P7MP0n(NwFP_PbBK`x1_BygAsy9QBsvh6)ejl>E_BmH^3dOvF?0{1~uRLMIb8 z5=6i1J5bbK_aedDZ^X`{zWc#VKya?b9#8cgZnQ2g=xs1fnZm;WLOrG04K1*_or4Ef zMG1V2&bjkG)OjroeEzU>a>MaKAw%}v;oHDPqdX#_AZbD*vsIQ8AZU? z6&jYV=@!DTUVvyYRqcEwUy?eVZix;K3_X@w2$U}9D0PnbTp?$lJPw#u+zTw3}6CRUQ)Wl-tgEjH`%Q%E@-=AWw52oz}1%ORNfW9U+PJTFTE5(DuMnFEGR2st+m<;NX@3I583azL?VS!Awyd%*yxFq{$mRsG&WQB1lx zEL@6c>q`8sKID{U8WYc0JvF0npX;83M8e&r`&#yTt8FOc%lT~Qu!(gHA?op$DB;xg zBEZvfQe;Uv){tK*KADxX(TbB;wh=S2y+Jxs<&G%MST}D0Z5|=4*sD}xSf(RfL|=XT zHs~U$8SOTo&3gy$mi6VG3qHB6Kk6(^&~G=h?+1429dYhI%B78K%{sfBG}(F6lR$wkZbG%Lj?kVhOyeUY)Td^$v@hB%Pl_;OI{QZF3S`# zX}-~^wygLNDK)v3z%^Ony*{#|)~~Ik(7{n18OOSObyGpg(;+$$ z2dQj-!=;WDIB=!v^Oq{`bQ;613^Ajg3qS#%e)o7KEhcq=bJw<|sT zjgzEWEqxa&ohFQBW6Fvj_dS`>6UmQr%NMj65FeA2m{yX`>DpF^HpXTWhh2#wE_c7j zqv}UCKMO}@LIXrgB`SZp7Qz&z55)o!)w4TdV+4C8&h&wa<#=Y1IE8<#L^20{QN6u$ z_$GsAh|4G%^+?~+nEc7)92)>0xm#^C{oSaqi!7~}4iwf<{-WDQKw*t98+I+4q8P=Dm9rxUHzm`YggDj=;v&TzG4T1FZe2 zy2C|{FI`@A8feZtR)UMhaXgX(v7GHFGpoK~Q?nNycRDs<2r5b7W&A>Ud*>v4&?J-o zR>53MT?f7!NV2=m*esNomTJuz5X@34@Y4ay(j<@R^3*@AU>BHE$ivAsY z7*t;|Gq0idjf&B6uJ;st^m>JB{)Pb!oP=G~x4!-=D|lupzKn=dnV(}Rvj-mhKS zT@RoCqIwEBN&hyqE!*vEyRpeOkS@qP7u`=E^N2h@T{t{hj~TUpM>dE1KP?Qka8oRL zzNH=$z0iTw@j_33cPs~rkle!x+h(7Vme?Zgr*=JvydPGAouA6!uO{v0tK+O4bb}&R z6lmW1t6rC-i3Ia6Z>>zfv_g#}@4{tQpt@t+*;GYg&6^c%jf6Typ6kAXS$cA8DH5Es$ewgIPoqUP|*tp+VU6dGzTX;o7wPM4k^H# zRBUl0E9#=h%GHg-)hq0F4bSBr%a={TgJs!Z{rnJdTFA$pmRxbG-3^!lc;egOBOSH+ z4kBtxAl{jptXkVsE#6j>OnP6MM-e9t?C0C1{5txoOUS|;bYBvitgHmKM?xU3r8us9AYx9e z5;#(_b=)-Sje6F+lKQ>tjYs8jsw@g|saAK|bB=K-EA3bX9umnsXP-s?Fi9OD;h87^ z_H4<9W54`HSH7$}1x> zdmcb+M@MHruW7IUS==yn381+Ssd;CO5xoz^_nn)aWUG_i0Z2TO8!wB$np`wZusd$R zd5gQXtZZrN?OLZuMNiez*Qqzpq#{+O!X$t8c8&g(^(F=?M zoUpbh5A!RO+b`XgiIt&7<6;#vi6j2=_6Ck!7s^?epKPY%=i`5&56@lks(`nqTw#$X_%b)uI5ss$}JI9AXzLj5FSLf67%> zV7rnikERso10v`J)v6@BUm+o@Edt<>ns?s_$HSb$_)VrUL6$UEI`knV( z?>43SnN(9FPPC*aD-H94TzRl?9FnV-o^eJ|b=hxWm`(U!`1ac%{L@;i=)HKSG@24P zaW&t0{cWcCj=wT9{QzNwU;pZ<#^V0=5t!W!MCKibf#e?by%^T@?38E7LNSXi&+15J zG_z-zgSH_HmYa0H%(mHMmheGOD^LuH2SQo(;nVM`v_h0Wc&nN@0{FqWd+a=1skbr< zrCf`x*!R}vt5GZ*atXqfnH6yhX3kMb?zLXFFn2q79ZD5wPfFvbq_Md2h5Q0A%hD<3 z!DT!l##k~FzXTj~={S)(J}^PB7gTOdS|69eM*djhTaWh`8=+{gkL8eTp9#87q2Xw; zTK4CD;Td&iS#{^K1oMWdiqCya0U6NAD0lrrxd}9RnP?u-wyltmK4PYnJ{)kzN=e#jQmQx_sct(R1VmjcU>oX%nE(?v)RbKC)gWBBhU{0TeBV)mOBx_>_BxDI`gIoJhvBYf(b`+cQI!i!U z5%5X%0E|4i@8I6JV7eD}^)`G?z9S0Z7s2_zwgCdJ?eYqkJe$63|A-xE^7&u9U^;6t zJxgDJj~VrbRlS^rurQ`m0=!4$FMcCH&U{x2dspz01M}X^};l-179QF{oOsD4H{uqKv+f*HljcU2y1nBXq^WN$NqYg zGmWJxKp#b;C@+?8Q#}(R09l!zl6du4BTcgWI{$wf{r~=h|Ai+?vvu2!d~Tx%h1$jB z>%f@>e_dZIY1C@U)AYY&O#2!U$7k%3^0!cF|2@9C5x9Jc1_=MU%w1{POZ>lI@$r9q zMZ)&)+T{)g(J=_XVAi1L@}yGUqKBchsUJaOiOZB#^pYcO?h7VMo9sU4kUqjaF@LoN zMAU4-PbYLf6Bwf^z;lDK%ae$w@SG%j-l$kbSn z2!&SE{b!`P?Ul=m+ZzCDa#@N-%6E?b$IZVOGxZ)Po|Jg}is~~eTr3Bkn-6Z$z?>YGEltt@j4`3gqD@bzr zz9X+EZf1X)Mww0mGOK@GGGL&m#X{ixs#tHd@$diT%SuwhD2}-N>dmDj+LHX=OUAVz zFm#+8UL6jkHxCHkw3_JuUjFjtz?lpKwOhGYdba^4{!hdIeg}N=mw%CG4$l9+4Jb>n z&bL(>P1^b&chD_=0!|p9F~A`R=VtPee|%Z~Q?CJI5GuiH$Bm+K{^kEUt4^u_kIHxL zn~%X+;07AwdqU$M&)4((lpEmSZ>CY?dyjIZC@v?P0q!U9e;H#n-dJGFaf{&RGzgo3 z{PQhwZAZC^?8X*oV$kMqF^H1TvrZ%@&^(;mKMmklNM=B2G14oA*5X0ALOlAPL+X4g zHo!qm_6heBz_3(_TM>xQNKVuhIM8gjUDU&WH2jP0BkNi11`LD9^!LyweC{cN0YNwn zJmu6qzwHViLfk*~Ml$LoXzb{DAln6&YTl-j%((I-vhIC8lbAR(Gxd@*KNNN8pAQ(# z9*-HlDlm?*;4&rcldAOl^J_TrWU~Uk6qlrz{J^~MLwWpbZ+slyMYBKF6is{$fJ-m zzI%WJ_d|D2EK^g4Clu_qE(l9@))AHom)z#s|HmW2cgATY5MK)GXxQcd{dGsa2<^Ap zN~K^t>&^^Q*ZUh)i$~!LNse_}L-J<&G^YB0ulh@8bhy6lY`HR_yvKg%ZLZ#W@t;FFFpux^{9skwp71OPTW-5tFUK!=v-;P;^@8PI@ zlojfzrURTzR;o7J-z^uZHBxB` zHP`Iz>P`xE2(~kYW;@2AZB#=-pcxG1p8ew`PHp%7SNDxpd?oenhR_iy!N;i&k8y~n z>>oJYWb@2N92@pm{(tcU@Vfe9+Pvs;fK?jFj&O2z z@ky{){dPJZHG@2egZCAE=QxBBNAKagj)b@x<)4=IU6#?i%KcYAfZr~>LYoionFQe3 zqZ}({x3^V=>b-U*-&2G_&Y15t@=?3rAAKTKA3HQ5GvPI{ZE}DY|MQBU0}DlFH7z*m3q z<5sq^_G)qbZaWYd-UXQsDnS?f>Y&UMOT1vn72C--QP8Wi%ye26)($ zP`eoDgWefksm3W%wb3VuCQLUD@_PS$x;_MN>NB$dh>p+PmprTlqfMhwJ%`cJ4ZocQ z!WKEM=X&=I@)cFj)U-nzCCV0ZPiDtXH9LLW5&nJ%+)oyj-0TDB_j>7-$ z^P7c#_Sx-!_Sr{FY+1#BHB_4L%86>kq8O&j;d%&jFiSYU{XE6`?L8cPscvu0?EBll zu{Y4~-)VR=wAa*u#e8=JX6SDvX$M})0^d_dpG-fU`ZvO}UPR)@cDxxM)l#?0;hceC z??v}Lse~0JU*who(VaZJk8Tzc1+@2fu!X!v zRs?DfBRsf>*54cMwZ3*ey&GR^u5YSNu%4IM1rH`AaLm@tt^?>w%l+f{E7|1LF~Ao_ z8NHPVa7OQKIvz|vpZOkOiKiIyv{ zqhpU>^6}FzcGjZG7}ZIA$8Q4jn?9NNh4Bh+QOLRRA43aQ!bq9KmN&}wVV48Kmx0}a zbLBq!Tu+{V_UR;dg~Piki!W4!kk>mA%pCkVI6>mnp>Tp-eM0k zcHve(90QaR5tZ^%(CZx*Dr+N>D>TcoC}+5_5BxgNoW8|*y1&iFpIzmm4pYp*=Be+DTQ%v zsny0ss^v}29jl`!->*BD%5?&(h6EBl=vqQvvDeGv=JSD^2`Z2cqb%4}pt4%U!tfm@ z=$vF$^VxB26j$o9Y^mkcIs=mOZ)XYnV`hs7RFi+($*VIW!c5zm1&anZ{oT12+uqLa z-t8lvo&wr(UW74bwc76~!Y({M%BU?Y#7s3U4H)m;QBR6=9&lo?Vlxp=r+XpfE91_c zgX??Gjh#t%Qh7>8C$yOS%u%p)K!K}ML3PDZX?OKWRSIQK|Bts^YlENI9Q?bU(!il+ z-b`#3g+BYj_J)HU!c8cj{nC9|KTSLLAIghh2QzY>()3oG0$=(sixzTdW9aIu>3t9G z?;)b>sG32X`rV&9eY{58s+zNB>HO!c(H5JVeyr;sqlQT3ZC8~R1MU9hqbW-()bnGd ze@Ci6O^>pIPuoGHg_*JdyAWpTV#>PrUf|GogENR*4?RD?GPe3I^~xYyEu3ea#Es)v zc*6F#fZ6M;qsrWV1$a=`DS5@P?cq%9vt2oW4U%tWNC8%?_tv|slFMG?%_%Q}a%-#C#sO?Km<h$>jK643Ln9w1Sc^3k9Dl! z(SXkemfsk&ef5ht!M|K={Zc7tz(8(RN-ya;(+{2(e1Xo}g?+67_V-}K8x}Xu%RYB6 zWf59#wOGd4>qkIdaZ9B>1h$yZ;#7+5JT$JI!QC%D>G5YBg#8dX9D<|n;g=oZ)a+kL zK(XP!6^vG%c-TSWniPuTjsmg(sHwTQ6oJz^=OW*vNKgD_+R+-+Qo>hov{LYNth_i8 zmZ|5(T|^%zobJ5SL}0<|IQZC3wFLA5rN$1WH2?V0i$2`C#A{#e7zdiX{E|gq;B2nv^V-9VTKL8vMSFPsQkRW<{*4!xco==nYI4ZVag{o_GVfp%fwrD^(Obe(rYBtKXq zsJA@YGhgAkw(9z#ZMw-{s&kV*Mi zb8{^cmQ-m{c9JJ+%l!k45z_#qiM{Ygxs;cjLjv==Rw&(s5%~7}DJYShW&fEEH?UUJ zo1DWruR>VQnKzYod8K_=^#Bma=wGYK{uT*-vg40(J>>E;JV#2v0`;r*`2$|w4Vc&uMO!sZvVK5O@9J;6 zJ?Vq>V+hQ{r&^YdU5IvA)}s5R(_HGJar6vM1m-VMdU%(H1+Y9#+uxP;R>c8R|LzRb z=mJg5hggY*`ZrpqP+K(A4rXKYv#1=$JItWpQw$9VlP?ZW#Xgih9AXCBbR>%YQHcCP4#>1txJI2^X@}y(!feB1Pm6iIURO( z(nO_Da^OVeHvke(G$?8PwbuJ_kFP6H`z9D@a_}!;k_=}|h*C4>B9r2LmfRL`Vizpv zqqGmE<_(bVZ*|(oEen)J9|@`5-)$DIQwMq{lM(aX-zOC%D+(|v0!__MnhGisx?wfv z$Aqs176kZ+!=lU4l%D1yQJJuu^-4Ymo}&9YL-dNKCwiOw>FTcs`NbLV%O_9m(h-+s zud$l%(HznT;lm*kk1y(3+_L&EI6wn1+zl14Q7p!XIzojp%SdAI-OR?F?ZtJaoY*0n z?piIB$HI#FdYu7(mmGV$+P>^~^m947b3g~9Ig1pvyRRxRSBstiVSGe#gjKy(V#yo; zEj*-QQ~c-&;h{wAOy;DFLt$Xo#rODN0dJIlH$BZ+={BA3)?V-|c#gCy!gGze4Ubj(<(v5^5H=~dS!lSh-T)})eRmh( z?AsI)TP*HSORBqjT`j^Fdbm+s?fafNP}wx_Ck=iRvi9777q zBd5$3hmfNyibSiFG-_d_K*%Mc!Q0h2JV7i)iK@nO^g69Q%wvF51bZ@4o+11+ z8*`8TOnnd?cw@g=C}fxWA7(vQKH2#LHiS3-AI zO-f)Tb)ouHrTtNFKIND`PU>EA!Y~+?;%H=KXtuK&I`)3g$Jk_~>oTyXsa4|B)mQsH z@5D29QqKvVppdV9jW|U!ztt&yL;uz0;FQfi$jdAs%%bMM z#`A8H6eO78|NOQ2<<8>^p|6#JI;LkgQp`ROldh;GEAy=;MCG7;gbJiT( z-szL6f_xtf{b_OcqPVF%#SmrXs?1qPQ>CCD*1!Y{MlG1U=~auEtOzMK?1u=79R3v|a$o=KmUe_>MxOj>GSPaqTX8Wk+U_9p#--lKAG;gGn%N1ys!A6_2!( zOa^g`EpA!j_wQ01(?hk0i~!M}jTNnSAsmu(M^yttWn%6}F0O9+sDxgkF2SivpRTmH zPMYnNqQ{I+EO@O3a?<;|`9AH{NiI0e5&4w;Xxe&9;ZWf~Yh>$+X~+7sWJx zpl3r^r%ttDAiK>cgW&T)t*Z2+%_BY0R=ux_+dT2UMT^y&w?3Pp0;c<#lS+QyLk&&N zqaC?A0mUNnC)@$Mvz!LwDrWMY7s&dOrVAG1d^ToafNBj2g@~K(<+H!;y?TVMey8%T zY0A{)An%<;2&@jb>r+#8L8($pr>x-eN%x(ZHbt=3#ZD@Dm%OoQvNkoc4*kN$qRHM(K zIPxScchP5hWD{1>v08=$dp=yV*K6Oiyz?mH3M+)=8#4l=IN*`kvoThSbADW-H=>M{ zDX_~Qwh_^i_E03R>}<7S-@!svc9}t-ov|I~r#i=NYEwEaoqcK)ww1GA@ex5;m;rE2?HMXvFh`DSXr`+{9S@C)mWM;Pb8T%zTt^ zs>=>~uZTLlHoOAAs1`BPn@!jwu8kA+N7pbNXfIb?5t1FK25_7mMZ?ZXO1H=Fq?=OBckiJP(xAiSYTZ+4cvsAHvMw;N7lw<|7XQ2Q`j~ zpyMkSF+I6llMptPs1+q>I#F_$G*ZqmdT`M%@2+bP=_5X$ zJfaJN{)Db8!rmMzeK%VLMGnnCJF%_ca?5^dLD;AQ|G>io!3S;{PLMhICU4bx61F%# z_{??3wc)HH%=q|j@dRfO!|^GlFPaPSE7hFrTkcOrfn)uWlKd#>=DGrT=J@4oUx;>@ zQuj&^XhaXGlshIq%*VqSKAgyB!a3=IEI3KXR;x{&dR3>%bCG)(nW5W}(JX-s2eVTm z`U1k)m6{YkK5bmtr>q=Pco>lw3*XD8R_sYrw+K;TIdoqgIo~p~`~vpI>9QWz#op_C z)V?t0y+T=(_1+j!pzID$c@ogQMhBubztld%J|FK96z}z13i`4Eu`8HcmYUn5&QAZf zWcus;>F0)sq9DkpXOa~L1jTgY;#GD>(A#DYZwkdKo1J_zv>9bL+{=cRY*KXWJ1tkg z)AiB_$z0jIWyti&v-nA;38J`hQ>acklKy82xO`3m1(jTX$^eSEqIPU}wa0P`R|rPA zja25{&|({~lXwvBvjPna)m#}ZeSjA|tOh&I)k8^wqukcgpp`xIE+-b7nbi7v>ncuPZ&&#W8T@$2leK4f1MT*Ow^q9McWi_**L(p{f#h4B!RZ ziGw6rBUG&u>wEeR>zA6=J10*MdOY`8^4+Wh6tf4Kw1j1Fm9k-gt|_#}Unn(P0?Q|L z+|k~U)QtcBZfHhjICo_oj33UOzYT}+_A_QJY>{38XI7XLm8`!)Ce3fX8dbcoHZXcM zAoPlwR)fdL`2v{%%aCM3Bj{DQ$@|Z(_d<)XS}mSG_F*>*9f8ubawA2MNVO+ndV3il zYx-^Zw)fuRFd&)aZmEuX*tuvhRVsPF{1&~9roQx@U0a3r)j8f=zWt;DlLq~~5)LKp z)D;QL&aAx5@4eOwsDI;oIN7rZ!+;Iu8_M@$rh@`7jgF4vsswWgIjg3hV0pIDOKksF zZH-;eY=q?Hn44F`_IiF}uvR+%%;uQAlrV~N@>Gra03D6%)$hknB4HNWrg zc=T=OVbzx_ky4)oQZqJnPbK(~wgE?}i+s^!5D==u6uOXiW-|2as^ThP?T{fyDFv_a zO}*T4(9T1JeCbpvYJ|6XXr?iduX11R~?_1LFbO9r`i@=GtO9YYG%Ta5L-b~evblxp2*L|iy-1L&7jK)sdZI-IAjB!25+6boHQr_|uy*{8}XVMh3pLf-$ zD|$YNLFLM_pKJ_eMQeL3>N%uWEPD*B%lIpGGR}&UqFI^=74Hw=86*R!9KH+s5ajn53)- zWJngZ=JZ&`PDw`{hh55Xlf&N5e)ky=T{{x>sCjQ@hkRz>6z6(nCeW5gZSHn$+PirZ z?rQP_#OEt&LIYtj8~aFy?=gF?O?#X>PZNi?MWD)XmAq2@TF}Ad+++_ z4to*sXCY?N)KN6GmhLzZYc*2W!>Rgt5=ZD3iGw5#>>9AFkgs4IopI+jx4t!GQ@m6# zl1s-^eB(FkfkZigz!et$$f!=uv6Jk#-R<$VCeiI}Q!XYg6q9EoX!p|#SuEGExbb2R zCs>*xZ9A!fZX5^+*6QSeL|;|5{XvSA5zOG39dG+$ z3k+2OC&R)-K^T;j@JVK*5=Lfgh@qAe@Q zQRr`SPQiNzrpacmvFol)sC^~u^O#2g8lK`CS@3;!P(clLla6jNE-ebPW)+7oE%m$t zt^fEgW!qCzlj}`uz`X=v5Xi^Bx9pHz!h^Ir&gyqSd|WoS2w_Wfs+CDjaL7hAV5%@p zg~P=*@|*5{jKu|8eMdb%G+?0Rx;-R?ZRd@wwiJ$$HqL~a5r;QY zEqido)3w!MXSxYo?g(eBaIj7&v?uBe;8had-5g%V!jkx4&^)(*^uRcX%@ceC6s6m< z+x`?QwySh?9V%V{On0#Fb~$`T@gQYMe<_(TiF=kt5L*%zyP2%2v_07~#ct*ob&SKT zW_!@pJAwuhID~Bjbv{dQe2CK=YVX!#JGo$IsI7y4AlQK6k*?~PVV{W2NjR4M0~lW& zX@_e@wdA?7*$npdupN6S!X%6gtC<0`R8!w>V5+$K$x$v^oV4^~fsP3y>m1J2P+n(k zPq5~=UKegobZE48hGY`c1yM{Ok5N8NKgVzDVD@3VPu@7@1v6z+^`LwC)m~KoaFdPq zH0PVYo`;?W($xZ z_+WYD^}EzuhI=5}r;oUNvp66c%IRPrk6gF1?iIv(*lNAGw2)l2Oh(#103Zw|h!K{; zrwrJWu#rO>KRs7DlykXCEAWr=*F^x-zE0bl3ATRl!~z{Wv35c+AQZZc%{~oT1YY-P z00bTe9Ho2`pFrd=V{O3}>pS@-b0TW^5n|Q%U{OBC^?J1b8eK&+W1sqAIu1`BP;yZd z;lrY#x+Z+OfHa0nmQYn1B3>l`w&=b5SSy7QsQ>>2>8r2@vMWc7b&I0j;qnJ$#>~Mf zEPSm2-V(n{TzcqcWAz{+a!T>HF7_t@qYxGbc_?A?2P$~}pscNWUd}?y z1x<|XnT?=0Ei!-!R1p#;AD2aWEv6lvg-1XT#bLr3Oju)hI0zX$UT-pYU>`Xk@@oI3Uz-C#!u?(1} ztyeVT!IWq>Qw*=9e*kxOnOJMF~&htCyN|stccS z&w~hWVavi_+jb~ImRh%+*Tw8*fqaY;v*9SdiK00Yi75@wow;6FzT$^CfGE7Be-NVe z+=0&duiaH;n-nrwR^WUc?q|ljSzXm824G`-!c(gakWY4C8_sFT(-;Tb8mW#S_%R>{j$GECj!Wn!w zDHIF`b1>e)hbEw-T<>MCcCQ$t2*M);>#?k2VUZXZ z*xkDp`|Dc^>d^wDJ0aEnwr_ zd`F@eHD6Wo2$a`7zZVL=Ts{Yq=`|-}Hgm^OLjyCcsX&(UAWl?<*$m=2N>XlgZ~8z3 zqoG(}$fNV8&YaJqWX9eSz5wR|YOCjVii->4HNN#&7(tK1x#&NaPQS@u{#jvywJqyACsNFBLht>J2l6~zJ|=@idD`bX7ZaN4 z@D~;A9NLQr&52OOD^1;a7>Y$@f{PC6!uNcOBo_Sa6IXz^L8p4iU6G*&QV}rrVk0 zxvg~18rs*8rH2aru9}q837Oxz|DynLJwL797-T>3iUq{Rx{%&bG$%1|>nZ4m;*)?J z6I^(S`SR1@TpQNcRj!EHQe<4SE7<+RyF(4o*~40U5GTo>%sstWAp`BbFPxtwpzi58b=!av3(!B%w}Ey5{jh;(+X zUcU6S0@ue;N=(D9^pX~qz;Nz)R1s(1^1PRVJ{+eicgt8vfNx8oNI=#Vt@tc zWuDJWozJ@779(lgIz=44y_N@IeSky$Q6YJ8M46}+J8S(y&@C0THptZn6e|?VUza-z zNDGKIqFdw3fUq9;O%RNy_{p(MvbfPP3#d|dhqrr2pz`8++IqS}^Xs&%#*!7luIyZy zF+MNzbR1*@t#|!)@>5l2oK5cxZry!umUo}c1m4Qa3>=xK8K&|t6RXv_wewWdE5~Lc z5*lx_d+IXu9V;;vqIk}41dFvVdXo4hEc+-InO`C6q`tf{kIw=j2MV+O<}^@<3r`!; z8br0iQR7i;p{-p4kjb(!it4=NL}LyDNwarH%a`K4C$1 z>NRFth7sU=C``&O1m>8Rw(>dUGS|7rBFAht!ez54VG*B>R#&ve6V)DjH8Z&KdVOae zlsYXDwGv)snvx6cn;hsMw5>DKk$v}L@S|<}%vodqb_TU3|8fS1KQl>AEgaC393Uz*CB;57( zj0pH0iL%Q0`q1p6u+R=L1aZT@C6`wd7hVPS`~cN;XRcFxd@5)hYE98Ng?*{=dGWPQ zL#3%ZBb!u^gMFWJS=uGH{fhw)tD@y?al`4ULWnM~%a z#Ke+al?1YL1132vC#`sCP~uD2$5J(CJtecUj&~>DBW0C>FmK&y=rp%*IwssPuQLS| z$?_6B7g1%pWvCu6qUtPa_)M?dw-%>vRpOu}c?NP@;{dY)xZpX~R@?f6HOeu>+TNSB z6_XE5UH~mz9Y{3Ka=QI$>(#J^Q?+7Uu(R=KtQ5s`_+8g7BgjF+tES)QryJK+rBeLk z!@7D2KLoWE^X8-m`HIDjmcsiMKqs6b+SGw5)Vzz>^e}SHJ#}fzR=&kG28VWsYjsEJ zdTK~5!PLrihr#90a3;F40u!rK>^ise3`qSxE8$)cjPyGO&1l5h{38eP4QhLlm_y1*25~D>(zI5?reC^gJi;OHVs%BLk;Vj*N`D**a zjpCER+XS}f!@#slfb3$ z=%QhPk%|Rq6e-+|i4QdQL>5Tv{U7$;Gpxz1T?57LD8)_*WmN140unk{K}5htFA+mg zI#NOlSV4t=fE1}JVxvp1QPD)CL~24;14IZULTDi*ob`sHet!F${rg;de$EUlYdz(D z?x(EvDhcf0GqV4YO~zG$I#Al6wy1dizytxL0SnwQb79SIQ$ z+pM4d+g8YvNLXhAdu~>#-P}$L<}K~-eC@~T@=0(_wNyA94jzvaw8*$=orh`CDpgyX z!2f;*9N4K=TxU-JpqgfwLrI(J{2V0R=DZ(>63 zLA+{<(+45C9!f67pyvQi_2i_i#ywg4Mj<6!IdjNvRG!KfYR@0DNiv!czbdqEjuMbr zsR6GuQr$1K!ez78Fr)D4wzG$qoo}>naM%oJ`5W<@`K^gVlNTB}cZpWL5{8|xYVLc2 z@{8y9{HONQqiAyB{oOhl)KE}C+v=PX(2AdyHm%?7aM~1$2Q9FPxU#A{({!eCvP(!s z&pF#>a_L~9O(NB_vFJV#(c5M!qpy?oB73!w_wWEcpX&I}^{bI{n9n%`y&>jk(gZ|M z(53*BAYPU_k4Y5Q$6HpFOng7T#sAIITKLfyx1Ee0O}sb7Pkqw#aB1G1nT?&&av#cc zAM=V-a<(x?$2s?;B^yGGjtkCob<=&J<0( zZF|$b`}-rX+2jGS)@3t7#jdK-4lEvxFy|f{%>m^1CPHg7=SroRzlP@Ob|ZyeTjE63 z1af3TX=WJR5io#8=(bT~^&AhUsd(p2$Vx57>HEtKk82(n-bspYvmM(i92!{U;8pQ@ zYA^ETx8jHh2fD8?0-+6wR-5?=K36OHRUa&D@HvT}^C zb;_bwK87DNQSf^7#tqp@-*P8%=$OkO%gMtExRun5hS!rX4Xm`?KenUa6P)$;jk+_-yuDStquG%;Z`NH( z$TUcbV^{7oxr*vWx%PZcN!ChjUC5$S&TunMuxqh}ij&ZNCxy!348jY(edT6_8+hEN zgUpxqey&88@5_l~XXA`YSJ?IYgu;zi5(qM$%pPY4O+8IV3G0lf#CC8=C*mx5Ch#61 z9^J4S^mDvLE(bYf_7tZXj(L}6m8D29;o-;~0uJ!3VhK>|yJB1WymP;0VV;Be2+M5w zSGT(lJS`HxCu|D3)#RubIT|(&Y+f27R8nuJzkej8h(&XgF7RyyaQO<#AS>!ZJjjrL-qRBiO<5{lOx`nR3HkUy#r9 zkShd39qlc2ztcV1Uw@`@`9gJsMuXprltA{#7?Y8zwsSWql|h9gFtM?gE5n-yz4hvD zmN$~T0@zlK1TFdI;b~m6bp2j1UCHe{0w!uUz*ygY|An@*;`{O)u7MbJlWw6fYUy{z7Jq(4Q!hh%z0#RC_NR&Z*&h^kn+q2YR8hMVi{DUE z8h1`i*C>LXc*?41Zqg3sKg1WU<7UC2J=*Z5&yS?~B-mWg1id4ZwiZm*EaaRaM-F#u zkEGSyKiZi+R$P3EEYq>-N!jYbnRPoyRDft>X07zrd9$sef8sX0!xgc1vSxMIGU|3n z^U1s@vUE|a)?JtDhROoq&9k;!WD(MYs&VBU6vBeHFCW}!(Xbn1Vu@(FgpM2yU@X$? z1*>31EpC>yVZL}O1eI^2*VJEqnHK?G6yu=?E*QmeNfAcqZl9r@HhV~I(2MJ>bMop=u-7i`@z?aX6K3my8f`w*4oV>}3FFB^ze`qWqnnz)iI|>F z`wD97oZXz7YNZh0DflMPG+Iy|<;KhCXZ0*g>P{o4;Ym|~p_5yELR;5`-W2ybARMki zD$y!>|6O%YXqjQ@j)x{&T|_T)x0L9-m8A<_0MWD|Qb0a5`{-=6p%=NmZ*g*Ge!OD% z(ZTs>1uns8FL(o(G`Y9{E)DAkKYMNT9v)Kx>AwaQc;(3_#13K#K}Hlj(s(5)?hay| zkw=}8%dm%ep_V&{>lY8Jr_%-ivlA^I$W~9qWo}hB`dPL-a9L>YrdGqWDvdjMzC}9`Hfahj}6iQ3% z?>f3B8Js*Ykj>4YDVWB@@x=^U-Xv-P!LH92Pr$DcH&! z=NL{v^v^zOZ*sC#7+KQ1#%V&uwl|HIq!zyw7M<&n;oN$;P#b(DwfIBfer%xal8}5k6kmKgBra^(zT94hl{qkz<+f{fJQW2+) zuPa=Z31V7S%f*QUpl}h9WmDcJE+{tn@d0ZmqP3uYQs=mfEjBUO**h=mJEK@b^K?(f zRUalO=$!1_&#`<#uG%35KDjggVMt{w#bDbdi*DjG%Be`Gv>5QS=7lNt+)5!Zv{&O{ zxF}5_RjNSY_iv{W0)<6vwfSP9%E5CBgg0dbpDr{UH+Qq=~JIvl-*F z50@Y!(&z2jiyOj@ecK=)aeo1}z*N~;F5KS42(3T4{ng7Ct?Dbz99PRZju0E%MN(3& zG}+Q}2CKU*OliHs^NfD*t+Rs5$Tw!zt$BGI;f`z`l~cKSdY6j&P_K=Sk2sqfX7a~t zGF&&?gkQScvGa?!A@QlBZgkIW=kQ8UP`%Un`Z8sh-ZIdr_q(%Wo_yQ`kPceJASPa1 zcmJe-b&t>4^YTc$MJ58;DleC+ZLi&s7c!O`oU~4J&divKxdW>`cEkDRF$m=SiY$r@ zLXAFW%s7F};px`XiDp|qo1pC^4Ul#9YnKB;$Zpl7F6)|FxN^m2B=a@sGQ z2M?&7$=kM#*hI7*NMMC8%>tx6UYrF;K`(BR$7(Aq)b5IfObh<_L(3rWf-4k{z*S-X z(yArM`_8l~x_mzLIr#Y|1ftc1A-))>oU7+z?F zHaTu1F-5RabD@zaya%!*$c`SzmaR!_fBW*?ncJNe*k6bU-df=zV!WwXQU1VRaQB{-rWCcJF9QXBad!qA1FVZ{8NEl>6{Yj?K}56PbW3Uc)HvE zg&@)R$LENQ&r`KG1NRue={04$v=eB^Ae&yw^h~8;R7!s z#-{2BplOnwG4=U9&arcZ&`F=EBz9&FBt(hlbS7Bh%`A>vu^YYzI%PQd_Yyw?KVRhg*sTGA!SD;IdI& z)wVnJwQ&^JDQ3zq^t*QOAE4rjybqY&w{cW*3aERa5f zCF_~gf*8J4)$fWgIR#t`b10fuAGEVYKkeP>VI~<^1+f&KN7gqT4n!BCL%6LGASQ< zT|28VOSa&A_s};J+WG~qkPB;SP2Z7uZZdz+0b_kz-RUIH+tN!K*bNFVoubC_zXn-e zA6+75p_}K4SsiE#K%Hygp*}Vr8}FNTf5!s7qtQ!V(eZ$|?`flNV!{c8*Fv9Y?YP02 z+ysrdIwLm=HcPEQ=mu`BuhW??egW*1gKK$|Y~HjA z!S)@C2L5$+qrgAN7+lj&of&XS$>GeE&N)VDSsxyFkx)0}8NVHXk}8p~zB-x>U_{eq zyH>`bB^$`a_17|rYwhl?j{t7*G%u&d@t^se3vB)2Yg1~z)&Lo1U=RA5$I;^R{CX`f z!%1#=_$aTO*oqIOTj!iVxdW+J%B3Pq=3s(1a3+zB^2Z>Z|CncD>+C=h@-XY+1Hyd~ zz7WHlC1Q5Oe8*X#?YK7yCk`tTTP0^^z-1lK0LF@t$tA5739ZZ@$s+dp`79{FLH$}l!G>?H6*tmz5+Z;>@^|nYnfYoC;Nf2$>c;8!e5UGv zarr*e1?gXq6xn)N%kBxZ+PCjhjnjfb(a5jAut!?ik79Ff;>^EBs4zqE&Z_MBKmiRY zDvkzR?X1a~v8hbyQ(jnZ^RxXeLh_1uiR*d1mzVJReb0p?#|7#$dw{@gqQJ< zvVV5i_ODoilVHh|RVQ*EX9jO1tlyDK>MLB*!&{$601agly7v27Oinx+(|81K4Ujw* z6!Kj0ELx$nUh50E(&o8CWV-0;YVI__x*||VKoHiKooRa5cJkL^O0S0O@68oOd^|K> z11tqt-l2Z2JHRP>ubct6;+g@Ze8XfF69l`a0W9--d!y=}^{dQ*_8}^uW!YO&R&v3x z_hs3d1=a}+h5X$6S_Tl2SG4)WJq_V`OWCb3FF0lvv3f16J ze~A9!;rj5L-p-G8Uh9e^b>3Wk=WU6)!c%r0p1r*WJ|GaamgB+`Pwr8bpJA;poWMIm_wW6~^JaBr)N&WK>vXc~tD7KZbJZC#6vRPD zb3ncb{R?2bN)}N1mMonRIf?&37@r87u>rsiZls@i==t_)C?F0xx3}5@3Y1~AGrnG5 zWctgK{nhT71=xvuL&j}@IosAcVMvb*(6 z{C)u>qida)(p14$adI~Uzi51B)bSRMP%{s@yHIikCwy)QyU)`HcYR_I47Jvmzdg~o z@*kcfvU$sqnTO9B#bZK7pz2MJ`MX$XiV+~kxfbmqyME28K$+y9I!pUX(u7VZHsxxF zK0GRKX=T2oz?0xw>vhF@xt9&M!{3KDJ}#~$Jies6Ks7X8IbKvvNY&V%5wSq60dO;P zM^2c4YJAhZ+@UXfj&mu*+Y`{YW50$0eOT>1C{@uQNC+0$un&^cDiCUOb7oE*PBm=R z4)0Mmy;uo8=eZ#Hv&ZlA*fhsA|GA7H7LqdVbXfW-B53e}6P``gUOM5Edv7oIJF)OY zy22x8#L^MZ+~Pu^x}~Z5K92e9nQrP2Nce#0UU~`%|G9qM2IHPw6#435G9UZV7ANjy z830`OU!q0p4I~T|9v8m)?U+|LRw~A9wzIVCdX;cU_YZj;@&)<=1n8VoH|6WEjafVF zAkt&tN%ew+r~9%-YPn1Ux)FB$URwevLwUYZ82n>PKSL39VA_AK;xu`}-!T6J-wnt{ zFXn=xM0p<+Z{YbqjJYux)EH$fReTT7wx7Co8doAUR6d&7G5N1=%B%q=G`iL}ToAi2 zL-ivdr@ow`MPL6H+^Bmi+?Xr4s!cXv+meHOA8paF!z-r5D#V^F`PW&BIwlVJ*BkI9 zl7esGs#X-GW8z-n5~7`huC)tEK=#TFDC0VrHxHMCET!X=cK~^CxT7XUqepjM4M5#* z&OroV+W{ii^p~W6NMlLhKk^$k=v}tuvuS64Xdj+N|2vN_VAi00FUbd#XIs+$9dPLajB96Vk#vBgtYHa!N2J&8C-_j7|=DK{y&OQbpHa^1^WNV&7(>X2i70v%3thd z#8lHCV09^A?;^@A)gOSzudvg=KA6hdlKn*qp{5E*QzOOvfAol@QY=WstmQxpAqncJ zi8!bM6u%jP#^x*;@csWV;Ny!4CaAS-gZRPLDLdO6I4H2cWDXCpCl-0he|qunhdct( z-9GjGcMco|unn2W@C@=#?EFo^zwdSW5rFB2a96d1dg&0fReAntje zmHXxh8RFC}sNmT%|Dz@FZ(Xv*Lsrme?E9@E#&aA9AT>0i|98Jvv8Nxy)jbv*c9KksL*R+y{8#A~ShQDG)jS5)I=$rr<11hK@xZFEPv=tH%a`} zz#g3P?2v^<=_ZPI5?R`lhnsG4x#|qJ0LESTG2cQCe#jllT+x6FUiJ=P_W%-i;l`n{ zSs2AHiQ!JeE4+=_03IphUYY>xspvn0A;|A{c@t=cue|&Cd}f{ZVNLYKEe>VqskqvZR5rDryeDXb zh2)+M0bw5M4NRq}(CmNQv+gNwP~HH% zpNV9C?~izI)pr}?c*J7;_k<0^U`(qhau?X@hpk(G$>qq_|BV0O#t#D`)B2=#&}Z0N zcjcs3l-B{3ZFfY;2~pj=nc1?^1;1(L{8G`2r{nQLErN0zB5?^IV?cRUOk1mmjej-9 zT5-q{*sY`;?HwiF9~5lZ37d%VC2b!R@G*kFZRb};ut0vmx69tvtiTKog<+W^^jH}y z&fcVx*Br@an}`oFhN7!Pm;JK2q`z1Zn1Hwl?2XCC_Io@!8m+nZa%9&dcZ|-8@OHiT zLkWHFd3m_$D-_w!ER3Rn$7X(MYZ+9XwFSkO%~vFqW3MAEqQ7_at>gRcuNJ!!fBcm@ zb8L2GFKs~JPH!bMj%!ADGEdR!OICj@+>4d|sIWiVFq`yCjBg9Ljb{ojAzz^8jL1a8l4&AVbc=Nhv+ zHRYcRk)p}&&i5TJ23Fp8jBADc65REx3z_yWI+?psNLHJkBo!VmsM#lQBZ$%2`;S4S zXr+6WpO}kH)4XT2U0+30%qZkA?NC#D8g9X}&`X znf3xh1x~5O?QTGwjj=UYfxroBe`uWMy3>(rO5~2M#9U&AVs^H(JH{h@%`Zo5koYfF z9I5_OUBzm4!=CPPMeu6IbdALAv{T|0?gv91&9;FvkiVNz?hE{O1}w$m*D`vIP%;Oc zArg8;Xjc%)pPIt~FRcJUo`_Ua#3>xic4m4>XZvQ){-#Fe!W0oG6aT`gr!dCP$!>%+ zqGI;khWmY`^3eWkb5JhQzwq)pgL`LhzK%an`@t{>p$^ndYbC}srdxCFq@GIgC!0MlG=YUu@$mh<;1f9z-+VG zQS+e$US(D4?o~e?x8nNEtYzToD(*o-{+o2at|>i+k!+Xh5+dpc9i4|+D8yW^_7~p` zT}S1Hp0gnf?l>F|p_&TUq?$&`u@+T6%(S1IbYg{wpGu5y3i8>>?tBw*E4ku>YQ#K3 zn*ZgTmZ0aR1XZ7+e{?4X?E{ZH@Ks~n>+9ZQG90g1=(3M4wg$U2-hf% zV|v+xkKS(5fgjF(I5^>~v`(c$c5rq|)@ zSDZJ$|K+d3!7n3O!40(l%(v^OtijF{Uf-nSeK`Ax`$3GOgM~T!&itNN!MIO|Dg8Hd zybe_!l-yl<+5KZ5YbEYPpL&z#&WCZl3c2F{YK0%WRcC1igq6{!uIZA^5)j7S59YUh zVG0a+!l5rhq%B-D``!J%?1XxG4H6{IKrwdnsU0;bVU7-gXpCbPR%srJZe~I4SfT%x z39DZNaeB)h@HKYqmJ{GlF^-NFNU|AKhJPW2&Vc$gxc`zLA0a3bzcJ=ma~qG%|6O3R z7jpSRPAwt`zWM3?SF}py{jvfo)p$XIE-&Q(r+jegnl?@WZe9p%8snIQJ+iQ6u;I5# z{~0qtyYaSD%rV51^gt;-FdrF zhu_A+gWLflUJAOm_>*7f?CJbgeXloH&h?)3c3~^l?GDx17yYWIV9+Ky`IOKX%*&Du z+5Z~51)J6#*(Pjbp%i|oSJmJQm<+3K`g%JH^j+R>MSnOHh zA>@?Q)gbukKu)F06-k}-()ganT=%K}&%fg>qQU>vUl_ct)xk zggl25eGs@y^;e5rE7sDvM%3cj;{<+pGiWLH$~!%j)CmUI-r|-V2DX*Vd-$shCaNzR z!=q0Ef4>KedvNM=&qYZJL*1ilFFCNhm)w`@0exr0?+^Izy()aEeeevXE{9BxvR>GdpaNQ#Q(U z28V)F_4oo`@N~f2VA{p6AfLzZZD>^~1m|<}oGKbae1>vs0=Fw7STZ z^aIA46^ve2tcN{|Y(V4W&-&*?d%7tb1qBgt^=r^;RwU)dSR>iFqwhZ!15I;n*x_%f zFUNzG>vO6-&aM*2B%#=%yr+#b0uJ_5cY>q6TRfT?iv%eeGMXa_f7`QE^|#1T ziT6Fz-=8;rxmo)%^T)9f15HQtS<^9Z#57ZeQg#5Tbq{E>qhl47(tuT)BFWJ&q)NX} zoe+r&%y!uWW z@iI5_BQ&obvLTT^gRi<7)jiIuT~A~%6UvW>z@_be#1oo}Xz{PSKNF8=XebA>^no8` zRPnh$%3y^tM3CL|*JmqFGY;+oJ}xfAl+}aCoAoQv}=n zFanW6n4TkebhR_R2PN>MjxpI5mGGH4h6o&8VP0Hi{%8tq_}MXmINanf(S>F=sYS#@ zc!?iCNR%>$rpc*6bOjWI!{`2%^_?Idf9j+n?pQDe6M|vR)_iq-ge-3&ScAQ*0>cg$ z)|Jkgng@;EQo zyo?=5@#X7d`9-E8hB`_dzxrG^k`qca3JhviJ>6DiCtO`PT3R$bRXNT`ufh91s>bck z87#gRN~X7+IYhmO zdRl&MqFM`eJ!w2X7}H(A9^F$F?(a7HGvqQ?W){iT$Y5he*wBFR=I~z5vvP5GR!#Sq zgH?Xlt2_*$@cFGKQ@TI6l`vKn#$mZmF;IrVn0&1l`LrINFZfr3#8ZKYXrjJ8m^yg) zH@u!{Y`vmSRdA|1n>T)}nODRy)xQ31UZ3>MbYNP<3U+q+=*M~^4I|%Ph9g5+L3%}_ zj;rFFH2C!AM@3kKxVIigY!5oP*Gx zAbzkrsOawyeCXY12)y_-{nMUmoQ`dak@uRoIEr7Duwty$2Nf#+T_FA1Zi&tc-REVF zv&^JlJE7<1jT61RjLQ3*a`LcdiM@!W72=y*=`{xwb{!WOc{%SW~EQLd86Rhn8ohK z*sz_tDfG-@TM~(8DThgmGY|j9RO*YTslvEsALJAAJ|JZzYh0N=hb9jQ!^ICjsQv1q z_B2Ddx3woGdqCN$)NkZ1{*$ImDcL4aFELe>`vi^)kEEM1wf9v;*TY%3{H(h3u^#$5C!x{-A z%r&v%=t&xkA3v1)rEmCl3d^=>6j>up(@|tK04!CpaVFv4(p2Fz@n*C=Hz<;438j-B z`8CNx@+~SqTtb=l>BlP)h{ZM!;}9NXM&|{IJ%k*a>!xyh6Dj%uzV-66y23jL<_J{p zFAQfYnsBzL53PAcw7rj!POrwXZGB4SlqqvLrR4sj5|m2B9%iosA6gI({ORiE(uoSDx?)8=uH528UlA6ui>5Tm<~|B zGTlM6CKpU8-)h`V#$A<&ZYo!d?NPr7xlqgBA{PBh%KOG%twU9JI^)c{Nmm<%E>nGJ zjVw>y8NRdDb=Lh;UN=e!5TJ>xq>{T1G^gTWYjS3z`N%2falzKQlIBY_ma84tT#D;q zU7}fA#Ys@y^H;~~^-M)YOcl%nBGG1$awajg*_UmH&UB<5OW-eK*+r|m!_i{>5WPJ7 zx5!rTu6`jt&CwSjz*Y&vrJYDVGj(Ywmu?O&w=wtJ!8oL^2ETF3l z0r`1E0e(E$a6P@cBCLJ4x|UVq8`TViBb#p!m;ysm} zoTz!a5-&V&$DgL>DvcC6%FQ~Dl^%rR#q+=Uh3KW+(VwA~-QV=6icV@MPXEyQFCHPK zwtQ>&V4du)I(#qjnr8UUUy=y~lA+&^2Q2+gDb3DgrYoVV)upXOhERzir0&i!uVQL`!qh;+DxJ8YFRFup7bY?`Wmj6 z`gf~UnSA$_qH6| z;C>GLhb;h(^M}x%@E?ipSlZB_swfw9S;|hCrJF75kp{3^2mQMgN01jL<5DVe-++)p zXIYED^)MR>8JV@FhXz3 zKTfj$fHDce_+t6Xqdoh)?AaaIu^jD>9S>bpFi@FL1uJ z3IQ;$wm#MiNr7+f<$EWP4C5T>B6Yw?^XJ8ETVFK~_m)X5y0o3SR|d zydoZzs}!j_4R^|(g6uPdN+9tnf|>zT1;}4a)OXK5am3l7N1U_EI%{S+QF?t~mp(1eFaDXF;lm@sM#c+mEX`Kd1?MlO6u6pQOh)p$M z*tYzzJs2?$?YF-4Ath?zelfV6=Og^k>#mP)K#;9iU8TRhN$`vWZwX}ty#bm zm%tGfewe(|fl6~5jnvZ!1N{9~mDuSUtGVTh5PQ<}XL?UORYAHk6fu%KX7r6g!BL89 z1A}|e7(r$rg+J0V;7o(YWXt;yOtA~vp0pRh(Dg#(UoaFue*8_|d6~~wT!qPRnu^|@xW4a!_v3XmXU5!hK$l`jb^?wzCHTg8AtwS^xyfN)H zdNK#iQd0&@(L)p1Ll6o?s*kDbg=1$D6r5H91t?S(@aE%CMdl~+X`&|Arrw8rklUsT z*mlM4bWOS?FoeSG-I+O~CwXDzKE0hnr@^zliuY5E1DzAoa9%KYo0>M{U}xX|ZTf@2 z^l?@Y4xbdn3^e$aR$C>mcv*yV5_&IlMECh%%s$ixDGoE}^InO|-Dz6$C~!#Pzj{n(#frxR2X5s>t=9%2%Hs)2 z{Y-SQldtryTP0l^b6s}==4wYa!(##!ITe#D__&(uEWOY(9Ucwzqad={?u6HupIMDmA9DiL{d$XYET>9$ zKsDAwHx_Hi0MAyRW)F5T<0#@HMQD6AU8XNEkXEiy#P*Fz;B{jt zx8VS#^hh58|Feg@lP6RSX$LW{8s{YhuVTd2qQseloBJud_y=<@a4Xz=i;(`0rX&nL z`J$^ecOcxi*d?f$+4;yTj7J5H62x#|BT7J3lqpBmtgO0O=DS{84OWR&|3kOv)$Q>$^J zWb}*q(xf6v+G0F6&!)ssm6JG?9plW$I<19v=7*J6cpyhuJp-07hDy)$tamHX76HPq zgln}HM6Y7s<(?bj=-&|D*TCwnHBe)8{m7GRk#~}kP#ExX9P@+0L7^H<1q>|IapQl6 zWDDODUNHg5c1GZybd|D4KzvYdU!E@Qjfwx7PrUr{RT*MR1L&8+=NkNIAo^qB`;MPN zl(Vm@&DJk55N~-}qCJ4`p$Th}k~pftgYwybuDma+r@}SkXBBntOhEaTb<*zu+RMBO~9{|EWnURiMQ;Dv|4d7RD;fn=m2&`$AJ>eRJWqdM7HTmS5 z#w(iG_0C-^80~90ARG${^MA;lM1e9%U@KD91y&XttYjY?5bHkpI&6Dq#er{Sd@x5% z0bMKCgWgL7#jGXh%v4swlhz)0gx2LXm@c_XwLbfI7O_#dPSxcHd|mWHLh{9nF{(}d z=-MwbbZTb#ngL?p2)uMfzg$mo)RelbVu!h{itEyY2 z@1WVUEA_Zu_&?lckw~@HtIF+`!NH-N{F1P}05BAtx`+~U6E+kzc=5uaslaUhNi=rJp{G$0Tc*^Vgt{FiEz&}RJzc};(xIDCG!Kpr)KZVAlt{N zZ{HKwv#QH^H+2eq?4JHUa9-;XsJ>gMIUIJ9lF4x#^l)W4XS8oe&8H4y$ub;sO&jL?IRGZEUB*LeIvlh zC*O-}Lw!DLT(uVR87Cs9tZMybtw7N0=pJG;bi+IZu_t-u62mUVJR#n8EYYq+3`Ys5-~S9rF9%1b@Zt<`J0af z_w=!#PX?Y-WsYac@jLmSHTBGzBQ(?pWERcu{tg?>*xWuDID*r&Wg>KaSlw9 z{UPGSq5OgDp!EL2Pmbq3;()(1S9_#O2qN-p_aO*@@eoUu)Pa%_&)VE`4sDQ0z1Ebk zO%{{qeT`P_BxW1)?KMd8wHdh51XVA%{x1$h!wY-SZ43Sdkb{Xix8F%`v)@vn(jV?4 zoM0#%0wC;NDIAJAWZlJZa*G@bws~j$k9FIG9@pJNC z25BEETXc?LimdB6P4m7w9|yjKfj9uzx)#*06At?6u%)03kf@0(r{L1nMPYN3oP2oj zbxRD`lw6D2%TZS3R3qLjp=a7B1zG;PRnq1H>fMg-KX9w$WVnbU9uqM;elJ}BHa9wm z)j}0Y2@8eSChwE?&JSKh)zcQX5W0rw*Rt7F!9jhB$8hWG4k|7~$llNtK_HQQ4(Zu?nd z^3z+Nf5_gd7;z-VUBlzL`g7~ut$R{=ckuxR05D_*>dY=~d*!Xo<}#Q-lR%c(!s-%y zFjT}~RsNq&)j9!a&DMyqGCzJY==+x1TsKyIJbalnHAL_IVRI>dN)}ZE!aCIX{UHFN z2$Zrxoo{)t^fwCjFn`putq1XLnxB3(pvypp5EFO9a`2EeN@jS-w@*4a9~T%Z3inoU zkP=f|0CK6=Ka@S~2k-`WG^*ffzfcO&H~i0y&gFyt-c|1)c4u#Bh&zKa9L>NuU)Q?i@4oJmo>ojgp+W@5Ia!z31pwSv{qogLs(eeU3c=fTUg3J9Rb&YUJ zJPigFo#$Kok5z*)=Y56CV=T_be6vdJjVKC63%lCAH1Q*T1k$GahIO@%MW$+;8y70Q z(Elu=mUCKMUgE{AK-bTAYbh1bPriKzx;(;ga5&JEKjRJ+k^`1m_|3hEd?1-+qU=op zr<(6QEj0XHK$p9p{oNQVUG{jWwHKSW4HTxH*wc!XM)+fys9iZD1?6y>Oxj75?Y#7% zVTDEK*tc4<$8R@+2jHfYq@>OPqwsF!V2TM%Rpi&1%!4saaarO0=V`}E_(3tTe8)g| zc(WF!u)0wP<-DL%6H%^CqZgXz!0#Xi##|0{gS8f<1+s1NTC_Gqt9}EXAX5CYFV+%p zyNdS7Px5IWO(Ul8n(X!kz^UO%L;CWAE2O<(l);Dy9&(ti9|DOV-yO-TCqK*j2h29) zbtxVO)t3d-fZE8Qla+>LV0{aJxI3hFX5#BD#TJY^w)QvU=7qY-V(c%old3qd$sPUi z$w*ZAx2ovhY#SJ1A?SW5uMuG7LeVdgDa2GLBxLpJKL8dCg}vH-72z5PA^{>k{uwd= zcu9}RsVJjoqWNqdC^MfQl`s(nsL!@W_Vz~jhG0@Tgt=|%TC^&XrhoO{IJP;(658>>6|Cj=BeO^Ma$=V@$;II3bszW*dqg`BcHB+eVVox zQhfG)VaWxb^Tb0!Bp1lR=Us!OFg@BP&phS>$OR@?@)ZTNxgl-;y{1*LTQH_S=eV(L z0njK!+H=*oF$J6-=y#o{D!d|SR?iX4&+vsvzIxFwq^@B_A&saCEg9q`Sr8V+pc4vO zo}FkwNW&m+;o_~??@RH)^<5~T-$365v#?T`IhiKg$(@Usx0Scw0qvNmPBE0I^hAKG-8H+}jGiI~ON5zocxmwBGE4aD@8! zE%_LCw8je}*)nA>U-xC-)KmQteh=X0(2vrCmqFU01V9NAX6ByXL=m$Zwx?KI^8}V1 zE(<1So{2_lr-8|t0{X?@L;>o-LkCJ{$UMPGGda%s`WMb3Vd8lXwc6w=D|;L4lWkQ&t2}7J?RTa?RRMD;OQn=^VBx4oy70 zuvEW$a+nRMQ3BeP27q440)%S3Vo_C{ATB0DLS&0hQ&er9624C~(IadUvku~M1FrUz z&PE-Isc#l{ssaa5m1~M0n#$pJcS&uX=!q%UE!b`p=UOS~^47Q=LdDjJ?Ot$le!<_Q z!p93250pg+L3Z}?R8*`*_($d46wey(lG{DyuGRpCIs?D=%5B8^+45Asj9L$$EllFq)twS}9X^B&8R$^{B z{B+YBdRzQ8r%5sHX#iq!Q`YL-a|y0}7tDga^;Y|rlC6Uy6ALUwJQg(8*ZdT0f3pnf-1=Y6;$&i(LFe7KE7WlaRd`;=G+N2URb5k z()?M1v8s}2Z>4+NPq!|Jd#Xaze_|S9#r7I5uxeaE&}}8U*a2PI@<+s-D^C5UtCqR! zx%^?#F9)#xX|2Wn-@cn?Ra%1o?j`58xAcGdIn)=i)w;DuTI*`W^N4;VI2zUF z>z59HBF?-RD|k1d-PuumqzJJ>r+P@p7kaOFZTLSW+j*g80|s zZF3*pK;rHR>!kCF=t}I|+0+yf`iB_9cy$|!ZSKY+I&qz#W^Oj>yMueY+_q~Wxn!6* zBD`u}6+1jHQu5$SQ4f#ddRbDp2waawG}2XM`rC=nd`L)7C(bc# zM>{`%ebWbpI>3j&!9~S|xl@myp{YktNgc5`q;q(w^5lTfFl-}a`~XCt`~(`bY_Tf! z|F)T+R-Ahd*<-XirjU>iidQq#UQSPYZoYTRLNNJq5O`KbBe4AY1gy=<_VJNET4*{d zMATU^a0J|fr$ zV*L8_rfEP)N=F$~fNfQdwxFBcL)Z;fBf01~f7)w;xC9SbfJX1HJTqayi!^649a`e$ zNW@`Re4iO=+2Jr>>#Upc21}yJZhqMiw8l0P@TM#lb ztdZt))M^Z)Ds@3;-2kaTrbWA3NU=LzRpi<|Lu*K%(s&s-oUnZ!yiC?>N4WH$rV@X4 z(uMxjIbYjPQqgD_h^MLw{3g+f$>t|f<8Gg^g#VCpeEIE>lL zwAYi6j{u1_27ajJ%3>N^a9>h?Z-k z_|FJ;VCI;Uh13ulyMgs^>L8uMnIcl|aOv?7C~y>*S(Z#2k+)w??DuU^1NAoG`ME~n z0tS^VcCXaW3fU;h!i(Xrl#2$0sH#w%_nA9DL9{(9jX>iZbWyHRlAe>AqqSwxw~bkh zDZcA>79Y335$qcY`!I;qq!uyFxY6F5abt?y8rsN&e?Q7KjN{9}Rp}6n7yawE5#B7T zQr34lZ44;05W9gI0sAeyHca}-37T`}aTSr&X-euhQPId=+>WP@gGy5ETIoGobPXKr zHV{8Du)xV%8Kj`63J9uYn5aCbR_N#Wqx_SEU08U|;8W1>Oca)l)gV;nSZX{E6}`*# zi@HA=xK}4W7mC!1D8hw7t%bV<&QVq8pxJxYQIZN$_%EZQEdpE=wnlzln^RL$&-AaT0H;5i*zuN|+Z$na|zjUW>a7kHa9T!Bk zpqVKVPUU1p<9spYqVNIzP-m<+D8Tnqxz&jA>%X^Qp0!F7ulM=INw2{;&!&T(BvgG- z=L^wZU7eNK+dDb!yL0i!Jf!MnTNSqfl5({&1j7gyp{Q^41#>dVsbSqg#19D_e(3Z1 zY82lBb?|W{Wf8^C|CmGlC(a-93I#L$GC~9em^0!+G}cFrn0>fX7lb%~8<%<|zE*)s zOYrHaizeZZ$YlHQ^r|$-mZ_ji_c+(n#@KA6x3B2sIb^dta&AbmVPS*s4Bm4smsowK`*U)g~WiqvZS!}9%`SwRGc+()M%NrcRIL1Muqcb zpsjoT@m{P`uB49q=e%nHU3Ic8s7(t8?UX=!Q-+ZSg(}xGnC5L`idY5ZZz`NlasuxT zhW}}UrU9k`8s=P)onHMVf#OA*b=Ahdd$_qLosI~!gautlRjp?2*MmXL z=2cd57c<5BV))lE6yLOljg19dYx1JMbqOHW@J>2tMeZWV_G&?9II4YvF08#@4L=pud zDncj;0Rn^~i6KCMkmNfzBF>{e&-&K-{`l5<*UO)JbMHC(?7n|{A5ulltK_vg!EjVm z?Bn@$q3VjNtNZbN;~P|r`o}*N&Uq%^V9^Q7px{j;-a)hC(g8Gg-mR4*8z^M;6;_yY zbaVIV#(74r!|>ezyNq5_({8%qZfHuM_oYmgzwXjE5!|mN>N2y4`XF~%AdV!KR}_J7 z$KQK*`gMxdK60#hHC)Q|>iA9JCb(E}W#m-^edf#*% z+^s4(bTdX3a>DDPVxhw5kS~9jt?{8xJIcwd_`a`mNcU;>>dr&?y@Jy-_CoqzEo=)R z&%fN*6VX0~Uh{CT3sS0U^MH5yO}oTCH~QMw8SgR{0U1y+NF6#kd6zhT$BY9|!T}*P ziUU+*BD1RByPhOpwoW}Ea|git_Bq#-%Q%H{jN*Xc!_L=!4?Nj;1CZk3u7^;g1b`Nb zHDvc`VcTiPUvs@p>M}JHp&}29c-X)^HOA(b22jZfljj$mLxnuqC#3=B2Q=6iky`CD z+#f^_0`=NRo0|%r#^hM5SmOy5eMn?LP%U$gA0yt&oiySGaR5l*TIT^yW2=9V(MZni zFlB?lqfOhhqymcmo)s;W72?&kQbRB^Q5B%Lkj1^z6lODs_M&kO$^%&caAwb*H&J6~A0+53&Iw&*h z0}lwQaw{l)SGC1CSoqAylAb_K7NGPY|7c~lqj6xLav=+hs@ZAJY2LN?Xcp@wW1 zE+9LCbYDETJomv|)bUvmPp@>BfRGS0y`(D)*hui6A)j1#9MB)p=an7e*7DBFfRX1?Gzv*$Y*Damjj$rjpOe#iFEyTSkpsQqS&duka{64KoN2|1o>;0kHNftb+WM+21qwi-jI1dSz%HP$MdbGVK3pN^+^{uhvbI9$lB&_(;~&y^LgH478MnBd zanjVcQ>@|>d10BlK?}W*@LEGwO1D;Eihim>z;wYBge@E-er7BW;k7r zu~*ZyrsQn=tzxH9qf()p5(Wje$7ItN>BifdRK8&>-e(oN>S5!1+Gfl5MUe@?xYJ=C zpWPdfDgEZ$jQ%Fir+ntN3_bufFlrAS9%rbaKel2wzRs&ngY@^{W_dOKaJu;c&Ru(x zPa8B0@5ZUx?uzuJFY*nwd+D&^<$GFozy3yzz5NPzSFy;vtIr%tBcw1bd$aEpN|ozY zbxmW)V}iIvOf-tKiUS}8WcjK=FXPoQlo&y03M8fLjEjt_pi|9mBIx#UZ~$AhhgCkq zzkdiB8NP~(8q`=sVFA8un_>2U87iF<}HSd#ncurRjrb>sz8z0Ypq1Try!xVWW~RGNA6 z7IDV`wPQsh)qd@3!OXJI5kJ9Rm(MX)DQ;q}+ih-FT^ua~E!-LO1`MkH*WNvtfZNaS z_n|_@3M+*Asks4`(k90mav2D6d~$MY%8ODvny8hVRhI{js|M*?&f@MO27qT$FjjBS=g_wkDD|vHVTe23keZ?<=-jl0Mb2@qF{1*t-&}`EptOkx z^jvHp?n#sVo_h#n@EX=_h+D2KP=wz3uq3#$Wy?SkrYn)jJgIDi3Ub(@ z%z!JH4HOQXYb_BxvTeG6bT*9u0LfvHczUbzoi&_iZwv7PSxLDUhXr%9L4@?KuQ6;Y z6n`w-x@oa$!8zoSL{qhX<9@Fwl@9ANq#Fo!ML@m9$^=h^IaL;^7{%e69uOgBst1g%)uQ8ENJW%1Y2IYyd!M%IzA8xbRGNCwMNDTfA$+b1e*52n zp0s}!)-nl~5%h0Ul%@!ziPihxH~3WDHxBXVS3-`J*cB;u5U1Gv0-Gx;efZH2q!v|@ z!Q+(p3Yfu{ArgG90Bi%L_;31GVOfJa7u>4L%MO5 z;P=ip3^k#3ewFdS{QvzvS>S1bO}P&ebV&vz%0k(%RQN#?7DAdh&h!5egrS!RvE_a+ zD8KW$ZS~R*C_Av@qAyFLoIFk)#a3MW`Y>YY_Y_d~lg3uvDatlp5(+4}Nv`OEjENT) zUe6u>?WeEXaQL2!eXeK#`9w+1`))QG-zH|5*N~m2FhWVNX3d6QzwYPI^5X|VhtV%zt!VSZYf(k zo*3V^WC7$eeeQg|^}Uncb=}3x2a`O>%04|IzQ3o2{3@3r;qnum9ljo_&+k9@gQ6~%~NF%d+0d2pUK|ifu@KGcXBj$bO$o=0t0_QE=ecbrfSWZickUAkLds;)j zM)}uIez3~TPfMD5fU|U)KJ_ml`rcPMZ+Y?)v=zmr@fvEKxVO2RR1EqBooE`FQQUn; z<|`?%->dMh>lqr$@5-q?bl>mp{R!-~s955ty?`$7C-4mEoA*^Vzo!DCxi9V- z@W64KmJr^P!{#bB2vUlw#=7aNbnU5CxFCIUoH-&&}y>oZY|PCs5%7Sj%>BkcAU zMojgux}Zu7x7thx5 zR!(^=mh(rc&@uGyuWKe$elLN9YkusPKsCXYl{jLFzT!LoR%O}Bkr$>rf0~oO^EDuI z_f4n=+c2Yr#?~*GuOF{VCHQh{e`SR}gv~Kb6=VNsq>pMZ47441xv#n;cTM5 zv-<6;kPUy|UIW|En@ZI8N~U{F+k;Y>74@vZxCFK0D|5Caeb3m(UITTAp@TuT>iP!9}F3oGmTl_PgQ_rtpnJcxhLNKKx_Y>`b0ai7%~BW7F9sDqBt9^ijBl`MjN6(|@!Qw_{RN)o#U_xBv9Pw_0LXULJ$-jv=Aq$i~qz{vg&Zv7a%s|9- z7vBy$AMuUS{e~Vy0sFd~(i)H{=~mJU9b2sS{UC{NHl?ym4!}5URJV!;);tmWfTBt` z{OLT{D!AR;m-b5Gq5tuvZ0@fe5YN<~@g3DrweeB}lo?pF6_zG-IgdYeWdR|FdJ>J{ zJ!_0%=li7c`yUK)yk>C`H1~n3eoNJSf|JW{QUP;NAf1_AN8n9bCY^xhfDm!jO#tT< zet$m9-b@-t)a*L1e+uBZpi1zgaTC`h)6JZUGu%|-*3{OJbr`=fTNT(_sed*kBj7b_vkz+x4rK+a!mrkz&{o5f?-M{ z^I)5#rXft#p#StOR*fz9fQjKvl3Y7T0KueyE2wmYu$Bkiv8}iSncUw#%hWO9B~R^k zH4q)72EOZrvTLH=1+%@IDSnNI>>ADRwlm-Y9Z26i3efnxrFNIet!1qZE<wD9gm}AWS(9wdbpFMqllf^8cgac)CX*{;KQ-LdURXdRgA3adFE8C7 zM@}1eO{z^W=Inf%L>h>@pRoo%sdYo;#?(}m(h0rh@ikjA*RWo*m6n$x!Gxrn)quPF zUsRJ@Nxv(halM9R?eAm3lKCKX-AgVKtys zsRFqw!;XYl(?u^ee)Zr0BfN@}dQ$oh-PXz8rX(lF@~2*mhxTjQytIOL0?yKwfz&@3 z7RYIHWSHr9fn*l6^5=~UI+UGbmXph9D!Mbume-GMgPngWeZQ@u0eLt&U9_;p7zS%; zKtSW5z!8k7{me_il`lfP1uKpKi#hAGu!zTHfcvhDCWOC1pLq}dy<;SzVVrLlFs$l( z=t)V*Ejt9*hjf=JK&iv*VbY%tE$ApgR`;J1lm#yC3KRsQ1Na{{=)w@6U-M@~tc^uQ zTdDnGSkFCf&YSHQW>wt3rh(8pC5FbhhCPJq$_|sC44o(muxClEKCkv}OC|!G6HF;#Bx_^2q zvwi&9u#&eyQb&}tC-}A2H@`j%er>SO3*(K1z2Be*OVfdN^puN0cI-?9pYc~|lgc2p z;^agrmt+B2n@#o>bm$CqZVS(^5N)v_Zvc9mI=oQ&+hGJU%e?ia4!E*m?px;DmM0KVCY#9aOh9T2d`!J0~!wQ9{KkSG!-Jb`SD8Z_NzaG@a z7%7WgTF?P;a>FIqHWw+0-&T`{ge#LqIG%y#ZW5{|0)$jLUt|RaTMC7<3p#{F9kP9> zTV>a{t`cA8+Ig^Q=%cEpt;#)adwmZ*ZeOVFL<(A*Yg#@HECPIvVle1zUtjb*me6p? zH_9rv7xtOgu7R(jqU|vmPPa+LcSiclqr{bn39~IGWG{SY-|E6ag=UXJtB5F z=Z!MvOctn0j7J;tj=$Wn1$I6l&jw5|lS%^t0fNzut%1ipR+op1*H<7P+M!`SZPF7g zl~K#gHFUd@7g)tRCopN*RK5k6W7+Sv>z#M+)9ZW_6gOfmFsg5VhAy zsa@g=sO|rwpN}9SRp*^YKpI2?MbLejqQX*$EyQ@2hx1lDq47gg~9~kaUUQ zUf*Lb5ifs7j+|#Ta{}bHhZKV6&7{u@PlEBJ8=(f3g&;NgP#Mx(Pn12fDk=GGoKE*B zHGzbF{5M$DXe%TwAEEoxW~uQLEXEC5Pm15S>nRB81Mipn@9)k_yn>Er5}krwSMq4GM-FN$L0!*!iY>=yckko6`{0 z$8N54096&`T8IOWwH(YOaWJO?A!RXD8MPWn zDR|}t=GJppiHiaMz$mBjz_-nZ?)IGJZBW>{CKbuMfG36%*5Eromfr-zCoknD=?!n6 zg>UX?3*~|S@;UxrNi73)Jk&^K2;ANRJHG&A9#4Y%(GWm)&+3w}|9Y|z@27oM%0Kuv zWH@1CuK#Thkd`}d@n4B32iE;I>IVc{3lU6e1f~i9?TCS$gKg9L|7p{2`T$BIzGvJ$ z$J?V=QGNO3bos|lu58r{sj`72q-5Ekngx%fv4ry5XI-}``Ii6u1imqwQNw6 zEfnl&Yn9H6xsOR&ala7mN?JO;h*(KlZQ2%{QS}Y8g6ZS+Ufwa>B^fiHGV5xb+-p-* z>{2AJuj+BBKS0;&XZw1Syf4%|zwo$R{@J&AFFtF`h3q=SL%vtnR!A9uQ+pH8XkSzs z&g;KL^&(|VKx))VZgkjoh-GGk4-ntaFgB$9ILXvTKES+2HyC9i6{{%yl55$6ca^PlBP7Wf`?RvYjd zHelWC>%Nkz%L7W;-Y_)2uN1Lyzsa#LnkN}!m>G_fQG1XA$>T}Fjdeif>IA?2CH;84 zk${A1s@Q&ret|HI&+W`6l-RNY1qK%ERpu_K9^RzqYa;)>{JWmSu(tv89j13hMPLA_ zTt~+!b&h-7QRAf=B)2?fjBFJN|B75} znjQNQzS?5qy(EW+*|cxkyy%O7Y&`5J?}--89NoA!u;LG7na|+b7A-ZM(F2&Qo+)+e za6J2s^m zGK#(puRo%+eEkG9G$@ND>5mgUmN$qTa+0kNxX}`T7g6ZMCYBiOIBHxjP`7`96O4S( z{?UIdWcImd<+oRp6{BlT4gPa#oY{Bo#D{pCi)gZP;lLms-bc)_mf!Y-OU@wj3+sYE zFs9n88k{`YLQ5*EqtTm{tk-BbY~jt;KY!Ak)x}?x)LnaWBwgqcdih zjY|z%6U{VzQ^UO@PMnH;kYh|ss4Kja&OYX~sey6Scmk*MMb1R26K~O#M!6l1q@Y_l z-j6WY==fp&Q?BBXiXdB&@q5!3kGYB%a|)bHTRU-f_0j9tsT(XMIo3GYgi6g6g@Hn+ zwDkgBg5QM<|B(!DYf7QLp>??8^h}s4l@&o64#|ng87YnaqAL(*>n?w~zo4zGnoR!( ziEjrbUhUK+cISpmg6^IuG3|@YFEhO0cBAO*yaIbUCLN60tE!af4eqM?$R>r0&wbj} z)DwF#=}ETtjuA;1p17hhENjTZDimMa!}(k7=q%-5II@qYG%nOr(ymLjk}s)or18ah zB%Qusgjd9I-<(oOXJ%4JS&s1s=OyNGA~D*)Yk!P9YJMZ=XuWi<<9C`Q*p{U5y9?3m zv@-x=w2nV6VqP_(*~FvS6hhDey2R;?`L05gyfAkO1#<^OL>&Ec0#m6IiTZIx=x+Ly z`1*sI(b5#PoTsKXoY8rFy-^JT zL4i_ZHfhehR_(OW)~;NPTIO3^@h13)Z*k4M;l+ap8(zQ!+bv*trBfp*9-S5nEdL?Ph{vzd>Z;SJvO%Fg~;9OG!I6Q z)Vg^@Ent96yK~E1{p>3JtFyR~Rmk#R|6F*jnUdC;cD&rzR+4V@U-}v%3PZfw)j~M&A27+{wQYNtSOeWuwvp_2AwIDM)(eVg1=dAgHu%o{iI!T z?uf*j5qz*?D)21u$;-A^3{7=a2fO9x5kSxwLVu>#?8n?k!*9Z5)uYFHhFd&TW8w$> zs#D4q&bxzo9?GP#*}S~LUHSWzJ>GccqbgW`=ab(DjGP=|o*fWkPx^p~`zjtMp9!8* zl6Cq!i*tw>eqPJc>s5D#q}ruwDOm>H%e|#`1w~Tpo^g3-=50+|<>u7Y6`HU7OGU6M z8^+^CM>}xik9HvMsA+n%TirO}axO$s++{RgvY1&dKCc{vG9lTtY`>i4Xn< zlGXZ?M(LOV?!L08>0W%t@tNmTV=u3fG~WW({-5C1sKo(nsx{^0CzEZX$}K6ThKzN{ zv$)*H!~1L*eFQ4k%B#kS$$dDfu4~`!uhb$U6}MFV`9%ZpQYT8P$wKyoCq}{4h%~ZU zIicd%g=b`e;8>e3hBY7Nj^GkYU<#O+k z=Nc^kEBPbVF-Y~y^qrkmlBI0Q`|V{dY*fEl z$eY>=tJ`4r=nv9H%JmG*T8jp=I0_eH;n;rRIa5P3`-f+Ue}wht%#WpBenT+~kGd!`ElC{Y!`4BO^6lCZp>=MlOY;`_eGc`{s#<2Cw7jLr* zkyqFh`Sfa(xL@5vZm^#?7JIwWuF2|-dVM!SFlRsh`Jx`MNw{wn#afd$m`)L>AAYS>{l8!>D=KiuV0)vhp(5e zeZNZHz?~Ltr6>*3G`rDd%ASy%2JEA(S4CXtJ!kj8`~A>tOcLO5ko zHNXXR?E#q{>_s!(-9K?=YtChL$7Q7w#-B+o+us-7wZMpmLwNmTDF4b1cX!WouaHZ? zoWRY9wmh7o)yUu;+B3I?0*Z#Q4o^Kir?7Oahu6$Z7!!nCt3aY~oc1-yF9b}Sl8?e- z!b^b7{qgm@0Ur#!t8J!XtGvxZAquNmB}yxe9jH`<0BJILA1)=Ut;V z`CHvtXJ|Al#C@SID0ga8ZeZ>cGwN{Jo?(0V@O5Uw15DjM+QMlCgFxfr5kCJh+=@-) zt-{EhX@7MuJT^zIW?DUSRTj#+V(CpH`qb3qOOqyD&R++!d`ECDXpBFhrRweYhFRww z`3UpLq&9dDvzqXLU5jkwvL{uog=Xok9lGunt2K_GLY&8(yk9dGD+JervX2>?d^ji3(SsJp3l|tSHJT=eO^~-!BB|Y`wg8Kk*Xy} z)weDn+c>qRwD6Ij2DDZWek8$lPfiUsXp72PR0ry3MJ!-^0nr| zCR^<*)bW7#)n&-?*ISz14t6Yob%-6gN>LzX+|%$tgkC1-e|z23wKvDWUR#{tt(i4y z9}p%U!Mi-EJihKrgdsT2S7v9GZeS!N9qFMzv)4-WEvWmGeabRwd^&W*pMQ`Rdoj#_ z|2Td-EjEyA7}Ux9+fI?gEs#X`oh#CU%7D>in94q%mTKGe+2nV>u`If3j?Z1*_xl}GxFZD;sM zdSRXy|5&o&0nzvqBOSG}UpF$0Xr~Ez!@*8$criRG`P@UNCaN33_aZal{&?)ei)!Ne+0ZkO&Fo9PxDMRjK9QPVO=czMKCyg^Rxs#q`P;9?cChv~3+vHQzvZOF z(kVcxRJCBWDVfwKSk@e#+o#Xk26`k$VPeqbzvHk~jC1OzIjCsvb$BzW#bu;b&v9gMuD2iaMieu+d<`I`qJaWWflv=DtiuI{l4bT{U@ZuY?WC zL@1by8f72e5UqKOZnD3uWiu_s(HP_tq^YeCykhgm6(wLO;y<(}&FF!2K5@CyCu4!B z!GQn^vwkz|E9yHFxqGEo0us>O$SkG(<3U0qU`RZ>J{g5>Kph$pVrFw=NRZXr+_0m$ zf5Nrn`Z2lkSVmP)Ry8?Y{$k!*%_QO7GUcsof^*rS!g|KfO%#uh(bS#;D}n!!WH4N` zDK6E6kXN(WXXA8Z$dg}Y6B5Z4eyxO&#!t42hPAXVn`SpTeNE6D9nEs@?9f0TxSfh28^615 z4nwEFHRU?>%W+{bxrZ?H)kGw6OY2skiFx|B_+3K_idpJGZ`q+mSYtuRuIV6*xeLIn z-!IHV8%5#Kp4t-^G_tloCMC5z`glv4o`({^>b7~V!)=^XjP&eDc3zr=Kfm`7$Y)sE zn^Yxu{F2h6y%@bora?a|fq3y$0@3$?d27%o``R?5JKwnpfWaeTYg4ps2v3z~`MdGm z37wpLxZOQeMkeR4-A;|Go>=H)?lrUxG*{AVJp=d~y@|2RfquxXYx*!vzhsqja&*9! z*_>WT%CcaR|C^L@g~*x-wpAFlG)fK(uWcGYJBNZD3r?q-XlWKGY#yVg&p)c`=zz88 z^d$@_535*4t!Z+##?e&4Fg*c7o!V!Q-b?$(tzx}^nr+ke)s7og=GaAZOYiZNBVq@e zf38>BHwf3_@2XFZ-j0?Zu0`sfbTwii4C|w*B7QdYj(og+t1{EFDP=ERw;DrUt6l?E8?k&BL5_%FG!Bh>8Z=!*URmF<0W3ygL%R{jA?^THT)3H$7t z8Pxy^;u*i&{}rL+;MjTg-?{piM8Vu@R;lFl;DRI~y`jL%=5IXQbj&`WGO71G+xvhz zK8T)~J^s@hpybjiYmYbibbgG8&0CYzo%6Jfw0Kv}(Uc}M4KiJz4hPEA8x!?AvpJw3 zo0GJLt?A+6=tE_^_T6rI7Ogn^Sj(=W$CXz5-qks5JQFk~7mPeyIJHn%oCCS~?1aa*j{+BDu}p1by-q#OCz_vg)M)rH2x?@do3q%ws3HFXB$3gtJCerobt-nN8=uXEsfZ+ zR7EYvb)=fhe(4r?B1UY~H6$#}?7@cYKa{)Y(piy8*Y`V6AA z!w9~03+^dJ?0|8Ud@28V8NX1Q z?dHiuXC;jVyO>Kl{rFQDX0C6HXz8HfL)p?lgulM;&Pa{0krf(ReAHDoS?fU5`KQlZ zOkaRc0!=at;@h>$j$)Sc)`iQ;8w8%{Sl_}p_MEmtkeqx@l)+~xuc-_wuio{=RKjju zt9>@~&lD(!=Gl#v6{p?x=+7dKc3!{yaTV#;598FwYVeMw7U(34sEu`)u$U%F?x1xd zD7Gz4+G*-syXdn%$zE{c!16}?dvr+|dTKc^WStH^&*ZPmCY@7lG#@sIPYD4xs%X>C ze)`l^P7EjT5o-%aezKXb6(w=x= zkrI7xBR)#O`6z96%F-w>zM#yfS`fy(35rJ}xxzcdUV>yFHqt-;B@YJ)4 zJ!{M?c*5(V6egU_!WT0pzmPvu+Jtm*o#rX(9T2+A{{I$OJk4rO&?CcKj2oK zEYoZr1oLc^yk;*)BAv2MfIcv;tm3hsCa0WZBkEc^nK(pK|q~#XrG$lIMar- z{grXtlG*&DF`HJ{7VFfvix_Er&QnR|nJHWA_=tP5C>Yn&pGpsQH}NmIR88(lHdTou zViYuzjFB}??v}^cre+47{n1psM}M^bc?-+5CkKn?O?Wk(Y2XbNxHkvNl1GCR!#7Ff z5l?5G!Q@f%5ew9xrTlVY^vjRbn(3_Nk5IC;Q!X_cW07)Pb&#qF%LWR!p3kCJ#*+D; zF3i7T9e-B$jmZmPv_G3Bn;v9#jmqR1-5EA4W!L>lGL%tEqQ$fX6_d-ttRrZL^-$Nt zI9E(+YgzIJ?O#f5_Az7UoIUkDe|p2XOc=hyZHf&ObpGz}E@>MWV2!^_9da@q>I`}s z=5Z}HjM15OcDn3|*|Axk>~qw2`V}`Y6+Cz*B6bryvvfneP5{Ao0QtUerqoOR(MY1e z_!ufgQ{bR8Shfy5M7;mP@n4&5=QrP7UZz~WhgqW|-rxV%b|+c2j){%8F%Ie>O0`2k zXxpa4V{@rou7r+G!7XLK_Vw*er?_`f-v)#|sZZ%W9@bj?w#e$Q$f9exG{NaMTqq+& z3tfYR_PuCLTl{T@`6pNm)lBxNQwzMFNh!nYJ6UbuUhEhbzLFoEsQ3?MSD(kQ2*Ob+ zCo);JFT6%B2J}Ch3{xs@T2NJK_qXEa^FMrRXt)J$Iq~# z=<>|a5=L1i&y6sv^)|)W7XM1{ntzP8JQrA)$X5HsY`m|t3Omg==XlPVBZmBq!GydS z<1+f?eCiaxf)a|$VOB2Zi9)tbqc@J%P1I69xQ0C~F+Ej7_3>$*(zJY7Iv#ldgT1su z@3X4~$!Eue;-599LUj3L=%E>Ik?W&LL0@g~P-C^K>}!iq#wdzR)AC#1iwupWQ|V)9 zo2RWC2&G}I>^v1Ax?!{+ENG)!MaFc&eqY}3knXjB=cD{5ly#LY6?or&kcBPP6%mxs zYlZ)uR6K|${-NzKRg!?SA@fV9EWCvv((Lqm>N^33ot#RPX00JlH2H>K-m@|vdhol^ zniu?x%Z+rl(K~X1|DxRCpE}>d?HmtfkIMYL@qD0hq~+3e_1wJa)!TXc0vFsXUHC-a zPqPl_=?w+JgpjyaLHRm!ie|@c_Q2qs*J?PsTjLiS*;SSj$Nm|8Y@<(rptLze z{A^}ske%AYHkz0|T*^6^W9aX+;lA4n#^IKPv_a!@5J*Fsc&=~pTi&*gbG`Ud?mYin z&M;IC;K;`!4D(ACU=AOU*rhLGEa@=qy!=O(`j-UOj*xe0C5XnGB$tR-ALE`KuFcHa zNrwLs#C`pMIh#3)4mz>y5IyWu4XChL7%gJOS!|S07Y1& zP3a%%e_9Any!)kkG6$cyZd79VGEgv~22u}Y;POTQb*iS!cl>=e4{)m$kF}%bJ~U!G z4;4divZ8Mf++;~3Ed5ePn1i-#>w${)?_+Q01+Nq2Y9s4< zBuq(x1qSo8k=1M@l>Ud(?|Z3~;q{SfHm?vX93zKzzNKd`N}tQk&A~r<0id8K?sq3c z+q;&rPdbnM>LUf(0W?HHX?mfb@HHTa|}LZvcwLeMhl_r-@+@VD4V$9bMB8 zL50|n1F=<)zeFeX##0~yHqwdju5|RpP;A4a2L(l7i?An%FL}bbwLG69+}jc^F#y)0 zcGnB#lN-f?{)z6VhKGMj2FrlTNBZ@9+z9aF!pepJV zDbP)9Sg6fiL6G_GkiX!UWYkfZeV9Cc+lPc!# zH&+3)>a;1BMBFIiVt=r}>RF!NTmX=gw`{xvlK@U~nts`n?;-H>oPU5;a0#g?9wdY^Yjv+6yH#$$wK6rECYgi$<#A{Kq(&Lt)m_;UXjX3;akrLzzsH=H zPN}TN509Ev^dj#FHAYXoI6Q}?`4(-a;&JJ0?J`@hs$7!++C+QknOG(bBtNEkPO=JU z<_Qk9U&gq;=YW4$RJnFvSpU$cb5rW)uvx627RDkyQ8_XmJ3UD=k3vsd*ibq4P9x5O zDZY%FLkH942kaCvtNL8aN8@}UgkIA&WYe;4kOpxDq|6_#qNRvPHn^OU#map+V{CpovZ@NIrp~e;oYU-!W+->Cz zG}SXj{E7b;Yf9}=hy>!1Br|cX`lW~xGqt5a-slvkN*R+~A9hCW+T)1(PLW$}c~j^J z_h#w|_1t-Qp<^SZtaFbZ#_$cDp`&QQyhN?Fz;q;|2t4)p<}8w6v+fT#Sc+Q&BKFo= zZtYQS24-_|v4qXzvJ`x5Lo1ABlNC7O#gfjZZbA>+I=m$heu9Q<#VCJNZ=_7i#ivta zmA6^LS6Aq<6S;aCJtO?nY;}(}=H9f>tbTDt)Vlx0Tobf6o*1=_k&jnbc68C_ALzp- zHxu_ClZ2UkyrcGung=echhNw^p5K4qCOgRDSj#DSV~$twX1U-`xt=)ntH?V*6+Lkpu}_dh4hE*MYkSSjM6iJ2hC1o}fmxFG>^n36+D_i*s$# zt-Q_8v%u8GxE2?=R*&h%VO{B&X*I62T^9rw?(!rdYc0^p4^x{R!)3%F-*T4@T@=z>Q28O%Tye z^6&JZwra5U8EYkl*z0T!;|w{;Wya$|*1U{hcVFdb2JN9dE5V-KLJ#8R|2*`Ju zz=CkEcvG1}X-&!$b&sqHQ@WUa4}i1su2LPaGd*7ZLZmun`h6p%U%6$U7Ht#{2k<_@ zxRWs^H#$DsOq<88k9Vrm*lH7y)x)`BO?g(<42drmMA8EIpe<;D3PKQIWN@zKD)C|3>| z+VYZidYjKgHMxX;a#Xam#*t}M9*y+1D~q!{%HM_tSk1>Axxo$>hssdI~)~CkXYGyu|PaG7yV`CKKJ~s*cSbFwvh)jO};H7_6 zUOn3wOi~UiS*KyK9~7l>e4Q$}=@-aEVq-&)*W%&av->pD_D79Bt9c9pS-I$zu#eRQ z=RVzQ^IC=|$7GMQSnpjc9&jH&F+Mhe1?aFCpWpu1el>LuD$Td?JzeTwm0ORukyU%5 z{##b()treOA73jyeW86M0C^g>vSSfQk#^BV`|8@RvK<|Ms zrr2-yGtiS^l40m>|7?AvT+@Zxvg(=$B4b42*mT{^`1TSw$~TI5mAj=aw7gPtM-o!m zpTp0~VPZJct>&wn*@wn`bJeC}*bd{!N^xpnZq!T+NI7c{*&l_6cjY}3D@<{<_t|l7 zO$}0U-C^56n_7uYdi{bu0N|a7sBW3n0I;msS%)}II87W@b)C{Y8B$D9R*s?CZn7u> zaJL%9z;C)I9aPBcWmY3$c_4jMK}7Z;SwiCp-|SBFT$3|_Z>sC^*vLU2M>A~!r$q_# zw!ADj#7C*&F7a@Gs+BcHJ4-nE0M&t(H%MjWfvCVCdUQ%s!Ie}&Jt6B(lpi2KIP$J5 z3yWr>4j967)(s>a)J?u4=U&(xX!vSO`??c%V}gRE_DGzXZmU6`PusdiN*#BqOSc^^ z`<}%dSGZrA`!10EVv=1NuVq3op&?i|TA5r<2J$3+_)>|ZvrV~Ma&_yC&(po2KlS|_+t&Z;j9X9 z4*qXjqaT4!zP<4!6tVw;9@uz7_ecN{5A~}1__-E#E`h8lC+|`8>y+aSdv5iIyDYl<)wWGr{cp$^|%W_4-Zx(g3nCXT;37rU2zU{6D8jJZc$nLbRQL7 zBrek2Cx<=|OewcbiPvZN>V=cFG3w>F(KNKhF>s`}Mh{dmXIj|Y%ITrvPDRj(fdO@O zZYQzH1ngCBHj4WRhC1~*kp8)4BPRpHRk#acv}|5z)>-@bdgEgdFkIE+q<)WA6^+YH z6gJ@{FN7CB>(g3irL2*E^uVh!=Ni4{P6~jd!I8vDk3`PE{@l)JiJ^~V)DyUwjs(~OYc=+8}Ml=hkO!E z>4fzl6EMU;O9tXer>hQu<*2xa@-vy`!gn^|6PzUGH2omd9`yx34K8^5LN(MlXuD(F zmu1KqICthC**w%pn-KRq9c5l7Pw{LQnF&aRP>*QWAlIi>7q0 z30{K+%HTgEVtCBSvGHMdB9_=jw-|f&3y`^2vkQk+9hY_@$*5f@eAc<#<1>GQ&yn-? za_j691b^6PD!+;)ZVd=d-3Qup?d0@0k`67UPgjUWSbflR=kwElA%;=o*%qS@iK+1_ z9_2B}W`ouNZNubfWuF*k$7tgt9z9{@_y(~!t8>ud_;KfAz=9hueaC`TXJ2-K8%(Qx z6Baj4+t&(G7=Knu*eH#+3jjmFU+{{wdH|NhVaAvE~V!W1*$OLCV$ zd9JacUq7EOZ0U=+qjxZFo$RMc+=2jBRb#A)G?Up=_yS70bl+J#`}Dt9tDr=9xct}@ z&t>M#r^uCiOa`KG6UbrJ*#`+*=eW5cH8i9knzo)9JhdhgYDM0zQ#mfIE!$P@{;BQ< z%V>jorD{=k2Jn(`rkv02n~#X%dYn*;8>O0ykqAIKaDHy`>}L?m=ftnwGsmU;Ds6+L z8!mpjTmcNp7|WFiCFMe(pX2o9XMbS-*KGO_MhGMcduzG3F`hA|dMf?bSH3>T!Z?es zf>G+9pRGDPE70@KqY0(q;yOr)h46=QrE2G5q>ZQRKtCMxSM_2xRWR>-0fAv5Z6d8( z9;qd6i)V`XByrL_#XUE*&!q7vI9>tq0@*Et2a=vjkS78C5w?AyRaf#6E?rqPh?}Nz z!>1E);~Z}Z2Y>B?Y=qYFbCOB8Bw^*#)4mD)C5hEsNjHWgzty6xGkl6@<2(~*2XwOZ zk8rRL!Lq@L7eZCSr@jQ;$e+tYeuA|u<1`+rz=A!L#q^LQQ15Oqq<5r$3+)sP!ns2D zW~gqRUpxFW1~TMpIUoMab#;5?iWc?6UI2S&d@|{c1xgU~?UiIy8v;MfSv32Gs=Xct z#fr%JRfeSTQV3ywdj!&=qR48|uuLwPQ!@8={#{+B8fmK8Th1GtEjDbt*_+F`^hw&# z`Q==phtIz=fErh`z>J8QH?SzMZkmf^)Vq_J?MuWCAN|6T(4(8LLfJ%R`^o-d3ms0~ z$t!?^??BdbX+$gu6Cjjz)}K8p=xJC}tCyBX4#?V`>6V4hpe@xQ`^f2cq-Xm|OqM(A z1ikx07wGBz?x1B!Ibz{ErlclU9=-dff468{N7C;E8b}ym%D~*;d52J_AFvNr15w{n zn_0zWWKIcRd&MH~ynFrtSv%wr11 zNJ1#@CuP$m|5_u=iVx<3SV@Tj<+Mybf)N3Yxs%@E^apv$XXv0IeU2%huO+{MTDNh6 z*U`+Y+pU1_6<%rzZ0!I2`@aZ0Uh>dU4Y4Te)ZT zm^wBv?|7^{Dp_C3LooWga&VtxlJ`1Hqz7DG2t%`bEEU!})m!xKmnrdIvoY31eM8APN@xPy4< z@b6Z56-sWl_Zt)0xwWqm3CBl=7&W85!Wp*fluKxi#AV_to*7sf|5M)DgL?To(a<;o zn9oAgbzZ~ha9QVA;M9>5xGPj*RG+UCDx{)Z)dBejG*RO7U(me2ViK3!jt%|i;HGPD zJ4r6#Tk5EI={q*tUit&c7-VSGyVMNtOW=}qLs}Ak2K~#kf6nJmEKtjZFY@_N%L`uY z@&B}U<^NE&-`~?i3#k;6twjrENix|r$7Fz8d+vQ!eqjAa_z z7)xa)StiBISO@bkG#E@{$o9R}r=HK}Px!uGpX-O=hx@+nbDis4XL+A)1vx)B3^lPr~>a8|9i}A=s(7+M){o_p*@7K z`BDQ`QIAGi(f;YyvA`?PBCHfvlw)M>z$@e$@X~A2$zQiMN}y>FX!uP=Wd7>%W{^of ztA){8ymvoSt{I;{a0<9ABsUpU))O^otiBgIt-$YR_8&2s<;|{XM$KnLuBD7>sr+(U zL}uQ0$6{^0=(mzKt2X;BYBa-xyQ6Z~8MqS>t~^L~Fj?N*L|Gu2tv8n#qB=OCOMZ+KuDMQ6zXlPO|C>{o3a9mg|IQEBwI*mAW`WFAky zLj#(9Q)AeU${On$>;Co7#vno*wr6_T;k@6}a)>^!lT$0ADgJtuU$*RzCZ}jH%EsPB6DR;5DVSaKds}rK(2m8C;@gKcjx1Z*Un>Ba+nL zdV@C0522DNdF`qRBw;m$cWJ_j(O`(<^pQC!kD(^?$Rj?yuw}$8a>{Idf5mxZ)D)3L zTA@|0ZgVltn~XH2&<0eN#eq|ReHGC@)*Crch-!cR2H$leW%X<1O_LSRMVl-VWo4Sv zNkriu5Xp@~8}T}vIqU~e|Y z%#3Fur;Kk%o6yCN!t)kfZ~?de&T!aG)%_&*N5h4Hs(C!?x!!DBM5Pg-m*qjE^*jgq zH;K#%o<7ih>8p~T!E2T`Ym0Fl^H<@IuVmN4oY`SkPDZ0>W3?izYyz(w^OK!3FGj>FD;Yr*n*9(vJn%TKH1Klk+tq zJVe=S;4q8oc!!aD(}{q_6F-$+GtxI?G99D!*`aT$yNOA69t&xfg@BJA9ay1z|A7_O zlV(bQu*b8*Bz6uSW$IN7em0;@_3VSwzpsnckJ0!I!Ul`jZHe)qmWa{mB3G|C1qZe5 zX?nBLA>^^NOg*5poF}6UH4cUl?zLx0$E`s%*l-uZiMrrkjo|u)v@T5=GbYiTqI-eC zWwV#6gWQwAz_Rpu3ucvtfMSMVC;F^BrllekBtaA~ZCu_gT#LTLbCUu)L*KAv~IAmRRww(>s=PzP2hVv zOM*Ml(yQ8Vmh_#!v}N?(t|SOll=$4nNAh8Jt#0L{G^;1ZH>%!0IepS- zFDoUl21whjDL02WoCf3MG`UBswbUIAo$bWmSCqGQ?4~ATdd*R@G=Z|hpRU9}*l;y> z78`|c4roDNfGRWxU8M@-Ww~2wPANt(S)%MRug2su9VKjylIsjDETZoMW8z4ru%FbA;#1BbNKInoDms?r==# z2FGD-MXI)!Po*^6>Ge6?`ghg{?KMkFw7$a3>6MDxJUKtM;w9gi@_K$CEdV+jdZ?)r z42uR=&w3#UOX_06ify6=++x(-HiKY#?H0QE>uya+$sAG3!I(6THc7R79+QhgNjmIK zom_MurZ}Rv1It+OV`Tmd6+80%3kM%v(C!BWVHNZN==~n=8J~meoeZdJK))fPY8I zfE9e^xKSa$`jza60y&qSvjn@HM`w4v#Yo1Kt48*1@O99`$x_tgCw#;Lh||#|sL{ME z%OgIJ=!fmA?xKK}BI`C)DKbi)OiXIt=^?aDm($%&NOYMLHlQmY(BQlt41ZMqvS=#6 zZ@sFHPfPbxq3}lJ!M{&I<8Xjq;7GsmTIl3r9i}LG^*2e`!Q5nQ-?k+O)nY*yxV9#~ zM8XZepw?v|dA4!Ng_a-0a~O7Q4JD+GbfPQXlG27;Cr4O2FNG%{+iNx66H<5`lauJf z%nY(b-%>!L*_d&zC6^_Iqp3*JL95Py2%5RA&WD9w?+bd3!A|gvmfQLly!@2lyL9NO z2SflpC@1VcLBr*cPI~qTC>qRfCkdz&Z0N(tzW#_mlF*(teQbh4znbwlel;xa z=F+xgMjrUyT+t4VzQ+wjt`l91H*VN{ISre00G6eX-+v5Ir+FgjW@CtThwO5WB&bq0 zi4rlxAm5A(*nQr z)~pGF7kMAT7?EEp?BQ_d^xwzoe7ATWy^;QIu6*K)d{M0;!A?{cEE-(QzD*GGlhRB& zP|>PqoU7JvC?4K^v|eEg$g`=&v4I5apq0js%>FfK_$hq(5xo!)GXs@bBBN%Zr;{Mf z>+H1s>7Gaj_GJj06~A3NMeXgq!ZY{_lj85Fd$j zMrJ=?We#pju)U<0k6~-nY8s^j=He7A=pFzELssR@D&4HxLNOd{)mBh)uvPe12s<5G z=MZT;K%V^@eBj@!7n%99#-pq}Y|`9o9J3kZnIq3Oxv-x&xRfV@XiEvF>?Myhh3+TCXQP-~|f(@`du&Nu?%QKiW=R4k1-P!F~*>(X_*CO=eX#QR!3c)W4G zV2C$2364wdv?>=G&_oqVBV^hTTMas&SFNO2Y+?Rc10m+)gQwj|&U2XQ*;c}9 zQIq_cGJ$?GawM;hQv?b4+u6VnpFi?Fzxvj}fUpz@+a<|)ei=go=Pr`=V_+(&J$+j$ z7hJBz77=(ri>V=u%oE}Ju=8#CH(f}1Z~;QIyXNxAL(B}nE8W#S*1j4;hc+n)Z(3>e zFjmkW-$Zf)80!myD##JUa8bO&*@kgl2ji%X5$C+*^`9XM}4m&07F zrE|OS`whh1sUO~2BlFrBc|i|bYj>tin{q4DQ5GK(cs_ZH@&moPN7 zf5O2RfTyUk^^r_qw>ZJm#ahFjzB4)@)t=rGus6AFLr#I;E$(Guyp2Qfn!__!z;YSW zW3jN>!S2C_5%$^=5ozMPEU84gOd0XZSzkm#{3GJ@lgBn5%Y)a=@26<&9}GyGmjAPX zJVPg6@qWoJ9B0>dU5H!^T{&aPdLQ1l& z#H}<+kwC6z|P3ePk^Z~p(bQ`Elo1RXSk+w(WO@V zbKmIIwmxXGBGsW(cj8+}DFn*X_Hk>IyNif>@%6j22lVhS+M~59qB}KAmYzCt1%ONC zxWT5coZT-~*qEupT$tY5Hr;T(*(p?-mYTi|_Pwi@_DQz+By0pFp!MP*)8f$(WK zJ@AzDVLzxsQzJLf-C6BO5|_GC?K#}4Hz+?DL9PQ!$ZO>-@YJ*IF)5Cbd#gBd)SBrR z8DjI58``E!st&XXBF+yk(vwqgS**;srO7ak7VopbkTr*n@mr7lH0qYfG}y1a;^POcZAgUjd|vCBY!PS#I@g$nK9LC0(c1E4L0OF z@E^|pUI8o*O>s&X$;IMn1ySd1=aFNBt(0ownWoHgV?#VnEUmAaVoFPzI6vzFKVJFG zuv1=nN{Q4H#e1_cnZR1<5h_rhD2=S2zz6TM(eqBV=v)JNgcIj=9KQ{v^7`XplYD?M zV%Ys-gb7cgPiPe$sp&}wIqguU!A5wafH^f<-W63 zElmNV)U?2F$=uaU;%zM<135;nQRbxC08Q^bCeR~@^w0F0odoco)E?eyuXA9TSLLA+ zpf6ryW7gHS;Ui*-(1C*>BOiSp5PqbiqA3B;epV&^Rw4w-1z+?1k~b-*6I)d7ccAMx zHWZX8gGdUvB7L*@$Xlpw9UUA%4>N|vVV~%R-%yiZ8mk{v-)k{lQ1HY_u+5)Dum8?q zg}n4UI{se(9_X0T&G-Sy*Sw>^P=#pj_4`sqsbUZ#(+q^7^^bs@5p@AI-Wi7CaYs z3@E6y$vMljjMYL+cmBUGXkUi`6Yz<=LCw6Z4Oqb1Zdlh&|BOcO zsMWwlO!$HEg>H^u?&xaN?S0sF?*Bgj`OD1;EK#SIh!Gua)%$?fT=+A9O@Z zHLO)GtDh7a{g~S*YWwz9Q{avXP2ObwkEi}57tLQ6BN>RvPdJ&zic(Hn%OuSHiyYOk z9Q0=X(|_RS(fijoS^C$tS`e2N>Rh_Mf>uwSf10bV2>bc$Au*C=6Jtr(YK_cY;PgOOxKneiy=0L<1={9NlkUZfQHR$ZpP9N9 z0RCr@#}Ez670VhXuoNA*)o@!xf7r^wu?1xELYo{R{W##gW?h7DryXL3@L&!K#pw%4 zzt|VO`#{3>6cecp{c8y6>tq193lUQ17&pX{0Q_e*$CRbskXw^RWb$q$F7= zy%mJ#!93b5r?;;Mbo1?X)qyS%5ha^hGMwskefE5y)Qg10VL{E!foC3Zxv1$qfkUmd z^s$D%@8|rzN??&|9>&khB5y@Bs9d0$W^rju=6LI(-*LRIc1nuw)8g64{=q6b@mZX3 zx*X)W#3Ai%=mmFv2*hISQyk>_v>IH~g<3yX66!d}(i2Yz82 zQMBcGnc6Dp8)4}{*@J<8h7GvjUU3i}eENolDkESrg~)@&JI!)>^ud%D%yav;Jiy0L zF2n%M=PR#cH(G z@U7h3ec;vzeBc)f_uf;m_4%ob;|K(PO|PPd7FIuqBrh*#4tXXG%X=c~Xc~Xp%eMlb zm7nWrKoeQ_)2xa>T$0Jml8msAuMUR;aSr{vpI~+Hr|1B`(%s^nBQ(>y@_R9fCE#~R zF4Z&PQ zswnWeA`!h{AXiekYLj&)9rR^l%SsN|6!=0|&mF@8Vmf`%hu7QI$tfbaw~#4bPT%(0`(2A zSc0pqwuuiWvO}6mA1mN`Cj~Djx-{hxGfELmxw36_qG5@QF!k} za^H7?gRRT_fa4|wczg;n#e7|%v!`VMe{LmSKR^vauke)Ozs)#R*>5Sk!%%0f9bXPY zV`m&%?WqwKWAMu%i3p$H zj-XA~)l|7=8{1DZ=lsgwtz~W~RKJJ5#!N>Y?9bB@@1b*7!rO^6f2ZdyE%yX3ltz>W z`5T`LB+gE#nISeynNSv-Q@s13c4Zkd_Q}$S4snoO)auiV>zGmmJ(S%NifVOQ^ujl+ zMH&A=Snz9$X>hn(bi28t{cf1S0g8RIfKo?PTShM~eh!6mwPsng z(MN+bkMKJ9{3>o^CmEM>WV`s=3)FiDD(IIp9FR`gBs;G(V=CB;SXdSqHLwKh--T$y zJFM4dK=7TwI)y^`25r;2Tq>o(bqx*LuGtQS2QK%Hoq;i|0i6{Wf+_d}DbaR+R?+*t zrL#_7fnm=Zk36NxaILMsW8;oAR_QBx^+wZ1;xH&UT~Qq5`3D2MyB(oXQmJA zdN8*ky7q6hPVbS-smBR)kOOiMKr+p1z}h#8WZE9rV_u37uDRbhYHxTHl!!EvFaErc zCQf_)baE(suce`;C+Aqanjtvd*dbvc##FGc8PLY*qDFh{IYW|==kXE=E zL*Spe5tk znqvvb<*BPV>>IJ(+UUK`rY##XiNw^;!Y{h%6zpw_c6mlVuQCX3RFgcT$2P#!yMhf{ zKw|JMd^)|*hwJT7R_-xS)T>eP*%yEVe~za|w-gvxD(2hW3%({TM;gnMeEV3uWaldF3sXy_#z`wMrsCb?)<&?;C&+FArPUz{7 zhR_WTP9{>4gNGZo-BXq!Oub7W@~3zj$85NvyI(iGHHQRQ9Iu>MPKRBay7cr6Fkhq9 zfB}qt`5qXoGA*qc?x_9WQtTrUhnbW!8&fR0Ia7a*% zE-Qc2(tV!MK8YUp3M}8lwSYwle{14xR%&gZJ&fo{SFkQ$i?isc1F|9~=A2dJm%CKf9~q@~4{ppQv>1vJntjD>C)~>7vb` z`BDWB=OZgqzXQdsp$Py~cm~TwH8?~L51@&Ima0SSI1v97q-fs{Q>6mBRoF++tmsONo>$qZ{JKdW9@ z$eGG!R&41cQ?8fIj*2S4$iN4f|2C*r_FRi6IWrvX8e`R4C6-pIvg z8^_%zbQLLz;nZ~P^FH~`pf17SU|!CnLV$C`=oWMXD6(u#*W zVX1|MPZ@STIAI7g;_3w_4G0S7x2>a0WJ6=_ZtcTF=((BMHgGF03jO0nhOGw?RicFX6Q&$|UEaSOh?oQF~pO zo!-|r&%eBdbxrGt!b4!sxPtU6Aps3Bwus&!9uk)mxVKJyz}5eQKrI&AjeP-xE#N$u zZ{3B4Ge4?keu!oxK>*O8es*`fcaJ_BcHm9b6eTa7=_%u;B(}3EwlO#ML%w<26~;YP zr(&0@1@BJ3`Z98g9k{2pcj1x2AtNC7FmDt#tpuFRJE2ewCUZwe7D&rfYG-l$0iF~> zQQzV=e}r~Z=^$Qfx&fw=*K0tzn!-JQe6|>lkJpxft99#^+z}K#06fpJ&vQmlbswtg z01p?3HEvqx{*Mt|+7;_o1whv?-o1t5LU3T4>*IbIGBy^>icuHBO)~xMo05>yLhjAr zk}FlsR!%ToMF+Jjn6D7%ypyA$9U#*->Fo^_J9w&E|LO+vQ&thez$b z-AYl7MZqY#~M)>YtOS}2{<<0ftE4|AT_O|ZyuxU}={)Pi zSVHJW6&RY&uL7l48F%aya@Un#4Ly|83CJE`s8>ntDi;IkFD?#IH&0G+-dIZ^F1-s# zU%IFJFvFTEWY9)?8KF@pIIO$lFO%T7V{RpuPSb^_8W+1mA0CHZ%Wa`pW zb|&f#Wyy)rG_nh5Db+v}TK^Nnhg1Sb!xCNVO4@W%wty&Y?U^G9&shmeIO-_g`aJcx zLRA_BwtR_8KrA}tsg(snjYlO!qroup??~aP*M&0VTWyO!Ly^;IJBANORuZF2f|ABp(`C|$P8UTt z5#U~1b}J9EA@(Qnj*lfWL_{`S`3uP0k_$=0fk1x7D4mW5yyfVMTnK#?vmOf0%9H*~ z+Yq7gMAmt2`6^K9#}i(fDb?MK<{`9v!UOXSUY%K|ua((tt^STp@6Q z-QEf3-TntpIbLFy+ASaO;}6G8CI!FA7Fp@3rCzc z(v13uY7(m?*r8XiBOBp$HiCbsY8xQ zjC4$$JZ<6q+U|KkCLokLgRv=VZK_e0kP<~D3Y4K^S?`Re_30-nG0Ca@VZ3zYIC+hu zho9BN2}8(f$Qo7;&6`9)4NUNv152UPd84b5D^|b7>)%rLzd!%u!2dY#KMwql1OGob du)KM7FXqVh-92T?$?FvVb?)+6yg4NH{{R&%p7H&J9(b57n#!swqM&%tp`g5ZkAiXvPQ6({L2+S6L0Nl&f+84= zfo%o^4TMI z3m>QLE-tsNi_==gYVHZ%V9I;Nkl+v0Y*~nuZ&^PJD!1?5qh=8L__6v8O9yq9gf;=~25UEg#6JMhG5cJLMS03%acRcG$PLxQBugjwq$b z=#4$&ism_5_Vp{dfr0{QLV#{w|0N=pzJr1iA$_^b)BZDQlm^*Cq+=6uUVpVMb_3-H z&91WV2|3&4Fk)~&0~H0O@6HP|FmxEWOCRycZbT>N__t@gua`E)8GXl?Yex`feoK*> zM!b{W$#)|Q^$%_z9bAOyfG_zz`AHKwyc13zggbv4O3LK>YW*-@;7)*`57jW=5O(_4 zn1}L=xlaPGOSX>~osbijvbeH+X>X;WqK$a501s#tv^SeSSpv6!yTdW0FN-y@cg^A^ z%#Y!LdAt&Ke7mXd-pOIKG_TvM{&Y9;-bA-vtK6yEzH>R905z+i}-JxDr%n*Bf=&TR6;? z>222Gu?RRFDk~>Oin{9xf=||+>(1KR;JZn^p&=hTe50d$HrKdoS4)<cJm85*b%3KuZ|JHgbDhF4qhgWM_d-6)vD2aEh{O1) zsYPZje{$ihIo6X))Vqmd+gL%jg4)|hxj3^dA4w1~`Ca+6=6&q=SbenpMPRDVsk*#i zDNyIs`l0)2SV^j>$%N1Z4UVIM_h$L$&DdMLH4z=bNpPlB>a<+>rSQ-PxO=xB8_Cy> zxQ8nUYvo4*vuNv7SF*y|@65Bc-oJH@$jUlyzLora+r;aHZmfg;KH#LQEs&9Km5gF5JNt74qPRF#!U-5c$)u0b`X z&3ezP#EP)(WQYtc&hy`gkI=LXq|93qFU~dz1a@qsN@D?*2@vj^s zH0bSQ?!XQIV)EFq#_j4dB6k(-Ep2AT(!!F`VBFT`Jaaf^Mp}Bo-j3WedEnU#zB`=T z!Pf1oVrybduhlg)c+M;j4zNpIa>2x56YQ8AEj)HCQW=xU`u$j}i@lT31j25{7J3@edQKy&wC%klA>?x)PPHJ`|Yc-bj;4i88x zU~S$AjEKfptKPZN4<^bLnKrMYR=Fa$Sbg;MpX=;IQCMIZL3$EwY;9F4*Tf%^r`dmr z{)+bqS3+0@n8dKi!=j=G5bVq$onUU_6>_}O5bsG6@5@Ei#2gbcpgnw0oTUw8H2 zS$Q=fU77oG?ekx7mb_t+rKRQVT^-ghv#!R+B*Pn-3K{B?V&uGdqb;c;4#Sz$CvB3U zMi}OZ-~1n_Lf$t^!epQD{-B8ZN|TxK2{{S8j#v5<6YU3Y6C{~0#82rr&P#fRx6Lz= z>Ih&g{d`CvGBMd%b#}s95o_xSP;vA?~ z#c!D~itQz57`>j1%vm;#gu%)-VXk+8bW}2@+ty5brMu~r z^d-cDb;!_THW5Y$uLAehD#-9G&{eFRy)urhQ=d?-z0xhSmd{2zom7NQCKi zDJ_3A!#?oD!pvZy!GV66F4JaGvY2J)kw=Ve-{h#W!%`SdP;{l~uU(H`DVgw-cmYpM z8UiN$IkYosRvmSHns7{y0^NK$Iqb~UnLZV$oQq4@lC&oLaTTXoWk^hutn4$IOAnaV z&AF`|4G@EtJ(t*x01#vwHGPv95t6(-*Q&T;F6(uQ`Qwkx?0FA7oalgVJ7I>J7eD>wC>S-mzB%8iAK^@l<7=ZF=npc={aao^k}SZrWqGvHnx3oP z;TMRvPoJ7EnyXs*0w9NaRLyizWUeYA8<`GIlKrphju5dXu^x%pKWL9H?T%MD1pNaqr4ME1(6V@$hj@*QrNRHJNvj-7)YE zEmR#69Y5=Q$OR%tQ&S^Slo2L>_K;jOubk-YtYzr5%5goT7>3`dLV6Bh-1Bfds{PJG zGSQSdO~)vqu`{Md9rxUet?iGEq96rGp8adwa+dcCxRHK;Rxy}?z-XZ>{?##ROz{GzcX)= z&sjX7psWx|=C+Dcrc4P?MSMqbFs?vslyd)PLqo&c&yR%K>(ASi6T$7iiIcNC4l|nV zW__c4Imw&SH+pi6g$|+%w;5j9zuiyVK`_=O zapZo_`u;uZGe(GUt~s-2NG65Ov?ilfHf=g>>=A@ZGHV3Eq|9q!`-lKUBk4^(Y{mCM zq&nsSz9+^3+AJ93MSf(A4a-h)kX#Kk3F1%lpJTYpD)&o=5cUcpX2lJ5RFjyB&ps^C z>v#dc2ZJ*Q$p^54g!)%=iwcbWsoaVVRc#+5P*J~hu4;{(o#Y?w2{|3w9{SlX<@UHW z1ppGaZP|5d9O>g_ax-wyKus?JP?N=d=4Nfa>{2lvR=e1leURlrTDy8{+tc`HXR;732LEIXdMJYF+T0hIuAyaE|{3daqwQt- zaLlTz$F!q&9A+C#O77gD>F(|pa@`(DTh07E5|A1ktUlqpf9zPch)+O1Gub(}2cLt% z!qCw0?nuSz>54EhVBI@*o`>Ndwx|RkDRJA298A9x&dVtfnZ>}{F*-VcgVlR6F7A2& zUYzS%gV*p@BG9mA1uy8993vxB8zgs1-uySg$Otv;&4hQ2<*aCsq~uHglh2kby+J{t zn=3D)WScQD4~8@_*d35XLlh29WsPBsEjty*^YEOsV3mBBMxw2CP{>E>OKKlR2(zW^ zKE!-k7z^#JO27d2{CT#ORT_-=E10&p0%j4!oa^Y@8yAN?hL7nPY0Z;Er;U7~cjlGF zuFPJfl@*ShF9s6l+p%^O7CakfCpv|JUJGqiWPu!+FjevZW%JPmFF!ve?8E9Ee4pC{ z+B&m!PI}bXm=7KRpdTtqpLla3zRqRY>yf9u`m3B~Yk*cXNr-Vzz-y8H0fh(??8Du= zcUMBZmbVfduQuPqZm8Iq0e3g28e$qn9nT+wlpWI|?&nT7p{Y%`g#Phk@N40MCqI18 zk2y{lOsxYsM*E`qIq=A*!jJFX%6VjR1A_Vu28-~lR6leDwb!wSotgRHD>3N+WIcu~ zMhn3JACN~x#NY$+h@BIBKpr74xjy=VtN{OhgX<&YrN?N}t-dZdQQkOw3;mC~ z{D0o_x>)?bbnZz-=tjZOBNUXZ+t&kO=ls)U@b?YO_`2FGYel5TXe~hD`fP=aJsG)Q zmO9!F(%pSkybJj*&N9bG4Ij48gktbT;M*E-hwDdpFung^_XMEV zvUXnT*`i2~ph1pYD(-4uxYw@E`g%h=yUr(P9z@zc!K@9Wb56U3Egr<@L0u=Se(Tfu2SeUvBcfD7Ub52*h62jnI&(z#dD+gFcWd+t z@6b|6&(?pvXZ^86tM|g8>qa=O*VyFJ?P`nt>B(~&N9=|~C|tPN<&!uE&T!6)A6TOT zJW@J^SEtbZX+7iZJsa3rcJ7L64hnWt5T;V?qrCp3?KJAkMJ}Oiu^0RjL>{c_t*#b( zIB@;C&S{n8puTCYerV;fqC7ase85W2QB>~$@hzEzPr_a zKXL~iT_$nQ@AvJkClKO1S9mj=gqnA`;jk0d(co4wlG+k^vi&j#i7l}V3uWNZO z7L7_L|9byI$XIz980(VYso4m*}(6dwvWweDHO7 zI%VrZcfkj)zh!e+Pj9lo6*sj2bvHwxxz%oKFZ!d3Z*>S<`D>RspVlwB7TbI*{!n;# zl;vyZB8CV;Xle;q87pc$$=s~0mVlh=%GK7E#kIb0mucxu5RPa~Pi&Q3|K>sz&J7*& z>`ZY{?{nF&R6J>sYXeai;+&SqTW?WucYS)iVJf? zC*DDZe-<1~GiM*mjcDwyKYgqKBG)Fnzfd|-t`q9u;|K}74ewms{qUl9vE;I;?P2Oe z)!yf$GofNUG~olp+NxiR>*rEVH92ZNwj-C}{)>=J5C<+v@ zj_D-nXYu~r7(xJlt0;^aY*(WiMgof?JoJ7sXXYno=RKjK>7}@u&kUm|QKkM0d0wq% z4hi!cNSQ_7`gtnGXx#qXi)ZZ)G&BvIZdd} ztgxm11zexJYND}ipJD-e(iTQ>uL8&G{MgvmHlzn35S2Px|42@NxTei?W<-ihLW}it z=VE{Lh?gVejP+Pdsv_J7QyyIRt@80^*MmmUt{coz>^p9yMtyp*FXGr%mjI{2>ijcPW5c*AcTT|IHyn4oMxx6rCrWgpU z^b-g)RI9V9$(TvRdBMmIF}#Z1No7jr!n({2KWqjqciJO=fo(qC*L{JZ7Z=@?O|O!Y%I^kjAj_t||UV zT%^k{Qx=S4GL|FKsW^q{dcg15tbk5wp|?a-SYDYr}+<$1`+S zdl!?~5!Yu{&fG{6_lJ6@m)@*~keOYfVrQy1Gk4ddKy4+QG=glOl&)o7rYsc!k$dsTR?x?Yhm5sORKBlo>dAL9+tqz`tToK_qfK{e{6 zYFiwo-DmQXqfi$RMo{h##W3$@SINKT66TV%AWik$!rrnq;^HLZ01ZIaIB+S$_A3K9 zP---+24FgKO~i3$ZbMNK$Knpc@Q$yC7oW!1;K|lz9AEu;SxM0^=bt8uH!awq14Wc3 z8(atQq{iskNA^zbPuoDU$i?>L8PD!;Jq5uD5+9&0m>9%wLzI3t`YLE;cFxTa=F`o2@ImE$$ zdv8cODhlVRf!qT$ifaG@?uxUmpEWzH?LEIrx66DN)sXaI3}Gny%}?6C!0UXc>80m1 zS45%cO(Nnwz@1;1U9YA5Kp@FBU|C4!8j?pU9Vy$4g7OXLpBjH4X5(Q8m?3qt=260o zF3v7zs&H=!uhhUiKc3q!7983UxHXbm`3H4TG1-2WC!^0N31>TpxHvCce;_7ant7u_ zZlaS`KdL^eS@GC$>6v#&XE{4P7JMz28k!g9I{-SOqXxlEpPd*X!6U<|aatY~P|N&5 z{17bo0B(IQL##uM?dI$n&00z)dUUY!kV44b%ErOi)a`i8u~;N`%7zLLt&y7Ajx2%2 zZZlj}l?G>L&1HtqVV17M&fcoLv}E}e|IlEm zdP_BhTm#P|M|f>>@2z)reN8e;k4s%&IV#F4rmsV(>IWA0zW;<(FQZAQaV^ts5%W1P zQZ(|Ld`pQJlL#0x<*O)O-P)qwTU}ezePKE|J>8-rgdw1oj2>4|%>7t!F{dUHHutM; z=v5s&b2N4>);i!3BcTv}1jmNh>y?f&n+1mg{aO-_751_Lo@{+!_rzNeH&@qKy>YCh zCTi;1i*vo}*XZ$aVrWPj*DidI!)D}+o0rGMxfFNV!``QE567)YTk`zH(PiIWQ4xk6 zR)F{ITXw)mYVO2pS}iSYg?k5Fh<0n8H_nc9Oy`8 zsz>OJ+ww+Dl49f6LN^65d!LxAw^Cx=)ATH?cUk@Xbl_5> zNrc^|onFQESe5tPo#C1BvW)V`V|@d)&7Z&IEzRymwU|{0G@CA3r@;IB#$K3jBjz26 zL%O~{cIArO%J@>%(cWEKSC?qJI>`pTWG$av%o{;CpJ)rQd{maVwz4y>EV`H?%F60W zVv|@a8XX=T=NG*1e=|kEc6mWO&!pf{ReW}zzoM2-l7=%{%UFNElGoBsWk7}nN#fg% zzLviJapUC$C=*LpPkVZ5i3AmeA`>B)9rcIdwYPc88-(0Md}rj;1Kws6C-p)^_fCZU zW(#o5v!DCQLB*JDV3Rm7*-E>%p5ru{B_F{6Zy2WCVs~~fhGKV?TddjRK=B^y&}UJ~ zU~%qApJs{w$fp8(0XUqA>*TLK``^0HY0M!@nFq*IV0`r?4oAxAJjr!Vcr>*Bx<+5kOzI{ zA7E#ONm0WB)oZjU(cs;;USIpr%TvZPl$&5%?&e$?-nqI<^^i%3zHMM6@i>RFxHt5v z9dJFMknMIA-`}o=EFTfh)hd!p3e4Q^QnO{ZNFuv!wY8t z5rcfy;Vp$tb1z1Y{>k3@@`6uo^P;St<&I8R>6-i?7;f}I(>Xa1t zlp#S}8EA*cvn9Rx#=3})?m4O%vVfwOLIgbxlN$hM}cmsi%LogF!i z0<{frFP`xl{WO{!X%F*WNF5e(n*Yo-%)*U1b}lY$Sv&+- z#?8(9Qt$0cW2vy}Pit%IUHNwI@{h3^5aCxnGqw`QoDjuwBxGBeu!}U zJPbZHv-@#ZqU{rFsguf?IAO>+Cb2tpbu@)!KQkF-pH0Dgp4wutKe?yg9Z9`qbeXm{rR*O%=0 zFsLmO6TT!DXegCrw{uJgzyXHCj8+>p1%~N~&2-#P#DxMCf`TwK#6HEmh?w7ATT6)} z&^PuK3S1|yV$&fXXq<5! ztob8Sc4s6WQpm|GM#whj=jXRB5!BX--~{nA(k}jhL2!b`?8bNBHHwobwavYHKrT>4 z&#m6bpPIU4XI3V|lpHgz+T{L}m^$hudwQm%pF1b9#WqdFFgwO#28Vq-xhN44GUmH7OT>?O_=@Rda-bFpn9H}#Kj?>_ z(9n`}g}1YNW_IAbxHn%C(xo!W#4HtV%6(i5TW!pUljY(NFi%cs8Z5T7&h;VVYRCym zve#8t%ur9S{_vIA|AfXedbG44F`hdoGL|*0jVIngX*zhaco8JZrf?Bf8^{&!EE=#l zj>}&b_k`E-ep12-dcDILwhA7h&*(U`mg(>|rZI*WF2wG`G*ITkn<$g1}gnnW^&(TVj=oz;zg~ljXyti{M%J zwx5R27g?7{QXguUo%(1lkx&>FyT9gvq~_)-(BPQVYHGg_eN3d*iSDT$#059|uupY7OA1i#DoSb28tc6+pUK{)_dAETv(HN9# zYE?kDFxgXHV%3V z_x7(uiXp|+sGYVFjJ={N_!U<=6E+QtCPe=71MHc+#pjq}Gkl722UgnME_2qZWjoOUlRy zRmar!j9wvvaHFkWc97`U(9hiZN$OFuA6EB)jh0SVfS>Jq(KM;Y8+&c4kdT-F6qM*t zT)>w8Rng=9-Ut@!C$2dVEVRN-hlRwJ71TpV6hp3FMqUBVxnP;JUrMflCzN|=IG{(mi35bpgwQb`pqP~NiAi842esL9;;UOZl? zIFvK04I&CCEG~ryeCquISQw;=d3N~y8~c{3*GBqr;B9}-m=N_>igwd2?nQs%Vp?*U7x-I{&#gOzF$>)P>x=E)*bj zi9!@57PZQzYHBhvo-4^s&5f1E$1Zi3EWEkZ)y!t2TdDL)YhPh|%(CntB0LWG2b#6w><)^RUVmIkzrI!t-#>&lay^wfHq6h%)++gn-HzS_a5 zhTrCW56EG*=|Up8lD1@8Twvzg?3mh;^&Pd$cDj<<5*tN3)*X0N#zaGlMm}u3+ZGD< z>-+^OC;w?cmPbcNag&4ug=`50*3}E8oD@1Q^74|ClQYfD3E2#DvhztvNUEY@hNlKN zxw*f7-Y;ZbF=XST5{Oa%uELOZsH?82(bhum>;_i-kZS z?aas#^pYh>h(h8}9bs1Nv}~&GN*0(DEH5k1=AnP{VIu-a859>I-K)I36+pfsjgEy~ zG1jK0CRm$UYl6t@uv?I_R~WM`XA>K*_L;Z94R%>vD+A+V)+#KDiz}S1Jh6GqYbbjyy#HV*Z*O{qiT645GlL7DM#WOa=}yj&J&G7DK#}z57s`L8%VIz zOWZK7^#4SY?ffk#=ce-E3$r)<4zffScaT>&e4v~I*#1|~|H8h%4eamG__u-m)%;e8 zSm0bA@BB8n1^e!(#O#lI*MJFr{!*BqtS9?ByNnhe&^kcQ?VfxG(BtQ0v_G~Af72Tf z>M8LMkoo&*6uhEdr!0f;HdIV0H0(J0_|^>IQ1{vCB!ST=DTiAw=Eui5yAPp z_7bNz4)&SA;+$PvSicu-0_nt)^}YC000g0_;pzF_s`6+~J!%=%5)zOKH|I11xiCSB z@UO8WePj2s0iqWdkdE_FzEVIOw$aiGiz*vy=zEAn-ML1! zaM@N^bupSGW|AnhXMSZZV@f)sQ^zuCqpY;N)!<{` z5K?;^4XyDi8$BT9i`7=V`II8Kd&2GaH-{&bMQf@iDL^B#Gk6r%=B;~ZJHJF(RbWVX zWDZ!&jL&7q$fu7%IwdoiK?l`7W}tKV6iBF#Pb80dHZm|lLYRc|H-Ev?N}UxDuFRe? zsA^n7^iilXpMdjW7exPF9MgA~GOw0khVGFsF$ZfrCnsiQYv7@{LH_22UO-zPQ79}e)>od1vJYYp@tNbt9bQX28= z*UfBalrIAb|4ciKi%4>FnC{%6G&ksXG&dIr9!7%Q69xJ>iz1TXVD#NRrypN4D=Xi$ zSf?qGJU~uR6uTRLXG3q8#=19Bex*#+=(8^}GO=0PTOmc)Z|U3>+@nJyb>!s47yNfJ zgbM>@tgUUbRIeMQ@bC$1K?`X(WL2DmG`yai99)XTt8bwTON*a;-iNs`g!+(mc6S23 z#q4k6twH^RasM&izsylriPUp{J_aTWfbodW{&@MZH(Y0TtfOHkO!V3HS>uJrFUA-h z7KYbroc8vvR{W6nCpyU`(V6`r8^id`VlgTI;6OoEiLSnto;H8)fZiv2_qV`*1s^ZN zPC=o3`<>{%E@cBktt9k3pPQ-8Zh>AoX@U((fOZ=vNSgs~j1B6uyU!>QAWF)+g(=e4 zH`X`WW?3>0I~0c{wVA5k79)83JM7*nFk_4jcruxBSQHSy<`FidHiIbbXl322S?k)yf!M+^J{@5G-uid zByAFcd(#0xG8yIM)SrqX>ES!t*Htr6>+UNUgsP0ZjA`-giDcF32({JbYG zr)ty9bpq`MF6u>YtYmBVtZvCN@^{033t!=G;K|NDVOhUR@dF>xq zn_Qd@cTV0#=G?N{(MHq7wUD?9pt?zz`bE@2!rEv@MutXk#ImyU9bY-piVFP;-D5Ty z2Cyo3k)4(qXu9}Q7C8cEX$yqRqQg74t%)K_2SmX%(n=7~XK&MDsT}`jVwAb+Jha%8|MYOHYtUj)o+6ktpD`;(b<4$s} zC0`uD%1Xm-#LC(lPSAUx^Q&iOO<|v)-d^QeNHrGo3kXB}Ne~^K_`mwoLi38B5KSP! zUV!c}Jftt`LyHJ1wx$5bt%^@nGFUG$hV<7~&-g;dJKg_7mi@e|@#yc=aXKTi{P3uR z6NJBFUIyR`*-FphklnjWBjstuF?%uJU{QsKRX+35VDywLrbRku56Jg1@2OwLhznab zHnng41QxTTrsihBs=}=Q1nUn2tjwkmw*5y-#lTB_@b8vb_+q5sPb|Ifd~ z&H;*22?>Me{i)~YWYfu6E8r+Wn??NjXDMW1@M72MWmaw;3k4{;hts*a_eVQAid$O+ z@owwjA+1Q4l#(Lj=QnWa19saEJUTt21qa|116nZy(%a8OK_ODLL^&V{-v2uJ(jO*8 zoot_CYi7WP_J>aWaf1ps4IY{^t~q2K`uvaP@<%>-lS1|On=;>X-eNYw+el;np$=v! z3?yso^S;4=*DA8#HHY}7N^v+MfA)`yA*jDSF?UXC?gN307^~F0E5xzj9LNee! z0?6L$sUQ^%19M~3sL%0JgOfu1{Mwq&w@QrXZ|x1;0uuax}#b%a=ozZX@1 z{rrSw0qWT+Ej_^k$^gc>lew^q#C_PhdYWZwRDqCINnNT);V6Vs#aDLV6#kj_i zt@aYji;FLXSU5=If@P?vNg-?&+s!yVUG)Opny%FS_Cc*eLrmFp8Kw9spdA(IgN*#D zbEII)emqx;!_kp>B#$;SDKtcXef}sVH&?lj(Bt@C5j#*l9qKU+rl&71E`*LYM4b1D zV%l#(w0L)KaSc^g#%3$T>cxU(t#&`~7)K<)P~2czoS-^!VY6%hN25t!wvW9ZYtZp@55(QxP(XPwY9a|Gqtp@&ki^F>=qt*9wyv>n8_yK&FeK< zcd_tPj^@j|6l$=uAg;mzxsRbw00JU{PTWZ$7}U7?{^%|)F8Ox(;O9Xp)tuw+`rwF@ ztGdb%JZ}eAB|N zCxY@rtJT$J@gPZ1i|wYgD1gPw#|A~5+s2oCc4neUZT9v%(?l=1XQy7)!FvNx2&#cD z%}Dn3Ngrs@dAW>5{0I~2*}#yg>1m#)l~aa5)m-Y1gTeSDBz*Djoqkxn`E+)Dv_2#x z1mj^n*pT8dTSt3s4k-ULD(Xek^~dheDUk*iB)=Q%_BLEfmA0d_$ElvZ#9WdT7s9Wf{I}- z@N0wwV3;JfJ){U8|LVMk+$YQ-Q{&?W|8fmHHC6GS;4hyYs;8IxPXMZGyf89CFfBQb zsM5d2<GbVCx!Q&_AYaq`rSo>L~#dUH#fKlatx__;NEc zzO+~mJ+iiDa&jsmAzfF&``fhi0!hQz*vG_V>SPbQO2WiM-*`@kF38S~^}7rCfcrl#uyZi8vT*HwPn literal 0 HcmV?d00001 diff --git a/assets/qubes-client.py b/assets/qubes-client.py new file mode 100644 index 0000000000..93a74b899b --- /dev/null +++ b/assets/qubes-client.py @@ -0,0 +1,23 @@ +""" +This implements a dispatcher which listens to localhost:8550, and proxies +requests via qrexec to the service qubes.EthSign on a target domain +""" + +import http.server +import socketserver,subprocess + +PORT=8550 +TARGET_DOMAIN= 'debian-work' + +class Dispatcher(http.server.BaseHTTPRequestHandler): + def do_POST(self): + post_data = self.rfile.read(int(self.headers['Content-Length'])) + p = subprocess.Popen(['/usr/bin/qrexec-client-vm',TARGET_DOMAIN,'qubes.Clefsign'],stdin=subprocess.PIPE, stdout=subprocess.PIPE) + output = p.communicate(post_data)[0] + self.wfile.write(output) + + +with socketserver.TCPServer(("",PORT), Dispatcher) as httpd: + print("Serving at port", PORT) + httpd.serve_forever() + diff --git a/assets/qubes.Clefsign b/assets/qubes.Clefsign new file mode 100644 index 0000000000..9b5af7b4fe --- /dev/null +++ b/assets/qubes.Clefsign @@ -0,0 +1,16 @@ +#!/bin/bash + +SIGNER_BIN="/home/user/tools/clef/clef" +SIGNER_CMD="/home/user/tools/gtksigner/gtkui.py -s $SIGNER_BIN" + +# Start clef if not already started +if [ ! -S /home/user/.clef/clef.ipc ]; then + $SIGNER_CMD & + sleep 1 +fi + +# Should be started by now +if [ -S /home/user/.clef/clef.ipc ]; then + # Post incoming request to HTTP channel + curl -H "Content-Type: application/json" -X POST -d @- http://localhost:8550 2>/dev/null +fi diff --git a/assets/qubes_newaccount-1.png b/assets/qubes_newaccount-1.png new file mode 100644 index 0000000000000000000000000000000000000000..3bfc8b5b7e91330f1f773d9fef259906eab06c31 GIT binary patch literal 22348 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 IQcs@$AA2scU;qFB literal 0 HcmV?d00001 diff --git a/content/docs/monitoring/dashboards.md b/content/docs/monitoring/dashboards.md index 76671417a3..c3c1fff839 100644 --- a/content/docs/monitoring/dashboards.md +++ b/content/docs/monitoring/dashboards.md @@ -130,40 +130,40 @@ When Grafana is up and running, it should be reachable at `localhost:3000`. A br to access a visualization dashboard. The browser will prompt for login credentials (user: `admin` and password: `admin`). When prompted, the default password should be changed and saved. -![](assets/grafana1.png) +![](/assets/grafana1.png) The browser first redirects to the Grafana home page to set up the source data. Click on the configuration icon in the left bar and select "Data sources". -![](assets/grafana2.png) +![](/assets/grafana2.png) There aren't any data sources yet, click on "Add data source" to define one. -![](assets/grafana3.png) +![](/assets/grafana3.png) Select "InfluxDB" and proceed. -![](assets/grafana4.png) +![](/assets/grafana4.png) Data source configuration is pretty straight forward if you are running tools on the same machine. You need to set the InfluxDB address and details for accessing the database. Refer to the picture below. -![](assets/grafana5.png) +![](/assets/grafana5.png) If everything is complete and InfluxDB is reachable, click on "Save and test" and wait for the confirmation to pop up. -![](assets/grafana6.png) +![](/assets/grafana6.png) Grafana is now set up to read data from InfluxDB. Now you need to create a dashboard which will interpret and display it. Dashboards properties are encoded in JSON files which can be created by anybody and easily imported. On the left bar, click on "Create and Import". -![](assets/grafana7.png) +![](/assets/grafana7.png) For a Geth monitoring dashboard, copy the ID of [this dashboard](https://grafana.com/grafana/dashboards/13877/) and paste it in the "Import page" in Grafana. After saving the dashboard, it should look like this: -![](assets/grafana8.png) +![](/assets/grafana8.png) The dashboards can be customized further. Each panel can be edited, moved, removed or added. To learn more about how dashboards work, refer to [Grafana's documentation](https://grafana.com/docs/grafana/latest/dashboards/). diff --git a/content/docs/monitoring/ethstats.md b/content/docs/monitoring/ethstats.md index 65b47e6913..dc209244a8 100644 --- a/content/docs/monitoring/ethstats.md +++ b/content/docs/monitoring/ethstats.md @@ -32,7 +32,7 @@ Ethstats has three components: The summary dashboard for Ethereum Mainnet can be viewed at [ethstats.net](https://ethstats.net/). -![Ethstats](/ethstats-mainnet.png) +![Ethstats](assets/ethstats-mainnet.png) Note that the Ethstats dashboard is not a reliable source of information about the entire Ethereum network because submitting data to the Ethstats server is voluntary and has to be configured by diff --git a/content/docs/tools/Clef/CliqueSigning.md b/content/docs/tools/Clef/CliqueSigning.md index a227dbbcc8..b523badc46 100644 --- a/content/docs/tools/Clef/CliqueSigning.md +++ b/content/docs/tools/Clef/CliqueSigning.md @@ -1,5 +1,6 @@ --- -title:Clique signing +title: Clique signing +description: Instructions for setting up Clef to seal blocks on a Clique network --- Clique is a proof-of-authority system where new blocks can be created by authorized ‘signers’ only. The initial set of authorized signers is configured in the genesis block. Signers can be authorized and de-authorized using a voting mechanism, thus allowing the set of signers to change while the blockchain operates. Signing blocks in Clique networks classically uses the "unlock" feature of Geth so that each node is always ready to sign without requiring a user to manually provide authorization. @@ -12,12 +13,10 @@ Clef provides a way to safely circumvent `--unlock` while maintaining a enough a It is useful to have basic knowledge of private networks and Clef. These topics are covered on our [private networks](/content/docs/developers/geth-developer/private-network) and [Introduction to Clef](/content/docs/tools/Clef/introduction) pages. -{:toc} -- this will be removed by the toc ## Prepping a Clique network -First of all, set up a rudimentary testnet to have something to sign. Create a new keystore (password `testtesttest`) +First of all, set up a rudimentary testnet to have something to sign. Create a new keystore (password `testtesttest`): ```terminal $ geth account new --datadir ./ddir @@ -186,6 +185,7 @@ And indeed, after approving with `y`, the password is not required - the signed ```terminal INFO [06-16|11:36:46.714] Successfully sealed new block number=1 sealhash=9589ed..662d03 hash=bd20b9..af8b87 elapsed=4.214s ``` + This mode of operation offers quite a poor UX because each block to be sealed requires manual approval. That is fixed in the following section. ## Using rules to approve blocks @@ -334,11 +334,7 @@ DEBUG[06-16|14:20:33.584] Served account_signData reqid=5 durat ## Refinements -If an attacker find the Clef "external" interface (which would only happen if you start it with `http` enabled), they -- cannot make it sign arbitrary transactions, -- cannot sign arbitrary data message, - -However, they could still make it sign e.g. 1000 versions of a certain block height, making the chain very unstable. +If an attacker finds the Clef "external" interface (which would only happen if you start it with `--http` enabled), they cannot sign arbitrary data or transactions. However, they could still make it sign e.g. 1000 versions of a certain block height, making the chain very unstable. It is possible for rule execution to be stateful (i.e. storing data). In this case, one could, for example, store what block heights have been sealed and reject sealing a particular block height twice. In other words, these rules could be used to build a miniature version of an execution layer slashing-db. @@ -381,12 +377,13 @@ JS:> number 46 latest 45 INFO [06-16|22:26:44.313] Op approved DEBUG[06-16|22:26:45.317] Served account_signData reqid=4 duration=1.010612774s ``` -This might be a bit over-the-top, security-wise, and may cause problems if, for some reason, a clique-deadlock needs to be resolved by rolling back and continuing on a side-chain. It is mainly meant as a demonstration that rules can use Javascript and statefulness to construct very intricate signing logic. +This might be a bit over-the-top security-wise, and may cause problems if, for some reason, a clique-deadlock needs to be resolved by rolling back and continuing on a side-chain. It is mainly meant as a demonstration that rules can use Javascript and statefulness to construct very intricate signing logic. ## TLDR quick-version Creation and attestation is a one-off event: + ```sh ## Create the rules-file cat << END > rules.js diff --git a/content/docs/tools/Clef/Introduction.md b/content/docs/tools/Clef/Introduction.md index 2aeadde9ac..fd7cac89e2 100644 --- a/content/docs/tools/Clef/Introduction.md +++ b/content/docs/tools/Clef/Introduction.md @@ -1,24 +1,11 @@ --- title: Introduction to Clef -sort_key: A +description: Introduction to the external signing tool, Clef --- -{:toc} -- this will be removed by the toc - ## What is Clef? -Clef is a tool for **signing transactions and data** in a secure local environment. -t is intended to become a more composable and secure replacement for Geth's built-in -account management. Clef decouples key management from Geth itself, meaning it can be -used as an independent, standalone key management and signing application, or it -can be integrated into Geth. This provides a more flexible modular tool compared to -Geth's account manager. Clef can be used safely in situations where access to Ethereum is -via a remote and/or untrusted node because signing happens locally, either manually or -automatically using custom rulesets. The separation of Clef from the node itself enables it -to run as a daemon on the same machine as the client software, on a secure usb-stick like -[USB armory](https://inversepath.com/usbarmory), or even a separate VM in a -[QubesOS](https://www.qubes-os.org/) type setup. +Clef is a tool for **signing transactions and data** in a secure local environment. It is intended to become a more composable and secure replacement for Geth's built-in account management. Clef decouples key management from Geth itself, meaning it can be used as an independent, standalone key management and signing application, or it can be integrated into Geth. This provides a more flexible modular tool compared to Geth's account manager. Clef can be used safely in situations where access to Ethereum is via a remote and/or untrusted node because signing happens locally, either manually or automatically using custom rulesets. The separation of Clef from the node itself enables it to run as a daemon on the same machine as the client software, on a secure usb-stick like [USB armory](https://inversepath.com/usbarmory), or even a separate VM in a [QubesOS](https://www.qubes-os.org/) type setup. ## Installing and starting Clef @@ -30,9 +17,7 @@ However, Clef is not bound to Geth and can be built on its own using: `make clef` -Once built, Clef must be initialized. This includes storing some data, some of which is sensitive -(such as passwords, account data, signing rules etc). Initializing Clef takes that data and -encrypts it using a user-defined password. +Once built, Clef must be initialized. This includes storing some data, some of which is sensitive (such as passwords, account data, signing rules etc). Initializing Clef takes that data and encrypts it using a user-defined password. `clef init` @@ -71,66 +56,31 @@ You should treat 'masterseed.json' with utmost secrecy and make a backup of it! ## Security model -One of the major benefits of Clef is that it is decoupled from the client software, -meaning it can be used by users and dapps to sign data and transactions in a secure, -local environment and send the signed packet to an arbitrary Ethereum entry-point, which -might include, for example, an untrusted remote node. Alternatively, Clef can simply be -used as a standalone, composable signer that can be a backend component for decentralized -applications. This requires a secure architecture that separates cryptographic operations -from user interactions and internal/external communication. +One of the major benefits of Clef is that it is decoupled from the client software, meaning it can be used by users and dapps to sign data and transactions in a secure, local environment and send the signed packet to an arbitrary Ethereum entry-point, which might include, for example, an untrusted remote node. Alternatively, Clef can simply be used as a standalone, composable signer that can be a backend component for decentralized applications. This requires a secure architecture that separates cryptographic operations from user interactions and internal/external communication. The security model of Clef is as follows: -* A self-contained binary controls all cryptographic operations including encryption, - decryption and storage of keystore files, and signing data and transactions. +* A self-contained binary controls all cryptographic operations including encryption, decryption and storage of keystore files, and signing data and transactions. -* A well defined, deliberately minimal "external" API is used to communicate with the - Clef binary - Clef considers this external traffic to be UNTRUSTED. This means Clef - does not accept any credentials and does not recognize authority of requests received - over this channel. Clef listens on `http.addr:http.port` or `ipcpath` - the same as Geth - - and expects messages to be formatted using the [JSON-RPC 2.0 standard](https://www.jsonrpc.org/specification). - Some of the external API calls require some user interaction (manual approve/deny)- if it is - not received responses can be delayed indefinitely. +* A well defined, deliberately minimal "external" API is used to communicate with the Clef binary - Clef considers this external traffic to be UNTRUSTED. This means Clef does not accept any credentials and does not recognize authority of requests received over this channel. Clef listens on `http.addr:http.port` or `ipcpath` - the same as Geth - and expects messages to be formatted using the [JSON-RPC 2.0 standard](https://www.jsonrpc.org/specification). Some of the external API calls require some user interaction (manual approve/deny)- if it is not received responses can be delayed indefinitely. -* Clef communicates with the process that invoked the binary using stin/stout. The process - invoking the binary is usually the native console-based user interface (UI) but there is - also an API that enables communication with an external UI. This has to be enabled using `--stdio-ui` - at startup. This channel is considered TRUSTED and is used to pass approvals and passwords between - the user and Clef. +* Clef communicates with the process that invoked the binary using stin/stout. The process invoking the binary is usually the native console-based user interface (UI) but there is also an API that enables communication with an external UI. This has to be enabled using `--stdio-ui` at startup. This channel is considered TRUSTED and is used to pass approvals and passwords between the user and Clef. -* Clef does not store keys - the user is responsible for securely storing and backing up keyfiles. - Clef does store account passwords in its encrypted vault if they are explicitly provided to - Clef by the user to enable automatic account unlocking. +* Clef does not store keys - the user is responsible for securely storing and backing up keyfiles. Clef does store account passwords in its encrypted vault if they are explicitly provided to Clef by the user to enable automatic account unlocking. -The external API never handles any sensitive data directly, but it can be used to request Clef to -sign some data or a transaction. It is the internal API that controls signing and triggers requests for -manual approval (automatic approves actions that conform to attested rulesets) and passwords. +The external API never handles any sensitive data directly, but it can be used to request Clef to sign some data or a transaction. It is the internal API that controls signing and triggers requests for manual approval (automatic approves actions that conform to attested rulesets) and passwords. -The general flow for a basic transaction-signing operation using Clef and an Ethereum node such as -Geth is as follows: +The general flow for a basic transaction-signing operation using Clef and an Ethereum node such as Geth is as follows: -![Clef signing logic](/static/images/clef_sign_flow.png) +![Clef signing logic](/assets/clef_sign_flow.png) -In the case illustrated in the schematic above, Geth would be started with `--signer :` and -would relay requests to `eth.sendTransaction`. Text in `mono` font positioned along arrows shows the objects -passed between each component. - -Most users use Clef by manually approving transactions through the UI as in the schematic above, but it is also -possible to configure Clef to sign transactions without always prompting the user. This requires defining the -precise conditions under which a transaction will be signed. These conditions are known as `Rules` and they are -small Javascript snippets that are *attested* by the user by injecting the snippet's hash into Clef's secure -whitelist. Clef is then started with the rule file, so that requests that satisfy the conditions in the whitelisted -rule files are automatically signed. This is covered in detail on the [Rules page](/docs/_clef/Rules.md). +In the case illustrated in the schematic above, Geth would be started with `--signer :` and would relay requests to `eth.sendTransaction`. Text in `mono` font positioned along arrows shows the objects passed between each component. +Most users use Clef by manually approving transactions through the UI as in the schematic above, but it is also possible to configure Clef to sign transactions without always prompting the user. This requires defining the precise conditions under which a transaction will be signed. These conditions are known as `Rules` and they are small Javascript snippets that are *attested* by the user by injecting the snippet's hash into Clef's secure whitelist. Clef is then started with the rule file, so that requests that satisfy the conditions in the whitelisted rule files are automatically signed. This is covered in detail on the [Rules page](/content/docs/tools/Clef/rules). ## Basic usage -Clef is started on the command line using the `clef` command. Clef can be configured by providing flags and -commands to `clef` on startup. The full list of command line options is available [below](#command-line-options). -Frequently used options include `--keystore` and `--chainid` which configure the path to an existing keystore -and a network to connect to. These options default to `$HOME/.ethereum/keystore` and `1` (corresponding to -Ethereum Mainnet) respectively. The following code snippet starts Clef, providing a custom path to an existing -keystore and connecting to the Goerli testnet: +Clef is started on the command line using the `clef` command. Clef can be configured by providing flags and commands to `clef` on startup. The full list of command line options is available [below](#command-line-options). Frequently used options include `--keystore` and `--chainid` which configure the path to an existing keystore and a network to connect to. These options default to `$HOME/.ethereum/keystore` and `1` (corresponding to Ethereum Mainnet) respectively. The following code snippet starts Clef, providing a custom path to an existing keystore and connecting to the Goerli testnet: ```sh clef --keystore /my/keystore --chainid 5 @@ -155,12 +105,9 @@ Enter 'ok' to proceed: > ``` -Requests requiring account access or signing now require explicit consent in this terminal. -Activities such as sending transactions via a local Geth node's attached Javascript console or -RPC will now hang indefinitely, awaiting approval in this terminal. - -A much more detailed Clef tutorial is available on the [Tutorial page](/docs/clef/tutorial). +Requests requiring account access or signing now require explicit consent in this terminal. Activities such as sending transactions via a local Geth node's attached Javascript console or RPC will now hang indefinitely, awaiting approval in this terminal. +A much more detailed Clef tutorial is available on the [Tutorial page](/content/docs/tools/Clef/tutorial). ## Command line options @@ -200,9 +147,5 @@ GLOBAL OPTIONS: ## Summary -Clef is an external key management and signer tool that comes bundled with Geth but can either be used -as a backend account manager and signer for Geth or as a completely separate standalone application. Being -modular and composable it can be used as a component in decentralized applications or to sign data and -transactions in untrusted environments. Clef is intended to eventually replace Geth's built-in account -management tools. +Clef is an external key management and signer tool that comes bundled with Geth but can either be used as a backend account manager and signer for Geth or as a completely separate standalone application. Being modular and composable it can be used as a component in decentralized applications or to sign data and transactions in untrusted environments. Clef is intended to eventually replace Geth's built-in account management tools. \ No newline at end of file diff --git a/content/docs/tools/Clef/Rules.md b/content/docs/tools/Clef/Rules.md index b7a7416cce..95fc34cf5e 100644 --- a/content/docs/tools/Clef/Rules.md +++ b/content/docs/tools/Clef/Rules.md @@ -1,58 +1,35 @@ --- title: Rules -sort_key: C +description: Introduction to automated rulesets in Clef --- -This page provides a fairly low-level explanation for how rules are implemented in -Clef. It is a good idea to read the [Introduction to Clef](/docs/clef/introduction) -and the [Clef tutorial](/docs/clef/tutorial) before diving in to this page. +This page provides a fairly low-level explanation for how rules are implemented in Clef. It is a good idea to read the [Introduction to Clef](/content/docs/tools/Clef/introduction) and the [Clef tutorial](/content/docs/tools/Clef/tutorial) before diving in to this page. -{:toc} -- this will be removed by the toc - ## Introduction -Rules in Clef are sets of conditions that determine whether a given action can be -approved automatically without requiring manual intervention from the user. This can be -useful for automatically approving transactions between a user's own accounts, or -approving patterns that are commonly used by applications. Automatic signing also -requires Clef to have access to account passwords which is configured independently -of the ruleset. +Rules in Clef are sets of conditions that determine whether a given action can be approved automatically without requiring manual intervention from the user. This can be useful for automatically approving transactions between a user's own accounts, or approving patterns that are commonly used by applications. Automatic signing also requires Clef to have access to account passwords which is configured independently of the ruleset. Rules can define arbitrary conditions such as: -* Auto-approve 10 transactions with contract `CasinoDapp`, with value between `0.05 ether` and - `1 ether` per 24h period. +* Auto-approve 10 transactions with contract `CasinoDapp`, with value between `0.05 ether` and `1 ether` per 24h period. -* Auto-approve transactions to contract `Uniswapv2` with `value` up to 1 ether, if - `gas < 44k` and `gasPrice < 40Gwei`. +* Auto-approve transactions to contract `Uniswapv2` with `value` up to 1 ether, if `gas < 44k` and `gasPrice < 40Gwei`. * Auto-approve signing if the data to be signed contains the string `"approve_me"`. * Auto-approve any requests to list accounts in keystore if the request arrives over IPC -Because the rules are Javascript files they can be customized to implement any arbitrary logic on -the available request data. +Because the rules are Javascript files they can be customized to implement any arbitrary logic on the available request data. -This page will explain how rules are implemented in Clef and how best to manage credentials -when automatic rulesets are enabled. +This page will explain how rules are implemented in Clef and how best to manage credentials when automatic rulesets are enabled. ## Rule Implementation - -The ruleset engine acts as a gatekeeper to the command line interface - it auto-approves -any requests that meet the conditions defined in a set of authenticated rule files. This -prevents the user from having to manually approve or reject every request - instead they -can define common patterns in a rule file and abstract that task away to the ruleset engine. -The general architecture is as follows: +The ruleset engine acts as a gatekeeper to the command line interface - it auto-approves any requests that meet the conditions defined in a set of authenticated rule files. This prevents the user from having to manually approve or reject every request - instead they can define common patterns in a rule file and abstract that task away to the ruleset engine. The general architecture is as follows: ![Clef ruleset logic](/static/images/clef_ruleset.png) -When Clef receives a request, the ruleset engine evaluates a Javascript file for -each method defined in the internal [UI API docs](/docs/clef/apis). For example the code -snippet below is an example ruleset that calls the function `ApproveTx`. The call to `ApproveTx` -is invoking the `ui_approveTx` [JSON_RPC API endpoint](/docs/clef/apis/#ui-api). Every time an RPC -method is invoked the Javascript code is executed in a freshly instantiated virtual machine. +When Clef receives a request, the ruleset engine evaluates a Javascript file for each method defined in the internal [UI API docs](/content/docs/tools/Clef/apis). For example the code snippet below is an example ruleset that calls the function `ApproveTx`. The call to `ApproveTx` is invoking the `ui_approveTx` [JSON_RPC API endpoint](/content/docs/tools/Clef/apis/#ui-api). Every time an RPC method is invoked the Javascript code is executed in a freshly instantiated virtual machine. ```js function asBig(str) { @@ -102,43 +79,33 @@ handled in different ways: | Anything else | Pass decision to UI for manual approval | -There are some additional noteworthy implementation details that are important -for defining rules correctly in `ruleset.js`: +There are some additional noteworthy implementation details that are important for defining rules correctly in `ruleset.js`: * The code in `ruleset.js` **cannot** load external Javascript files. * The Javascript engine can access `storage` and `console` -* The only preloaded library in the Javascript environment is - `bignumber.js` version `2.0.3`. +* The only preloaded library in the Javascript environment is `bignumber.js` version `2.0.3`. -* Each invocation is made in a fresh virtual machine meaning data cannot be - stored in global variables between invocations. +* Each invocation is made in a fresh virtual machine meaning data cannot be stored in global variables between invocations. -* Since no global variable storage is available, disk backed `storage` must be - used - rules should not rely on ephemeral data. +* Since no global variable storage is available, disk backed `storage` must be used - rules should not rely on ephemeral data. -* Javascript API parameters are always objects. This ensures parameters are - accessed by _key_ to avoid misordering errors. +* Javascript API parameters are always objects. This ensures parameters are accessed by _key_ to avoid misordering errors. * Otto VM uses ES5. ES6-specific features (such as Typed Arrays) are not supported. -* The regular expression engine (re2/regexp) in Otto VM is not fully compatible - with the [ECMA5 specification](https://tc39.es/ecma262/#sec-intro). +* The regular expression engine (re2/regexp) in Otto VM is not fully compatible with the [ECMA5 specification](https://tc39.es/ecma262/#sec-intro). -* [Strict mode](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Strict_mode) - is not supported. "Use strict" will parse but it does nothing. +* [Strict mode](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Strict_mode) is not supported. "Use strict" will parse but it does nothing. ## Credential management -The ability to auto-approve transaction requires that the signer has -the necessary credentials, i.e. account passwords, to decrypt keyfiles. +The ability to auto-approve transaction requires that the signer has the necessary credentials, i.e. account passwords, to decrypt keyfiles. These are stored encrypted as follows: -When the `signer` is started it generates a seed that is locked with a -user specified password. The seed is saved to a location that defaults to -`$HOME/.clef/masterseed.json`. The `seed` itself is a blob of bytes. +When the `signer` is started it generates a seed that is locked with a user specified password. The seed is saved to a location that defaults to `$HOME/.clef/masterseed.json`. The `seed` itself is a blob of bytes. The `signer` uses the `seed` to: @@ -147,56 +114,28 @@ The `signer` uses the `seed` to: * `$HOME/.clef/790046d38025/credentials.json` * Generate the encryption password for the config and credentials files. -`config.json` stores the hashes of any attested rulesets. `credentials.json` -stores encrypted account passwords. The masterseed is required to decrypt -these files. The decrypted account passwords can then be used to decrypt keyfiles. +`config.json` stores the hashes of any attested rulesets. `credentials.json` stores encrypted account passwords. The masterseed is required to decrypt these files. The decrypted account passwords can then be used to decrypt keyfiles. ## Security ### The Javascript VM -The downside of the very flexible rule implementation included in Clef is -that the `signer` binary needs to contain a Javascript engine. This is an -additional attack surface. The only viable attack is for an adversary to -somehow extract cryptographic keys from memory during the Javascript VM execution. -The hash-based rule attestation condition means the actual Javascript code -executed by the Javascript engine is not a viable attack surface -- since if the attacker can control the ruleset, a much simpler -attack would be to surreptitiously insert an attested "always-approve" rule -instead of attempting to exploit the Javascript virtual machine. The Javascript -engine is quite simple to implement and there are currently no known security -vulnerabilities, not have there been any security problems identified for the +The downside of the very flexible rule implementation included in Clef is that the `signer` binary needs to contain a Javascript engine. This is an additional attack surface. The only viable attack is for an adversary to somehow extract cryptographic keys from memory during the Javascript VM execution. The hash-based rule attestation condition means the actual Javascript code executed by the Javascript engine is not a viable attack surface -- since if the attacker can control the ruleset, a much simpler attack would be to surreptitiously insert an attested "always-approve" rule instead of attempting to exploit the Javascript virtual machine. The Javascript engine is quite simple to implement and there are currently no known security vulnerabilities, not have there been any security problems identified for the similar Javascript VM implemented in Geth. ### Writing rules -Since the user has complete freedom to write custom rules, it is plausible that those rules -could create unintended security vulnerabilities. This can only really be protected by -coding very carefully and trying to test rulesets (e.g. on a private testnet) before +Since the user has complete freedom to write custom rules, it is plausible that those rules could create unintended security vulnerabilities. This can only really be protected by coding very carefully and trying to test rulesets (e.g. on a private testnet) before implementing them on a public network. -Javascript is very flexible but also easy to write incorrectly. For example, users -might assume that javascript can handle large integers natively rather than explicitly -using `bigInt`. This is an error commonly encountered in the Ethereum context when -users attempt to multiply `gas` by `gasCost`. - -It’s unclear whether any other language would be more secure - there is alwas the possibility -of implementing an insecure rule. - -### File security +Javascript is very flexible but also easy to write incorrectly. For example, users might assume that javascript can handle large integers natively rather than explicitly using `bigInt`. This is an error commonly encountered in the Ethereum context when users attempt to multiply `gas` by `gasCost`. +It’s unclear whether any other language would be more secure - there is alwas the possibility of implementing an insecure rule. ### Credential security -Clef implements a secure, encrypted vault for storing sensitive data. This vault is -encrypted using a `masterseed` which the user is responsible for storing and backing -up safely and securely. Since this `masterseed` is used to decrypt the secure vault, -and its security is not handled by Clef, it could represent a security vulnerability -if the user does not implement best practise in keeping it safe. +Clef implements a secure, encrypted vault for storing sensitive data. This vault is encrypted using a `masterseed` which the user is responsible for storing and backing up safely and securely. Since this `masterseed` is used to decrypt the secure vault, and its security is not handled by Clef, it could represent a security vulnerability if the user does not implement best practise in keeping it safe. -The same is also true for keys. Keys are not stored by Clef, they are only accessed -using account passwords that Clef does store in its vault. The keys themselves are stored -in an external `keystore` whose security is the responsibility of the user. If the -keys are compromised, the account is not safe irrespective of the security benefits -derived from Clef. +The same is also true for keys. Keys are not stored by Clef, they are only accessed using account passwords that Clef does store in its vault. The keys themselves are stored in an external `keystore` whose security is the responsibility of the user. If the keys are compromised, the account is not safe irrespective of the security benefits derived from Clef. ## Ruleset examples @@ -316,9 +255,4 @@ function OnApprovedTx(resp) { ## Summary -Rules are sets of conditions encoded in Javascript files that enable certain actions to -be auto-approved by Clef. This page outlined the implementation details and security -considerations that will help to build suitrable ruleset files. See the -[Clef Github](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef) for further reading. - - +Rules are sets of conditions encoded in Javascript files that enable certain actions to be auto-approved by Clef. This page outlined the implementation details and security considerations that will help to build suitrable ruleset files. See the [Clef Github](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef) for further reading. diff --git a/content/docs/tools/Clef/datatypes.md b/content/docs/tools/Clef/datatypes.md index fc1499c00f..a3772eac0b 100644 --- a/content/docs/tools/Clef/datatypes.md +++ b/content/docs/tools/Clef/datatypes.md @@ -1,6 +1,6 @@ --- title: Communication data types -sort_key: F +description: The data types used by the Clef APIs --- ## UI Client interface From 5026c8d557f8c300329109449a1bccca0a3bc816 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 16 Aug 2022 14:10:29 +0100 Subject: [PATCH 032/432] md formatting for clef docs --- content/docs/monitoring/dashboards.md | 64 +++----- content/docs/tools/Clef/Setup.md | 41 ++--- content/docs/tools/Clef/Tutorial.md | 214 ++++++-------------------- 3 files changed, 87 insertions(+), 232 deletions(-) diff --git a/content/docs/monitoring/dashboards.md b/content/docs/monitoring/dashboards.md index c3c1fff839..b2c8aea8c4 100644 --- a/content/docs/monitoring/dashboards.md +++ b/content/docs/monitoring/dashboards.md @@ -1,10 +1,9 @@ --- title: Monitoring Geth with InfluxDB and Grafana +description: introduction to monitoring Geth nodes with Grafana --- -There are several ways to monitor the performance of a Geth node. Insights into a node's -performance are useful for debugging, tuning and understanding what is really happening when -Geth is running. +There are several ways to monitor the performance of a Geth node. Insights into a node's performance are useful for debugging, tuning and understanding what is really happening when Geth is running. ## Prerequisites {#prerequisites} @@ -13,14 +12,11 @@ To follow along with the instructions on this page it will be useful to have: - a running Geth instance. - basic working knowlegde of bash/terminal. -[This video](https://www.youtube.com/watch?v=cOBab8IJMYI) provides an excellent introduction -to Geth monitoring. +[This video](https://www.youtube.com/watch?v=cOBab8IJMYI) provides an excellent introduction to Geth monitoring. ## Monitoring stack {#monitoring-stack} -An Ethereum client collects lots of data which can be read in the form of a chronological -database. To make monitoring easier, this data can be fed into data visualisation software. -There are many options available: +An Ethereum client collects lots of data which can be read in the form of a chronological database. To make monitoring easier, this data can be fed into data visualisation software. There are many options available: - [Prometheus](https://prometheus.io/) (pull model) - [InfluxDB](https://www.influxdata.com/get-influxdb/) (push model) @@ -29,18 +25,13 @@ There are many options available: - [Datadog](https://www.datadoghq.com/) - [Chronograf](https://www.influxdata.com/time-series-platform/chronograf/) -There's also [Geth Prometheus Exporter](https://github.com/hunterlong/gethexporter), an option -preconfigured with InfluxDB and Grafana. You can set it up easily using docker and -[Ethbian OS](https://ethbian.org/index.html) for RPi 4. +There's also [Geth Prometheus Exporter](https://github.com/hunterlong/gethexporter), an option preconfigured with InfluxDB and Grafana. You can set it up easily using docker and [Ethbian OS](https://ethbian.org/index.html) for RPi 4. -On this page, a Geth client will be configured to push data into a InfluxDB database and -Grafana will be used to visualize the data. +On this page, a Geth client will be configured to push data into a InfluxDB database and Grafana will be used to visualize the data. ## Setting up InfluxDB {#setting-up-influxdb} -InfluxDB can be downloaded from the [Influxdata release page](https://portal.influxdata.com/downloads/). -It can also be installed from a [repository](https://repos.influxdata.com/). -For example for a Debian based Linux operating system: +InfluxDB can be downloaded from the [Influxdata release page](https://portal.influxdata.com/downloads/). It can also be installed from a [repository](https://repos.influxdata.com/). For example for a Debian based Linux operating system: ```sh curl -tlsv1.3 --proto =https -sL https://repos.influxdata.com/influxdb.key | sudo apt-key add @@ -53,8 +44,7 @@ sudo systemctl start influxdb sudo apt install influxdb-client ``` -By default,InfluxDB it is reachable at `localhost:8086`. Before using the `influx` client, a new user with admin privileges -needs to be created. This user will serve for high level management, creating databases and users. +By default,InfluxDB it is reachable at `localhost:8086`. Before using the `influx` client, a new user with admin privileges needs to be created. This user will serve for high level management, creating databases and users. ```sh curl -XPOST "http://localhost:8086/query" --data-urlencode "q=CREATE USER username WITH PASSWORD 'password' WITH ALL PRIVILEGES" @@ -90,10 +80,7 @@ InfluxDB is running and configured to store metrics from Geth. ## Preparing Geth {#preparing-geth} -After setting up database, metrics need to be enabled in Geth. Various options are available, -as documented in the `METRICS AND STATS OPTIONS` in `geth --help` and in our [metrics page](). -In this case Geth will be configured to push data into InfluxDB. Basic setup specifies the endpoint -where InfluxDB is reachable and authenticates the database. +After setting up database, metrics need to be enabled in Geth. Various options are available, as documented in the `METRICS AND STATS OPTIONS` in `geth --help` and in our [metrics page](). In this case Geth will be configured to push data into InfluxDB. Basic setup specifies the endpoint where InfluxDB is reachable and authenticates the database. ```sh geth --metrics --metrics.influxdb --metrics.influxdb.endpoint "http://0.0.0.0:8086" --metrics.influxdb.username "geth" --metrics.influxdb.password "chosenpassword" @@ -110,12 +97,9 @@ show measurements ## Setting up Grafana {#setting-up-grafana} -With the InfluxDB database setup and successfully receiving data from Geth, the next step is to -install Grafana so that the data can be visualized. Instructions for specific operating systems -are available on the Grafana [downloads page](https://grafana.com/grafana/download?pg=get&plcmt=selfmanaged-box1-cta1). +With the InfluxDB database setup and successfully receiving data from Geth, the next step is to install Grafana so that the data can be visualized. Instructions for specific operating systems are available on the Grafana [downloads page](https://grafana.com/grafana/download?pg=get&plcmt=selfmanaged-box1-cta1). -Alternatively, the following code snippet shows how to download, install and run Grafana on a Debian -based Linux system: +Alternatively, the following code snippet shows how to download, install and run Grafana on a Debian based Linux system: ```sh curl -tlsv1.3 --proto =https -sL https://packages.grafana.com/gpg.key | sudo apt-key add - @@ -126,14 +110,11 @@ sudo systemctl enable grafana-server sudo systemctl start grafana-server ``` -When Grafana is up and running, it should be reachable at `localhost:3000`. A browser can be pointed to that URL -to access a visualization dashboard. The browser will prompt for login credentials (user: `admin` and password: `admin`). -When prompted, the default password should be changed and saved. +When Grafana is up and running, it should be reachable at `localhost:3000`. A browser can be pointed to that URL to access a visualization dashboard. The browser will prompt for login credentials (user: `admin` and password: `admin`). When prompted, the default password should be changed and saved. ![](/assets/grafana1.png) -The browser first redirects to the Grafana home page to set up the source data. -Click on the configuration icon in the left bar and select "Data sources". +The browser first redirects to the Grafana home page to set up the source data. Click on the configuration icon in the left bar and select "Data sources". ![](/assets/grafana2.png) @@ -145,8 +126,7 @@ Select "InfluxDB" and proceed. ![](/assets/grafana4.png) -Data source configuration is pretty straight forward if you are running tools on the same machine. You need to set the -InfluxDB address and details for accessing the database. Refer to the picture below. +Data source configuration is pretty straight forward if the tools run on the same machine as Geth. The InfluxDB address and details for accessing the database must be set. Refer to the image below. ![](/assets/grafana5.png) @@ -154,20 +134,18 @@ If everything is complete and InfluxDB is reachable, click on "Save and test" an ![](/assets/grafana6.png) -Grafana is now set up to read data from InfluxDB. Now you need to create a dashboard which will interpret and display it. -Dashboards properties are encoded in JSON files which can be created by anybody and easily imported. On the left bar, -click on "Create and Import". +Grafana is now set up to read data from InfluxDB. Now a dashboard can be created to interpret and display it. Dashboards properties are encoded in JSON files which can be created by anybody and easily imported. On the left bar, click on "Create and Import". ![](/assets/grafana7.png) -For a Geth monitoring dashboard, copy the ID of [this dashboard](https://grafana.com/grafana/dashboards/13877/) -and paste it in the "Import page" in Grafana. After saving the dashboard, it should look like this: +For a Geth monitoring dashboard, copy the ID of [this dashboard](https://grafana.com/grafana/dashboards/13877/) and paste it in the "Import page" in Grafana. After saving the dashboard, it should look like this: ![](/assets/grafana8.png) -The dashboards can be customized further. Each panel can be edited, moved, removed or added. -To learn more about how dashboards work, refer to [Grafana's documentation](https://grafana.com/docs/grafana/latest/dashboards/). +The dashboards can be customized further. Each panel can be edited, moved, removed or added. To learn more about how dashboards work, refer to [Grafana's documentation](https://grafana.com/docs/grafana/latest/dashboards/). -Some users might also be interested in automatic [alerting](https://grafana.com/docs/grafana/latest/alerting/), which -sets up alert notifications that are sent automatically when metrics reach certain values. Various communication channels are supported. +Some users might also be interested in automatic [alerting](https://grafana.com/docs/grafana/latest/alerting/), which sets up alert notifications that are sent automatically when metrics reach certain values. Various communication channels are supported. +## Summary + +This page has outlined how to set up a simple node monitoring dashboard using Grafana. \ No newline at end of file diff --git a/content/docs/tools/Clef/Setup.md b/content/docs/tools/Clef/Setup.md index 205a37a223..2ae9a90644 100644 --- a/content/docs/tools/Clef/Setup.md +++ b/content/docs/tools/Clef/Setup.md @@ -1,14 +1,11 @@ --- title: Advanced setup -sort_key: D +description: More advanced ways to set up Clef for additional security --- Clef is a signer and account management tool that is external to Geth. This means it can be run as a separate process or even on a separate machine to the one running Geth, for example on secure hardware that is not connected to any external network, or on secure virtual machines. This page describes how Clef can be used with Qubes OS to provide a more secure setup than a normal laptop. Using Clef with USBArmory hardware is also briefly described. -{:toc} -- this will be removed by the toc - ## Qubes OS ### Background @@ -36,19 +33,17 @@ There are two ways that this can be achieved: integrated via Qubes or integrated #### 1. Qubes Integrated -Qubes provides a facility for inter-qubes communication via `qrexec`. A qube can request to make a cross-qube RPC request -to another qube. The OS then asks the user if the call is permitted. +Qubes provides a facility for inter-qubes communication via `qrexec`. A qube can request to make a cross-qube RPC request to another qube. The OS then asks the user if the call is permitted. -![Example](qrexec-example.png) +![Example](assets/qrexec-example.png) -A policy-file can be created to allow such interaction. On the `target` domain, a service is invoked which can read the -`stdin` from the `client` qube. +A policy-file can be created to allow such interaction. On the `target` domain, a service is invoked which can read the `stdin` from the `client` qube. This is how [Split GPG](https://www.qubes-os.org/doc/split-gpg/) is implemented. Clef can be set up in the same way: ##### Server -![Clef via qrexec](clef_qubes_qrexec.png) +![Clef via qrexec](/assets/clef_qubes_qrexec.png) On the `target` qubes, we need to define the RPC service. @@ -71,12 +66,9 @@ if [ -S /home/user/.clef/clef.ipc ]; then fi ``` -This RPC service is not complete (see notes about HTTP headers below), but works as a proof-of-concept. -It will forward the data received on `stdin` (forwarded by the OS) to Clef's HTTP channel. +This RPC service is not complete (see notes about HTTP headers below), but works as a proof-of-concept. It will forward the data received on `stdin` (forwarded by the OS) to Clef's HTTP channel. -It would have been possible to send data directly to the `/home/user/.clef/.clef.ipc` -socket via e.g `nc -U /home/user/.clef/clef.ipc`, but the reason for sending the request -data over `HTTP` instead of `IPC` is for the ability to forward `HTTP` headers. +It would have been possible to send data directly to the `/home/user/.clef/.clef.ipc` socket via e.g `nc -U /home/user/.clef/clef.ipc`, but the reason for sending the request data over `HTTP` instead of `IPC` is for the ability to forward `HTTP` headers. To enable the service: @@ -85,8 +77,7 @@ sudo cp qubes.Clefsign /etc/qubes-rpc/ sudo chmod +x /etc/qubes-rpc/ qubes.Clefsign ``` -This setup uses [gtksigner](https://github.com/holiman/gtksigner), which is a very minimal GTK-based UI that works well -with minimal requirements. +This setup uses [gtksigner](https://github.com/holiman/gtksigner), which is a very minimal GTK-based UI that works well with minimal requirements. ##### Client @@ -169,21 +160,19 @@ However, it comes with a couple of drawbacks: #### 2. Network integrated -The second way to set up Clef on a qubes system is to allow networking, and have Clef listen to a port which is accessible -from other qubes. +The second way to set up Clef on a qubes system is to allow networking, and have Clef listen to a port which is accessible from other qubes. ![Clef via http](clef_qubes_http.png) ## USBArmory -The [USB armory](https://inversepath.com/usbarmory) is an open source hardware design with an 800 MHz ARM processor. It is a pocket-size -computer. When inserted into a laptop, it identifies itself as a USB network interface, basically adding another network -to your computer that can be used to SSH into the device. +The [USB armory](https://inversepath.com/usbarmory) is an open source hardware design with an 800 MHz ARM processor. It is a pocket-sized computer. When inserted into a laptop, it identifies itself as a USB network interface, basically adding another network to your computer that can be used to SSH into the device. -Running Clef off a USB armory means that the armory can be used as a very versatile offline computer, which only -ever connects to a local network between the local computer and the device itself. +Running Clef off a USB armory means that the armory can be used as a very versatile offline computer, which only ever connects to a local network between the local computer and the device itself. -Needless to say, while this model should be fairly secure against remote attacks, an attacker with physical access -to the USB Armory would trivially be able to extract the contents of the device filesystem. +Needless to say, while this model should be fairly secure against remote attacks, an attacker with physical access to the USB Armory would trivially be able to extract the contents of the device filesystem. +## Summary + +This page introduced two ways to setup Clef that give additional security compared to running on a normal laptop. \ No newline at end of file diff --git a/content/docs/tools/Clef/Tutorial.md b/content/docs/tools/Clef/Tutorial.md index d7919bfde1..35c5318b59 100644 --- a/content/docs/tools/Clef/Tutorial.md +++ b/content/docs/tools/Clef/Tutorial.md @@ -1,22 +1,14 @@ --- title: Tutorial -sort_key: A +description: Beginner tutorial for using Clef as an external signer for Geth --- -This page provides a step-by-step walkthrough tutorial demonstrating some common uses of Clef. This -includes manual approvals and automated rules. Clef is presented both as a standalone general signer -with requests made via RPC and also as a backend signer for Geth. - -{:toc} -- this will be removed by the toc +This page provides a step-by-step walkthrough tutorial demonstrating some common uses of Clef. This includes manual approvals and automated rules. Clef is presented both as a standalone general signer with requests made via RPC and also as a backend signer for Geth. ## Initializing Clef -First things first, Clef needs to store some data itself. Since that data might be sensitive -(passwords, signing rules, accounts), Clef's entire storage is encrypted. To support encrypting data, -the first step is to initialize Clef with a random master seed, itself too encrypted with your chosen -password: +First things first, Clef needs to store some data itself. Since that data might be sensitive (passwords, signing rules, accounts), Clef's entire storage is encrypted. To support encrypting data, the first step is to initialize Clef with a random master seed, itself too encrypted with a password: ```text $ clef init @@ -57,18 +49,9 @@ You should treat 'masterseed.json' with utmost secrecy and make a backup of it! ## Remote interactions -This tutorial will use Clef with Geth on the Goerli testnet. The accounts used will be in the -Goerli keystore with the path `~/go-ethereum/goerli-data/keystore`. The tutorial assumes there -are two accounts in this keystore. Instructions for creating accounts can be found on the -[Account managament page](/docs/interface/managing-your-accounts). Note that Clef can also interact -with hardware wallets, although that is not demonstrated here. +This tutorial will use Clef with Geth on the Goerli testnet. The accounts used will be in the Goerli keystore with the path `~/go-ethereum/goerli-data/keystore`. The tutorial assumes there are two accounts in this keystore. Instructions for creating accounts can be found on the [Account managament page](/docs/interface/managing-your-accounts). Note that Clef can also interact with hardware wallets, although that is not demonstrated here. -Clef should be started before Geth, otherwise Geth will complain that it cannot find a Clef -instance to connect to. Clef should be started with the correct `chainid` for Goerli. Clef -itself does not connect to a blockchain, but the `chainID` parameter is included in the data -that is aggregated to form a signature. Clef also needs a path to the correct keystore passed to -the `--keystore` command. A custom path to the config directory can also be provided. This is where the -`ipc` file will be saved which is needed to connect Clef to Geth: +Clef should be started before Geth, otherwise Geth will complain that it cannot find a Clef instance to connect to. Clef should be started with the correct `chainid` for Goerli. Clef itself does not connect to a blockchain, but the `chainID` parameter is included in the data that is aggregated to form a signature. Clef also needs a path to the correct keystore passed to the `--keystore` command. A custom path to the config directory can also be provided. This is where the `ipc` file will be saved which is needed to connect Clef to Geth: ```sh clef --keystore ~/go-ethereum/goerli-data/keystore --configdir ~/go-ethereum/goerli-data/clef --chainid=5 @@ -92,22 +75,15 @@ INFO [07-01|11:00:46.392] IPC endpoint opened url=go-ethere * extapi_ipc : go-ethereum/goerli-data/clef/clef.ipc ``` -Clef starts up in CLI (Command Line Interface) mode by default. Arbitrary remote -processes may *request* account interactions (e.g. sign a transaction), which the user -can individually *confirm* or *deny*. +Clef starts up in CLI (Command Line Interface) mode by default. Arbitrary remote processes may *request* account interactions (e.g. sign a transaction), which the user can individually *confirm* or *deny*. -The code snippet below shows a request made to Clef via its *External API endpoint* using -[NetCat](http://netcat.sourceforge.net/). The request invokes the -["account_list"](/docs/_clef/apis#accountlist) endpoint which lists the accounts in the keystore. -This command should be run in a new terminal. +The code snippet below shows a request made to Clef via its *External API endpoint* using [NetCat](http://netcat.sourceforge.net/). The request invokes the ["account_list"](/content/docs/tools/Clef/apis#accountlist) endpoint which lists the accounts in the keystore. This command should be run in a new terminal. ```sh echo '{"id": 1, "jsonrpc": "2.0", "method": "account_list"}' | nc -U ~/.clef/clef.ipc ``` -The terminal used to send the command will now hang. This is because the process is awaiting -confirmation from Clef. Switching to the Clef console reveals Clef's prompt to the user to -confirm or deny the request: +The terminal used to send the command will now hang. This is because the process is awaiting confirmation from Clef. Switching to the Clef console reveals Clef's prompt to the user to confirm or deny the request: ```terminal -------- List Account request-------------- @@ -127,8 +103,7 @@ Additional HTTP header data, provided by the external caller: Approve? [y/N]: ``` -Depending on whether the request is approved or denied, the NetCat process in the other terminal -will receive one of the following responses: +Depending on whether the request is approved or denied, the NetCat process in the other terminal will receive one of the following responses: ```terminal {"jsonrpc":"2.0","id":1,"result":["0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3","0x086278a6c067775f71d6b2bb1856db6e28c30418"]} @@ -140,22 +115,11 @@ or {"jsonrpc":"2.0","id":1,"error":{"code":-32000,"message":"Request denied"}} ``` -Apart from listing accounts, you can also *request* creating a new account, signing transactions -and data or recovering signatures. The available methods are documented in the Clef -[External API Spec](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef#external-api-1) -and the [External API Changelog](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/extapi_changelog.md). +Apart from listing accounts, a *request* can be submitted to create a new account, signing transactions and data or recovering signatures. The available methods are documented in the Clef [External API Spec](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef#external-api-1) and the [External API Changelog](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/extapi_changelog.md). -*Note, the number of things you can do from the External API is deliberately small to limit -the power of remote calls as much as possible! Clef has an -[Internal API](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef#ui-api-1) -too for the UI (User Interface) which is much richer and can support custom interfaces on top. -But that's out of scope here.* +*Note, the number of things that can be done from the External API is deliberately small to limit the power of remote calls as much as possible! Clef has an [Internal API](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef#ui-api-1) too for the UI (User Interface) which is much richer and can support custom interfaces on top. But that's out of scope here.* -The example above used Clef completely independently of Geth. However, by defining Clef as -the signer when Geth is started imposes Clef's `request - confirm - result` pattern to any -interaction with the local Geth node that touches accounts, including requests made using -RPC or an attached Javascript console. To demonstrate this, Geth can be started, -with Clef as the signer: +The example above used Clef completely independently of Geth. However, by defining Clef as the signer when Geth is started imposes Clef's `request - confirm - result` pattern to any interaction with the local Geth node that touches accounts, including requests made using RPC or an attached Javascript console. To demonstrate this, Geth can be started, with Clef as the signer: ```sh geth --goerli --datadir goerli-data --signer=goerli-data/clef/clef.ipc @@ -173,9 +137,7 @@ A simple request to list the accounts in the keystore will cause the Javascript eth.accounts ``` -Switching to the Clef terminal reveals that this is because the request is awaiting explicit -confirmation from the user. The log is identical to the one shown above, when the same request -for account information was made to Clef via Netcat: +Switching to the Clef terminal reveals that this is because the request is awaiting explicit confirmation from the user. The log is identical to the one shown above, when the same request for account information was made to Clef via Netcat: ```terminal -------- List Account request-------------- @@ -195,11 +157,9 @@ Additional HTTP header data, provided by the external caller: Approve? [y/N]: ``` -In this mode, the user is required to manually confirm every action that touches account data, -including querying accounts, signing and sending transactions. +In this mode, the user is required to manually confirm every action that touches account data, including querying accounts, signing and sending transactions. -The example below shows an ether transaction between the two accounts in the keystore -using `eth.sendTransaction` in the attached Javascript console. +The example below shows an ether transaction between the two accounts in the keystore using `eth.sendTransaction` in the attached Javascript console. ```js // this command requires 2x approval in Clef because it loads account data via eth.accounts[0] @@ -210,12 +170,8 @@ var tx = {from: eth.accounts[0], to: eth.accounts[1], value: web3.toWei(0.1, "et eth.sendTransaction(tx) ``` -This example demonstrates the power of Clef much more clearly than the account-listing example. -In the Clef terminal, all the details of the transaction are presented to the user so that they -can be reviewed before being confirmed. This gives the user an opportunity to review the fine -details and make absolutely sure they really want to sign the transaction. `eth.sendTransaction` -returns the following confirmation prompt in the Clef terminal: - +This example demonstrates the power of Clef much more clearly than the account-listing example. In the Clef terminal, all the details of the transaction are presented to the user so that they can be reviewed before being confirmed. This gives the user an opportunity to review the fine +details and make absolutely sure they really want to sign the transaction. `eth.sendTransaction` returns the following confirmation prompt in the Clef terminal: ```terminal -------- Transaction request---------------- @@ -241,34 +197,20 @@ Approve? [y/N] ``` -Approving this transaction causes Clef to prompt the user to provide the password for -the sender account. Providing the password enables the transaction to be signed and sent to -Geth for broadcasting to the network. The details of the signed transaction are displayed -in the console. Account passwords can also be stored in Clef's encrypted vault so that they -do not have to be manually entered - [more on this below](#account-passwords). +Approving this transaction causes Clef to prompt the user to provide the password for the sender account. Providing the password enables the transaction to be signed and sent to Geth for broadcasting to the network. The details of the signed transaction are displayed in the console. Account passwords can also be stored in Clef's encrypted vault so that they do not have to be manually entered - [more on this below](#account-passwords). ## Automatic rules -For most users, manually confirming every transaction is the right way to use Clef because a -human-in-the-loop can review every action. However, there are cases when it makes sense to -set up some rules which permit Clef to sign a transaction without prompting the user. - +For most users, manually confirming every transaction is the right way to use Clef because a human-in-the-loop can review every action. However, there are cases when it makes sense to set up some rules which permit Clef to sign a transaction without prompting the user. For example, well defined rules such as: -* Auto-approve transactions with Uniswap v2, with value between 0.1 and 0.5 ETH - per 24h period -* Auto-approve transactions to address `0xD9C9Cd5f6779558b6e0eD4e6Acf6b1947E7fA1F3` - as long as gas < 44k and gasPrice < 80Gwei - -can be encoded and intepreted by Clef's built-in ruleset engine. +* Auto-approve transactions with Uniswap v2, with value between 0.1 and 0.5 ETH per 24h period +* Auto-approve transactions to address `0xD9C9Cd5f6779558b6e0eD4e6Acf6b1947E7fA1F3` as long as gas < 44k and gasPrice < 80Gwei can be encoded and intepreted by Clef's built-in ruleset engine. ### Rule files -Rules are implemented as Javascript code in `js` files. The ruleset engine includes the -same methods as the JSON_RPC defined in the [UI Protocol](/docs/_clef/datatypes.md). -The following code snippet demonstrates a rule file that approves a transaction if it -satisfies the following conditions: +Rules are implemented as Javascript code in `js` files. The ruleset engine includes the same methods as the JSON_RPC defined in the [UI Protocol](/docs/_clef/datatypes.md). The following code snippet demonstrates a rule file that approves a transaction if it satisfies the following conditions: * the recipient is `0xae967917c465db8578ca9024c205720b1a3651a9` * the value is less than 50000000000000000 wei (0.05 ETH) @@ -320,11 +262,7 @@ There are three possible outcomes to this ruleset that are handled in different ### Attestations -Clef will not just accept and run arbitrary scripts - that would create an attack vector because a malicious party could -change the rule file. Instead, the user explicitly *attests* to a rule file, which involves injecting the file's SHA256 -hash into Clef's secure store. The following code snippet shows how to calculate a SHA256 hash for a file named `rules.js` -and pass it to Clef. Note that Clef will prompt the user to provide the master password because the Clef store has to -be decrypted in order to add the attestation to it. +Clef will not just accept and run arbitrary scripts - that would create an attack vector because a malicious party could change the rule file.Instead, the user explicitly *attests* to a rule file, which involves injecting the file's SHA256 hash into Clef's secure store. The following code snippet shows how to calculate a SHA256 hash for a file named `rules.js` and pass it to Clef. Note that Clef will prompt the user to provide the master password because the Clef store has to be decrypted in order to add the attestation to it. ```sh # calculate hash @@ -334,15 +272,11 @@ sha256sum rules.js clef attest 645b58e4f945e24d0221714ff29f6aa8e860382ced43490529db1695f5fcc71c ``` -Once this attestation has been added to the Clef store, it can be used to automatically approve -interactions that satisfy the conditions encoded in `rules.js` in Clef. - +Once this attestation has been added to the Clef store, it can be used to automatically approve interactions that satisfy the conditions encoded in `rules.js` in Clef. ### Account passwords -The rules described in `rules.js` above require access to the accounts in the Clef keystore which -are protected by user-defined passwords. The signer therefore requires access to these passwords -in order to automatically unlock the keystore and sign data and transactions using the accounts. +The rules described in `rules.js` above require access to the accounts in the Clef keystore which are protected by user-defined passwords. The signer therefore requires access to these passwords in order to automatically unlock the keystore and sign data and transactions using the accounts. This is done using `clef setpw`, passing the account address as the sole argument: @@ -362,16 +296,12 @@ Password: INFO [07-01|14:05:56.031] Credential store updated key=0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3 ``` -Note that Clef does not really 'unlock' an account, it just abstracts the process of providing the -password away from the end-user in specific, predefined scenarios. If an account password -exists in the Clef vault and the rule evaluates to "Approve" then Clef decrypts the password, -uses it to decrypt the key, does the requested signing and then re-locks the account. +Note that Clef does not really 'unlock' an account, it just abstracts the process of providing the password away from the end-user in specific, predefined scenarios. If an account password exists in the Clef vault and the rule evaluates to "Approve" then Clef decrypts the password, uses it to decrypt the key, does the requested signing and then re-locks the account. ### Implementing rules -Clef can be instructed to run an attested rule file simply by passing the path to `rules.js` -to the `--rules` flag: +Clef can be instructed to run an attested rule file simply by passing the path to `rules.js` to the `--rules` flag: ```sh clef --keystore go-ethereum/goerli-data/ --configdir go-ethereum/goerli-data/clef --chainid 5 --rules rules.js @@ -396,10 +326,7 @@ INFO [07-01|13:39:49.728] IPC endpoint opened url=go-ethere * extapi_ipc : go-ethereum/goerli-data/clef/clef.ipc ``` -Any request that satisfies the ruleset will now be auto-approved by the rule file, for example -the following request to sign a transaction made using the Geth Javascript console -(note that the password for account `0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3` -has already been provided to `setpw` and the recipient and value comply with the rules in `rules.js`): +Any request that satisfies the ruleset will now be auto-approved by the rule file, for example the following request to sign a transaction made using the Geth Javascript console (note that the password for account `0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3` has already been provided to `setpw` and the recipient and value comply with the rules in `rules.js`): ```js var tx = {to: "0xae967917c465db8578ca9024c205720b1a3651a9", from: "0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3", value: web3.toWei(0.01, "ether")} @@ -420,8 +347,7 @@ var tx = {to: "0xae967917c465db8578ca9024c205720b1a3651a9", from: "0xd4c4bb7d688 eth.sendTransaction(tx) ``` -These latter two transactions, that do not satisfy the encoded rules in `rules.js`, are not automatically approved, but instead pass the -decision back to the UI for manual approval by the user. +These latter two transactions, that do not satisfy the encoded rules in `rules.js`, are not automatically approved, but instead pass the decision back to the UI for manual approval by the user. ### Summary of basic usage @@ -443,12 +369,8 @@ To summarize, the steps required to run Clef with an automated ruleset that requ ## More rules -Since rules are defined as Javascript code, rulesets of arbitrary complexity can be created and they can -impose conditions on any part of a transaction, not only the recipient and value. - -A simple example is implementing a "whitelist" of recipients where transactions that have those -accounts in the `to` field are automatically signed (for example perhaps transactions between -a user's own accounts might be whitelisted): +Since rules are defined as Javascript code, rulesets of arbitrary complexity can be created and they can impose conditions on any part of a transaction, not only the recipient and value. A simple example is implementing a "whitelist" of recipients where transactions that have those +accounts in the `to` field are automatically signed (for example perhaps transactions between a user's own accounts might be whitelisted): ```js function ApproveTx(r) { @@ -462,15 +384,12 @@ function ApproveTx(r) { } ``` -In addition to addresses and values, other properties of a request can also be incorporated -into a ruleset. The example below demonstrates a ruleset for `approve_signData` imposing -the following conditions on a transaction's sender and message data. +In addition to addresses and values, other properties of a request can also be incorporated into a ruleset. The example below demonstrates a ruleset for `approve_signData` imposing the following conditions on a transaction's sender and message data. 1. The sender must be `0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3` 2. The transaction message must include the text `wen-merge`, which is `77656E2D6D65726765` in hex. -If these conditions are satisfied then the transaction is auto-approved (assuming the password for -`0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3` has been provided to `setpw`). +If these conditions are satisfied then the transaction is auto-approved (assuming the password for `0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3` has been provided to `setpw`). ```js function ApproveListing() { @@ -537,13 +456,7 @@ INFO [07-01|14:12:41.638] IPC endpoint opened url=go-ethere * extapi_ipc : go-ethereum/goerli-data/clef/clef.ipc ``` -Finally, a request can be submitted to test that the rules are being applied as expected. -Here, Clef is used independently of Geth by making a request via RPC, but the same logic -would be imposed if the request was made via a connected Geth node. Some arbitrary text -will be included in the message data that includes the term `wen-merge`. The plaintext -`clefdemotextthatincludeswen-merge` is `636c656664656d6f7465787474686174696e636c7564657377656e2d6d65726765` -when represented as a hexadecimal string. This can be passed as data to an `account_signData` -request as follows: +Finally, a request can be submitted to test that the rules are being applied as expected. Here, Clef is used independently of Geth by making a request via RPC, but the same logic would be imposed if the request was made via a connected Geth node. Some arbitrary text will be included in the message data that includes the term `wen-merge`. The plaintext `clefdemotextthatincludeswen-merge` is `636c656664656d6f7465787474686174696e636c7564657377656e2d6d65726765` when represented as a hexadecimal string. This can be passed as data to an `account_signData` request as follows: ```sh echo '{"id": 1, "jsonrpc":"2.0", "method":"account_signData", "params":["data/plain", "0x636c656664656d6f7465787474686174696e636c7564657377656e2d6d65726765"]}' | nc -U ~/go-ethereum.goerli-data/clef/clef.ipc @@ -555,8 +468,7 @@ This will be automatically signed, returning a result that looks like the follow {"jsonrpc":"2.0","id":1,"result":"0x4f93e3457027f6be99b06b3392d0ebc60615ba448bb7544687ef1248dea4f5317f789002df783979c417d969836b6fda3710f5bffb296b4d51c8aaae6e2ac4831c"} ``` -Alternatively, a request that does not include the phrase `wen-merge` will not automatically approve. For example, the following request passes the hexadecimal -string representing the plaintext `clefdemotextwithoutspecialtext`: +Alternatively, a request that does not include the phrase `wen-merge` will not automatically approve. For example, the following request passes the hexadecimal string representing the plaintext `clefdemotextwithoutspecialtext`: ```sh echo '{"id": 1, "jsonrpc":"2.0", "method":"account_signData", "params":["data/plain", "0x636c656664656d6f74657874776974686f75747370656369616c74657874"]}' | nc -U ~/go-ethereum.goerli-data/clef/clef.ipc @@ -567,14 +479,14 @@ This returns a `Request denied` message as follows: {"jsonrpc":"2.0","id":1,"error":{"code":-32000,"message":"Request denied"}} ``` -Meanwhile, in the output logs in the Clef terminal you can see: +Meanwhile, in the output logs in the Clef terminal: + ```text INFO [02-21|14:42:41] Op approved INFO [02-21|14:42:56] Op rejected ``` -The signer also stores all traffic over the external API in a log file. -The last 4 lines shows the two requests and their responses: +The signer also stores all traffic over the external API in a log file. The last 4 lines shows the two requests and their responses: ```text $ tail -n 4 audit.log @@ -584,19 +496,14 @@ t=2022-07-01T15:52:23+0300 lvl=info msg=SignData api=signer type=request meta t=2022-07-01T15:52:23+0300 lvl=info msg=SignData api=signer type=response data= error="Request denied" ``` -More examples, including a ruleset for a rate-limited window, are available on the [Clef Github][rate-limited-window-example] -and on the [Rules page](/docs/clef/rules). +More examples, including a ruleset for a rate-limited window, are available on the [Clef Github](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/rules.md#example-1-ruleset-for-a-rate-limited-window) and on the [Rules page](/content/docs/tools/Clef/rules). ## Under the hood -The examples on this page have provided step-by-step instructions for verious operations using Clef. -However, they have not provided much detail as to what is happening under the hood. -This section will provide some more details about how Clef organizes itself locally. +The examples on this page have provided step-by-step instructions for verious operations using Clef. However, they have not provided much detail as to what is happening under the hood. This section will provide some more details about how Clef organizes itself locally. -Initializing Clef with a master password and providing an account password to `clef setpw` -and attesting a ruleset creates the following files in the directory `~/.clef/` -(this path is independent of the paths provided to `--keystore` and `--configdir` on startup): +Initializing Clef with a master password and providing an account password to `clef setpw` and attesting a ruleset creates the following files in the directory `~/.clef/` (this path is independent of the paths provided to `--keystore` and `--configdir` on startup): ```terminal # displayed using $ ls -laR ~/.clef/ @@ -616,27 +523,20 @@ drwxr-x--x 3 user user 4096 Jul 1 13:45 .. -rw------- 1 user user 115 Jul 1 13:35 credentials.json ``` -The file `masterseed.json` includes a json object containing the masterseed which was used to derive -the vault directory (in this case `02f90c0603f4f2f60188`). The vault is encrypted using a password -which is also derived from the masterseed. Inside the vault are two subdirectories: +The file `masterseed.json` includes a json object containing the masterseed which was used to derive the vault directory (in this case `02f90c0603f4f2f60188`). The vault is encrypted using a password which is also derived from the masterseed. Inside the vault are two subdirectories: `credentials.json` `config.json` -Inside `credentials.json` are the confidential `ksp` data (standing for "keystore pass" - these -are the account passwords used to unlock the keystore). +Inside `credentials.json` are the confidential `ksp` data (standing for "keystore pass" - these are the account passwords used to unlock the keystore). -The `config.json` file contains encrypted key/value pairs for configuration data. Usually -this is only the `sha256` hashes of any attested rulesets. +The `config.json` file contains encrypted key/value pairs for configuration data. Usually this is only the `sha256` hashes of any attested rulesets. -Vault locations map uniquely to masterseeds so that multiple instances of Clef can co-exist -each with their own attested rules and their own set of keystore passwords. This is useful for, -for example, maintaining separate setups for Mainnet and testnets. +Vault locations map uniquely to masterseeds so that multiple instances of Clef can co-exist each with their own attested rules and their own set of keystore passwords. This is useful for, for example, maintaining separate setups for Mainnet and testnets. -The contents of each of these json files can be viewed using `cat` and should look something -like the following: +The contents of each of these json files can be viewed using `cat` and should look something like the following: For `config.json`: @@ -660,26 +560,14 @@ cat ~/.clef/02f90c0603f4f2f60188/config.json ## Geth integration -This tutorial has bounced back and forth between demonstrating Clef as a standalone tool by making -'manual` JSON RPC requests from the terminal and integrating it as a backend singer for Geth. -Using Clef for account management is considered best practise for Geth users because of the additional -security benefits it offers over and above what it offered by Geth's built-in accounts module. Clef is -far more flexible and composable than Geth's built-in account management tool and can interface directly -with hardware wallets, while Apps and wallets can request signatures directly from Clef. +This tutorial has bounced back and forth between demonstrating Clef as a standalone tool by making 'manual` JSON RPC requests from the terminal and integrating it as a backend singer for Geth. Using Clef for account management is considered best practise for Geth users because of the additional +security benefits it offers over and above what it offered by Geth's built-in accounts module. Clef is far more flexible and composable than Geth's built-in account management tool and can interface directly with hardware wallets, while Apps and wallets can request signatures directly from Clef. -Ultimately, the goal is to deprecate Geth's account management tools completely and replace them with -Clef. Until then, users are simply encouraged to choose to use Clef as an optional backend signer for Geth. -In addition to the examples on this page, the [Getting started tutorial](/docs/_getting-started/index.md) -also demonstrates Clef/Geth integration. +Ultimately, the goal is to deprecate Geth's account management tools completely and replace them with Clef. Until then, users are simply encouraged to choose to use Clef as an optional backend signer for Geth. In addition to the examples on this page, the [Getting started tutorial](/docs/_getting-started/index.md) also demonstrates Clef/Geth integration. ## Summary -This page includes step-by-step instructions for basic and intermediate uses of Clef, including using -it as a standalone app and a backend signer for Geth. Further information is available on our other -Clef pages, including [Introduction](/docs/clef/introduction), [Setup](/docs/clef/setup), -[Rules](/docs/clef/rules), [Communication Datatypes](/docs/clef/datatypes) and [Communication APIs](/docs/clef/apis). -Also see the [Clef Github](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef) for further reading. +This page includes step-by-step instructions for basic and intermediate uses of Clef, including using it as a standalone app and a backend signer for Geth. Further information is available on our other Clef pages, including [Introduction](/docs/clef/introduction), [Setup](/docs/clef/setup), +[Rules](/docs/clef/rules), [Communication Datatypes](/docs/clef/datatypes) and [Communication APIs](/docs/clef/apis). Also see the [Clef Github](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef) for further reading. - -[rate-limited-window-example]:https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/rules.md#example-1-ruleset-for-a-rate-limited-window \ No newline at end of file From 50a86c7d32e89b7675a8265b034b7ec66bd96ce7 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 16 Aug 2022 14:16:28 +0100 Subject: [PATCH 033/432] more md formatting --- content/docs/tools/Clef/apis.md | 7 ++--- content/docs/tools/abigen/index.md | 41 ++++++------------------------ 2 files changed, 10 insertions(+), 38 deletions(-) diff --git a/content/docs/tools/Clef/apis.md b/content/docs/tools/Clef/apis.md index 2963850c04..a2bcc3d224 100644 --- a/content/docs/tools/Clef/apis.md +++ b/content/docs/tools/Clef/apis.md @@ -1,12 +1,10 @@ --- title: Clef APIs -sort_key: E +description: Reference documentation for the Clef APIs --- Clef uses two separate APIs. The **external API** is an untrusted set of JSON-RPC methods that can be called by a user. The **internal API** is a set of JSON-RPC methods that can be called by a UI. The UI could be Clef's native command line interface or a custom UI. -{:toc} -- this will be removed by the toc ## External API @@ -32,8 +30,7 @@ All hex encoded values must be prefixed with `0x`. ##### Create new password protected account -The signer will generate a new private key, encrypt it according to [web3 keystore spec](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) and store it in the keystore directory. -The client is responsible for creating a backup of the keystore. If the keystore is lost there is no method of retrieving lost accounts. +The signer will generate a new private key, encrypt it according to [web3 keystore spec](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) and store it in the keystore directory. The client is responsible for creating a backup of the keystore. If the keystore is lost there is no method of retrieving lost accounts. ##### Arguments diff --git a/content/docs/tools/abigen/index.md b/content/docs/tools/abigen/index.md index d6a6017ace..34f4569864 100644 --- a/content/docs/tools/abigen/index.md +++ b/content/docs/tools/abigen/index.md @@ -1,15 +1,9 @@ --- title: Abigen -root: .. +description: Introduction to the Go binding generator tool, Abigen --- -Abigen is a binding-generator for easily interacting with Ethereum using Go. -Abigen creates easy-to-use, type-safe Go packages from Ethereum smart contract definitions known -as ABIs. This abstracts away a lot of the complexity of handling smart contract deployment -and interaction in Go native applications such as encoding and decoding smart contracts into -EVM bytecode. Abigen comes bundled with Geth. A full Geth installation includes the abigen binary. -Abigen can also be built independently by navigating to `go-ethereum/cmd/abigen` and running -`go build`, or equivalently: +Abigen is a binding-generator for easily interacting with Ethereum using Go. Abigen creates easy-to-use, type-safe Go packages from Ethereum smart contract definitions known as ABIs. This abstracts away a lot of the complexity of handling smart contract deployment and interaction in Go native applications such as encoding and decoding smart contracts into EVM bytecode. Abigen comes bundled with Geth. A full Geth installation includes the abigen binary. Abigen can also be built independently by navigating to `go-ethereum/cmd/abigen` and running `go build`, or equivalently: ``` $ cd $GOPATH/src/github.com/ethereum/go-ethereum @@ -18,20 +12,11 @@ $ go build ./cmd/abigen ## What is an ABI? -Ethereum smart contracts have a schema that defines its functions and return types in the form -of a JSON file. This JSON file is known as an *Application Binary Interface*, or ABI. The ABI -acts as a specification for precisely how to encode data sent to a contract and how to -decode the data the contract sends back. The ABI is the only essential piece of information required to -generate Go bindings. Go developers can then use the bindings to interact with the contract -from their Go application without having to deal directly with data encoding and decoding. -An ABI is generated when a contract is compiled. - +Ethereum smart contracts have a schema that defines its functions and return types in the form of a JSON file. This JSON file is known as an *Application Binary Interface*, or ABI. The ABI acts as a specification for precisely how to encode data sent to a contract and how to decode the data the contract sends back. The ABI is the only essential piece of information required to generate Go bindings. Go developers can then use the bindings to interact with the contract from their Go application without having to deal directly with data encoding and decoding. An ABI is generated when a contract is compiled. ### Generating the bindings -To demonstrate the binding generator a contract is required. The contract `Storage.sol` implements two -very simple functions: `store` updates a user-defined `uint256` to the contract's storage, and `retrieve` -displays the value stored in the contract to the user. The Solidity code is as follows: +To demonstrate the binding generator a contract is required. The contract `Storage.sol` implements two very simple functions: `store` updates a user-defined `uint256` to the contract's storage, and `retrieve` displays the value stored in the contract to the user. The Solidity code is as follows: ```solidity // SPDX-License-Identifier: GPL-3.0 @@ -56,19 +41,13 @@ contract Storage { } ``` -This contract can be pasted into a text file and saved as `Storage.sol`. - -The following code snippet shows how an ABI can be generated for `Storage.sol` -using the Solidity compiler `solc`. +This contract can be pasted into a text file and saved as `Storage.sol`. The following code snippet shows how an ABI can be generated for `Storage.sol` using the Solidity compiler `solc`. ```shell solc --abi Storage.sol -o build ``` -The ABI can also be generated in other ways such as using the `compile` commands in development -frameworks such as [Truffle][truffle-link], [Hardhat][hardhat-link] and [Brownie][brownie-link] -or in the online IDE [Remix][remix-link]. ABIs for existing -verified contracts can be downloaded from [Etherscan](etherscan.io). +The ABI can also be generated in other ways such as using the `compile` commands in development frameworks such as [Truffle](https://trufflesuite.com/), [Hardhat](https://hardhat.org/) and [Brownie](https://eth-brownie.readthedocs.io/en/stable/) or in the online IDE [Remix](https://remix.ethereum.org/). ABIs for existing verified contracts can be downloaded from [Etherscan](etherscan.io). The ABI for `Storage.sol` (`Storage.abi`) looks as follows: @@ -90,9 +69,7 @@ Where the flags are: * `--type`: Optional Go type name to assign to the binding struct * `--out`: Optional output path for the generated Go source file (not set = stdout) -This will generate a type-safe Go binding for the Storage contract. The generated code will -look something like the snippet below, the full version of which can be viewed -[here](https://gist.github.com/jmcook1186/a78e59d203bb54b06e1b81f2cda79d93). +This will generate a type-safe Go binding for the Storage contract. The generated code will look something like the snippet below, the full version of which can be viewed [here](https://gist.github.com/jmcook1186/a78e59d203bb54b06e1b81f2cda79d93). ```go // Code generated - DO NOT EDIT. @@ -146,6 +123,4 @@ type Storage struct { `Storage.go` contains all the bindings required to interact with `Storage.sol` from a Go application. -For instructions on how to deploy this contract to Ethereum from a Go native application read our -[Go bindings page](/content/docs/developers/dapp-developer/native.md). To browse the Abigen source code -visit the Geth [Github repository](https://github.com/ethereum/go-ethereum/tree/master/cmd/abigen). \ No newline at end of file +For instructions on how to deploy this contract to Ethereum from a Go native application read our [Go bindings page](/content/docs/developers/dapp-developer/native.md). To browse the Abigen source code visit the Geth [Github repository](https://github.com/ethereum/go-ethereum/tree/master/cmd/abigen). \ No newline at end of file From 008150095d08d39862892ec100f8350f4c36cdc5 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 16 Aug 2022 15:29:36 +0100 Subject: [PATCH 034/432] more md formatting --- .../dapp-developer/custom-tracer.md | 76 ++----- .../docs/developers/dapp-developer/mobile.md | 194 ++++-------------- .../dapp-developer/native-accounts.md | 153 +++----------- .../dapp-developer/native-bindings.md | 170 ++++----------- content/docs/monitoring/ethstats.md | 1 + content/docs/monitoring/metrics.md | 3 +- 6 files changed, 131 insertions(+), 466 deletions(-) diff --git a/content/docs/developers/dapp-developer/custom-tracer.md b/content/docs/developers/dapp-developer/custom-tracer.md index 4817ed4053..231760a4c6 100644 --- a/content/docs/developers/dapp-developer/custom-tracer.md +++ b/content/docs/developers/dapp-developer/custom-tracer.md @@ -1,29 +1,17 @@ --- title: Custom EVM tracer -sort_key: B +description: Introduction to writing custom tracers for Geth --- -In addition to the default opcode tracer and the built-in tracers, Geth offers the possibility to write custom code -that hook to events in the EVM to process and return the data in a consumable format. Custom tracers can be -written either in Javascript or Go. JS tracers are good for quick prototyping and experimentation as well as for -less intensive applications. Go tracers are performant but require the tracer to be compiled together with the Geth source code. - -* TOC -{:toc} +In addition to the default opcode tracer and the built-in tracers, Geth offers the possibility to write custom code that hook to events in the EVM to process and return the data in a consumable format. Custom tracers can be written either in Javascript or Go. JS tracers are good for quick prototyping and experimentation as well as for less intensive applications. Go tracers are performant but require the tracer to be compiled together with the Geth source code. ## Custom Javascript tracing -Transaction traces include the complete status of the EVM at every point during the transaction execution, which -can be a very large amount of data. Often, users are only interested in a small subset of that data. Javascript trace -filters are available to isolate the useful information. Detailed information about `debug_traceTransaction` and its -component parts is available in the [reference documentation](/docs/rpc/ns-debug#debug_tracetransaction). +Transaction traces include the complete status of the EVM at every point during the transaction execution, which can be a very large amount of data. Often, users are only interested in a small subset of that data. Javascript trace filters are available to isolate the useful information. Detailed information about `debug_traceTransaction` and its component parts is available in the [reference documentation](/content/docs/developers/interacting-with-geth/rpc/ns-debug#debug_tracetransaction). ### A simple filter -Filters are Javascript functions that select information from the trace to persist and discard based on some -conditions. The following Javascript function returns only the sequence of opcodes executed by the transaction as a -comma-separated list. The function could be written directly in the Javascript console, but it is cleaner to -write it in a separate re-usable file and load it into the console. +Filters are Javascript functions that select information from the trace to persist and discard based on some conditions. The following Javascript function returns only the sequence of opcodes executed by the transaction as a comma-separated list. The function could be written directly in the Javascript console, but it is cleaner to write it in a separate re-usable file and load it into the console. 1. Create a file, `filterTrace_1.js`, with this content: @@ -71,12 +59,9 @@ write it in a separate re-usable file and load it into the console. console.log(JSON.stringify(tracer(""), null, 2)) ``` -More information about the `JSON.stringify` function is available -[here](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify). +More information about the `JSON.stringify` function is available [here](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify). -The commands above worked by calling the same `debug.traceTransaction` function that was previously -explained in [basic traces](https://geth.ethereum.org/docs/dapp/tracing), but with a new parameter, `tracer`. -This parameter takes the JavaScript object formated as a string. In the case of the trace above, it is: +The commands above worked by calling the same `debug.traceTransaction` function that was previously explained in [basic traces](https://geth.ethereum.org/docs/dapp/tracing), but with a new parameter, `tracer`. This parameter takes the JavaScript object formated as a string. In the case of the trace above, it is: ```javascript { @@ -94,14 +79,11 @@ This object has three member functions: In this case, `retVal` is used to store the list of strings to return in `result`. -The `step` function adds to `retVal` the program counter and the name of the opcode there. Then, in `result`, this -list is returned to be sent to the caller. - +The `step` function adds to `retVal` the program counter and the name of the opcode there. Then, in `result`, this list is returned to be sent to the caller. ### Filtering with conditions -For actual filtered tracing we need an `if` statement to only log relevant information. For example, to isolate -the transaction's interaction with storage, the following tracer could be used: +For actual filtered tracing we need an `if` statement to only log relevant information. For example, to isolate the transaction's interaction with storage, the following tracer could be used: ```javascript tracer = function(tx) { @@ -121,9 +103,7 @@ tracer = function(tx) { } // tracer = function ... ``` -The `step` function here looks at the opcode number of the op, and only pushes an entry if the opcode is -`SLOAD` or `SSTORE` ([here is a list of EVM opcodes and their numbers](https://github.com/wolflo/evm-opcodes)). -We could have used `log.op.toString()` instead, but it is faster to compare numbers rather than strings. +The `step` function here looks at the opcode number of the op, and only pushes an entry if the opcode is `SLOAD` or `SSTORE` ([here is a list of EVM opcodes and their numbers](https://github.com/wolflo/evm-opcodes)). We could have used `log.op.toString()` instead, but it is faster to compare numbers rather than strings. The output looks similar to this: @@ -143,18 +123,13 @@ The output looks similar to this: ### Stack Information -The trace above reports the program counter (PC) and whether the program read from storage or wrote to it. -That alone isn't particularly useful. To know more, the `log.stack.peek` function can be used to peek -into the stack. `log.stack.peek(0)` is the stack top, `log.stack.peek(1)` the entry below it, etc. +The trace above reports the program counter (PC) and whether the program read from storage or wrote to it. That alone isn't particularly useful. To know more, the `log.stack.peek` function can be used to peek into the stack. `log.stack.peek(0)` is the stack top, `log.stack.peek(1)` the entry below it, etc. -The values returned by `log.stack.peek` are Go `big.Int` objects. By default they are converted to JavaScript -floating point numbers, so you need `toString(16)` to get them as hexadecimals, which is how 256-bit values such as -storage cells and their content are normally represented. +The values returned by `log.stack.peek` are Go `big.Int` objects. By default they are converted to JavaScript floating point numbers, so you need `toString(16)` to get them as hexadecimals, which is how 256-bit values such as storage cells and their content are normally represented. #### Storage Information -The function below provides a trace of all the storage operations and their parameters. This gives -a more complete picture of the program's interaction with storage. +The function below provides a trace of all the storage operations and their parameters. This gives a more complete picture of the program's interaction with storage. ```javascript tracer = function(tx) { @@ -195,13 +170,10 @@ The output is similar to: #### Operation Results -One piece of information missing from the function above is the result on an `SLOAD` operation. The -state we get inside `log` is the state prior to the execution of the opcode, so that value is not -known yet. For more operations we can figure it out for ourselves, but we don't have access to the +One piece of information missing from the function above is the result on an `SLOAD` operation. The state we get inside `log` is the state prior to the execution of the opcode, so that value is not known yet. For more operations we can figure it out for ourselves, but we don't have access to the storage, so here we can't. -The solution is to have a flag, `afterSload`, which is only true in the opcode right after an -`SLOAD`, when we can see the result at the top of the stack. +The solution is to have a flag, `afterSload`, which is only true in the opcode right after an `SLOAD`, when we can see the result at the top of the stack. ```javascript tracer = function(tx) { @@ -251,14 +223,10 @@ The output now contains the result in the line that follows the `SLOAD`. ### Dealing With Calls Between Contracts -So the storage has been treated as if there are only 2256 cells. However, that is not true. -Contracts can call other contracts, and then the storage involved is the storage of the other contract. -We can see the address of the current contract in `log.contract.getAddress()`. This value is the execution -context - the contract whose storage we are using - even when code from another contract is executed (by using -[`CALLCODE` or `DELEGATECALL`][solidity-delcall]). +So the storage has been treated as if there are only 2256 cells. However, that is not true. Contracts can call other contracts, and then the storage involved is the storage of the other contract. We can see the address of the current contract in `log.contract.getAddress()`. This value is the execution context - the contract whose storage we are using - even when code from another contract is executed (by using +[`CALLCODE` or `DELEGATECALL`](https://docs.soliditylang.org/en/v0.8.14/introduction-to-smart-contracts.html#delegatecall-callcode-and-libraries)). -However, `log.contract.getAddress()` returns an array of bytes. To convert this to the familiar hexadecimal -representation of Ethereum addresses, `this.byteHex()` and `array2Hex()` can be used. +However, `log.contract.getAddress()` returns an array of bytes. To convert this to the familiar hexadecimal representation of Ethereum addresses, `this.byteHex()` and `array2Hex()` can be used. ```javascript tracer = function(tx) { @@ -345,10 +313,7 @@ The output is similar to: ## Other traces -This tutorial has focused on `debug_traceTransaction()` which reports information about individual transactions. There are -also RPC endpoints that provide different information, including tracing the EVM execution within a block, between two blocks, -for specific `eth_call`s or rejected blocks. The fill list of trace functions can be explored in the -[reference documentation][debug-docs]. +This tutorial has focused on `debug_traceTransaction()` which reports information about individual transactions. There are also RPC endpoints that provide different information, including tracing the EVM execution within a block, between two blocks, for specific `eth_call`s or rejected blocks. The full list of trace functions can be explored in the [reference documentation](/content/docs/interacting_with_geth/RPC/ns-debug.md). ## Custom Go tracing @@ -356,7 +321,7 @@ for specific `eth_call`s or rejected blocks. The fill list of trace functions ca Custom tracers can also be made more performant by writing them in Go. The gain in performance mostly comes from the fact that Geth doesn't need to interpret JS code and can execute native functions. Geth comes with several built-in [native tracers](https://github.com/ethereum/go-ethereum/tree/master/eth/tracers/native) which can serve as examples. Please note that unlike JS tracers, Go tracing scripts cannot be simply passed as an argument to the API. They will need to be added to and compiled with the rest of the Geth source code. -In this section a simple native tracer that counts the number of opcodes will be covered. First follow the instructions to [clone and build](install-and-build/installing-geth#build-from-source-code) Geth from source code. Next save the following snippet as a `.go` file and add it to `eth/tracers/native`: +In this section a simple native tracer that counts the number of opcodes will be covered. First follow the instructions to [clone and build](/content/docs/getting_started/Installing-Geth.md) Geth from source code. Next save the following snippet as a `.go` file and add it to `eth/tracers/native`: ```go package native @@ -454,5 +419,4 @@ As can be seen every method of the [EVMLogger interface](https://pkg.go.dev/gith } ``` -[solidity-delcall]:https://docs.soliditylang.org/en/v0.8.14/introduction-to-smart-contracts.html#delegatecall-callcode-and-libraries -[debug-docs]: /docs/rpc/ns-debug + diff --git a/content/docs/developers/dapp-developer/mobile.md b/content/docs/developers/dapp-developer/mobile.md index 0de0d40933..07741098f5 100644 --- a/content/docs/developers/dapp-developer/mobile.md +++ b/content/docs/developers/dapp-developer/mobile.md @@ -1,18 +1,10 @@ --- title: Geth for Mobile -sort_key: F +description: Introduction to mobile development with Geth --- -Embedding clients into mobile devices is an important part of Ethereum's decentralization vision. -This is because being able to verify data, follow the chain and submit transactions without -relying on centralized intermediaries is critical for censorship resistant access -to the network. Doing so on a mobile device is the most convenient route for many users. -This relies on Geth running a [light client](/docs/interface/les) on the mobile -device and exposing an API that developers can use to build mobile apps on top of Geth. This -page outlines how to download Geth for mobile and how to get started with managing Ethereum -accounts in mobile applications. Ethereum mobile development is relatively nascent, but there is -an active developer community. For further information on Geth mobile development visit the -#mobile channel in the [Geth discord](https://discord.gg/wQdpS5aA). +Embedding clients into mobile devices is an important part of Ethereum's decentralization vision. This is because being able to verify data, follow the chain and submit transactions without relying on centralized intermediaries is critical for censorship resistant access to the network. Doing so on a mobile device is the most convenient route for many users. This relies on Geth running a [light client](/docs/interface/les) on the mobile +device and exposing an API that developers can use to build mobile apps on top of Geth. This page outlines how to download Geth for mobile and how to get started with managing Ethereum accounts in mobile applications. Ethereum mobile development is relatively nascent, but there is an active developer community. For further information on Geth mobile development visit the #mobile channel in the [Geth discord](https://discord.gg/wQdpS5aA). ## Download and install @@ -20,12 +12,9 @@ an active developer community. For further information on Geth mobile developmen #### Android Studio -Geth for Mobile bundles can be downloaded directly from [the download page](https://geth.ethereum.org/downloads/) -and inserted into a project in Android Studio via `File -> New -> New module... -> Import .JAR/.AAR Package`. +Geth for Mobile bundles can be downloaded directly from [the download page](https://geth.ethereum.org/downloads/) and inserted into a project in Android Studio via `File -> New -> New module... -> Import .JAR/.AAR Package`. -It is also necessary to configure `gradle` to link the mobile library bundle to the -application. This can be done by adding a new entry to the `dependencies` section of the -`build.gradle` script, pointing it to the module that was just added (named `geth` by default). +It is also necessary to configure `gradle` to link the mobile library bundle to the application. This can be done by adding a new entry to the `dependencies` section of the `build.gradle` script, pointing it to the module that was just added (named `geth` by default). ```gradle dependencies { @@ -36,9 +25,7 @@ dependencies { #### Manual build -Geth can also be built it locally using a `make` command. This will create an Android -archive called `geth.aar` in the `build/bin` folder that can be imported into Android -Studio as described above. +Geth can also be built it locally using a `make` command. This will create an Android archive called `geth.aar` in the `build/bin` folder that can be imported into Android Studio as described above. ```shell $ make android @@ -49,9 +36,7 @@ Import "build/bin/geth.aar" to use the library. ### iOS -Geth must be downloaded and built locally for IoS. Building locally is achieved using the -`make` command. This will create an iOS XCode framework called `Geth.framework` in the -`build/bin` folder that can be imported into XCode as described above. +Geth must be downloaded and built locally for IoS. Building locally is achieved using the `make` command. This will create an iOS XCode framework called `Geth.framework` in the `build/bin` folder that can be imported into XCode as described above. ```bash $ make ios @@ -62,54 +47,37 @@ Import "build/bin/Geth.framework" to use the library. ## Mobile API -Similarly to the reusable [Go libraries](/docs/dapp/native), the mobile wrappers focus on -three main usage areas: +Similarly to the reusable [Go libraries](content/docs/developers/dapp-developer/native-accounts.md), the mobile wrappers focus on three main usage areas: - Simplified client side account management - Remote node interfacing via different transports - Contract interactions through auto-generated bindings -The Geth mobile API is broadly equivalent to the [Go API](/docs/dapp/native). -The source code can be found in the `mobile` section of Geth's +The Geth mobile API is broadly equivalent to the [Go API](/content/docs/developers/dapp-developer/native-accounts.md). The source code can be found in the `mobile` section of Geth's [Github](https://github.com/ethereum/go-ethereum/tree/master/mobile). ## Mobile Account Management -Best practise for account management is to do it client-side, with all sensitive information -self-contained inside the local application. This ensures the developer/user retains -fine-grained control over the access permissions for user-data instead of outsourcing security +Best practise for account management is to do it client-side, with all sensitive information self-contained inside the local application. This ensures the developer/user retains fine-grained control over the access permissions for user-data instead of outsourcing security to a third party. -To support this, Geth provides an accounts library that includes the tools required -for secure account management via encrypted keystores and passphrase protected accounts, -similarly to running a full Geth node. +To support this, Geth provides an accounts library that includes the tools required for secure account management via encrypted keystores and passphrase protected accounts, similarly to running a full Geth node. ### Encrypted keystores -Access keys to Ethereum accounts should never be stored in plain-text. Instead, they should -be stored encrypted so that even if the mobile device is accessed by a malicious third party -the keys are still hidden under an additional layer of security. Geth provides a keystore -that enables developers to store keys securely using the [`secp256k1` elliptic curve](sec2), -implemented using [`libsecp256k`][secp256k1] and wrapped by [Geth accounts][accounts-go]. -Accounts are stored on disk in the [Web3 Secret Storage][secstore] format. Developers should be -aware of these implementation details but are not required to deeply understand the cryptographic -primitives in order to use the keystore. +Access keys to Ethereum accounts should never be stored in plain-text. Instead, they should be stored encrypted so that even if the mobile device is accessed by a malicious third party the keys are still hidden under an additional layer of security. Geth provides a keystore that enables developers to store keys securely using the [`secp256k1` elliptic curve](https://www.secg.org/sec2-v2.pdf), implemented using [`libsecp256k`](https://github.com/bitcoin-core/secp256k1) and wrapped by [Geth accounts](https://godoc.org/github.com/ethereum/go-ethereum/accounts). -One thing that should be understood, though, is that the cryptographic primitives underpinning -the keystore can operate in *light* or *standard* mode. Light mode is computationally cheaper, while -standard mode has extra security. Light mode is appropriate for mobile devices, but developers +Accounts are stored on disk in the [Web3 Secret Storage](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) format. Developers should be aware of these implementation details but are not required to deeply understand the cryptographic primitives in order to use the keystore. + +One thing that should be understood, though, is that the cryptographic primitives underpinning the keystore can operate in *light* or *standard* mode. Light mode is computationally cheaper, while standard mode has extra security. Light mode is appropriate for mobile devices, but developers should be aware that there is a security trade-off. -* *standard* needs 256MB memory and 1 second processing on a modern CPU to access a key +* *standard* needs 256MB memory and 1 second processing on a modern CPU to access a key * *light* needs 4MB memory and 100 millisecond processing on a modern CPU to access a key ### Keystores on Android (Java) -The encrypted keystore on Android is implemented by the `KeyStore` class from the -`org.ethereum.geth` package. The configuration constants are located in the `Geth` -abstract class, similarly from the `org.ethereum.geth` package. -Hence to do client side account management on Android, two classes should be -imported into the Java code: +The encrypted keystore on Android is implemented by the `KeyStore` class from the `org.ethereum.geth` package. The configuration constants are located in the `Geth` abstract class, similarly from the `org.ethereum.geth` package. Hence to do client side account management on Android, two classes should be imported into the Java code: ```java import org.ethereum.geth.Geth; @@ -122,23 +90,13 @@ Then new encrypted keystore can be created via: KeyStore ks = new KeyStore("/path/to/keystore", Geth.LightScryptN, Geth.LightScryptP); ``` -The keystore should be in a location writable by the local mobile application but -on-readable for other installed applications such as inside the app's data directory. -If the `KeyStore` is created from within a class extending an Android object, access -to the `Context.getFilesDir()` method is probably provided via `this.getFilesDir()`, -so the keystore path could be set to `this.getFilesDir() + "/keystore"`. - -The last two arguments of the `KeyStore` constructor are the crypto parameters defining -how resource-intensive the keystore encryption should be. The choices are -`Geth.StandardScryptN, Geth.StandardScryptP`, `Geth.LightScryptN, Geth.LightScryptP` or -custom numbers. The *light* version is recommended. +The keystore should be in a location writable by the local mobile application but on-readable for other installed applications such as inside the app's data directory. If the `KeyStore` is created from within a class extending an Android object, access to the `Context.getFilesDir()` method is probably provided via `this.getFilesDir()`, so the keystore path could be set to `this.getFilesDir() + "/keystore"`. +The last two arguments of the `KeyStore` constructor are the crypto parameters defining how resource-intensive the keystore encryption should be. The choices are `Geth.StandardScryptN, Geth.StandardScryptP`, `Geth.LightScryptN, Geth.LightScryptP` or custom numbers. The *light* version is recommended. ### Keystores on iOS (Swift 3) -The encrypted keystore on iOS is implemented by the `GethKeyStore` class from the `Geth` -framework. The configuration constants are located in the same namespace as global -variables. Hence to do client side account management on iOS, `Geth` framework should be +The encrypted keystore on iOS is implemented by the `GethKeyStore` class from the `Geth` framework. The configuration constants are located in the same namespace as global variables. Hence to do client side account management on iOS, `Geth` framework should be imported into the Swift code: ```swift @@ -151,60 +109,31 @@ Then a new encrypted account manager can be created using: let ks = GethNewKeyStore("/path/to/keystore", GethLightScryptN, GethLightScryptP); ``` -The keystore folder needs to be in a location writable by the local mobile application -but non-readable for other installed applications such as inside the app's document -directory. The document directory shopuld be retrievable using -`let datadir = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0]`, -so the keystore path could be `datadir + "/keystore"`. +The keystore folder needs to be in a location writable by the local mobile application but non-readable for other installed applications such as inside the app's document directory. The document directory shopuld be retrievable using +`let datadir = NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0]`, so the keystore path could be `datadir + "/keystore"`. -The last two arguments of the `GethNewKeyStore` factory method are the crypto parameters -defining how resource-intensive the keystore encryption should be. The choices are -`GethStandardScryptN, GethStandardScryptP`, `GethLightScryptN, GethLightScryptP` or -custom numbers. The *light* version is recommended. +The last two arguments of the `GethNewKeyStore` factory method are the crypto parameters defining how resource-intensive the keystore encryption should be. The choices are `GethStandardScryptN, GethStandardScryptP`, `GethLightScryptN, GethLightScryptP` or custom numbers. The *light* version is recommended. ### Account lifecycle -The encyrpted keystore can be used for the entire account lifecycle requirements of a mobile -application. This includes the basic functionality of creating new accounts and deleting -existing ones as well as more advanced functions like updating access credentials and account +The encyrpted keystore can be used for the entire account lifecycle requirements of a mobile application. This includes the basic functionality of creating new accounts and deleting existing ones as well as more advanced functions like updating access credentials and account import/export. -Although the keystore defines the encryption strength it uses to store accounts, -there is no global master password that can grant access to all of them. Rather each -account is maintained individually, and stored on disk in its [encrypted format][secstore] -individually, ensuring a much cleaner and stricter separation of credentials. +Although the keystore defines the encryption strength it uses to store accounts, there is no global master password that can grant access to all of them. Rather each account is maintained individually, and stored on disk in its [encrypted format][secstore] individually, ensuring a much cleaner and stricter separation of credentials. -This individuality means that any operation requiring access to an account will -need to provide the necessary authentication credentials for that particular account in -the form of a passphrase: +This individuality means that any operation requiring access to an account will need to provide the necessary authentication credentials for that particular account in the form of a passphrase: - * When creating a new account, the caller must supply a passphrase to encrypt the account - with. This passphrase will be required for any subsequent access. - * When deleting an existing account, the caller must supply a passphrase to verify - ownership of the account. This isn't cryptographically necessary, rather a protective - measure against accidental loss of accounts. - * When updating an existing account, the caller must supply both current and new - passphrases. After completing the operation, the account will not be accessible via the - old passphrase. - * When exporting an existing account, the caller must supply both the current passphrase - to decrypt the account, as well as an export passphrase to re-encrypt it with before - returning the key-file to the user. This is required to allow moving accounts between - devices without sharing original credentials. - * When importing a new account, the caller must supply both the encryption passphrase of - the key-file being imported, as well as a new passphrase with which to store the - account. This is required to allow storing account with different credentials than used - for moving them around. + * When creating a new account, the caller must supply a passphrase to encrypt the account with. This passphrase will be required for any subsequent access. + * When deleting an existing account, the caller must supply a passphrase to verify ownership of the account. This isn't cryptographically necessary, rather a protective measure against accidental loss of accounts. + * When updating an existing account, the caller must supply both current and new passphrases. After completing the operation, the account will not be accessible via the old passphrase. + * When exporting an existing account, the caller must supply both the current passphrase to decrypt the account, as well as an export passphrase to re-encrypt it with before returning the key-file to the user. This is required to allow moving accounts between devices without sharing original credentials. + * When importing a new account, the caller must supply both the encryption passphrase of the key-file being imported, as well as a new passphrase with which to store the account. This is required to allow storing account with different credentials than used for moving them around. -*Please note, there is no recovery mechanisms for losing the passphrases. The -cryptographic properties of the encrypted keystore (if using the provided parameters) -guarantee that account credentials cannot be brute forced in any meaningful time.* +*Please note, there is no recovery mechanisms for losing the passphrases. The cryptographic properties of the encrypted keystore (if using the provided parameters) guarantee that account credentials cannot be brute forced in any meaningful time.* ### Accounts on Android (Java) -An Ethereum account on Android is implemented by the `Account` class from the -`org.ethereum.geth` package. Assuming an instance of a `KeyStore` called -`ks` exists, all of the described lifecycle operations can be executed with -a handful of function calls: +An Ethereum account on Android is implemented by the `Account` class from the `org.ethereum.geth` package. Assuming an instance of a `KeyStore` called `ks` exists, all of the described lifecycle operations can be executed with a handful of function calls: ```java // Create a new account with the specified encryption passphrase. @@ -225,15 +154,11 @@ ks.deleteAccount(newAcc, "Update password"); Account impAcc = ks.importKey(jsonAcc, "Export password", "Import password"); ``` -Although instances of `Account` can be used to access various information about specific -Ethereum accounts, they do not contain any sensitive data (such as passphrases or private -keys), rather they act solely as identifiers for client code and the keystore. +Although instances of `Account` can be used to access various information about specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or private keys), rather they act solely as identifiers for client code and the keystore. ### Accounts on iOS (Swift 3) -An Ethereum account on iOS is implemented by the `GethAccount` class from the `Geth` -framework. Assuming an instance of a `GethKeyStore` called `ks` exists, all of the described -lifecycle operations can be executed with a handful of function calls: +An Ethereum account on iOS is implemented by the `GethAccount` class from the `Geth` framework. Assuming an instance of a `GethKeyStore` called `ks` exists, all of the described lifecycle operations can be executed with a handful of function calls: ```swift // Create a new account with the specified encryption passphrase. @@ -254,46 +179,22 @@ try! ks?.delete(newAcc, passphrase: "Update password") let impAcc = try! ks?.importKey(jsonKey, passphrase: "Export password", newPassphrase: "Import password") ``` -Although instances of `GethAccount` can be used to access various information about -specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or -private keys), rather they act solely as identifiers for client code and the keystore. +Although instances of `GethAccount` can be used to access various information about specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or private keys), rather they act solely as identifiers for client code and the keystore. ## Signing authorization -As mentioned above, account objects do not hold the sensitive private keys of the -associated Ethereum accounts - they are merely placeholders to identify the cryptographic -keys with. All operations that require authorization (e.g. transaction signing) are -performed by the account manager after granting it access to the private keys. +As mentioned above, account objects do not hold the sensitive private keys of the associated Ethereum accounts - they are merely placeholders to identify the cryptographic keys with. All operations that require authorization (e.g. transaction signing) are performed by the account manager after granting it access to the private keys. -There are a few different ways one can authorize the account manager to execute signing -operations. Since the different methods have very different security guarantees, -it is essential to be clear on how each works: +There are a few different ways one can authorize the account manager to execute signing operations. Since the different methods have very different security guarantees, it is essential to be clear on how each works: - * **Single authorization**: The simplest way to sign a transaction via the keystore is to - provide the passphrase of the account every time something needs to be signed, which - will ephemerally decrypt the private key, execute the signing operation and immediately - throw away the decrypted key. The drawbacks are that the passphrase needs to be queried - from the user every time, which can become annoying if done frequently; or the - application needs to keep the passphrase in memory, which can have security - consequences if not done properly; and depending on the keystore's configured strength, - constantly decrypting keys can result in non-negligible resource requirements. - * **Multiple authorizations**: A more complex way of signing transactions via the - keystore is to unlock the account via its passphrase once, and allow the account - manager to cache the decrypted private key, enabling all subsequent signing requests to - complete without the passphrase. The lifetime of the cached private key may be managed - manually (by explicitly locking the account back up) or automatically (by providing a - timeout during unlock). This mechanism is useful for scenarios where the user may need - to sign many transactions or the application would need to do so without requiring user - input. The crucial aspect to remember is that **anyone with access to the account - manager can sign transactions while a particular account is unlocked** (e.g. device - left unattended; application running untrusted code). + * **Single authorization**: The simplest way to sign a transaction via the keystore is to provide the passphrase of the account every time something needs to be signed, which will ephemerally decrypt the private key, execute the signing operation and immediately throw away the decrypted key. The drawbacks are that the passphrase needs to be queried from the user every time, which can become annoying if done frequently; or the application needs to keep the passphrase in memory, which can have security consequences if not done properly; and depending on the keystore's configured strength, constantly decrypting keys can result in non-negligible resource requirements. + + * **Multiple authorizations**: A more complex way of signing transactions via the keystore is to unlock the account via its passphrase once, and allow the account manager to cache the decrypted private key, enabling all subsequent signing requests tocomplete without the passphrase. The lifetime of the cached private key may be managed manually (by explicitly locking the account back up) or automatically (by providing a timeout during unlock). This mechanism is useful for scenarios where the user may need to sign many transactions or the application would need to do so without requiring user input. The crucial aspect to remember is that **anyone with access to the account manager can sign transactions while a particular account is unlocked** (e.g. device left unattended; application running untrusted code). ### Signing on Android (Java) -Assuming an instance of a `KeyStore` called `ks` exists, a new account to sign transactions -can be created using its `newAccount` method. For this demonstation a hard-coded -example transaction is created to sign: +Assuming an instance of a `KeyStore` called `ks` exists, a new account to sign transactions can be created using its `newAccount` method. For this demonstation a hard-coded example transaction is created to sign: ```java // Create a new account to sign transactions with @@ -322,8 +223,7 @@ signed = ks.signTx(signer, tx, chain); ### Signing on iOS (Swift 3) -Assuming an instance of a `GethKeyStore` called `ks` exists, a new account -can be created to sign transactions with its `newAccount` method. For +Assuming an instance of a `GethKeyStore` called `ks` exists, a new account can be created to sign transactions with its `newAccount` method. For this demonstation a hard-coded example transaction is created to sign: ```swift @@ -354,10 +254,6 @@ signed = try! ks?.signTx(signer, tx: tx, chainID: chain) ## Summary -This page introduced Geth for mobile. In addition to download and installation instructions, basic -account management was demonstrated for mobile applications on iOS and Android. +This page introduced Geth for mobile. In addition to download and installation instructions, basic account management was demonstrated for mobile applications on iOS and Android. + -[sec2]: https://www.secg.org/sec2-v2.pdf -[accounts-go]: https://godoc.org/github.com/ethereum/go-ethereum/accounts -[secp256k1]: https://github.com/bitcoin-core/secp256k1 -[secstore]: https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition diff --git a/content/docs/developers/dapp-developer/native-accounts.md b/content/docs/developers/dapp-developer/native-accounts.md index 867a438018..016abdb0ee 100644 --- a/content/docs/developers/dapp-developer/native-accounts.md +++ b/content/docs/developers/dapp-developer/native-accounts.md @@ -1,42 +1,23 @@ --- title: Go Account Management -sort_key: D +description: Introduction to account management in Go native applications. --- -Geth provides a simple, yet thorough accounts package that includes all the tools developers -need to leverage all the security of Geth's crypto implementation in a Go native application. -The account management is done client side with all sensitive data held inside the application. -This gives the user control over access permissions without relying on any third party. +Geth provides a simple, yet thorough accounts package that includes all the tools developers need to leverage all the security of Geth's crypto implementation in a Go native application. The account management is done client side with all sensitive data held inside the application. This gives the user control over access permissions without relying on any third party. -**Note Geth's built-in account management is convenient and straightforward to use, but -best practise is to use the external tool *Clef* for key management.** - -{:toc} - -- this will be removed by the toc +**Note Geth's built-in account management is convenient and straightforward to use, but best practise is to use the external tool *Clef* for key management.** ## Encrypted keystores -Access keys to Ethereum accounts should never be stored in plain-text. Instead, they should be -stored encrypted so that even if the mobile device is accessed by a malicious third party the -keys are still hidden under an additional layer of security. Geth provides a keystore that enables -developers to store keys securely. The Geth keystore uses [Scrypt][scrypt-docs] to store keys that are encoded -using the [`secp256k1`][secp256k1] elliptic curve. Accounts are stored on disk in the -[Web3 Secret Storage][wss] format. Developers should be aware of these implementation details +Access keys to Ethereum accounts should never be stored in plain-text. Instead, they should be stored encrypted so that even if the mobile device is accessed by a malicious third party the keys are still hidden under an additional layer of security. Geth provides a keystore that enables developers to store keys securely. The Geth keystore uses [Scrypt](https://pkg.go.dev/golang.org/x/crypto/scrypt) to store keys that are encoded using the [`secp256k1`](https://www.secg.org/sec2-v2.pdf) elliptic curve. Accounts are stored on disk in the [Web3 Secret Storage](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) format. Developers should be aware of these implementation details but are not required to deeply understand the cryptographic primitives in order to use the keystore. -One thing that should be understood, though, is that the cryptographic primitives underpinning the -keystore can operate in light or standard mode. Light mode is computationally cheaper, while standard -mode has extra security. Light mode is appropriate for mobile devices, but developers should be -aware that there is a security trade-off. +One thing that should be understood, though, is that the cryptographic primitives underpinning the keystore can operate in light or standard mode.Light mode is computationally cheaper, while standard mode has extra security. Light mode is appropriate for mobile devices, but developers should be aware that there is a security trade-off. * standard needs 256MB memory and 1 second processing on a modern CPU to access a key * light needs 4MB memory and 100 millisecond processing on a modern CPU to access a key - -The encrypted keystore is implemented by the [`accounts.Manager`][accounts-manager] struct -from the [`accounts`][accounts-pkg] package, which also contains the configuration constants for the -*standard* or *light* security modes described above. Hence client side account management +The encrypted keystore is implemented by the [`accounts.Manager`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager) struct from the [`accounts`](https://godoc.org/github.com/ethereum/go-ethereum/accounts) package, which also contains the configuration constants for the *standard* or *light* security modes described above. Hence client side account management simply requires importing the `accounts` package into the application code. ```go @@ -51,61 +32,31 @@ ks := keystore.NewKeyStore("/path/to/keystore", keystore.StandardScryptN, keysto am := accounts.NewManager(&accounts.Config{InsecureUnlockAllowed: false}, ks) ``` -The path to the keystore folder needs to be a location that is writable by the local user -but non-readable for other system users, such as inside the user's home directory. - -The last two arguments of [`keystore.NewKeyStore`][keystore] are the crypto parameters defining -how resource-intensive the keystore encryption should be. The options are -[`accounts.StandardScryptN, accounts.StandardScryptP`, `accounts.LightScryptN, -accounts.LightScryptP`][pkg-constants] or custom values (requiring understanding of the underlying -cryptography). The *standard* version is recommended. +The path to the keystore folder needs to be a location that is writable by the local user but non-readable for other system users, such as inside the user's home directory. +The last two arguments of [`keystore.NewKeyStore`](https://godoc.org/github.com/ethereum/go-ethereum/accounts/keystore#NewKeyStore) are the crypto parameters defining how resource-intensive the keystore encryption should be. The options are [`accounts.StandardScryptN, accounts.StandardScryptP`, `accounts.LightScryptN, accounts.LightScryptP`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#pkg-constants) or custom values (requiring understanding of the underlying cryptography). The *standard* version is recommended. ## Account lifecycle -Once an encrypted keystore for Ethereum accounts exists it, it can be used to manage accounts for the -entire account lifecycle requirements of a Go native application. This includes the basic functionality -of creating new accounts and deleting existing ones as well as updating access credentials, -exporting existing accounts, and importing them on other devices. +Once an encrypted keystore for Ethereum accounts exists it, it can be used to manage accounts for the entire account lifecycle requirements of a Go native application. This includes the basic functionality of creating new accounts and deleting existing ones as well as updating access credentials, exporting existing accounts, and importing them on other devices. -Although the keystore defines the encryption strength it uses to store accounts, there is no global master -password that can grant access to all of them. Rather each account is maintained individually, and stored on -disk in its [encrypted format][wss] individually, ensuring a much cleaner and stricter separation of -credentials. +Although the keystore defines the encryption strength it uses to store accounts, there is no global master password that can grant access to all of them. Rather each account is maintained individually, and stored on disk in its [encrypted format](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) individually, ensuring a much cleaner and stricter separation of credentials. -This individuality means that any operation requiring access to an account will need to provide the -necessary authentication credentials for that particular account in the form of a passphrase: +This individuality means that any operation requiring access to an account will need to provide the necessary authentication credentials for that particular account in the form of a passphrase: - * When creating a new account, the caller must supply a passphrase to encrypt the account - with. This passphrase will be required for any subsequent access, the lack of which - will forever forfeit using the newly created account. +* When creating a new account, the caller must supply a passphrase to encrypt the account with. This passphrase will be required for any subsequent access, the lack of which will forever forfeit using the newly created account. - * When deleting an existing account, the caller must supply a passphrase to verify - ownership of the account. This isn't cryptographically necessary, rather a protective - measure against accidental loss of accounts. +* When deleting an existing account, the caller must supply a passphrase to verify ownership of the account. This isn't cryptographically necessary, rather a protective measure against accidental loss of accounts. - * When updating an existing account, the caller must supply both current and new - passphrases. After completing the operation, the account will not be accessible via the - old passphrase any more. +* When updating an existing account, the caller must supply both current and new passphrases. After completing the operation, the account will not be accessible via the old passphrase any more. - * When exporting an existing account, the caller must supply both the current passphrase - to decrypt the account, as well as an export passphrase to re-encrypt it with before - returning the key-file to the user. This is required to allow moving accounts between - machines and applications without sharing original credentials. +* When exporting an existing account, the caller must supply both the current passphrase to decrypt the account, as well as an export passphrase to re-encrypt it with before returning the key-file to the user. This is required to allow moving accounts between machines and applications without sharing original credentials. - * When importing a new account, the caller must supply both the encryption passphrase of - the key-file being imported, as well as a new passhprase with which to store the - account. This is required to allow storing account with different credentials than used - for moving them around. +* When importing a new account, the caller must supply both the encryption passphrase of the key-file being imported, as well as a new passhprase with which to store the account. This is required to allow storing account with different credentials than used for moving them around. -***Please note, there are no recovery mechanisms for lost passphrases. The -cryptographic properties of the encrypted keystore (using the provided parameters) -guarantee that account credentials cannot be brute forced in any meaningful time.*** +***Please note, there are no recovery mechanisms for lost passphrases. The cryptographic properties of the encrypted keystore (using the provided parameters) guarantee that account credentials cannot be brute forced in any meaningful time.*** -An Ethereum account is implemented by the [`accounts.Account`][accounts-account] struct from -the Geth [accounts][accounts-pkg] package. Assuming an instance of an -[`accounts.Manager`][accounts-manager] called `am` exists, all of the described lifecycle -operations can be executed with a handful of function calls (error handling omitted). +An Ethereum account is implemented by the [`accounts.Account`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Account) struct from the Geth [accounts](https://godoc.org/github.com/ethereum/go-ethereum/accounts) package. Assuming an instance of an [`accounts.Manager`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager) called `am` exists, all of the described lifecycle operations can be executed with a handful of function calls (error handling omitted). ```go // Create a new account with the specified encryption passphrase. @@ -127,46 +78,20 @@ _ = ks.Delete(newAcc, "Update password") impAcc, _ := ks.Import(jsonAcc, "Export password", "Import password") ``` -*Although instances of [`accounts.Account`][accounts-account] can be used to access various information about -specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or private keys), -rather they act solely as identifiers for client code and the keystore.* +*Although instances of [`accounts.Account`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Account) can be used to access various information about specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or private keys), rather they act solely as identifiers for client code and the keystore.* ## Signing authorization -Account objects do not hold the sensitive private keys of the associated Ethereum accounts. -Account objects are placeholders that identify the cryptographic keys. All operations that -require authorization (e.g. transaction signing) are performed by the account manager after -granting it access to the private keys. +Account objects do not hold the sensitive private keys of the associated Ethereum accounts. Account objects are placeholders that identify the cryptographic keys. All operations that require authorization (e.g. transaction signing) are performed by the account manager after granting it access to the private keys. -There are a few different ways to authorize the account manager to execute signing -operations, each having its advantages and drawbacks. Since the different methods have -wildly different security guarantees, it is essential to be clear on how each works: +There are a few different ways to authorize the account manager to execute signing operations, each having its advantages and drawbacks. Since the different methods have wildly different security guarantees, it is essential to be clear on how each works: -* **Single authorization**: The simplest way to sign a transaction via the account - manager is to provide the passphrase of the account every time something needs to be - signed, which will ephemerally decrypt the private key, execute the signing operation - and immediately throw away the decrypted key. The drawbacks are that the passphrase - needs to be queried from the user every time, which can become annoying if done - frequently or the application needs to keep the passphrase in memory, which can have - security consequences if not done properly. Depending on the keystore's configured - strength, constantly decrypting keys can result in non-negligible resource - requirements. +* **Single authorization**: The simplest way to sign a transaction via the account manager is to provide the passphrase of the account every time something needs to be signed, which will ephemerally decrypt the private key, execute the signing operation and immediately throw away the decrypted key. The drawbacks are that the passphrase needs to be queried from the user every time, which can become annoying if done frequently or the application needs to keep the passphrase in memory, which can have security consequences if not done properly. Depending on the keystore's configured strength, constantly decrypting keys can result in non-negligible resource requirements. -* **Multiple authorizations**: A more complex way of signing transactions via the account - manager is to unlock the account via its passphrase once, and allow the account manager - to cache the decrypted private key, enabling all subsequent signing requests to - complete without the passphrase. The lifetime of the cached private key may be managed - manually (by explicitly locking the account back up) or automatically (by providing a - timeout during unlock). This mechanism is useful for scenarios where the user may need - to sign many transactions or the application would need to do so without requiring user - input. The crucial aspect to remember is that **anyone with access to the account - manager can sign transactions while a particular account is unlocked** (e.g. - application running untrusted code). +* **Multiple authorizations**: A more complex way of signing transactions via the account manager is to unlock the account via its passphrase once, and allow the account manager to cache the decrypted private key, enabling all subsequent signing requests to complete without the passphrase. The lifetime of the cached private key may be managed manually (by explicitly locking the account back up) or automatically (by providing a timeout during unlock). This mechanism is useful for scenarios where the user may need to sign many transactions or the application would need to do so without requiring user input. The crucial aspect to remember is that **anyone with access to the account manager can sign transactions while a particular account is unlocked** (e.g. application running untrusted code). +Assuming an instance of an [`accounts.Manager`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager) called `am` exists, a new account can be created to sign transactions using [`NewAccount`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.NewAccount). Creating transactions is out of scope for this page so instead a random [`common.Hash`](https://godoc.org/github.com/ethereum/go-ethereum/common#Hash) will be signed instead. -Assuming an instance of an [`accounts.Manager`][accounts-manager] called `am` exists, a new -account can be created to sign transactions using [`NewAccount`][new-account]. Creating transactions -is out of scope for this page so instead a random [`common.Hash`][common-hash] will be signed instead. For information on creating transactions in Go native applications see the [Go API page](/docs/dapp/native). ```go @@ -175,8 +100,7 @@ signer, _ := ks.NewAccount("Signer password") txHash := common.HexToHash("0x0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef") ``` -With the boilerplate out of the way, the transaction can be signed using the authorization -mechanisms described above: +With the boilerplate out of the way, the transaction can be signed using the authorization mechanisms described above: ```go // Sign a transaction with a single authorization @@ -192,32 +116,9 @@ _ = ks.TimedUnlock(signer, "Signer password", time.Second) signature, _ = ks.SignHash(signer, txHash.Bytes()) ``` -Note that [`SignWithPassphrase`][sign-w-phrase] takes an [`accounts.Account`][accounts-account] as the -signer, whereas [`Sign`][accounts-sign] takes only a [`common.Address`][common-address]. The reason -for this is that an [`accounts.Account`][accounts-account] object may also contain a custom key-path, allowing -[`SignWithPassphrase`][sign-w-phrase] to sign using accounts outside of the keystore; however -[`Sign`][accounts-sign] relies on accounts already unlocked within the keystore, so it cannot specify custom paths. - +Note that [`SignWithPassphrase`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.SignWithPassphrase) takes an [`accounts.Account`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Account) as the signer, whereas [`Sign`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.Sign) takes only a [`common.Address`](https://godoc.org/github.com/ethereum/go-ethereum/common#Address). The reason for this is that an [`accounts.Account`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Account) object may also contain a custom key-path, allowing [`SignWithPassphrase`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.SignWithPassphrase) to sign using accounts outside of the keystore; however [`Sign`](https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.Sign) relies on accounts already unlocked within the keystore, so it cannot specify custom paths. ## Summary -Account management is a fundamental pillar of Ethereum development. Geth's Go API provides the tools required -to integrate best-practise account security into Go native applications using a simple set of Go functions. +Account management is a fundamental pillar of Ethereum development. Geth's Go API provides the tools required to integrate best-practise account security into Go native applications using a simple set of Go functions. - -[accounts-sign]: (https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.Sign) -[common-address]: https://godoc.org/github.com/ethereum/go-ethereum/common#Address -[accounts-sign]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.Sign -[sign-w-phrase]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.SignWithPassphrase -[secp256k1]: https://www.secg.org/sec2-v2.pdf -[libsecp256k1]: https://github.com/bitcoin-core/secp256k1 -[wss]:https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition -[go-accounts]:https://godoc.org/github.com/ethereum/go-ethereum/accounts -[accounts-manager]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager -[accounts-pkg]: https://godoc.org/github.com/ethereum/go-ethereum/accounts -[keystore]: https://godoc.org/github.com/ethereum/go-ethereum/accounts/keystore#NewKeyStore -[pkg-constants]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#pkg-constants -[accounts-account]:https://godoc.org/github.com/ethereum/go-ethereum/accounts#Account -[new-account]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.NewAccount -[common-hash]: https://godoc.org/github.com/ethereum/go-ethereum/common#Hash -[scrypt-docs]: https://pkg.go.dev/golang.org/x/crypto/scrypt diff --git a/content/docs/developers/dapp-developer/native-bindings.md b/content/docs/developers/dapp-developer/native-bindings.md index 248bd12e01..5b81dec66a 100644 --- a/content/docs/developers/dapp-developer/native-bindings.md +++ b/content/docs/developers/dapp-developer/native-bindings.md @@ -1,51 +1,26 @@ --- title: Go Contract Bindings -sort_key: E +description: Intriduction to generating bindings for using Geth features in Go native applications --- -This page introduces the concept of server-side native dapps. Geth provides the tools required -to generate [Go][go-link] language bindings to any Ethereum contract that is compile-time type safe, -highly performant and can be generated completely automatically from a compiled contract. +This page introduces the concept of server-side native dapps. Geth provides the tools required to generate [Go](https://github.com/golang/go/wiki#getting-started-with-go) language bindings to any Ethereum contract that is compile-time type safe, highly performant and can be generated completely automatically from a compiled contract. -Interacting with a contract on the Ethereum blockchain from Go is already possible via the -RPC interfaces exposed by Ethereum clients. However, writing the boilerplate code that -translates Go language constructs into RPC calls and back is time consuming and brittle - -implementation bugs can only be detected during runtime and it's almost impossible to evolve -a contract as even a tiny change in Solidity is awkward to port over to Go. Therefore, -Geth provides tools for easily converting contract code into Go code that can be used directly -in Go applications. +Interacting with a contract on the Ethereum blockchain from Go is already possible via the RPC interfaces exposed by Ethereum clients. However, writing the boilerplate code that translates Go language constructs into RPC calls and back is time consuming and brittle - implementation bugs can only be detected during runtime and it's almost impossible to evolve a contract as even a tiny change in Solidity is awkward to port over to Go. Therefore, Geth provides tools for easily converting contract code into Go code that can be used directly in Go applications. -This page provides an introduction to generating Go contract bindings and using them in a simple -Go application. - -{:toc} - -- this will be removed by the toc +This page provides an introduction to generating Go contract bindings and using them in a simple Go application. ## Prerequisites -This page is fairly beginner-friendly and designed for people starting out with -writing Go native dapps. The core concepts will be introduced gradually as a developer -would encounter them. However, some basic familiarity with [Ethereum](https://ethereum.org), -[Solidity](https://docs.soliditylang.org/en/v0.8.15/) and [Go](https://go.dev/) is -assumed. +This page is fairly beginner-friendly and designed for people starting out with writing Go native dapps. The core concepts will be introduced gradually as a developer would encounter them. However, some basic familiarity with [Ethereum](https://ethereum.org), [Solidity](https://docs.soliditylang.org/en/v0.8.15/) and [Go](https://go.dev/) is assumed. ## What is an ABI? -Ethereum smart contracts have a schema that defines its functions and return types in the form -of a JSON file. This JSON file is known as an *Application Binary Interface*, or ABI. The ABI -acts as a specification for precisely how to encode data sent to a contract and how to -decode the data the contract sends back. The ABI is the only essential piece of information required to -generate Go bindings. Go developers can then use the bindings to interact with the contract -from their Go application without having to deal directly with data encoding and decoding. -An ABI is generated when a contract is compiled. +Ethereum smart contracts have a schema that defines its functions and return types in the form of a JSON file. This JSON file is known as an *Application Binary Interface*, or ABI. The ABI acts as a specification for precisely how to encode data sent to a contract and how to decode the data the contract sends back. The ABI is the only essential piece of information required to generate Go bindings. Go developers can then use the bindings to interact with the contract from their Go application without having to deal directly with data encoding and decoding. An ABI is generated when a contract is compiled. ## Abigen: Go binding generator -Geth includes a source code generator called `abigen` that can convert Ethereum ABI definitions -into easy to use, type-safe Go packages. With a valid Go development environment -set up and the go-ethereum repository checked out correctly, `abigen` can be built as follows: +Geth includes a source code generator called `abigen` that can convert Ethereum ABI definitions into easy to use, type-safe Go packages. With a valid Go development environment set up and the go-ethereum repository checked out correctly, `abigen` can be built as follows: ``` $ cd $GOPATH/src/github.com/ethereum/go-ethereum @@ -54,9 +29,7 @@ $ go build ./cmd/abigen ### Generating the bindings -To demonstrate the binding generator a contract is required. The contract `Storage.sol` implements two -very simple functions: `store` updates a user-defined `uint256` to the contract's storage, and `retrieve` -displays the value stored in the contract to the user. The Solidity code is as follows: +To demonstrate the binding generator a contract is required. The contract `Storage.sol` implements two very simple functions: `store` updates a user-defined `uint256` to the contract's storage, and `retrieve` displays the value stored in the contract to the user. The Solidity code is as follows: ```solidity // SPDX-License-Identifier: GPL-3.0 @@ -83,18 +56,13 @@ contract Storage { This contract can be pasted into a text file and saved as `Storage.sol`. -The following code snippet shows how an ABI can be generated for `Storage.sol` -using the Solidity compiler `solc`. +The following code snippet shows how an ABI can be generated for `Storage.sol` using the Solidity compiler `solc`. ```shell solc --abi Storage.sol -o build ``` -The ABI can also be generated in other ways such as using the `compile` commands in development -frameworks such as [Truffle][truffle-link], [Hardhat][hardhat-link] and [Brownie][brownie-link] -or in the online IDE [Remix][remix-link]. ABIs for existing -verified contracts can be downloaded from [Etherscan](etherscan.io). - +The ABI can also be generated in other ways such as using the `compile` commands in development frameworks such as [Truffle](https://trufflesuite.com/docs/truffle/), [Hardhat](https://hardhat.org/) and [Brownie](https://eth-brownie.readthedocs.io/en/stable/) or in the online IDE [Remix](https://remix.ethereum.org/). ABIs for existing verified contracts can be downloaded from [Etherscan](etherscan.io). The ABI for `Storage.sol` (`Storage.abi`) looks as follows: @@ -115,9 +83,7 @@ Where the flags are: * `--type`: Optional Go type name to assign to the binding struct * `--out`: Optional output path for the generated Go source file (not set = stdout) -This will generate a type-safe Go binding for the Storage contract. The generated code will -look something like the snippet below, the full version of which can be viewed -[here](https://gist.github.com/jmcook1186/a78e59d203bb54b06e1b81f2cda79d93). +This will generate a type-safe Go binding for the Storage contract. The generated code will look something like the snippet below, the full version of which can be viewed [here](https://gist.github.com/jmcook1186/a78e59d203bb54b06e1b81f2cda79d93). ```go // Code generated - DO NOT EDIT. @@ -169,16 +135,12 @@ type Storage struct { ``` -`Storage.go` contains all the bindings required to interact with `Storage.sol` from a Go application. -However, this isn't very useful unless the contract is actually deployed on Ethereum or one of -Ethereum's testnets. The following sections will demonstrate how to deploy the contract to +`Storage.go` contains all the bindings required to interact with `Storage.sol` from a Go application. However, this isn't very useful unless the contract is actually deployed on Ethereum or one of Ethereum's testnets. The following sections will demonstrate how to deploy the contract to an Ethereum testnet and interact with it using the Go bindings. ### Deploying contracts to Ethereum -In the previous section, the contract ABI was sufficient for generating the contract bindings from its ABI. -However, deploying the contract requires some additional information in the form of the compiled -bytecode. +In the previous section, the contract ABI was sufficient for generating the contract bindings from its ABI. However, deploying the contract requires some additional information in the form of the compiled bytecode. The bytecode is obtained by running the compiler again but this passing the `--bin` flag, e.g. @@ -193,8 +155,7 @@ Then `abigen` can be run again, this time passing `Storage.bin`: $ abigen --abi Storage.abi --pkg main --type Storage --out Storage.go --bin Storage.bin ``` -This will generate something similar to the bindings generated in the previous section. However, -an additional `DeployStorage` function has been injected: +This will generate something similar to the bindings generated in the previous section. However, an additional `DeployStorage` function has been injected: ```go // DeployStorage deploys a new Ethereum contract, binding an instance of Storage to it. @@ -216,16 +177,12 @@ func DeployStorage(auth *bind.TransactOpts, backend bind.ContractBackend) (commo ``` View the full file [here](https://gist.github.com/jmcook1186/91124cfcbc7f22dcd3bb4f148d2868a8). -The new `DeployStorage()` function can be used to deploy the contract to an Ethereum testnet from a Go application. To do this -requires incorporating the bindings into a Go application that also handles account management, authorization and Ethereum backend -to deploy the contract through. Specifically, this requires: +The new `DeployStorage()` function can be used to deploy the contract to an Ethereum testnet from a Go application. To do this requires incorporating the bindings into a Go application that also handles account management, authorization and Ethereum backend to deploy the contract through. Specifically, this requires: 1. A running Geth node connected to an Ethereum testnet (recommended Goerli) 2. An account in the keystore prefunded with enough ETH to cover gas costs for deploying and interacting with the contract -Assuming these prerequisites exist, a new `ethclient` can be instantiated with the local Geth node's ipc file, providing -access to the testnet from the Go application. The key can be instantiated as a variable in the application by copying the -JSON object from the keyfile in the keystore. +Assuming these prerequisites exist, a new `ethclient` can be instantiated with the local Geth node's ipc file, providing access to the testnet from the Go application. The key can be instantiated as a variable in the application by copying the JSON object from the keyfile in the keystore. Putting it all together would result in: @@ -275,8 +232,7 @@ func main() { } ``` -Running this code requests the creation of a brand new `Storage` contract on the Goerli blockchain. -The contract functions can be called while the contract is waiting to be mined. +Running this code requests the creation of a brand new `Storage` contract on the Goerli blockchain. The contract functions can be called while the contract is waiting to be included in a block. ``` Contract pending deploy: 0x46506d900559ad005feb4645dcbb2dbbf65e19cc @@ -285,8 +241,7 @@ Transaction waiting to be mined: 0x6a81231874edd2461879b7280ddde1a857162a744e365 Pending name: Storage contract in Go! ``` -Once mined, the contract exists permanently at its deployment address and can now be interacted with -from other applications without ever needing to be redeployed. +Once the contract deployment has been included in a validated block, the contract exists permanently at its deployment address and can now be interacted with from other applications without ever needing to be redeployed. Note that `DeployStorage` returns four variables: @@ -301,15 +256,11 @@ Note that `DeployStorage` returns four variables: ### Accessing an Ethereum contract -To interact with a contract already deployed on the blockchain, the deployment `address` is required and -a `backend` through which to access Ethereum must be defined. The binding generator provides an RPC -backend out-of-the-box that can be used to attach to an existing Ethereum node via IPC, HTTP or WebSockets. +To interact with a contract already deployed on the blockchain, the deployment `address` is required and a `backend` through which to access Ethereum must be defined. The binding generator provides an RPC backend out-of-the-box that can be used to attach to an existing Ethereum node via IPC, HTTP or WebSockets. -As in the previous section, a Geth node running on an Ethereum testnet (recommend Goerli) and an account -with some test ETH to cover gas is required. The `Storage.sol` deployment address is also needed. +As in the previous section, a Geth node running on an Ethereum testnet (recommend Goerli) and an account with some test ETH to cover gas is required. The `Storage.sol` deployment address is also needed. -Again, an instance of `ethclient` can be created, passing the path to Geth's ipc file. In the example -below this backend is assigned to the variable `conn`. +Again, an instance of `ethclient` can be created, passing the path to Geth's ipc file. In the example below this backend is assigned to the variable `conn`. ```go // Create an IPC based RPC connection to a remote node @@ -320,9 +271,7 @@ if err != nil { } ``` -The functions available for interacting with the `Storage` contract are defined in `Storage.go`. To create -a new instance of the contract in a Go application, the `NewStorage()` function can be used. The function -is defined in `Storage.go` as follows: +The functions available for interacting with the `Storage` contract are defined in `Storage.go`. To create a new instance of the contract in a Go application, the `NewStorage()` function can be used. The function is defined in `Storage.go` as follows: ```go // NewStorage creates a new instance of Storage, bound to a specific deployed contract. @@ -335,8 +284,7 @@ func NewStorage(address common.Address, backend bind.ContractBackend) (*Storage, } ``` -`NewStorage()` takes two arguments: the deployment address and a backend (`conn`) and returns -an instance of the deployed contract. In the example below, the instance is assigned to `store`. +`NewStorage()` takes two arguments: the deployment address and a backend (`conn`) and returns an instance of the deployed contract. In the example below, the instance is assigned to `store`. ```go @@ -366,9 +314,7 @@ func main() { ``` -The contract instance is then available to interact with in the Go application. To read a value from -the blockchain, for example the `value` stored in the contract, the contract's `Retrieve()` function -can be called. Again, the function is defined in `Storage.go` as follows: +The contract instance is then available to interact with in the Go application. To read a value from the blockchain, for example the `value` stored in the contract, the contract's `Retrieve()` function can be called. Again, the function is defined in `Storage.go` as follows: ```go // Retrieve is a free data retrieval call binding the contract method 0x2e64cec1. @@ -389,10 +335,7 @@ func (_Storage *StorageCaller) Retrieve(opts *bind.CallOpts) (*big.Int, error) { } ``` -Note that the `Retrieve()` function requires a parameter to be passed, even though the -original Solidity contract didn't require any at all none. The parameter required is -a `*bind.CallOpts` type, which can be used to fine tune the call. If no adjustments to the -call are required, pass `nil`. Adjustments to the call include: +Note that the `Retrieve()` function requires a parameter to be passed, even though the original Solidity contract didn't require any at all none. The parameter required is a `*bind.CallOpts` type, which can be used to fine tune the call. If no adjustments to the call are required, pass `nil`. Adjustments to the call include: * `Pending`: Whether to access pending contract state or the current stable one * `GasLimit`: Place a limit on the computing resources the call might consume @@ -416,17 +359,9 @@ Value: 56 ### Transacting with an Ethereum contract -Invoking a method that changes contract state (i.e. transacting) is a bit more involved, -as a live transaction needs to be authorized and broadcast into the network. **Go bindings -require local signing of transactions and do not delegate this to a remote node.** This is -to keep accounts private within dapps, and not shared (by default) between them. +Invoking a method that changes contract state (i.e. transacting) is a bit more involved, as a live transaction needs to be authorized and broadcast into the network. **Go bindings require local signing of transactions and do not delegate this to a remote node.** This is to keep accounts private within dapps, and not shared (by default) between them. -Thus to allow transacting with a contract, your code needs to implement a method that -given an input transaction, signs it and returns an authorized output transaction. Since -most users have their keys in the [Web3 Secret Storage][web3-ss-link] format, the `bind` -package contains a small utility method (`bind.NewTransactor(keyjson, passphrase)`) that can -create an authorized transactor from a key file and associated password, without the user -needing to implement key signing themselves. +Thus to allow transacting with a contract, your code needs to implement a method that given an input transaction, signs it and returns an authorized output transaction. Since most users have their keys in the [Web3 Secret Storage](https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition) format, the `bind` package contains a small utility method (`bind.NewTransactor(keyjson, passphrase)`) that can create an authorized transactor from a key file and associated password, without the user needing to implement key signing themselves. Changing the previous code snippet to update the value stored in the contract: @@ -476,9 +411,7 @@ And the output: Update pending: 0x4f4aaeb29ed48e88dd653a81f0b05d4df64a86c99d4e83b5bfeb0f0006b0e55b ``` -Similar to the method invocations in the previous section which only read contract state, -transacting methods also require a mandatory first parameter, a `*bind.TransactOpts` type, -which authorizes the transaction and potentially fine tunes it: +Similar to the method invocations in the previous section which only read contract state, transacting methods also require a mandatory first parameter, a `*bind.TransactOpts` type, which authorizes the transaction and potentially fine tunes it: * `From`: Address of the account to invoke the method with (mandatory) * `Signer`: Method to sign a transaction locally before broadcasting it (mandatory) @@ -487,21 +420,14 @@ which authorizes the transaction and potentially fine tunes it: * `GasPrice`: Explicitly set the gas price to run the transaction with (optional) * `Value`: Any funds to transfer along with the method call (optional) -The two mandatory fields are automatically set by the `bind` package if the auth options are -constructed using `bind.NewTransactor`. The nonce and gas related fields are automatically -derived by the binding if they are not set. Unset values are assumed to be zero. +The two mandatory fields are automatically set by the `bind` package if the auth options are constructed using `bind.NewTransactor`. The nonce and gas related fields are automatically derived by the binding if they are not set. Unset values are assumed to be zero. ### Pre-configured contract sessions -Reading and state modifying contract-calls require a mandatory first parameter which can -authorize and fine tune some of the internal parameters. However, most of the time the -same accounts and parameters will be used to issue many transactions, so constructing -the call/transact options individually quickly becomes unwieldy. +Reading and state modifying contract-calls require a mandatory first parameter which can authorize and fine tune some of the internal parameters. However, most of the time the same accounts and parameters will be used to issue many transactions, so constructing the call/transact options individually quickly becomes unwieldy. -To avoid this, the generator also creates specialized wrappers that can be pre-configured with -tuning and authorization parameters, allowing all the Solidity defined methods to be invoked -without needing an extra parameter. +To avoid this, the generator also creates specialized wrappers that can be pre-configured with tuning and authorization parameters, allowing all the Solidity defined methods to be invoked without needing an extra parameter. These are named similarly to the original contract type name but suffixed with `Sessions`: @@ -524,20 +450,17 @@ session.Store(big.NewInt(69)) ## Bind Solidity directly -In the past, abigen allowed compilation and binding of a Solidity source file directly to a Go package in a single step. -This feature has been discontinued from [v1.10.18](https://github.com/ethereum/go-ethereum/releases/tag/v1.10.18) -onwards due to maintenance synchronization challenges with the compiler in Geth. +In the past, abigen allowed compilation and binding of a Solidity source file directly to a Go package in a single step. This feature has been discontinued from [v1.10.18](https://github.com/ethereum/go-ethereum/releases/tag/v1.10.18) onwards due to maintenance synchronization challenges with the compiler in Geth. The compilation and binding steps can be joined together into a pipeline, for example: + ``` solc Storage.sol --combined-json abi,bin | abigen --pkg main --type storage --out Storage.go --combined-json - ``` ### Project integration (`go generate`) -The `abigen` command was made in such a way as to integrate easily into existing -Go toolchains: instead of having to remember the exact command needed to bind an Ethereum -contract into a Go project, `go generate` can handle all the fine details. +The `abigen` command was made in such a way as to integrate easily into existing Go toolchains: instead of having to remember the exact command needed to bind an Ethereum contract into a Go project, `go generate` can handle all the fine details. Place the binding generation command into a Go source file before the package definition: @@ -545,19 +468,12 @@ Place the binding generation command into a Go source file before the package de //go:generate abigen --sol Storage.sol --pkg main --out Storage.go ``` -After which whenever the Solidity contract is modified, instead of needing to remember and -run the above command, we can simply call `go generate` on the package (or even the entire -source tree via `go generate ./...`), and it will correctly generate the new bindings for us. +After which whenever the Solidity contract is modified, instead of needing to remember and run the above command, we can simply call `go generate` on the package (or even the entire source tree via `go generate ./...`), and it will correctly generate the new bindings for us. ## Blockchain simulator -Being able to deploy and access deployed Ethereum contracts from native Go code is a powerful -feature. However, using public testnets as a backend does not lend itself well to -*automated unit testing*. Therefore, Geth also implements a *simulated blockchain* -that can be set as a backend to native contracts the same way as a live RPC backend, using the -command `backends.NewSimulatedBackend(genesisAccounts)`. The code snippet below shows how this -can be used as a backend in a Go applicatioon. +Being able to deploy and access deployed Ethereum contracts from native Go code is a powerful feature. However, using public testnets as a backend does not lend itself well to *automated unit testing*. Therefore, Geth also implements a *simulated blockchain* that can be set as a backend to native contracts the same way as a live RPC backend, using the command `backends.NewSimulatedBackend(genesisAccounts)`. The code snippet below shows how this can be used as a backend in a Go application. ```go package main @@ -599,19 +515,7 @@ func main() { } ``` -Note, that it is not necessary to wait for a local private chain miner, or testnet miner to -integrate the currently pending transactions. To mine the next block, simply `Commit()` the simulator. - ## Summary -To make interacting with Ethereum contracts easier for Go developers, Geth provides tools that generate -contract bindings automatically. This makes contract functions available in Go native applications. - - -[go-link]:https://github.com/golang/go/wiki#getting-started-with-go -[truffle-link]:https://trufflesuite.com/docs/truffle/ -[hardhat-link]:https://hardhat.org/ -[brownie-link]:https://eth-brownie.readthedocs.io/en/stable/ -[remix-link]:https://remix.ethereum.org/ -[web3-ss-link]:https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition \ No newline at end of file +To make interacting with Ethereum contracts easier for Go developers, Geth provides tools that generate contract bindings automatically. This makes contract functions available in Go native applications. diff --git a/content/docs/monitoring/ethstats.md b/content/docs/monitoring/ethstats.md index dc209244a8..707ecf4d64 100644 --- a/content/docs/monitoring/ethstats.md +++ b/content/docs/monitoring/ethstats.md @@ -1,5 +1,6 @@ --- title: Monitoring with Ethstats +description: Setting up an Ethstats server --- Ethstats is a service that displays real time and historical statistics about individual diff --git a/content/docs/monitoring/metrics.md b/content/docs/monitoring/metrics.md index 51fed3ecd5..a12fdbe706 100644 --- a/content/docs/monitoring/metrics.md +++ b/content/docs/monitoring/metrics.md @@ -1,9 +1,8 @@ --- title: Metrics -sort_key: G +description: Introduction to reporting metrics from Geth --- - Geth includes a variety of optional metrics that can be reported to the user. However, metrics are disabled by default to save on the computational overhead for the average user. Users that choose to see more detailed metrics can enable them using the `--metrics` flag when starting Geth. Some metrics are classed as especially expensive and are only enabled when the `--metrics.expensive` flag is supplied. For example, per-packet network traffic data is considered expensive. The goal of the Geth metrics system is that - similar to logs - arbitrary metric collections can be added to any part of the code without requiring fancy constructs to analyze them (counter variables, public interfaces, crossing over the APIs, console hooks, etc). Instead, metrics should be "updated" whenever and wherever needed and be automatically collected, surfaced through the APIs, queryable and visualizable for analysis. From 18ae820f7ab54e8612ea8f7321b7423add3ccf95 Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 17 Aug 2022 09:24:32 +0100 Subject: [PATCH 035/432] move tracer doc, md formatting --- assets/devcon2_labelled.webp | Bin 0 -> 145820 bytes .../built-in-tracers.md | 4 +- .../docs/developers/dapp-developer/native.md | 98 +++--------- .../docs/developers/dapp-developer/tracing.md | 148 +++++------------- 4 files changed, 60 insertions(+), 190 deletions(-) create mode 100644 assets/devcon2_labelled.webp rename content/docs/developers/{geth-developer => dapp-developer}/built-in-tracers.md (98%) diff --git a/assets/devcon2_labelled.webp b/assets/devcon2_labelled.webp new file mode 100644 index 0000000000000000000000000000000000000000..321326e64ad1df144f934c9b03ca57d8e4c98cd6 GIT binary patch literal 145820 zcmaI7bCe`O_bpm&+xE0EZQHi3Y1_7KP21DPv~7FZwr$kw@4Iik-~Hp>7rC->*N(Fz z;+%}ih**)OEF~_U!UYP@5EE8ZSLD=$1polV-zORbfD!^AB_g7j5BmKT0Ge-OV(Sdf z1OV9Dxi~3H2oq~+X%j;o0U!a$02lx_0AOU|>>#A5DElAl|8si!2LSm`&I0{^%KAUs z{9joFQ!{51004ye+d|O9!O7(t8-8PUcNd5M;EZpKZen3%`i-l;F`d(Q1HbXge|Y2n zg)jbtfBhH#*C})-Rb`QH-_XB#;$Qz8HvZqRiG`Exw+-vJ4Y{eU-FNw*n*R%%{s;T~ z2iw}Xez)zv=|3LAo7t(Ud|%1GPkev`KnfrSQ2Y+7F~AjI39tdU0O-H3cHfLMK>0gg z`2V8E{jXl}TV?#MvILlXD?|bI09%03fAxU>+=FkM@AN;hbv9>V{x1arFAM-cYypAy z6aWBJG63+I00h1l0D+%{007tq0MKjqKYIIo0D$xHn@{*3jyw+lKnei>{to^RXPgcI zw1fiy*sBgkPDcN&2kiS3)Z82ZxGMty5VXGg&MW``tMk9&_MP{id_d7M0HFFEE7>Uk zATtX9`0?wzY~BBh-_YNJ|1WO;zc&AG{JwiG@iaRqzyTWSHwXDczMky| zU+CkZBMv#OJlvutyQ#!4qkEQfgTzPYuj_=|C7{l@b*cX&F#lu!H4&%*jDOGb+Wsf7 z>3SW>5)hboO*E+R5m4hy;4Z$kC+=(aOXKtU8MtZC@?B>a zP~tuNi}7iH%V5?&0qFh3^33v)H!88eJqhdw+5p+Uj^Asqkp9ga_^$ySzm~s_Q=YEB z&cBx5X0{9h;w|~hzVhCe-;mz&wtBqywZ1yO1m64~iJk=}{DH539u)3~?)=C7D}WjZP z?%4$H0Oh_0fVFSm3gDN;SN!*}{o3=`^Xb3j|4qH&d`!Gkejwc#oB$tz8Q;wMbvkgl zvvzCS+WHYbt*eEaqfLSGMt-4*gxXxc|NJzWrSsJcN7*X(kB{H`$Zfk-J)>+%>NS=8?O2R$ zT*iV}>LAUnK2koe(=xz7q7{0pg{vyxT_V-NuX zS1K_zms4><;f#=)NDYtjaiON4s=aKR>Y1m*K|=B=yuV}WpiGO1k$1#Z@@^7Ud^c}u z)5#i22N%^9d7!P`rQJ2k00hL{!4C3xn)jPeT9*OKG8|vE5KwIx^m!S9o$xD{eXw(Y0P1FowdBD&sIXZ+F18|5r)w|oq z^{Hkn0JMXfJ8{IY4MpUNy{_wet`Prmm-ZSdMq_54`JA8SMh8jFLNaC9Uz4w6l!{|u zg0;U(Tyiad200*@8-bH=S+S1(4LasxQ1BCkvHKhDrR*#B z`1p`63nvp-Nh0w~0?Ugdc-B&DrlnLN&icC0YH@F^5XIkCcFEY+=iVSIK^)9Ft1QT) zkk0r;8qFxFxH|JM5oU^l=l!sZ^~Ycd3{yXOw%?)`GcG&V4jYKA2Ngc>%P_XQcL-mZ zPB5gVuW+~_3OzWHJkuYgj!V-pqhztcy54)4Z*QYu|3IO!PJlrnDfvoZwQ69`DUGmK zzQ9er4mXFyUD6tVi5JnxDacZ=6-{JMoHItA6D73(wIp^=za+}=%q zfcUN=TR{hkE4DHHL}4MZT64eba@fda_2NA@$*Yt1^P~u@d-dTz9(#6-(D~?>m>d}HM0BseZ(77g^e#VE9*uPx_1DQI*l_Ok5 zB-)2q$QbFd>;Vna`_xgWZJCsN4&_5G5k=q!s)#XELA$QP%5m%)Q<>^bY=YODCvxA8 zKx*qmQEvDYjPU2*UGsSDtIuaSJ%Z{eKQ4sTrbi+vmBc9c&srE7ldEVrgUKd}M!)=I zk(0oqgDlI8@eUO5j~4BuzWZ?~kjPO;_X+VMTsk!kV%kloyc`gIc?RgX`JLgawdo$h`+I|v6!TwbMLi=I~C^xvwkUc=PAMkIIT z>j}v)w{HVqLpCqDXA$(9yi~U zhF#$U8n$AnR9mxM`J(5QfLAef={^vt4R&DFfjqZE5!(>6uvp6(Z8xVs;+f(2_O$Cx zzy^=$7f6iuw;bzEbB(@JgJYDO@x6g;?MUil$#yb2t!b{u&_&Aw7wh@ii_R8C>iOKy z&qz$1LlMp_Txoi6jDA+>l+#9=5Sjwx%-?-t zwv}#g0%1af0aDL~AtU-Zk+|Nf3zlr7-Q2kZ-=v)I0D&*7II-M{wpF4NgE1d2yg)uG z1D~o!bAxiUr?1^KaTLNo^!cSzPBN`Yo+_|ucAa0Bu+CSX5?902f8cd!0|}VRO&*^f z)aNyot48>>&a$@Y;4dm;rQd1+o*IgBEhBE2DNC6s`*2sq8|iV(974bOmxeGYs^2ynXTL4 zKuJEurXrDa+yW#BDclY7oI(PLI-}Gwn@ftxc8;w5$H0_XkV|<17(E0OQeHMg5puMX z@x&LAL1!d{KaZRv#1Fq<0ePHx%C3Z3S&q__i-jEd!S1hWWyt%WLqSwu-yqN|WdE0D z>~r%l@Iz-^fz3Zfsc?Av4qB8v&pwB}|9+hgE$f#d?Aej4=p&qGf|7)e%YWpMi#xU- z26w=4&xj$uUl%+E)ihRuvDZiO`%*QEn?n<{XL!Rimk!W~ao` zTAmM-QVyIThm42ktTHh*CY5lUSX9=7qArv-*f=v&3Wj9Bqy6Wl2;B33U%bkVLmRwQ zgscz;PX1nOTCb!z9FQBG6}R&6y!2~9QKoNG?o}0rf9w7t!#qT+&x2Z2MWUdKW|ip3 z`+iK>VKm|T5145XyN*sKK!TkHzx&i<($;DU#i}&%MKB`5E#VtJHE#lpWO(dIfpf6} zJnaCyU5;#+Hihdr0nEbutXRHRx~xDnQ`pY3`zRK!Vdtbm#)GOKhx1dpj;+T~x&p`9 zPjW5vMwAp}ILwi)$B{>=l3NkK#S0<{~C^_kw%L9C%p|cPSQd%yIW@w z=Ef>B44ko5qaBR@6$6pTF&2{l14}(`FRENfVKxf6As!~(9TsB#q01 zQj>~>c-($Rc>OD@)`+NTlo86nbsDU8f@|5~=QZJY3MhgQg5W@N`$~m_ySh)&RbNHcqJNfA`?`N z5eQY+m>1#0zFEM(Gl%JDACv+ z+rrm5z-)TF(cb}K1*M6jPHvTGjy6pXYM;hWn%`^H0J!;R6E9L49=EVLzSI?9jr8{w zL-}VXrMSqA`8;R*^ck=lGXXx4S0CShMnbmHKLmqO;vRUtotzFHVK86=Qf5|dYH5hN z5*~z@4~N6A`K({z6rBgcTkaFP64Y7=>@rj)TatSZ3q|mGCrb3R?j z2;w`W5lsn2(|;^)OE?mN^QZiaDvPV8?4+kEj2GP3)-$L>Y&MpkDRgmML&RnkR>hb9 zJ>ZjugyFn*efPHm#WxQ7ZY5!01uc@hq_m|04k!0B;}Z|r$H>0{h$?t9)1~Y zRmMhl2X+u-GefhDteV8!j841flE-zgdlfI)Moj0?mfyp*gm$6B<~t96FRtD<4gF7z z08B2z2|qo(g=(-#H3!rjckQ8j5;+Qv{bUlkPJ7|uiEBn9e*I$Nd7~uH(Ii)WGo-2ZBv&uZ)8OsMwVrxNdK=B!-h3%>(sj>@NKeg-v zWz_4aue!QyNU1nx#mDzy*YSfb_NS)-U%dT7!l2_piIB60zx-eMGT0vvMLho*;IGpc zF~;wieoE%*Pd4boae|Fz0LhjO)OS6 zJ#aHh4tal_F&|j+^KExU;?d<2X8z)ypSuIOY9^Lb-mqS> zCY%hO!R)WDPUkoevB~P{YuYGZ>49VMALat6W?OugjqkZ?CkE8PEhO5w90vFjTN)0^ z6$e771^DY|Y3F;7e##0)xv>Y;8UvjoA~l$#f4Rlov_NxY4>pTqz0J?Ub|ytubi~&H z%490eTj55>QMn;5u0~^6SPm9}kcMt&k@+Aq;(Yh(I3A)dza#D1@y0E8TEAaBNf?z% zndji^2FneLr+PauG0$^V(NqekJg1kdr2^E+q|-Y*qGM=ICHs-2Qi{fc=?32;8b31V zLXs?O&v~Gy!a)n;9X%!$&H_n=6Ls%f?1k^jOxgK4$ZrpYF?-}m^jyc{ptWAa>>BDI z#E`Y5qJcn3os@jGXMYT32*E%|9}+z3h|s=A><+B|JPze4A)*6MWtQI)BnQ1`?-!D) zu-=)8-LGEU7K-JC3&gTn;P7QMrIaNFqi~kB7nM?Y3x9LVC2bjP%$n>rwZZ8L<8=@BCo4H1|m6$iy>QoGHg<{xD%hLF*4Mg4qV8baX8m@VCvI*YOfs;_? z8azT}xyVM?0GtkRy;5*l{5rVo3U#TBUd|kNm3mjCGVT^J_B0R}7b4q~aHcpC4VsGR z&M^bO=gzknP$%CL=?6Y!1^b;5cZZUOmtJk%4`>cr!@r;g6n}uxFtc(Cg25X>vMcdA zw95C0q0j-HZj4m62xj=TOC?rWirWp{@xkw&5wD8owYT?}@GWVz11-hqIy& z2jIAR%(r)c@vcS(@MS4s6XAdkz_iQ_6&s6>*<0sX8*(l6BeZp1PH!{Q0IWW3xM%Gx zpz)_rOsvu!%{dtUDM;5&9tXsG;SuAS!&!RNUnk6PJNAIw*ydO@023+RU4#aTeG8tf zf-J8`v+rrwX{+MMoktPnlCWV-Tc{QAWU7A4e+4(0$!M`zrbV^uWX;O;o@{cUl;; zc!xSof7&(f<^8TMOS)MxBsR$X1s$Pp9~_;W=by)I`eZ(pXiAEc;7?__fEyQk*(wz< zN0~KwizFbCHPbnj)%=;mOT2<(jRta@ekhqD5!BLdy@gfBuaP)V@Z@seBrMxQLLrnd zhT6eEl5?N^)=s3npVTqvpC)vk5a4|?;bh-i<9A~ui%2q|T##QFNisg0D zP@FBR8y#qtGk;3UC+P~0Bh|tOZ$y~}Z!xW0>ElaI>a1UG3;KCxG}dtr1Gf`+AU_kj zBhoac&HM4|j({r4(E?KE!IsrZSB83a9ezp*OyeY?$;yfacOHOiaLVY5k`<0yx*!uG!Px_i1c^ z${57O_#b{lSK3c5bVI#0#W&(5#X+Z+ zoe0ynEBA$ZpV}9``^Y6be`wM3loWYH!gYy>tO8&i`l>H~(r>Kwh`L?Mk>MH76i9I- z=B^Pou!r)1{Ua`P|7`IhLKeX|)Xj5RL76^;dEXRK2H?!*Gprl6Pa zmJ=H*?&Vqqa@vi#>eXy@*EUw|)7)LmL=}Y>u_+rCgX~qO=khriRlX!o6Gko)7FHwUI_BL*|w6Aw!RaF%L`Zte=e=T>L=~ zd%txSecI&Lj~n|8L;aU1uPrufX!U($<-gpS!f7VxJPENpJ^arR9iF@`1!5W8zFTXB zb)n(X1n+8y(KWP|@Q%?EKDykVpa-_tMOIgfMdMn52v;Y4l9loA$iO3Vmx}97`HmGn zKe=332i3#N_)*&5%~Nm4SE7rmzZV(9SwXMxwnzq+Ma~?hR9GaUpbnfp@edc0&g0Oi zx8K7`j8=uoXYW9y>nfN-uCF|NpSv8$BPx1n?kd8IPo$FrO8=!T0YWcjTK_V0$)@8j zd%(=KcZAw`nH%XQK?|f=SRwJ0$CAL9AmEU`5>Hj-2t1N}lqm~_ouwdBg;j@5;B)ni z{sa<73b`p!pq{^Fz_5#idqUUflaNau)?kFTb&cA&M>9I%07(PRqgUZD|6=#n1UedQ zX$LetvRg*xs7ZOY5zs4dAu#QzxS*?r#B51#PFu=-Hpmmm+;apL#M2b+C*r$V2iUwk zwU#RMU-7&A>q7RGlt5xk21>ztw}OCz-tpvslKh+Sb=EFTNKbTGiOWM>2X|as+i7tB zoo~5c0d3FVpc5bW5^Ps7At2<>yHH2R`o^+-YbDqs+P5=x$y6R+Zw2Nt^*54bV54C6 z$CT*QDYK^D6JLLjM;(e&|Lc3(FIXA|59^6Nwu-y4?de?7Vc&|!c`K*TKmHf+W6oU2 zMm;=t2_Q`k^gtnz*V?MJp`r7cdbLLT!rls5yTaJ+rHa@Q{X!P0Q>}zOTVG{q3{rm0 z61pOW8fF$DRz5}h^ZR}NcFy%#X^#*KdgD%*oVBIlT(2RkSsxd>ZTc@QXBW)&zVlkL zWP)3MZoTe@-sJOxb_5mHvbi&T-bZ7@u?J*zYf+^3BiIa>?q0OY(>xSqqN_*GnZLKaA+`m7(L#t%eG*l^LJ@|{>y=t_2si1TZlBTEoEaJ(RP9KJ<%)+*s zdfSP?SXA=(W0LA2tIy^JX=4M$AndR*2ZtqMr%R(OCAipIuK;p{mBMJz%p?99djXrL z@dla46Tw!OB|}tagp=*4C0(~+nf~9zu&k6}$u%UZTc>Nb9~Q!0xe{AUa8XrG=B1W8LLV8!1LorTVZNJ%CVmusU+@8bAUhdPmwwR z#7Xvyn}<`t3mw3opJ|jzq)U1#v(J8ZI=;!ss#Tj<}S6gi|&P#l-rxKN&0AK zd~}Mxq-0p`4}%3wmQ{QrA#zQ{$y^SGwS6R*Ct_~e8OErAo_S(wWBTkkY+7|mG9gT& zEIAhgGB+Jfuzb;qnszstai6u~t_%)PRF6kEKwSL-i`PNPg&J#dWS=FY?JLXN_Nh+Y zNcvB>%f2g>h6EBnN-oOKg>_+{4a8Nb568h*!81LmqzA)0#{ml^&TI+10uOhh-yM2} zHvA8PTodf-RUj#^L&KX-2N&UhuE*}R-50~>09k&+ zDG$C$#o^ugma;+?k}K;-rKZq}Kn)wCE$9-X=r=!>O}~NqO!UjnG$9|~2(<*GC7I;n zUGK)P+9k%xy}dS!g*2bxVZV_u|hiim71k*A4s&78$}rvviQd zEoaPSXka5APHu-Jd~Io?qu~KMPFzDBgB{%_hIPtP*|bMTH9sDR8cPcw_ug8R1L#+f@Ol`=%B&}6&4>%LDgO5bF)tunK8xff8O)hE6q#+L6o}y z_p!m$ajDlo6XKcChCID!39&SCG;bOuXWkKIPcDXj;ajg;sV-D{rnkCC2{b{Yc#{c3 zOuT+t)UCWXl(2r*K_Lry+{Nk~qNJc}!WOs%NeLkzmwUHZBF9~gp+zCZuI61@JwZ^U6g z`hXpUp?x3V@{}dZ{H1~i&Yt9__#mprpD_jPgKab1rPxD0F{loMzIGf6+YiSdQ_leI znc*9hs7kV~=%x4NJqMw}Zz_+tG7Al}OmQRYS;5}zQnV9g&tWa2mG^g|N78$s-Y)2F zimb_e!==#x-lz`AAWNz{W>amjg@vmFaK+FeGw51-xc;b)3@RFV(WZ%8< zaEl*>Priizj63CnhSvDPJgzN8+@M(@x5>_FpG~W2V_f<_Gpnzn6ib|!uX;(xP4LT4 zRVNww4KIVj7U11KA`a+nhfxvdd7rk=0&Q5*Mo?mRZW!c ziK%Jx=$?5_dPp<01f4BP36o0w#y6d3P3!RfJMnU(*b`Hai+M{^e zI;4iYD0pWh#NfsobWaFEWyo4LPZfH5HRU5?w;>PI@>T{_rfm2dy%#4?*m~nz_A6aw%1E`Z%5-QlFs$ZsZbv)z z5yYnz6^vzf>4JvGbqqrwKz2snnxj+iWauV03^>rSyZlYxuD&BDguEhh`}Iq0P+O_E z@eN|MFg@g?x9%h95*gCF=h)k>ulMj~MP^(X17l+W%Fg$I49sp%sANdDGSqt+K*BwE$rKr3j5AhhaTq{>B(%Z_Ei84?|^FNF!SMGnq>oGdhb^ zo=A1ywfEXZ3r$j@7rn$41aiNw#H$QkWCU5fx^m856;=GNw9!LC3qfKs*&#V7gf(^| z)D7KIcuvP2HWzREF-9Oh3>mCMH!YgBB) zikozUy%L8GSN(JMvX<`vKbd;NrIz45$H6o(>rG{dVDi@Oc)Kd3y-V|Z7oP@2CMQQ| ztgQw!Zgp$f&o*0;xm}Qd8%o?{EF8Y?<^~46iCORCWw@a)brYK6qatP}U=T7&OvT+0 z-OOd`N7ikhbI98Qbff*)4aGcgEGP-1Vv#%DQ)z1TK#BO5MrII>>IatGcO!jG!>i#w z@!U`WY@J^dsn{QN-JJ|t;Chw{STp59gs%Uz6M{`iurJNIOqV;D8C{pTD-lKTn$ zWy{aa1tVR|t~Z$H;?i@1t%|xC@zI&lgq21`{5hhw0ntUzDa z`*p9$qpXzGM|IhOErko1bj_6!KguRxxIYR1-j`EM2=6auRj}VcVv^4$N23$3>=TPv zOc%Z!wy(b%!TpWr9~>#->p^KUEEZ!R_YrK5Z!=e$*R{{nC$nPrR1IQYzc1o!6hRejuA;dT~))9Zkkyz8BPRM|HL% z`#TaQ4V@swVC-zW#;;o0tyu{lajhhcuc41mh=>?`prDdRf%KMxmv2>$+HGuCt?bhH z76Umuz5==EDGl(C{}AyL%f`N9obn|IOH?qcp`41F-Um_9qA5V+&kQ|yVYU(}e4}kA zKkc@X#E5cwn`$Vu3)WKi_}`|LP2N8rR#lzS3@M%)AQ*cUI9*A1 zWVCKzcxAZ)Wr;kxxN_D-RIbZ#zpJpemF6|IY<981cCj&bCH!#ErB(EQ#T^{;kV9+( z6Awp82gz(-8s^)bV91|qTX*S4F<%Hk&ucL`|HbefS7Bg081sfC4v$%5*E;nK5-xVV zS3pTd>g?p{x#Ee>(bTgKvuqRscJauTK@L8?Nbh)*} z-SgjN5VU@qDmn zF+uPbC0#{_yx!1XqVMJ_c(qH(?IPvbUbp|~WcI1rYP!}&%7k;tV`MZYsKt172L|6u zaCRLf4TlR>RO06}o=W9{{oF|6p@@Ty4xEXngDOtPa8|v6Vxm9Gqy95s&Ows{7kZ=< zx9;jlVTW`^N)U5}(b}S2;@#6Do$(Q4gogN(ac$FwsaF@Ykm67`Rjo2@*}{`1)dmIf zm)RrpiG4J>YpG=yGl`S45d=v^NeJ-=WCf(yl|XXsP+xEo@l|v|KK!hfD33sOFkZxhXwg z8nKVA;fJOMRyM=RWv>&?i`hS%g?hh-Tyh$MD=FbM!Z*dA3*iO)ciBJ2(H{M++#T03vFuj`DtALMK(NyT z!CqzQ>DFM!S&DC%p?UG{>?#h;_a5!z;aTBSti1taDHCq_6gnw&V0xXEF{{Xeh915> zLEhIW7HDa!Wuu)S=#vG#_;|41k@huob{ZT+FWrkINJ<)ksuTGP+|`029TU0~L?Xv& zs&Nd4XJjF=ac6Lue8+Wd`87MZ&VLT}Mh3syu<GS8w9c=58!0iZ+#$8(p~UP)fi)&%FPRubj@kPm@etrW}&M+XY% zgQ5H#4J|v;9`g*u$?rg0Yb7c$^N0(?ba}-D9FIHR*-G#V)^saC3SMh8sjn(kEC}SY zV8ms}nxZFE?tXz~)6bY}dV6Wd2iN^39lTPV-+C%h{!?y8J$sQGtN2tltRm4u80#{= z4a~B0AIV}8WJ2K>U)4V24}8D-EcBl4_=8OOcFU~y)KKmJQXw*lI<;$ zS4|1S!vGH2QFK;MtscpX-rXkVHDdfjen1d+tZ?O2p{>*_39Se{KyKsTxrA_zQ;iFfJvs~@T6J@mkcl597=pc z{hV>=hU{mJs{evVl>auuSCNG*bM810BH4qre@dN1)aW{oNW`^}D;@(h&yGZ~ut_8w ze>-H`&Brj6D*%%!O3#}XgpTO&ld^l!IEYkNJxkkD7)1EOG3vN-9ZoNmz@tPnWN*Nk z<;MDOidI@jxe`L87&qtcZwE!UOt0Za;%QVnxu&EL2YA9ze6XFc`f6{ZEqZ?bShqkA ze9(D^KY{F%zr?U>Ee7W(sCeF@P6YFgo9^)h;Qpf*@_$X($bb4YcoOB9U|gBs;?4U} zRuhy}eE526?uvlpl!pDP=Q%h}FDh2%;htQ4UL&^ss*7R|BIWq#<2Ehd8$$?M96JCp zzhN5{F6T?a#E#)g*>lvbn{68&EG?BO4fi)WP0j!uloT@sL(~%;@mR}1q~6$Hd%D>* zmt~T`cT3#FN_eDUU3tA`GY_^i${2o?kHS>@QCkkV@}pj+!z3CmMU{MPY&+&p)e}1lX()KZcsHXG_{NHRWu%5{SB$YnAABctfq~Q&~1TF)y*Vaxf0H z1zno3EZ^jZ2bbgO)DAMJ4gH^-^rW&tg4SkYaYgQa_j1FgMUwW^zyzlk8hb<8zI&{A zp}}kPL_IN2epK3yLu|G@}~g)9Gpf|(ACQ|l0Q}om$`d(1_IEeSJ`w8e-w`k+c5 zF2;mKWYZ{A&vp7Sac#DMiLoJJjw$WKcPj@Ux1*P-m1MF}PH3@7{5*Ibb)|NjL(0HV zo+0d|mAW*8Rb(NChv%~%c9cOfemNo3eeY62vfJs;D4I5EbD(5O%D*4D1{01nyAnF$ zrzpVkXmc#ZQ{QqT#B3w(;=G+q9xBolTP*HohdcqbsyC&a$0F5wW|JUVQM4+gF$ep( z$cSgjSV~&{UR`)hs~$%0h7l|=p|E@T#}_k5tKl60KFNvLx@>jdh{^qrp(kaYznyml zmRi4Q=wwArzP_a;IX3`w-Va7`hhgrvq^HQ-RKO~P*T)m*cEhhFG<#U^5h>psyEw(U z|GBBQ@`;EDzk7n(ym3$5O9G-)$Ec^Vx>XBl)Hb<``K^U1uG~)YRR|7`YA*x6$!5gw zf<@bg3NBMVaC(u5_(WC_Rw`W6uz#8GNtLnLta-rVg!Fg*%A}C&4u%@BuQ%#}Aj7|x zz-XKgcgO6Hfkp;COGwxFwj@5H_~oCpzTENaj+;GJB6r7<6$ofz>5L3309W-7qfnN4 z=-+eqII=kgcb6(J>aCuVRY6wOOgN%clbgCPbOA5p4KIL4f@(Okyy@ehVyJfmOEL-2 z_A_;dVsW&L*MiF8B<;KwNp_}^nsy%;q3=ze>pR%!DC+~=FW{X5tH$1-jz>cRl*V>v z{O%mutmjv;Ky1~6x-L`MfSv3yDN8>0n^r!)-l|1PDf|PS9GyBlv#+L7)R%l9uy4G_ zWH#Zg!pyC5M0+UuhqC?mTlBN$y;q#|b2s8uor2ttB!$ixN={&k=rzO+yy|8BW6u$q zT)Y`NY3{HNHHJ<#oNBoPv14;79tWYNnX?t}(f6w9$< za85p4jv5uR?)bE35onZ6KxAC$IvRQ8>w!iz2g_hKW>(-WUIuK^Et;Z(H*C=z$+Bi2fyQq*&CC*iVM(soHWt)G2jhDqy|uff z&y&)mN6#h{EQNzVQOPq_M?-u0{uGv7!nayx%9D#lk5=8W-o=ZTH?^LpOh(JBT*>nv zzA#!mC1ZyL7#&h+i5Yc?sltqp`-yvK2Ft@HsEVZb9L7sEZ*3|DZ1p#!_$wi6!_8{) zxbC_un$vF(EihQy#;$q066JcQbE5p}X}Z)>M^hzTv6Cg3e~BrTlZm`x>AZBPw{^s! zRiV{Ii7s8p#FvPgdLinW|L$PJKJ~aASVF(YLwqzYBnC?$9qCts&1rtI{5;+vB1DvU z2evX^4<{Aw?In5Qy{K8hRulTow#^4{?$4|Z_&J|qqr&Kv>FUY`ftII$`ukBJ&2OgT z)VCe=xjZHKKS75GAX5a8{M8nWB7^17wAH8;ytDqC3~n1w73&iTZ}R1!;XL)!(P3}a zN-?w70vX2T71dJ*hfly|6j<8YL`#c%)Zgp(5nl#11g9o65;N6gCV5&EJP4WaAp4tz zC3v!xA~urfAZET*B%?O$=gM%ps|pkGu>O7opNPM!;)@JcNT*u74GA@K#IGz_=B~95 zwWr2qlWf5(B7p0{FF*0iX_QVCLy}UlNrq|FB!DeJB}+>x=O3+3Ddk=umm2{6xw0dk zxm|ZC&ZA{f&WD-HAS+XI$5V=`H;Nl{p8kjqWR)PrF7p?@!C2y)Im(UnQx&}~L}L`! z93Lv8UU{UiyVkndF?KR0*ZhoX;z6q94zmWr#(J77-2L@5BS%enR2A&sEf;IN`_f~d%96~C+zm5y z!nv+hN(4YyqX z5Z;=`3a~$%TLQ~lel{Vlnw9y6$1`LN*!bW{O6D*pk;6&lLWK9ik~9L zxyQ1)7!aENkN-}+*DBO;U6~YTW*s!5UAivybtH31J*>(C8{HDh2mGGy>8zF@2*NQ%gD?I*aSy_T8Z%J?6f5zhcp2u5$f z33I_FhGE4{cIbQWHmAP6^>3(q;wQyH%KMZ!d{e|0ryOaeGq<0<%0sxV6_BP(cY3E( ziXClgmP{R)DAB4be+Z;NZvPrWG~j_WMNP6&w1lUu9!OLb<}fgMo47Jl zw|-^Sn1dLlu>);M1~UKrX1g%zq3nV*2aU=Pj#DhYT`m<+pANV0zlwf62TaHunXxB- zh4!s%51L8bAjAPc5mVjpyclp+uq?F%xjU;)EH}E6Rr(5_?%KCW2)gwW1QIj;jeO`Y zXb%y;1WYAKgZ_Z*T}k%{Y9Wd>drrP^3nB}jxk+=`&slKHNC3OJ75^j&!h=-ScnoXk zrl;4+YQD!!mM09f#F|4b!{wMo$l+pCwf2>&GhMuW&PyDhAXn7Q=KkKLgQ_;bPFa$) zHUWUHi{XA;@w zg76esCrLG+y5jP{#ZOj3ti zhO02#)#(T}X0e9`ts|E+xt+fFM~F7#ZNPVTf-gPkh4@7~_k31@$a{z1f}&N_6%hRF zsA7~8-5DEcLYT7b@`6ti$dfWWR{TdfwHe%@6dn(6!1&i-|2dk2d=B%dPSzwiqO4Mi zs~_WAGG2cfEr0DYjy>M(ICF%WQBS1L*RR2?jA-1Me5DEAkj%_ge72=7Z8k3>KbVBp zHNp))wX`5l=%Egn6b8Kjjvu%^gAmHE$Q(^%D5VZ<)g0dMQ4{w~h2o@77CDR0+k7)t z{lXLLIBm@IH|7CoHXX>Jj43{+^sBe_haUT*)xa+~4(nY1=2RA@7@Pd%b$czgd)5j zC<_QyMq}%L?k`Vx83=B;!k+Ao^ppm-@1!}TeI%O3w`Ewz#p-5 z0!?D^8n3VD?PlhqQI&kApkBFVXAz6{J=39`yjL(>Jhj)pf7xjRU#trPFWX&9hSVukR?8JAX&H6X0t=(GO-LQqUF~qY z@^&HTuWi-+skjl}zNVU`W^$EP_M_Ci<)gsjQliN_TC2~BwW8IVAQ~&!&r8$h%c|t2>x$){avm2PJB(gdvYPXSQq+NN3O-b4IE;=Dvz| z&l{#o>cpc{9V$*_G&S~TpGS1#tc}IJ8kGLustsEv0OAaMSLAu1+~anGjQ zueJx<RCS`T@-8J|V)Ku$r{P6AW;N>|B`i; zkEq^#65jG$s@1Wgh>}Wkz3OllJnLq;!H<9`&mn&tSy6C*;-@xII*|)kjj$kg#XC!cNZ8U>0lA zZE3x^fmYk2ARiCM!}*cd?+zbDSg@#Ska!31G8 zl1pCEbcrxhuP?8?eouA)Rm1-9cvAPbd{rpn{(kGU4 z^I5Z9$0sDTyRymOjg2I?)E{3F9FUDTY?@s3hI>iAvRXguZ}wMYdOgN9)ImU4)cP+Z zJ4x`xbWWmUzxxBWogX}7Qv>$qUPdyu;))K?Kk6iru??X&UNrVN%!{eQ!7#n8Jjtuv z&9qsfOR_|60WOW3r9xoM(M3oLbIfOUfrKwFT*2pQ%>BRRiidp^ zv(SFq1x*7bqSui#YIGkE6KVM1=lImN8w4Bg>hY!v+^+9U)ET$8Jg!B1qOxsToZj+z#$*4vf%YL+3;E_9cZj=1l#{Pea`i`%j32FT1mQqju|#zadT> zIuaJ}kO>ut!b$VL+5Q)jts{kso~6i7xbh|bLGxtskw>RNECADTYqb%s^F?LMVzt5- z?RLXD$i{szE9v`1!k@A-g!|;URy!G5Wn3Td;zGk(BS~@f`%CqbqR)D0cg(m+*RfMZ zd!HWeBm{+i^i^V4k4#yv&m2A9C4pRJnet;NRVd%QT=ks;R>Uu*sEDrmRo13_4Tgk0 zyFwBxTi`d8s!bPgY9I&9lghHz!QL39VkBvi$YUSMGJ}#Q&zTSSztZ2aK9KWOcQBW8 zi}P4pER1tJf|aI8ki#fGrb&Gf%W^RY2L1^Z6I#Gl_pdYlagxYd(6~JkwaYfwMQIjh z-wt{XQ z(tG}-2ogeJo>mvKJB7I}F51lNw2s4DkGY^XfVU1k+F)4yHYMz;g>_r44bPOc^dXX{k4nbl2(2 zC5qYVzeM)xa&IO>k=*Pt>!e#b+yCvQH)q}dbaN|Pk-8P9K?TASgtfQmWc)Be12!k= z>p09#_KB#4qJO;; z$0V7Z+g9edF1_Krv${zT`Q6-XDK*3kEB^|3%M&wgzqaWNn@zPbff-_@?YBxs+?_*C ziVS3^_z>M(2QY*FLBU~NT)#9hxKUL#JT8Q-8e_lfu>&5h{QcY%EEmg-=|u1D{vS=+ z59v@@tP^m?CF<<^QfY{-R>k?6&l?(W;(*1e#R$_sv}0IXXi8i8=0mHI{DuJ}@@~L& z5-*@I9Lzs(aYg4HZr{L)Af~(HOJ}otUeNd9=xXA~L&+q+&C)xo?)O7uS$E_`K~mk6 zVkuO)8Z|F(f93k%Yr+tMiS-Ol%@e337sO363o6Au-`(!)ls7ZKh5EtyXY%17!?^rR z&(qJQ`)*w72-o{YY}kUA^gO%6iL6t!ywIz*X@;tGkHENRpK^O=WBS&w|4~JZ;{RUt zDhTYgEVi8C2(l@Q2QIl{)ZMCd_G4!GbWOe0?&g#VbfQ)J5bF`4!GM0`(Gba-6;r~G zEl*pMMQUC14K$}T;X+h9s@}~}ZEJ}rXZF+iygipDcRvcHrUwEVf)4n<|F{TiT}D#3 zI9LdWPK7(yB`+fR*x8`4Q_t0VW%QR0mR%>a$MI~%{5PCzql~U)*9I1=qeoz9Qkyai zvlS6@t_V4BeZ~Vg8(T zTJCx?OT7*|iCpZnH0D--7ygll%~2fFfAmx0pH?&X=Fc|Yd;~cXfXRinC#B1om_8Sl z%y@G@h`2s>dSXe6@~GKf%T9G6yQtaoCjX; zbm$bLljB>Q)r}K=5luXp>2oupG}ZKPhi|udcCk)w41C6_kW8xqxY1;u7lpI!ULz*B zCUSBaC!qL12F85u%nE4~Jk;uwkx<#r=DTE5Fu?&TdpJV`fr-f*iKH&P;uDLxpQo+o z%B>N1R9_{or@Fh$p7ux)_%w@jR~J(?T>yvT(B#pu#R(X;glkUvaPj@Vf3 zPL%exJM+x?*GIe>As`Cbk1~P=E42dvZl6vWB3u)L2~H0ZFlwd@*lh%%^PbtTeGmFbuCR=YUpLQq%>HvU^LIp;P&rbbn{WIc-a}t3 z=a0OfMEU)=3F6FjmF#%_8zsc7!q969V0L+8Mc%%9)LF92vYPAO&q%WW);DIAweJj$N+TZ zG{1hGW-7QbigVk&FX$fM@qc{eax%ZMP#dNbZxAMbE2oh6u=>U$=^bUaW-%N@9F@8G zz+8$vF9E*dIYb$17gHCmdHj}E`)A(;gm1R2s8;EFO^pvdmW=GyUy@~$D`T_z7&i3q z@C@^%wVhr#oLz&PW-lI3`-79@ItDM$aM8wEjPo4Y{B&y62j-Y<5+7X!Tm-__rN)Hk zN_K7w|NMF13>WLL@Z;Z(MYePKuB(rOjHaF_35}>d+9uQY;p4G*)w`)dQ%Fs4sdtm`Zf%x|xyx)Ya%~OayGqn2m_oV@SRZH0YZC!$)u`=KBjy zau|lGm*vo9HEt&xpG9-+>uh?$GhQMP8E4av0D)*8K$xt46D0TS_tC!3Vje+tap2Lw z_Ke-0HRh)PFt{@tP)dwxJfiJg>*ng_?41DH3i(j>X-!j%5wm*7$h2*9$$!QC0``L2 zd(`>qYj8cKT8KEV6`Fizw|%>zQFlagDSgtY!G+J&yCR9O{U^e~z=mTmxY~){B{w0NlD6lwDHeuU`j(#Jd>b$9OJdesqtI3f)2$pIW)6 z8|C*t96_`=l@GwEYvrWzgCd(pA=hA#=lYy52mkoBmHYBZF-k|uM{8D4 zCKh5Sg7nI)$-v)1(*SH!Vj~b!dsQa(;y0>{IXuI?{-}1l-dME+MK`2S9g`HGM?Lc2 zkJQqRe^M4@Y2t24$9bh5I$AqKkNr4XG>)Nj1UE^^F)NXBEuTVLCYOB)W$*j^=#E0F zfS@iyKxkQ3GczdOTSI+ze3&PxPyZsdB0GZOEFJhivo2E;cmaMkJ5w-Z4i5oXBmIEk z3NitT_%-NhQFx@QDN2djYk;gwe=${jKB(QztL>b8Z{hwmSq6eLIuY_Ej(RN)q@WNJ z;ozRFH^?xvt=P|H;G}JepC;O)-t88MuBVI0D55L1KbN-knFpWaFUGfX*+1%lW+-NNW zUKzp$sV$jDf~zEyEno}N^Ue4-Q2(bp^61^<+MOobA_keJBG7EWjQjr0=w&Q3eZyO~utSHyP6Suil>KL6cN zilXaON6ZptjBiGR%kZ#vTjh_qzT2?9vR&s9>HO&}eF?s8C5=%x1OP56hGiPYBv|gD z!J*DS1CkpDjnn+L%|*n~6hcz+y?~(z%$17V+R$)=QWk^hifB4zlG}i_cx;85;N)P; z3N@}ck>BbhyGS>(xeA{~q2t>i&=!Idqv7{KFa2{Ap=c=8~f!w=FE=pvNfFv$I% ze`a1*TkB>YW6bKMzL-vR9CcPWB{UFQic)4V|MIg_19Jg&HLe)ZsT^jOhVXLNW%5r8 z?(8YmKi(q+txPxsIcrCyklhrV!mS%0H&4`BBYElK#g&M-7W#%IJtxLQB}TQ8GO|b` z$;B4zD|oy=uz?zMSmkaRw#X8OEI*P^GB#mL7A}IgV5D~LC(cd_RYz({HpDtcnAI;< z=0AqhyyQf~k$c>>&(E^5d(k>QjoA8KC)6xq?OZl&hQC}A#;xfibar<`9l zfq+S>qRd7*b1k<$A8V&8#D#ZYQmQUeyxS)Ax5v$4q`c4hy7p&?0-4EtQL9s!#a&kn z$Vs4x*lMsTNKec06Lu#J6^V$Cqeh=}vTZmg2t`cz?vEBO^m>;z62ISvr)F$*wrt=_ z>}}0x3+KE}_RH5F;L`NPs2i=f-)Wt2Bd#8w*Bj+8%T7ek+m51bpGP-qi}Rv)8(lN+ zfUOdWodEA#i+()NxYsGF|LsO_rnKV#0lr8Wg}vRzqaA&L2+Jk%z=M>hK@M45t!H zp{<}-7mwe9PDz@ug|fRK?p*B8iF4&@9I=C0;ItLP6^vG=?D4yG4AgFc+VfkIfLI#V z;-EOc%aXQM*1`8`veoX;vK+$?z~(!s`#W^^9QID``(vgZVgeIl48$Bnn~jR4`27Sd7nlw^}usUw*$|F&Oc1dWrVq10A7WMluK{0o$dyo;WMEhEaP}Z{*}2_ z2-lU>*dUU8@X^LAI5ass#7H5<5(f0Nm zZ5^ot^Z_@=q=X@b{DQe!&fT1>Aiol(5X1@F$4CB=^I<7K^$|RBF?ThG$rJ*l7L=0e z!TbWttOiK*Oo2A!=8?`V4vO{fcFdFIKbCtt!@UE}F87`AUe&=Nt8|w0!rJZD9;j51Eox{cR&w#$)#1%>6>1dH6sL19?`Oq4xn zVKQHVrUgd^otQ7iXXc;S9#kV0**(@1a7ddTAB>qIp<=h|&~tZ|vCT#8?BZ6V6T_fu z#(%wg-4>a3Pe=%e4PMaC2{C0M@9DfB_d~@WWu&r`GP+P8saahqQ_ODHN@}C_YLwk0 zz{yTL)w8hxhWY$8K~HJX0q_MhkP;3sx$^Is(<-Fo`h*DCr7lkw7~`A6+ZJNq(i8!s z;cb3aO{*ZMxMLFbaX@GPd3}x~PZ->bZXk47rC+tMaL0C>ylv9{q1jIduI!0hS{|9*h_dCpSFdrbv*wNHOf z`Y5}>CU78(KFs$_2IQ!1-`wp1D+9{I&AHoHRLnW;7=Rn3Pu&G ztA99k@Tesv?x`{(l>{V@U*@hZ;+vSKSw7*`Y`vkS-}1yir)1DsZ>^Ypk9knRS9iKh zwU)Xd;%y|bjj zEiz^j@GQ>1JvmKW*{Muxg)Ek*>J3A3Hw%KQ+csrnkV;EJhwCT;2Az1D3ts+eyTzS2 zTvESWNVLE@HwJbYCW@~C@HFbcSZhN z#o<58k14{vuJv^y)1Nf$nQ~5N4&S2ENMTsM34pdF)m3YJ=^X!WhRi{4&75epuN?Z} zUw|EJJ3{e&)H`1Zd;b*W9aZx**-8k3q@L_cl~pZf&U}^+l;(oM@A@5r%{tygj}@BePLQreR&g#3s$OFInj5thBd=R+QIYY<@0qc~ zS-=!2;48pnKPQ7HUvE>x{gEw={dee(THwV~r3T$lsw2hwtns2LHfq8o&udrxe6TCY zB{IY$I(G45dIP$Q?pj7dp9}T<`~&IdIZGw&G!@?305^N|pZN++Rg4FNc2l?Me?6Yp zqLXw41$xQsuFC)hmuSr%(nS zO;>nkPH#2`{9J`zn-pvA5Imk@k=#IS+Mq5D&MT!`qEi^4>=6I z#8))Nxzyqeu)iF&=P0T3uhiyqFJl8O%&&%LkcuF(?(@k#+OxjE;5csQzJwi-yao1k zhn(j+;jlf2qPp#+Kk8}Gg@7sR2Eq1uMcrx6M5X`O*+E{mJv5&MY;o6_=3g*M^Ey^6 z4Lh`4R}yOcb!2caX#@Y|G9KD^#Qg4wZjo$4EhVMV_3m8vsbK}!M-1D#=vIV29~ZTk zMb!L#lia3|l>Pweet@UuYP}=RU10_-0mQ3s`un(f^ULi%clHF83ki)+7*CLUs=Fx2 z9hdSpn%@BIJD(;W_~0HWEi)FTBFNL}CJh3-#M{6&vn^nOOCag)MF6ShFo1Qx-eR@KzD+YFr?s?kBc57hf1Wv&}})LkxW7scR7ZCUq80gv*_b=miz zmeZ>%=Cqd>68GrcM6TWvxDlBAaKk!0PJ_sh1xtj$apG#5Ae4BRs7D{+yUM<=wUI&m zKl@OC-gtm6YzO%OqD-)Ceb_qzD_vj`<%kHBK-QrCW94KQ4y|r>ldnrt<*FRL-3QkR zIJY?++DS2VZA`4IAx=#GSk6aXWHM3r9ALsfK0=$nf{bk83`?gtVu4V&3*`j}yPkuY z_`Y_85gJI>m%o){`&UWh&-af2QaT3=>tgDT%QZ`wCV|_E|1|72l0rltt1R_tL2Im2 zaH;Z)-3Q##u56~)R*?^as_+c{K@5CH=eIuHzyvHggV3O~H&I+G!WF`ZE=mS5iS$;{ zeU6c-rMBR3rM|X}RR~D?kO3H)t?v|q-RlEh4VMO?nC^c$jEi#6&d~vV!&c{jj_hha za}hSh`bQU^(DQ;2Y{kfaB}iQ@D8MI32HqU4VQw6XRGp3@kk*w{zsDBi8e;ywr9m%V zbhh~`&~t^e;fD8NMN(uk1?{N2YqG74lZ)&H)&E+oo;sbxEhcl0`6&+EUY{m=^^7MM z9qktPUx{G*80}LXPQxR!kso*kklS;F62L;FuEJ zM3La&mtub7SlA4cw&o6KcBbdDEpsG60GLOe!x z|I%g5|2CQi`@j%rgoHNW+O_&v-FK0Vn0U}0>;fq2WJyh?B111B-0N*wh^!fvJ97ye zLLlJ~_<66q9L)`SfhTELsK+7#xw;8_U@hAJme;Nq3Fy$%cKQ@Q#MZ}HQfy6!)Ligj z?Wh4urdU9Hfk`e0=P^ii#%v|%#zVa1YS~@X49;~IC9pLA`B3p&OD74bqE6)2-;=+p zRx)vG@R-qx1k+yl9@}V##&A*k-P5O9KkrU1d_+2q{qVX;yp{+F)M@~ylGSw~^p8dl zBR6@dr_OkOa#!>SH0#E}vt4$a2Z_OfH7`GQkWbgS9i=3J`s@y+90?vD?V_<=x6r6# z!3tx}Z?^XBc{Ee^3VVE@hnivmO%ZvSW&f^U78MJv+CyS>SpzzC{o8%8?jHW4ke=>4 zX+XN)(+|MgrYMZB4{+e{t!na+;o*F#0m(r6-XW#)M=64j-at(28st0h8mMvjk@wPFJ_of9{gX&vgt?i^JlBaI)EkRe zNb~&!t1EV;=oi$LGI$`vSayg~S*87xS@JE>|2Wj@FrxTXPz}$#Y(Evi?P_yI+&^A0D{CJP}e3=@=#_QTNL4B?4ldBJa_eAfA+@{{_o-F6#Ml78j5PGd%8_@z*?B72=D#*^Cf>`AsXTs zdNz7?d}M_FDHTvUH_>`Bn#e|mJ?hGwc0zBHUIejzaN3Pnz0OsgC>rHBcm78I+C%hs`wAhV3gnH{8k-SC>$tKuxMJb@2G9%d zQ#iP^d`trRhA9eq1KlNV>@MbI5}1SF({B|v;6UT94+*J$7;V58rKsJi=E7x(x3gN> zESJi345xG#=&_Bq=)vud-PyhvtV<=SCkZAjii`JJlX=2BCE2to(D-{>E&>1Bs2KpV zt#q8OtVg|1SweKIa`fbhc>q=;5VNdKM391mfT&OkhAtUYy#_Aj74ikCtfBm5rA`5e zyFECMS8eR*%zXV?MU$lWn?o;Z(oP<%T({Zir!%lc;fmoyk3-UT_0)IjNL(Zw@2k2s zOexefpIbbj&Ai1C8hp2Vr-{^e8k`F!J*gBVN$S}J2H&#NE}Rbd4v+d~ z3xdkK{&rC0aT+oJJ#-G!G1lMB1wEYOi|Zh6iS?dCYR}34C&x4hTe>&+B%aA|u04nh zd`?VZ=$&Qu@npPm8UCGEib6%pwy!TI*>}%0<}wIs%aIP|K$I#*9fhf9*=HJZo|bgH zr$5C4O-0UO!$jgVm$5l26-^Ki8a&nN%|1ie_9lCtO85I!Vr5$70>A-PlNIAHSkzq< zshY^L2xUviE>0!@p()`>YqD_RA$D3J&caR>`-zxYyPl0u&>c7>mDu;tB)7&YM}0!F z9k01&h4-b$YnFf`){_818CjfRx5-a^vAF9{G7pj6ftLH5CwgjCV~rK20d}(>NbElY zL88am0)I1)rEX^&chpsct>r?!a+9j#9jE_3>)C<@SM+AU_-k2+KpRS_sT%<$lvxY zyhXK4v3YAJ2E9d(lJr8fReinXNyZ@9Zh9Q4s26P65lX#O5Lx>CZfg=oQaMpPK17(T z?U0Q`+}RFGrAjj?F^Ot;RS11wmjiEUr~t2BQCNN*Pcc z0dGu8t?ZsYGl=6L2imbZkVE=1fF28#&m88ErQzu{ZOMd3iLR| z?CbJb1e#Csh`tpWhKID}VNYcAXLAT@T#Tng3a4X^C0Ga{Jy^3kj+%d3Xz4$EMK1S~ zm!pd(C&p`ti1$0MvM!*svF2m;1{#*`sh36!oMwwSLdVN@qtUd=D{+vFO zFVmbWj58R3wh9;lUt=T?v=w^TW_*#ofFbFQ^^&z=90Yqjno`6@4RO{7ojbKbGs%1u zQFn50r36!TN;L{RE(zgnY>t{jx~xAb&X2L zJnSg5j_P!Zzi7e=R1?{+>6bb;vNYXw^M#B%LGbMb^J9Rymf}MMW?%APe0lH^ zm<-=k+4Ww$aDO?wO=$dBQWlC1%gsd97zS%F4mA+AS1sh73DeYb@D#Y#SRRHKi-1pg zkN;JHy-`=$dLs!>bmjDkJG|RLY-lj$jIcy3kO|^r@CSQX-+w$`wd0)ixD!#@YlryT zHrDAlHq}WwO5|=L>Y~hCq=C(hqH1@q(~@=>ZHB2t%`FWgugG)JVow_7SidFW8+5j2 z>lkej&3EqFtg2RfI0Pprar+mTB@+XaG_*JHS?J)XJg~|SPOjEjCjt*=|EC?+n24zk zN8*VRF^>&b&0q6}q-hrjZtl zIDs+1hvsH^zQP{edR{ZZ5lOo9$^KCw(OOpu47DTWbk9uz(RW!8*5BtnnM`PdEqi2` zcbONF`(iYqL&<~^cbgqsVm=5lQ*H z$kEj_&}HDZ=$_|t4E7JAmt9{>gc{4h(*{-`Z=~I8>8!`NDbVu`Ec^i@R_DCClCOMO z+5@oY#wP{|xXjCdMBhi&6*5Hdc>tWxoiHerUV3O(@$0|OC+^D2kfHXKL{g@nRm6ae zQ~_c?EsoUj4h|-q@(1?4PMp$+_?JSrR4Fu1R2C}rJ4ng}B2E4<6F*(e5X82m?WB6q z+>l}}MwTLN28r4@3pN=Sd&FC3=7ryTi(kU*7CLuNg<~<7s~!&0Ws3Z3=%*106ie69+YqMAMlM1sKquQ4B~mm1a#V&?X3c6q^ob6@ zH5QklX7|!y#UnKay5I4x^;1xQjN$VfRq{3x;I^iO^SK%w?HG|0GvC$ce#j0|%`&@v zXxPvhDD-qno=Yfq7^n*y`6&Qim%`oLd|0-Df!4I^_nAV{ZVlt%Ua!*Ftvnvw*|bpM zn&L-}UYaN%S(s9*nAEid6FLHR=4t8{2CDCd zb+-byM7sq#H{3GBz=3`ZU78>4qz`WQM|Sl4V~oPRlL9~iFNry+o9P56Ap2}ob` zTVkK?<^sdlD*?%1CVvBnd}kWs{~=&Z=BN!X@qn10fkW2~l1mbJeL}MnvtP>HY|Tdd zmDhCD_@?MAjR2vMi5~T+R)l{^GLEHYZq_r6G+F8?ik#FAjotO?CvgppK^u~o@i_7& zReYwW{}uVglKI{tAc>PAwkr{og{6cPCw|ZpReDPa82i_2!M?UY>>j0f@F!Eic?XH_ zaNupUCz$A&_gwUx;Hk97@E5jP0v(C zI-`wdyMZ}S=vl14`PY;y=Jk>!?QD4^60Q38=-F~Gg~8$`FU=iM?+O9RAdEi%f#4n{ zrpd0G@sP>eYjfATQ3qyDbDIZeUDk~`hz20YgNIy1!=l!ziO-n_J}DVDog$d$F=|Gn zB6!3Tm_!S}#>SJdz%1r9xP6}y;={|dL~g?+-cRtg6TGZ%2X z*3J!;xyJ-KdiF8vtmD4vP>q*@7KA^6Dg+Z9m)J|S; zt+xG~IU2F*51g4@8)+C?hZ7~l0tW&{f4tum@&NPf@_BiD0szVzR*Ot;kesVbAe6Vu zFq{H<0YL^|bsixn7hjIMI!IT%#Yxv%!~_pMk;g!j!3U&X0*y6{9}qCT%(l~PlZ^~p zm?n#4>4C?56uC&O^Y5OT2pbm*qWAmUlTJ(H{pCOz`!w=IyyGQdVt>FjxKtO$egM{r z$EZwuYk-&raXN$9Fc4a$l9p=-@mb^Iu#-W%T#lSxb*(_)OQqMF?g`pjrxr`;EF-N0 zjftaT+v9St7~Iq#m+ZS%kcpA~VMaCwW00BqWTK}Xie2YV9&$F{akZy8w6BDP$L9sN z_qW!z7>Qb|ER*iFLaKDxi0gv)6^&X68S;|_l}x0;O@n`m$WT}p6$_P}kPv7Uc~N(T zi|7Jl1m=O8)oX9x5xh!9aOKs6T)uji3r5)FN&ro$Pn9Z}jnA&ONh(1&A{q~Xiu|gX zFJHtUlhwO@e^s}#O5WrW&S8Rh;cT9Z@cZJelRs+cwX%b~+;bE6^32fM+JxuRsa}_N&}#KYbu6E&zj{o} z9J3Zs4sW|LBUZC*KT$wT^pT{`@u9@9B!5v1S|-XMwpw+4KRQjYRPB)+w%adH75KX4 z@;h>jGtnt?!LqGOK+4~$bM_KP@{E=yUF#?tMNT(z@w9jt&11Wvoatmbd;~J?ZAr@O zT`z*T6bS2=zNnDLGmt=4PJ|W!yDMN!8~Oga{nLC?@&mB54GJ;??x+jyKV*r^6op(f z9!r5}UPO9Y@g7l`h;|?Wi&1prLcIrs@8xR^w>FhZ-gI? z#t6>N&N_k3@B5s>+Fj4L#-@OL-{!2&A!Ds*BrQR<0XG=pi1k_y+=ISFoR}VIF%%YQ z*?IrO8;%(jrB&3UbD4$8*J^>dueCvuQ#^E0X`^&j>_xa<#xm;2d~f2Ik|%jgt=FZ8 zk%038l#J0CZXD(m7+-}CtG*n!0H-juqS zY_6dh{sdbKhHcq@tEx|`K#?>?r``L~nq@VfA%Du0l&x^z`fYNmFM`ruC>BNA6D=3} z9|kVR=9{%RhsRr=vsfOPD2&H7pK8CtO9xt zLz}8VsXi(oWUj4v>!JT~quCP)S&XJfHSaa}0u2T)X0(N{=lhm3I8I+=4z!<@?R{MK zv~wfK{ zWhO~qxtIjS!BV_3HCcQfqy~UOrE%jiXDaxB@qP*AFXaT8`lL&UrMN74llki58K%JZ!5H4*~GfuajcZ}>1g`W`aMT_b|aOOriB!L(PJyt0GDUV2#( zY?x{MFRTpU7GLML1Z{TE29^_E^#AS*+6&^w_R+N%KZAyanP>b~bX$5Cqox?7wbQjC zx*b)%K@Ii($Ak(QnEURHHDq)Nh}8YYRpTlSl6c437y>y=AlOM45iPp3vv zuL^qa--(5aGrU4s@@A21xrY6)6!rj4{FdQX_{>yLDH&U#CVt@oNsjP>6G?=~B{<*K zz!)IyHRayuv~Lo|Oej=p6iwbrsc;css!Gga)im@INtZF|ByN5tq`WI~Beb1` zrogd1ZA1s;4pS;C(_s1&$)wN&^<0T^aV95C+g>SmF2$HO6eR&=-`sU-&dnIx&V$tS z8@-LM`p1G(U;YKiPH*HlNb4xa@Mz56a+)&IZE#919zd6M#2T-+ByAWd=*augr!kqH z9{vO|`sI5xK(|C5L%!&^^PhKL(ZNi6JfOg5;GJBUo0)T zo6Csqm)+C7GMT8WW@Nd;F`?2>ez^v{R>iUFR=ih0KNMS$2DdIs@jV;(rFm7BUYS32 zlCZg>eKUINV`OX`_2Wr*BdEc)a)1%MUxV?_!CP%SzhQIVTG6*Yz-q-@S!Zo`oRIcO zNi$WHI2nA~taLU2fV5fr;d&l>w5omL5r$kllilXXm(Q#tya;~ZvvQlOSaC$@M6zI*7>;I$Q=>p%4u_47cX22-&xK<-?0?_x z3Mf-#v+&GB*FCt$xM3BndW_SMGHz?a#8i!NDria0Yy8+&yCJnydSa>|H zwVjVF%S@TKD{D!Yj*Co-?7c6prdvP-a&=aU<8#&zr6if?k z1tm;q zK-Ved(+ZVNM{0%(rpuYlwLAl87VDh7rvO-jz;VdZgq&VUw&fFPDnU85xw)+kX0#ioZKPbXO|<6=nBra@DL zI2DHDh>UKK+2aI%0$KytLtTv?nFd^Qt9Kc{e;ZiK0FmbJMMH93DhRP9tK6kS{og5? zoM^zC5jL*F=M00OyWhlH0~3yROYIs$@&pos!Tqcrx;1Pz8@V*Imd4I9nBdKZ~zK@<^01- z$-3>%ulYMn3zD$R_2D`repwtsLYG;pkN+czg7J9P32F{`CnN>MP9TzRpIKx`Fk&O4 z=1S=$W$j1&GM4^95&s?!O;qq*^t5n_3aE4>iG?-6mjJq;dguyM`%G189Noj89i^#bscTNow6#;w8GRD00?^c9>HY=Km-%SA1~!3E%DsZcmpVSe!{C+k|!~O z^#x0R7^z~MkB76&=~G|9P&piu{vQZ(h2@~{1dZBPKzq7a$IHQzs({RUt(n%@HskInjEAe5*(pWUQgURGD*F+Tbsu^Wn? z;RP@&9FjAB4R;JG&1yuTZCAV{z)Qdw#QTHj&o5E}<1BnMvL??~{&-F!C3_a_KVq%z zK$uxCqjdSHXn8#OZSY8pI%Wmq3V_`~-bg@LqO7KBB8Q9-&G!XF6)$CPr)TQLV^TQ} zVep zhq28e^)=84A_D+uJh7-Bxe%LW7j}SzN9V+G=m<c<{=vpNW3QW~z&T!+Tralf9Qt zd4jt}c6dT!;3BTr`|Eg6uA1EGNJrNF-@N(b9)6CG0+Y3j4m*9pr&k6pj&|&s#&&5Yv;{DE##kMK{50Ven zT_BXDP))?ULhTX3sdlEouXH9OGF;=1h(w9?3x3`mi)Im3M#u*n*!Wcpx5_Fv`e&ar-X~*S^C#r3=+yRWx=Uo_Dn= zey3e&H9&yc_|x~ZWh|b_-RJ|D#3@G^_sJGqNu_yORmtH~?09H~T-l7b2R zBq#6EOU2lGIIea~sd@nqYb7_$HK^{{_diIBUT~+EVS>oeqbh?tIar0MxxCnWn zw^^^e&@0h!VbZO%+q82tJLFNZuED2B;qdY_iIm}Kr{D+%)k}XkUAM6d`~K=oZ++L{p7F> zt~QKk2wUCnv2{DYthOlpnH^Cq*D;g-Lma!>36wdf@UW8g*Dt4B)3nL7erGI!+ob{b zkAi$6VQx3l^W0ybD{%U*qYD@b8t1h zb5^<^Nwt(Ksm-5)Q5G7_uknFv^th>)Y+Qghian~O!mKx~L^|AGiF`nQ$kZ^@OK zz=d8B#FU)GhXuazxnAgr<`C#j8B$`NmJ;ni0k?x~FP{8ADnx8dS7Mz*%ic2I4nwCw z)F$OBeYNibxOgyfz25^{?25|sGh3s#+>Bvb<}g}i*bAy6*Z*xE!w$;3#8q_`W#xX7 zoB<`{*@FOdLozc@arzg>V}mBJpwx29mxQ+R^Og>G-j;|sq~b2c+%TalrlfdCP7bM7 z@YnPk%+lyh&`YDNCqT`K5KXY|H&z;PnyAR!C`HF zvI_E4Zq1SN53hFcY{^XTQ;^;VmfDGq6?^Y6Ujgz@$~~3&5Njm&KA>8`huw9;>64g{ zAoXy?CX;GpK|~+ENj@}#^Hd9b*ps;bMnG^sk9;1*G?<-qzQCp42p0v;4$bcF6K(qm zxXQ7OZcMe_>H^a7oX{dFYE;Zlsu%CiETw5FxXG&BCCuaW45;!mjuTwLg)MFP9@Tki zE>gyj#WAD{05w3$zt*s0DT4}jwT$zKk~ms>j{XECif{+SI`9Y+;j_U`{p9)V&eUhwSIPTHG^Q0@y)=A)UY~~CAb+n{yl#-p z^sSGBX8yKf7vA2ih@3uLhL`ceVS0j3h}_7h5?~YnWj?EfE12cBta9t_UyEtTU(Qs1L99AoxI*Ee<|eT#=74aXFmV3D1@y zS9%RyNXcD=JRA#uASje;$e-8_05iDJdQ{#wSv73~TsY7=%q$C&3Dvy1edmNkx#9NT z*Vf2N@SsIahcdxY~cw)+O>b=DOG_ zcd7A-znDKq>Hr};rjEnS$&-!?lu-qr|LRkqOWd!I@#TxZ)v3ljSEDvv)gob01rdAV zLDJ!N3{kLiw&#A~Lm(>#Bw7!xfaBIJT<)w$k!tlgA%{=zOghHUnwx`sGsZ>jF{W{I`;z7$XB_z8RUb{Cn;kGY-V5*7B$P+O&elGmr&Hv`gu6xF=i|_D|iXJ z)741yiNMk%v43cIa2C;|$?eo%jm<-!{rQ61eONH2^?kr@b~aAPVBfUNeqQYaMXCGB;=EBOXbCw!?3{TZ$O2OR1 zUr;NF-lK|z&H7Atk!**bDRJRB1&60zMQbx;Dg-g@vrQ#F{an3}?i~ew%Gu-G)UIwf z`<1PVvGlru`5S;&+oNEms;0qWE~#((aakTLN4$BACq`eN?u3*HWKj83N-6ASEV5v& z&q=`wV&>vsEb;I~B-`a>Sd-Ht%Slcv)nvm_RyuI;3bR} zY;E|OpCG~JCO&%)_7=H!F!;@s|CK~m|JSeAn)cr-j1C?`%q5L_9y}dO-7^(wsQ#A) zi%`l2*;OiyP+Bj|v>9LjTCD*NOHdygvM8d`;g1xsm+}l{O%w@@(%<+Bc4wEDUf=rM zEf;=7!Sz>kN&x&I63nUNsai7`0vpTh;TAcoa}CeoOJ9V_{s$6v1?}O@w*icNi5d1gOAvseyulBHQ<^TAL#*vm3~0?$_f^^;qj_!OzW5y2Yv z@h2t_{o09Nf^i2$PP(FCPVP{JZv?oOO4ZW!bOM`eXDZdg4H$)}s(6J#cK07!>AK@k zpIDiKGe_DoO>F^7^>cZ*cXmSsuF`uhE84qIMDD05Le81iu#Cu8 zi@p8>a0Ma=7FrpHChRhE7evLI_ZTY9nOb22+i>fG@oHXYUCyqK4PjIF4uUZITJucs zSuk6ys({1S6YgubafzJ<%XIynWf+Y?*&gxW;@g2h-sNSfz-U4frKIRCcXAyA>WIOE5Gre{c+>|_)tTq`o4Xj(|B$<4N41yut zX97gAL^q?epL~SNP?yFd{4pckPu!lMGp^_@D{op5yww0=>t(a|8k0rD$r6Qpo0?l0 zet^a3DoY>)CH%BRb{-zio6`Z~hkMA7uI#))}Ya9Ad=2%DnCSNY@7`et-;LUUr&H$jSp&JnZ1&Rw#M-meAswS(|3W$Ub*=8tsgLA_`qtf^3os{cOYLo zfA>QSAhi!Em}qHZu%a-18T;Z_>%N#GWd^-S)xVEA83C;|ugjfj)=q(=Tu7K(DO-6% zJSAJEY1bEdcYKqD$JONE=b(nK*BWP97yLc_86_YPt6F?Zohq#C|LC(K8-luCfH=CH z*kOryzDg2Z)9ij}xuY*=i`9ep=Vi-(K`y@*en?eaI8P?4{X&ljvFx0-QPh~6_DsT5 z8xV@)o&El_`Nq2)YE3<2dLs%%QO`N9MD%1M>9jw_D)4g4)({vDaJ^!oPYw;lNqKZVS_sWP{;6$-OJ6CPwLA{wzoW*fUe_)<&t_Q-T;Q1 zuso9p31i68)tHCo3xadz_+w@Y->|OPa3@Y^MNUFvOw~0+?N1{Rj_ZFf3?e%)y9;J>M7WwMT%@HG&5h!)WV>b`^ zeE297xWKW{dVIhlVFXbUulxa9`CWf$3aViB@Ju-!jR$keVTvTjw7g8DMZ%EU!N5xld(xVc?aUKgnI0T_iM^wxSmW7xExV4r6hL z_%F!h!*W;WMZP6t`K}YnEQ|5PM(0^6X^kJd;4G3(N=M;%vst`b%gR4xj@fFVxx3Mg z3UQtS%0r+QAabQ@aL0PCpyN-gn@Y%Cw3`(CB9YBLL6;bh&$01lVz+WhQnWKpx<*=c zc5c*d2XIxY^wXaS;)c*|gpoBTDz>O{s<^qLJ_!JvStjkE(PX(Hwz&P%YzXuduM=kS zV?2V?4t&5dV&lTyHsS@IP+#$4m#6MdZ-iD-C$|d;Pbw~g$BA7GrcJ%;_xXy;$EEg8 z-L$33N*V__QRNe(2h#h2aSeORB&jim3f~~Q>G_e{;Ngn1x)0umfi0(_6cQTk`A@KI zh~@JHhnsR4!d#oqRA~Pou$ZIvD*D*)LqyZRaNfG3XQ5ZS8ZG!n`Qcd>=aUB)`T0Av3kH8@&FA9$z{3$x? z@4rW7IYYF>yG7x4r|yr^8ZU>WGf1mrQ)hP!$Lz|{9tCB&?f#bHGFV_qL#Wsv(}gI= zT9jvSHRLTcz+pQ#YZUQZGi(|CEN4pL={n!^Tzz)y6cmtt%Nl{GnDZaqzaO$d{J{G^iQDoF|Ik)N zolpHfpP?kgG0(+`=!}U&fwuuMJHvDL>My%?=)5}__;>Pha2PssX_-YXYObYr0dSeP zR+9vE-LW7Q5+~M(B@>m!&tn|Mw^dBMVTrVq;-{uE-~y7!@*xjp zLPN9o5vCHppU$NQ2H@Z`LU-RGZ4g~U%x}``6-t={IgU5-5DILno)K!-$?S}AD3*dAS+CWZxly` zr%!FO%_EHq1d*&R*a1!2F7=FwDBm9jueG`$dv#D0x@*+Uf-gARQx-7(X12(T_ zVK2lIDcm+84?Ar%Ff$L>mv!)eKWCYhXpIm_gn;PTniiF^k$tv{ST=!sf7D&n7!1Ph z&WYX!hyPDvN0fqC%fng7p2vl5v9ljFj;gFFA&+6S`7w6RP@lC1Pr-89H*(-{fqBD@|gvfq$!K@0duuF{BJL90yO<+fNNdFV0UFg{RPXc zXu#@xy5(WU62V+LQE*0IIwXk>`!XRRn3(jB3Z6$Qt&3h%1 zS44T_il*&}1?^dCcZUiOP0jv8ziV=ba>BtG)f$A)>zIT}{hnM$RR}h;sgOqAchC@` zeFLM>FTxxPgh>C~Qx2L?X+>1EpKbo;VX6(JV;0nRui=3P;&hOId!ZDl2kouho$~5_ zrO*cSOl4y9c%VPcp8H9BnT4xbz36UZ^MHj{Q2<5|3w=i=9IhnY7Xb6b)2xM4a9Rqz zf37YWgosCj&GQc!h=j-;rf=Ug(RAfHR>YBR@+w}*N_7_aA9nlmihA=N0#3i4IUq2Y5rU_?lnFH8sPb0ngUO?|0AnFWYqi&^57p31o2LKmV~25`P?`RgSd=^( z+KD*U%iurNWGE{CeDcdT+MRi4Xy()T$A)8yJ(wQqP;7zPg2QQ|N?0D}5k}$t#29^V~6YO-QcXzB) zTJB>_(=N7^fapx<(4Qx{5X^l$F_D3b6%F6PMuW_wz|yY2{$x2(A`{)JyyW^}G*Ehn z)}SgA^EF$zz$f&~CGqeQ#BiO*i@Xv{y;r3PnyOBQSDDl4gbVyJwO&q*G$bT#@Fqo= zNK%@Q$8?_7r+bjOyeQdG)1TqI-H|H0TO$Jf{9&TtBQF@Y!{C(C)8^hz4=QYu zKf&16dCMfE$kCtz`$VJNohDcFasqA3sWzo9k?%iK=dQD8v-Qw^1x%1TR#9B$U&PB7 z1uE{L7fbh#b9!c331VaRuh_zeMRYx^Q%+~l+Q;;p>Xn} z=<3wmZW64*m{cEarG$h<&jm%IbXvslipc@tpX7{zqS-Jzm#a7ho+oX$9_sR-<0EN> z#F!ki!N6p6)Md1nDF`h{M%=hukbv{lb5WSlw}YCXAukTTknAm=9Ap}ETdyS}5Aw7y z_&e0URwpKjauCebz$9b7)y)gYe`Th*82CW|+)-15;rPt|w5Bl_W*)$uGzs>Hx5Tha z?mVPx0N^LKcutXWF(Yy?!D4At!{LJK1d-35T{ilsPBs zNzZv|k^RjqO;`l3F%&Wpq*zYHPbU<8VH-hMAuuLWnJM{CeK=tjDi5)2Y3$sNsy0P! zG|Wse>D!#zOxM+c23R|9ykpQ9J-sNw*Rdjt0}O3oGM~poSc(l$hrP~;eQ##V_Z9Kj zD^uTtawTT3s?OuWr#fdD;+LUIQcr$j$nSx}26l1R)%zx}H62I8j}J$TP(eK~6>P$L z*HDA#j)|y`xA{ewV*EMVdQw$n)EW;qnjLo7Y^PQ$Lirg3dUOiGop)l*m1tZG zN%Z#(l^cp>J)2_>f6mcV%;)T(+EfC-dXjH5t-1HC7?H;SlTkJC7cH7kF6_Cj$fivt zp>Sk_w~A9cfLU_Rmt^)t&E7x4AHN~VHQraUv`mqL$aBNgNx+X^BSCko!1}uZqTXZ{ z4a`vBCS(B~Z2?={_8*$oNG!_Dq~xsb&LrGLuXBa1xbfKk%uiGYjjSAa*sk)%?tSvf z#7A8Ug{UjNte0ES-w4_G{R!1U%_Y9Wb9ga*f0_WX|JpZI`vTU#cj7hB?1U|SaFpM* zJC5%eeYgI#qAvf4{n|EQn;Rcalrqh~rmHca+?y897Q`tp6cD_GJ243cT0J&Y&T$Y= zTmpi$76-2`mHd8)04(mH;>?vQ+i>$v4X5*r0^+3yu>xjRRKxLET>;aqyliO7KMqwd zUh8B&iUU`7cq4UxbwQ3l7MPrX{K*3$K~d^I*9lUOs?mlK8gKjh46I>6EkgegJT~`& zD(rHEO(E@1%q`t6M zbD_6|P$T(h8}=z#-U(9?)924j8HTS;dD8940kt?`r?dBuV%)|G zqJ8%++k){Oi9<9O=KfqrqI$p9+~l9|Bx$4Zn1wi%%E!)8%pxs*EZ5_mMA-y^N!QQL z;KIQERIaP?(|L6#DI_z1cJsb%@0-+5Dyk=3oN}xhp(MPjuef;>8Gz6X3lfZOgpwi< z;zPlu7ifF4L$w2+Xvr-IvecY05rceHr=%1+xFMkxDLpG~Tx+*2*{;DzHGH~wv5Gqq!-I;+zVHRse4LZ$n zn!hjIq@{2Ib>PsD@{j49!$R{Afw|E8L3SPluU{M`!15Iqfb93HH+Zq}MYv+4=#5mp zZQ_NhMJsV3QhSyR8dxIfl?7vUNU`G1D6hCXmn6m&M2UJMDoTE#41`%>nzW@dEs(ltZ=IY}l=VDF{-jP;5}& z{U_%Nqo!DI^KN<4xbs@(A0e_FLP(8AyEus6o}3$?Tmt6XYU=>?8Q9FKU`CRV`W*_v z-Sb2VRP{apyl_GuH^FQca)K5j@oPOl(-XaD-<+dd-demTmv|C+G}HvxI<77-lBD0w zV{lv>y?z=64pfURYoHKrrs44S%nkw1#t(1VSCut5Of*_3mlHWe+*tauw8ia(3~I*` z6s-T`bP9LR5Y-E>snl0$Rs|+zdvpR>o$qlp2C*MBjC~exE|jc1QKzO7>YGNP`dAl= z3=1DY$u-GICPAbHv&Ud>x{C5XO#8^CJa#i*T;n(Ps{b%(V#)<>RZri*S2sCI9$r7G z;b{N81@X+;>e~orq?|%u`0_F8GMK}LoJ;A%M7Pjl*e0kc4t^tJJ&McF`Ww6*`CT$- zXOL%3B&%Y|)3k_B5@%_5E^NY=z66L=tez8gS0b- z(7D z#SN??{3L7Pu;z)>a2Vs+W3Pw7kNL%ERHh+uSjb?%{V4gyx%6(}>}f$v9=E?%0`4x2IVOV3Z+CQ%zQontf=yVndfGOLh^;U2wbDYHkxwsYa?3s4aVi z3=$1uYCKJZ-wYj~?dO`VyONL?i;2#vF3owj0}Oh0A4bddx1T3a3SYEZri_x|eIvf; z9jsQ!X_v&rTI?$T-!ZSNCQ}=(=kO=u4ECz`0dKUF?zZeQ*#PR_2_v&JO^2XWrR-oR zsr8&j%=olR!zk7R&LZ;+XT(QbDdb^Th}$2JAG5G(X(|(UoVqN6v-9MMBRxh8-2A!E z)*;pQ3V_MT^+YRZ_5%G^EE)+$YZ#7?--=gleTlD%bo=u4w$q2Q^F0ma9!l?;^IsHs z{*s|Er4z{UATcmIz5g5!u0waT$WcQ7kMh?Qry6GFugkc|CVJv_&6 zoNaKJ=Q7&w#X^+XnE^%iZEU4!xBONhc)7W`Fw1h%J#SA>u9U}IwH<%MQK8<$%2P}A zf>2F+kT_s_>*&C8_j`xsl=+@eLx5bs!HThCs!4XIuWFWJ&r7b(ls8O5VjCWl_JPGP zXfPhLqCFnt69 zazq_C4)oOo?L9*p3Fo{gm>EYp2jOKUd^CgMf`X=VEk3eB@0KL$&B(pc}K@37%Kf}r!?*jf)-Q>T=xIqn2~ zv~cb+UU1woKOf5K*i$hng+Z9!S; z%T+BJ)23N|eVxk&O9L>uJl$s!mSaUiJWR%8%H$n7Xc~JIE~`ZpZ|P=jb*$qzdHADC zu@T6|WAl>tmp@%YB6?fcUWVN-KB}NW`n7r2njqV94YNl}kirktt~S7=cQS;}{GKpw zn!HsJyTc+WV#QBcv~G(}+F{WNsSCq5FNG1f184tlkWzjbnDoBo@zey!P$t_lgzQQ^ zCGY@cjTKX^)e-rh)x?i7D(CV>jl_;hP>uU}^eX4D8cXJw=j~b0qGXb1bq+1dJW*^3 zH`o5AxJXO1sn1V_geU-0)gP-8-_kZmfXNiCc?Ui&V13a0%1Gtv$)Jja6~~9|{y} zMZxrqteOyx@BcaaViio9$bC^71&F56&sebgYN4_VTY#?FHc***WVom58=Vz&MXZkS z{x2jL7_9sg3U~TSlJ6QeE_`(mNbZulD)oeNB~D~wzC%d(OI zdH`hm8CPdheCzts@TeOQngD~##k20ldgRZKrl9rUrtHuNZjH8<19F{SUJ}%0sI{2E z@FPaihF|GSL1nayE@fOga|7SBM6uHNFB2p!&r@*8!tl& zxq}mg<4o3C(Jck?bn6Wdyw(}<0roj*oKQ#1MLv2UCd=IG)U@zUkt(MdJYic1lU**D z@YXCnODq(lpjS%kMB+nFQ_6+PS9ERnxhZbIr@2lRiUUBqJrLkBK~)*2$H{qpP6cue z!m7&^;>w|59R zXi-p#+a?W-+zogC@(<)}jB|dY0nbT-7Dl{44#O>N7!F0b9bd>?Zj+8jS$RWL54D6CS1?lKtJxOEvcXU``EX81%(1 z=quv%amA*w-H44KvpZf^tv5FY^BWPU$eP(do1SUv(P8QlsZpYd5_2~}8`nGC?ovIP zyF8G$earSboQKuV_Lr$WBk>2hA-;7&NSC6-tgL(+U`xQqAQB2SUt>IdYVPx_PA-D| zb!VEa*nm7s-n#1d%20?sxWcM8m>smr9bK-@agV5BSzz;QfP#CLud6LOZ$zf&4d7kY z{Mofn+2+|rpE9?K`iC>jwd!?9~dUwb}Vc(@QA=JO7H7@TE?Xo2>CgYKt zX@wv=Bk>1DB_c@&F`LgFn%pgJ%+q49-8lo<=Y=KZpRtv$y5+Y`T&`~jvbhkoX=QKU zY>uZxAs`8nxSlC}9Q}9{Cj%jz73Il;Nof;&4U1%S-|*8Zla{@58=}kC%fu#vZz)c) zM!%)~{cqr8*6AePur!?Q@{8_~f;YUoQM8_j9o_~MQ_(k$79|#xqMp$K)g)D*Jga${MJDTBd_%EqXynLPL)|@nZeU?I0&#vY&Mx?l?j!IvCOOl%vEWmwfyXn zRS6I9G;)_WTLWdaQQ7UadPvfDku5RA)dgaANHT!YOvzpeyKDzrqHtNI|CP6eCFR*( zgC4jrr7iO#sD<~;W!V|m-}&`RF~&rHiBKs}6WTpzXB4rXHHkgA?YuivdRn*1J@r4Ss|AG_5Gc&p3vK_$zR?tuO~TWj~FYTxKpmW7AX zwLeb6kVVkBgyMx14Hhz=4TSj`@ag(FwAC3W5GEIRP8BzNy71k1>Oo7kJ|8`r=v7Ia z#s|8^$RvuvS+CvyyIJLN>SX1TS9>A3J+%F{uhvdAq&KXs%TZ4d>K|x`E!Gfb7Or>M z_;Dwy;VPRR+G!(1al{(9%;kOwEhG6PFt>6ZoBdq?_mT` zUqY}~&hLz^CWoP&4>jcsXC`v)_ju-!$34CwvO~NA?_55vAdfbG5_4VGFoyc~@x^js zCaor>o|L$j-D>CwyNQAqrV9F(AH7{&AhOr1*EoLr@UDE}li*zLJz((mRl{R7Fm3*5 zHSE#Z=GmE<^N}LG1x=F{6%cWJD9X4Vo>mmflHHN7ksuJ~7eQY=(l&zEr`=4p^=LZY z^9#yUHiU0}amQiqWUqY%*|p8tIs?F38N*8n6N2 z;M={)0`bNx+s|gyeV5D7y;Zns&_?QQ@Akua^{cpDrcFGQ$Nr=JB=dJI#ACwY^IWRT zbRH(pdqWvSyDC%|rIPQNCm%XxSQ7!NCypBj=;!QBp5R6R*s#%S@iNP4V!dfEJk^$S zEKi&ITn%wS(|IREuJpG2C3X{8466S#Mb^V`MpYs9O2ZmJqk)gaTp-;rbKBzepEFL` z8<+|(bk3VO9gA~5y$?K!0w#p?^3;!QRB*~|=O4CtoYPlla9SLfz|){E*am>_vn3PHSEg2O?g<>f+HG^JM>IYk^Lqc82+g{R)~RKYl;KeZ1l@H zz$u=lYi;+hMykTuydS+MZB#iTvWy-);YT=v)Zr*UWV)?c=LmE~Ct_F-gcAQZbv4!f zpL=x@di^F**4#DTyZmVwXtBr!W5_<_N`xv1gcT^P_1I0}cjrl0E8@Ct!o6fa3Ak-4 zn}@IoXLCm%GDMpBul$*sSQp*wii*)l!4IT?#`aei?_$_^wch;YpacCGMo=v`63&#- z=!rZtaxh?f=meh#%Ew$_kEDKE8EJU!B#{q}jvAS8KnYa=^34@uPKUy?6WC(j9Lw~z z`&;nHsVw$w+kG}}zvJ+XPzIjUci^|gqy=f7>==L`XB1(^-?Ac1*%8$iOp8o z^meD`{=Cy>u-JNh2M*^K5p{NqUJ+m}wHR^xv_ZJAfC42ROQE@*#l!iU{#Su$6am&j zU!?#E@rCBIZBI0&c@&IE0?<9?aK`xs5=_a_f*bx{)wTra)YDQ7Fwk<>iUUxfeG-d@us3F<$Kw&tQSX-O_f`-dyyt#<2jd5|v z=mG5nMc0|Z#T(to01H-`xj+uz^?ZuMWyvh^iblnIjfPfk(ajW3igA$OmN5jzFI{41 z>FKe2*E_d5Pb}r%$aIRpfk7&gC~kqqV4fn?_fivMI8j&Fvw*zqa=SP9JG$J3R-w7%ph!jQ+fK?F|G?5MM+%5;mh zr{i?=`vnkqt1>Op;1*080_hly3VRY|jP2$zohkh2!Y_jsg zMDra;>~W~fz-K?4Q;;mIP9;!TRw-#VeU6cDEb`NhFV?bf*OXbI0$^w+`S)5$SgyhV ziQUA0UNDrFgG^U~lRoSizuKRBAc1*5d>%Lrycoz7EIeRK`jV!tX0Gcc6=;@Y;)ApJ3lhz`4;ozj>tl2d9)UulrPiVAvF zdyoEYx}jjQbFZYW7NLW!f@I8re63ZOsZ~N`f@FSyWAONLo;HmM*z#@+9a@oDV+Zg< z+XZ%&3Qrk`aGMY^?0I#1j;(sxJ*6F1Dj)`!|)C+8CmmwLnDH7tNz z7)XMYyI2ATex!(|rvffn9P-xED^Cvls#!y%sthhbi~AN21kaAT$2NZ265+waz{IkT zDO(s6lNgmM*OYGA09H7upwc__ir_U^!NDTBUA%KqzZ%-rvKK@BCRCw7K%GGp+|O@r z1(!llW|viUTe@hkH9B?4GpJE2ECjvY(>MMcLztBoiO7&@xQkO0TRq>9sOVqEM?0Or zV|Ep2^5C?Ei^DgnT4;RA!1X#?_`eoifhix$$(cRx*x_mTtQXcpvNUXX@rYZ|ui0v* zApB~PR!6q_I5*@G@V(ggtE)k!4(33d+fvqzHuZ#R1`D<`j%Lh4@buJRT)7%z25g2w zRKX`NxXgpWN_l6vxbuMw{{IUqgkNFSqUu9;$O5d`o}MM2HO*=!yyP-4hr@LU9u#9viFnFRF!_e zl6-JN#rC&?he;MjQ1~dI!~kJ}_lt*=R7My{)r?ne(LzanHTM9xaPS-kW+Qg+Tnt2G zu(yt6%S9r8R=3}ISQ7TedS)aP^q%dlb2&meu{rP=S~wP;?H4nz1*X*h;o(c)4Nv-21uD{G&@0^(PEnKu0Z}03g>77<`v~lr zs6N3zD1{qr2@=dxDSfiP3Yg+t>m(2VEp%aAe-(iWx-ESije<-9h-FACt?*4L8gW{S z`5Fqt6_&0at&o<9Y)3Rp7MhsP$>-bHMVJ06uqIJ{%izI_oo6qNAO$Ew-F;-G?(NZZ z4GYQ1(%~4qKMM59N<~bA2r}!}C$QVDh9PI_AXP$BWint^Qd1DQID+f>TS#Q|s@dQ$ z4ve}((zn#0meDP<`+xrE9Y&sVIcr;=S1;}Z;cBV%-I>XH@dCQcxPN%%9Uv z&#ClM3t31Fb~H4^!TF+BeCML(+iE3J}05b&jJ(*i#r<9x}>lVqS=DAlB?{0@)-9c+OxEB zWSXW~Z2&%O4}3bm;(Hm0yZ~q1ve3~RVTn^nf^ym8o#64iO40wJc1`t2#%|Mou@B7X zW~(z#{inpNisLqlVYKdlD>dW+o@DcO*w|TOUJ{qYOv=!&DQ_szxL*(0PfVoAx;a>L zlIkuk1x;v@4ojTipQd66mG`#98`2a4hqA3zv30Pe2p3n8N^BO|!>M2|*kcDyDv&d} zr*H`<oM6>;dOZSu$pXP;BZANIw8L5`W4)8D15W?6rXI^V3?3{L*F&JDEb?7%| zLYstw-3LFaE1Jj%`Iy%Fmj>C>!t@UwIJSf;_4Eqz=4uq5B1C%49_PKv{|i1G&Ho*! zpWGViN+eGnNjwwf;^#eFT%zwbOE83%^u_CM3U%ej0YWJ(!9 z5n_98K8u}eEqOuG*D#!b;Sp`H9&!SjZqrSx3aGn=4*^na-=EmD_?wnwkvb>gH~%8; zTp9|b?A^V%hj}&;l|V)_J+~VP2LZ4AB?QBYt*euNqC6T{yveo00n#a+Jx*1DpU>Je zVxYeYwH_W3hZM;On`sJeiR$AKca3D*G2211t3*1g<>9+w)kNa%#u0ZRXPq zCQnL*6dG0>H$B6>M&8Hs`V+x-!1S|ja7z*cN}4g}T>xTUFKHZ4h>_=f79Q{?-v#!mUdb&I zW>^A5)fSq6fs7loWe7SP%rGW=kdhNo6x# z7+)SMXFt=uikFqX&)NR zGQLIxcxh9Aav;S}uph-N5t(6a{?KMy1}^|FyocnbVM91X5y?$h-InMKowuG!2-_oV z{fZ6ZexQc$LHeKeM)`Q3*y4*~uSbo*Z^Ulgt{CBJR+Qxbv306lqw^kWW3&|#^uQHj z)H*;y(dk!HpgYSb+4dHay%Ps3yOGZ-1K(nQJn4OHhCgVS%^%D{oLpagx9;0_^~_&} zqm57*R^9wKU{>IC0b$pSp6`HTdYF~vrVi}K?}=O)1{ODsz=+K3lANHnC1SEdc=pH7 z8!mz2xuO@h<1JbjR2^H0+av1gd!N|E-h$!7{6{Q2pgPU1MnN;NF3j@9Lxd1@N382r z8rQfqr!}TzdlSjsZJQ^a$=*%YKy&LGSxl_S?nM}S8cUnCa~+q#TjWY))*>AW3vQqy zPYW;&lhDL9cpV;w%t;*Khgw3Y$E|l8Hr-&DF66p_eh3mbf)R{5CL0+rDG?y5bshv% z@iUtVg0PxnBVys3#*-DSdeVm=Rhbs^YCrJ8j27$iQZr5?T8}j21ipo0eGA@WV-kgq^IQ`=s$!m274+`qipk0l&SCa z!flz6|9-*rTT|}UINLhk1=~Zg`e7IvrYK8EkHJ6}d#4sh`rtFOq(_Bc;YGUs8ui=& z)&_fb9JkBBT4YY6fQ(7<4U=E6Uf-GAyG5^{V`SS*E2^=nVwe>#( zAS?f4V(91pgH;V;80r7Y{SwIr+}#sj#%ANut0jnIy!17W++$O5>jo~!9asXtuTE{_$JrNmyiAI2JW=5QDo6O!ID#2v|6t$1kbQRCz_B$^Pn3T=$_`ppX zUXj{*u@ObSc%T0~G2_LOiAK4OcNWO=D@4X0lbY3zp7K*le!2CzyE)IPBF#1fNI-kJ z5MyO6#ZS=NiIS}Y2qIAo4V*mbDOZ!bM{NNWZSbiPA2{m+Bd$2Qpt5YkGnQlRCNhaH zMNzd_94%!e9bYPPVixs=;FsXIbFOi}hg#{`!kzR70)~1aRB(4G#0LWxdcf*0NL zXYGfrB3dqSM${tmp1Wvir_S|Qi10ON!h zD;TQ;XBgz_!Z3o`B0#v(c+S-THJEtv$sB==yqu?rdhwE1>P+N6PM<+0x!s`BTCeykrCDt3ZAl$xuVEf(;dN16L8(z+Xk z@5+OrEPBlfT2fFEUPuverN6mELz{V!DxI^V)q~K#dFg$Cz_X*B&RX#k#SM#q9)PQ;Yd0RIcUQVR;Hvby@{`!_Q~4ijZiYRU<_zMKXRM_ znp#aTO|#@2yd$LvfMOSufeHUj?OYfX*Xc=7GRjGc;D-+Deq1S1rn{Adcl;CF5Tg6l zkP?K>6Yg}2zeuC>1uvBIRbglXiX<4~51^LAN#U%gOXWcQ^8*dvX^qTL@25AId|$0` zI4$!xkDGvJI%+|l%Af!9{*O$MN+N~!ONeAp#j9dvh4GQ*K7^KZJp#G(I+Ly!TV~88 zCl$hhR}n;AIZfQizxC4izWrWOJ0+ok2G>cze zo?yRy_x&oCl6;8m-_~& zyH2{~s5?vHVTE_h?lMPp@1u z3z(9b@3pp8T0(D+p_sn68Gsr7OukYLqCO%M7Pq}9r>A1;5Bw%aA`rj&Zs;-iD;|bci4n6nTp3>hj_KHj%tsME-`yiki55?}8bBFgB(|t~9v-`stAq zAp0eC76nf9F20-`$%U0TG5PUrmTSOozG8YAI-PDLXQnJh-t1K#v;T{Udo0Ft8ju4-9g;rlcwb@m zktyW81@544NNmtDUtk4_Vjzmnw&@DKm`*%+!)6I1V?jtrCGW<3Qd1(sXipBU!lx^7 zRu5t2Wq{@4Hza<=DTv4qs{MLq%q1(WC%RpzgGq597)<4>1onz*ca(C_17V4*x+@|R zr3|92f56ZL5yTnNn%Sz?YX4f=8;5s#|Cw{nL}}(p&U>fBwMrnK{yNwoKp-)8BPoN2 zN!8(4W+;Ojp(z~46L>do54xM?TBgxhu|0T1zUeRlZ>lT@fA*JiJTurUW?VpZwSSLe zIo?@(c10xl1EB~@U&{iK-SVGwd1`PeU&Cb3o658k+_&~cJ!Lf-e^{9!EL$vB-NeJ= zi&M}`Jy%|w@H@TQ>hrQ&mFrG+E0z^nR~x}DZ0_+zaSeSv>9Nf}e>3bvofE8u*dTcg zq6Z4TjHnGIb)6Oyv@kLWLFvVCL{PE){z9a#mFx;J)YV`G9(gh2FGYn?>vP8!H7Qy` zG`MiV;4`8|^QNR73au;JSLIIKl!Du_my}Qr=;zatpvN|)5#oA9^tmmu2oa~ zhHvA<;KU8Q8`G|D$^(M4=_XvIEo`!$WTV zv5{`mtJ4qMf(hq*K#RD#vPvpzSa?-5QNz%8qNG4S&Jy z=bX@0z}U#4Ul>nTnrFy0=U%CS(Y|y%WRnSjdRxCbI@TaK$*PDZu1Hbry)Yhau0!73 z)keuyY^AN@LGNLD61(e;Fv!?+;Hjc^n&n~#tB4^b5lu{t&y9ng{P;d5a$^Kw_PZhb z`$TU6J9=>8#60(vJy4#>M$e!-yuR%W32wjIaZfh38e) zYglT^XkwS8)RNV_I!7C|s)XCeI>G9st1Oh6lq8-N_I2NkR>C9Us|**uDxdd^_LcIm z0*ro&l<1}GMNB6pdDK|}*;zj`PV1^!tJU2eT^g(Uc=ca+fTa49y+z6i(&GmKU-p_s zzytMEF^QDQ-n)pbB0%?bm6RRs{DM6j2sQ)!D`odjH|UBS#b)`0A$$Oi1HY@tCN{=c z{ZjTD+bzo!me5Fbzs-aI0{3n7e8`>}M@|~~1^ah-Ywv47cGigWkshNE@&|lS+4~-i z_q{!eMG-l2cF>N~``Pxw%yU zn53FX$}o+FXex2sL;zA0O(rX+2SQC)PvM?|vGyg$u?=2LCw|Bwgl|%n7CpPAX!LxJ!+(@<}TdRq4axBCK!SEiv>B9F@M?@_U%BeVQ9E1+}9$vZ2)K5H|M^Me(jXJKG*B+f+edAa5TH#Gj? zrm%mFb_D@vyX1LFe4(VFn?gd8kN`b-Ii9F`kF>RG$z-)F)5N}f9M!*AetC6}h&keq zC54yDwZ{8^5O&W|BK|nIT@*y_L}{q4v5RD9e!)uvi}78DprGP|dNZ_(pUkcf{oQ*> z{CwY6uVeUDA0nfu#%0^QF3JFagOPCh_%urjgUr8=+&D*@EuG%$R0odWDd=}Yc6U62 z8yB_YdT+ zQ=p_Z*~+JW{~X{9-py1Qogz^LZDxTVyZ+T+{xj~0Nul)$T*hMBvG9gVaoDD>DnS^u z6Nz}H(iBt_JYjp>NM#gle!IEU4)s&$iyJplh^ZxGdjfd7)^)O+SfjpJjVncqwTVsd zEkX9}-tS|?!_?cuyRshp= zrkGWf`{=Oy{ZyX)t$c?HtlG?0zg;<{>~Xja9Rld^lju*iZL?N4ks#n64U)0z#c=Yl z@}}T}&*T5v8G=WJDQ%8n^;G@#_T;Ur10xg%CS^N>+D%iZ_QAXx%8ZrG%6LLUc?i#= zg{#o)VU(;ou+_NM{~pC|$?r$zimxC+x(%=X=>Vx31ZG=7>HMAYQ z!!6?H?wcX9-x6~sMLtgB4tkV5hq0nn|3nDMaSxF$gXQ0W(5I%@K4qa{{ z*UkmlZA!R~B7l;#9~{i{$s%VBJYfh39yh67j{M6ufcK6wBLF@wv3~ea{VPQ3o$FFy zRB0qm50mwvaJj5rjxBRHuPDqv(;<%5N+6YzMfC@{!YkN3YVXQ=-@j=as^T(8kG>Kw zjHYQpwf~}Fk^nqpcZbaH#7$|zCFeNXezKrMx59sIVCm05`XC)37hhFF9!jP=_7F?k zbgpiCe9|jMHNs5bDjMbOZ7B;W<8=?{-2=Yo8 z{2Igy$0%>|p*}Sm%%uaU`h}#iuq%Z>*8clUA}rJN1mqaR4i0FNL^(!pNMdDv@J8Zp+Sr9v{;-mwhhV>k3>|2bhF);Sb{@n^oZ*3k3+LN4k9^ zMd6!IKZQjimajX2-6budjaz9$CvB^x!8iN(Am-B)s9=n5$_9z53q|CN0uEy(R0j+5g1L29`Z+h?kPdK zH2E~sH@iunEn)yl+yJR61_6(kkbX-y-Dqa^)+-}jGBl|91Xxc5hG_JBd9(S=RpLa) z#5JF??B$`kN0q@GkuAeVXfrLo>?9Lq4B5`CTIx0|#Ur(vv0uf|NqYhx%A$|06?H_y zefb?o4w50RjZC8w{XRISXQ>+3YpMe1q|#F^*_H2i_aj8@WPt%EQW&A%vGmul^ycFXSiq`FF`S z%%Oo6VYYs|G6H`O^OXjI5lrVaxt1vEix)DZQfO~1$Ho)hBlZaLB~b+_CX^()B!r&fGRw7vba4F8AVRV%BZQ4dhwq|w++{E< zEt-i>g*AT*F!x#`vx&pEN#vbMepxJcuv(OIwOF1I7_^89p;fp;L~pUHoC3QJCu8%m zvPfO^9b7ZBhFu3a3~pHUjx-G!^eL;R=1SFA21GG}nqxSiY3F+Z2j34X)$%B!wHK(e zfWH960c?S3VVD6q=D`-abRJJ%I?7GQ0`ejI%0E-yJ~Cb}0T|pnNrp+6?9{Sz)0LCb zVZrj}ofUvX?#^>t;aVP=a~783hjH8-#=TL3qpX+$Vnee(R(^2r?CSb;CQ4c-QY~Kc zitmr1P(l$TUa{8~nD_=BGi6pkStp!wAwtNNcG?r-a9$}Ld3Gf-1i3s=U)3i^x1B9+ zbZ^vUjF6tqY(&!WR?a^KE;x6PL90}ekDg1WKH%=h7} zecD_R->a7I?^mxQeO08QMt3|pbJ1EIQ*F_iJLO@&n6~eXyv|u7F+ZHvn-iW(JmU{k zh?=cie;bDEfqPb4%$ia19Z2X$hv+2ZMPC!FlHq-g3F9RI0qH~RcqigXa>l3w<;n!S z=M|jBaUB|UU^k)DPO+~38~P}gfAV*Jjx=C8{VM&ZaI5${7LE85Yy5xf5D@W`pJYux z{Q_{H2awt}-!0mI{7CDcNt92{o*E`n9~=GM7=Cp)aaHEp^CK!A%jcO-N^;#+5Et{A zZV#cc!LUxr4goJz|6*L(RE#V6*{fMWqm1&O94;Jn+*#)~TA{ZbBrF(Eip+VrELyc^ zw-TH=P-0}{y`BRxn}`$p;vR5_Llb=OW(jF%tQLb(4U~=B{IIF{}UE30n6EtxOG?%G3+?zP8lAVjBf*{(1ql@ z9n*oPw}T|zgC}j@&q#gQp<;J9b^3(RWy;~TK{rVS53J);Pmzw*lFOFUK67&;^ehZz-AU@A2UzO;o`> zAR4P|zUB(+HNf*YB@vPPB*g?y38Pi23IvBzBYg)QzCcKSAQ)}nY70+0n5pI>br}MN zesa;eWfs<*Ov zIc~a%sF7uD)HoOb-6P%aJ}?rk5jOYsXzzdY_}i5UQdaX#6pv6r%tcFEKM@hI`eG=03z}|6kmJJ? z$sGLBd*2W4_+FteJ1&79Q1c2!+@@0S`_g+|MRoFmPeRbwJv-p~VK0Tl7=h~>yO#Yi zP8BuDD<__sm##N{essq}Ye**!?D_e>ofzw;tGG=+U=BZWwr8rptEAE05Mzm3`zL7y z3jx7%BafDxV`P$Lts>tm$wb0bjeGnaz|2ICRQ>sEPtjA8v8w*V(?7^;p?~*LPk{vE zbteGfre27P3yUT0kT@8C>H`2mMRnI=$}OJ5!GW$Vb~Pxjm=dj{|332V%4nG~2PST`EP0o+U8 zKZ55iV>{>M(`|67d(^{wtCauoU-h%XD>|_+THj7g4KZ&-Acy`5$Fy@jQq4ka!AZDf z!PW5BpfqIYXIkdOK$Uy>oM^v#Tmts8R!#mdY$c4=?a%jf+ zZ8;e=3RBwlle2FmOPSGEg? za<5U+1V|$@;HKC7e+jL9$LtaOJmm{WLbUg4EA`4cETt51dG%*ltaYm*(>G#t(UyGn1ieu~*?(jv)^5gbYjVg<2n?yq?{ z;FPb1>3~eL?5ch0E{cb89`>38o$(!t%au0p3}y?^pgUmVY<20-k>~HhLk1-q!KZtG zLN`2g2mWA~CQUWx$SHa*;CW8o180mgR{Lo2CALugMxDz__TxUV`#{S}e)>Y~%F!K2 zaYDV`p`nAN!Q&m}-=J`_&!&h6mkKeJ2=BH+NpDGHE1lkOb8pv`TcS!>8VH5&S(ur% zk?Fv2cNVs4d?#k1f92ceZ26bGj{Qq`cL55FjR(&@8kfM)7!`Sc0KOQgJ6VYH{v=b} z{NK>kGQn8JSS?zRIOJh^_US7oQPDK!%7(m|qT@Vq#zFU%Xe)!?18&29K6F!v0RbXn z@!w$?p@2N%?LXg)Q|DaD6d+)3tA1G|@GxZ0{J{O7!W)e&%u~(~8CyR|Lf;q>0QtGH zfoa4`B~RcbYX$wYyjXJ_>;);ATA42q8rUm(E8Mcj61 zDfK1rc*169V^D0$`9{&>BhNDdExe9}q-ZHzv zX+Y8QZ1ov?dp6;_UNZ~f?EovU$;FGsS?)N1P!JXfwJ3sfRLOa@nE7oJLO;Q-wN2_D zi}2}cW-o_U7DeTA96ST&IU7a07M6O*-!7Q(8~d{x_f%hS#Jie~M>Mpd06{|YD>XB| zmgGAM;;W9ZnOyZ-8Np1KOyHK^(!$_UJ>PbtDoBjOX~fDUA(DBc3d(fV81e+Y3los+ zz5pQ+JVXpC0ex)4pdHd`33sa2{7$QdCUZlIR#lfSKQz1NqHd$C`JiSZozL@JHrWwS zu70|FKt=qA2!h5^>DgZvDJ);d%2?|A_L(_J+cy+%jdi+#K!IHeteA5QKdi8UmztqE zu?Ev-N%i7~<~jw7(pk@jdZQ5sTH&7}jPH_RS*P+Ij_9P}D$G73l<9TY_dp!C$KTaL z97Q>)1WZklr4V2_EtE5n&n0G86Zs&sJE-RWiAGzqy!U%pS;Sq8bWSmHIp{TR63gc5 zay)YB%`*__K9yP}y=}Zy*XE{VC75hD00@*a+Y7wM;-bx65~e|CuLcVP zpq=KErgHT@V#%$>u1vfE0i692+Bw2^T;CPu?!OaP+-TPOV33yRspZxhHeKWxOXLMC zca;XsRlfeB+`yNRJDUH)%1d)ps$QdKdB#*Nz5b^3Ug4b7$G~dO17~a!tF2R?f@@Z@ zBNbh@ltLrG&^G;!t>&@1Gp$7;QhSwxdt=NRYd%JYtW&A@XIrQZu?&C(-&}yhqE^jm zRQW2$(65r^AH*;3(${+WI|MWqbZ=+OyXtb8W-KWXb)3Q2T$lM4VUQi_NlJX8WHLjU z5--#hccB(*TTmNjy(@&mSdu!6pvlse9=mBYvXZ-DAg2fOg}PPslMu}_-U>4+gF4<|t_3FU8pI+a{;=qw3!BL;BBUFH?;BQVmA9fV>4Y|SiB%tj~* z!@+NM?C^Z<3A%J~K0NQ;dhjCGQ{cM za3HB5PiiBWOyeTT=U5I0JrbyDD4MOP*ER(mIhwP0T~;OB;WRCk1HmBLQGH+GiYE!mi|zwm z@nlOY79)z7{bIBQYWpFhEXVd}90wT$>D@p&x1SXoZH}y+k}jqR2Wg=%^GE`ls2afA z^_|uyWSn$#jQ=+e(drU&h|*B3MOrbV5mF+Ca9G)4HhyDa|^mx{nd{eV)}P7n9eE=j9VYnCj_j1 ziIRVDPx-nr85a8snDZ1tCYQ6Cy^rJq-PC(p3>QP-@Uw)j@T(Z<;Rdge# z1zMX$Q@)2MKxkdK2kMl;dJNy;Gq`4onY<|>+8Gp48n=dl1f-=bCwQ?LpiTiAHG;bd zF#52wBd^-);KWv?#SMFI+Dlm}>ymjqtr-o0@77Jbi2u$`>|cf`S&Tz33QMn8L0cmC-T zil{?`{vf-Z$IBf9L5CHsEnE`VrFaE@5j}ZlFvPNIw(3;kUf_TsxRDEuOBd=5f(&h@ zJjP0nY`+}uflNxAkZNYNId*`9vobXcw9?@}list&v^ao2nR&zddtlR2%#CT$RvQe|ybsjd zI8==yX&dNsXPEXl$w{pX2=!lt$;=*ZAwqCe1^zR5XV=LMW)G8rxko92^-`}as6+_b z+Q_Uc?4QyWjlw6ZO4Q{|6n=?&73%8YwU-l2k+jL~H++_HaYrq7g5T z{=d(;{-dX5tNw84BRiM5rBrE#2<=N`y&$_o za|0H>Dv2&_kh0*Y)#dnp{|pLQ5{wRJIPqIcy05Roq-DUc#qe-Fj9{KK{*EpYpf$io z&hGTlpWi#I^&9MBP|oL9(#&g;;6`$tQ6*kYW0G?ZsIg|q>j(P-BD7n9rm4Lw9g#G? zt7xTZ?y<8s>#cT^vxrd_#p3Qj&e|!m%~Wax6&p z;D%`qBtOoG2Ii^4PQg6mQS0lVJ)#21CvINX?>MOa3n&8=b3qzyo!LP2qpH5R91>v( z$fFwTY2y1vUv8_lcGCOT=JTw5%IcYArQMTapl0O2 z@mAw04W*ermPmR8rwaAwY?$=(per{I#~w6*h-o_OB>7fFDTLwDQ;%e;)wam0%59>3 z3MQ+(KMw zb@`xo^@7P(p1NQ(M7OY7W71}*p0cTfN8nD}_kIT$qb19ysl6vMF0ZOq$$?O?$+Dj2 zsKQ^%fopK7)ja<$Y3%(_B=(@2XI^GKG+)80^3pC7s=DrF?WwTq+_olp{s4tB(`T{( z)TX15+#nIZ*)<0DiB~Aj#$wyARbZO$5-Ub_?%Y;1F(W7!eqT!Tmu<|n$M<^JEY4O! z@D|3>7%0kTW=@j;V}o?p#Apedyr*__l;P~}G#97r#cYXO63HzYhXvb^3Sw;+Ova7S zX1Nz_>xmc{@{`Ag1Ud!*ZXGN?1ZeGFijrFCD1*Mn%SG){#T|>A;-<2b!8;6U1JkUy)oX@NW)V*)+}IA`(ffkZBL{hzS{2^Z7&7m}dXXkB$&--a zex6d0*2b(acPUsY6Ics`D|yAZjKV6VEQ&iZyae%*g7?g>$l1}%aiEK%P6e;`K zTboTfm=+}vcK=f-KM@m+kH{0fijmN#|EK4INj8!p~Ua&4n!ye`iv ze9yRZfzkY-#wct&h$wW+?QRcRL8p68W|9-{s9C|vgU$KBD?GF1=TIVsf z_?UMro<(Sd)qQFXIjz%T=h&$ydqmGZgsWaTGQ+|+HqT+&X1wgjd!Zw6_0uw&tBu@m zsU@-H8X2$WTiMi}S?5cr*VEKG@;}33KsVHMBVa$-UDA}8EeC{~2uOt*qM-hL^QtZ$ zF#8oNFR*#3nyW#ti`%Iu^keT1l6sUL*^lVW+VBQ;=@1}aOBi3B_$7OD`4OV~b*rK_ z#*Ca>5HJb^waefD2CvWPaD_b?LMF>lTjtI94Nx^R=2eO zIC)3Wih&%M;BF$hq@x0yRx;N!Zmn6JH~btSK13OH&pfpCJN^;kI30*-1TdK5vC()IiLdXu&TLNg-3#BL!{Ml{8LHpZL+pPe zJtZ6FY+!~=_D?1SF!MB1z1cu+QW3^TeMTRm54efXpKXutCuQ#v)j1?+4WWO;gpRsw zB+{K$k}Mw=ocv^ytSUVl|841iszUhHVB`o~*y)m1N^3 zI+gwDiC2us+b;GP>~9{RJqCBj6aRPH;2r8{pAXoF2lJkIC|%$BqS!@O-2uR^U2-sZ z|1#p9xY=iDj-u7AOJ&2SE}>Q~l?1*tpb{defSL9DNt+ng2!au z52a7I)a#^h#kJ<-crnM6706+JfVl!@b4lhGW6xVBM7>`B2#f43?=8r+1JS=d2~a z{4>w2FqO02q}GwL$lS=3NE>3jG?T}sHm3qlp>8W74ZYUJ(eZ#!d-C{l4~h5u%l}w? z_t^A{)sqEdF18$6$OhVMYLZ=6L3~8Ye1)vkTD$Yd5r0V$7bkR6ZV0*{gWoLS|LKGX zdEa~nQgZVXSF(BN;w9nw4UsSxXD(X(F4C_#nYZwS9+hw1Am2V#B~T4RC?np$>#&@& zjFIf&AU}lzufV9_pnPEvO-#K9sH5mmITEoAZY|oBmkI2b=Xxi;@_qc?^`nL7W(djA zzOxY~($44mZg0ZB)y=hJn;ue5x~i-kthmBFFAYFGP5Zp<+F5mf;Xmn)dQ9GhE$(n; zLSvFhHx43}mgwq4qK?30ljte95RzfI(AL=`6HuD;8jC>lLJ^$QS~ zrE8>N)6(D-8q4_fe^I*~QPp|HCSRl&9zhhHmr~fz-W2X)8JxA2z-y! z{zKMd&6%896PGS>j^w0{>!fZgfol$D3y5~K6oqS!AGh1H0wR*GLT?B$ualQcD#da# zJW2H%6u`)N=jWT!yaoojYXcHYJe==?2yd=Xx|z9cb;Nw8h^xrsoceo1L#UhB(sqf@V!yG=>Fw9|b&dlxGJwURvKrJ_Op8QN9~Lc;!lC>?JaMP$``;o4C>b6k z(@$s3u#od6E#fMpsn`AUjqre&{jk2roR&ubvk$O4>*z+(#m|mcsZsD*5VaevQ~9;n z=2)MV$}V&Hv4t@15arFN$@PzPeIPtF86s+gQ9>OwybV}b1f!bUesiNSbBREra?^-% zvXKCVL*i<6eiDDea!|oq>D16s4~&O%{NGi#y~1IPU5>d0*NrexB&Kw5@FSwJO#Q(~ z&)&vXx3Avt%I&qgX7DR-zw6)=#c=vfaDkl~unbERiYzlvdf`rqJ^c1@64%o|(Cc+B zK`J;PC=#P&skr~7A8I`+!nY-)_0y5N+pFY>iG-uQBFO1z5((5jP+z?9>og2%M z+!5d(a?PA&BlHr>Mex?F>r&AV$3zEOr&Q9j>U+S<9)%P5(#)td2naR9fo@ zm3(F>&~^mgmJFoZOAUeqQ|xfN{+a@<7dS=1^&=G_3^?pX0kvud3;>RuwStXuHg*I6$tngZ8}Y%TFe2kQbMN9W3FKEHc+T1gG1%l7JwBq|V6$KEp)(!;Ugzq4cK zmG3^<{NxkoRG|B21+pivAnR;<z4brws$^1potP#u@A1~)zz#d&V6MyH9w#o4yO@SJSG3fNi2Bn-@o32+em zcpSXD*3IXoENp07X45)(Qm|51+asV)J>M+D+8M>@*KP~KkkRr0s`Ihs$!7R?w6hN& zL^w_3dZO;bSjW&!3={Q0GLU@~&^L<%^*T6vha^G!DdhK{Tch%3gP0hI4M;AvkitoU zQgy|bM3RjRiw7uHZ4Rz&UehejRBk7)7@DkFA-xHt2uR<&jeboVjU{@a#*;i>-ov z>Y^6g&$1ir-^y?#p63HX0jt(1>yW;UgwJ$|WJ!}*HS3caqr%&I;m9A*%#s0lnG=f= zt_Z4n^ZJuH^OvGOAz)!EV1K(#N?#r_z`B5te_}Qe_uFtB+5M7Tdz=OAy7UI+j%6g2 zx*;mgO?NaVOzH>`BVs^0ozK?@i^#&ISLrF)8jOoaw|uzGCE_Du;P2$rE?WgK)ilDt zmv4Y>VL~<|(DJLaj)3<(;`7~P=1+_`Ud#3m)3ornEC0@p^;q<*b`Yfmve^7iO!u(e zFfd;u;A|*yHz~nd(=JuAO9nx#%r|VY1G-R?joiBJU@+yh_N1{ua4iBZDtrLZcoM5% zF;ez7svWib6a9U1M;(M^!>tv$=%HC`pVRWxy<=+0g;CPvh%Ma~~iEB@$ z{qnw@9cm9sta6^Js|*m;oLf#`4K<|+785;hfG;>S;9I6InNOX*)CRdhNLNf|oAni) zABjs_o;)2#At48c`DNZG5L(C1eo!HoGEZy#-R{W$8C+#(jes13&cz-H>KK+m*8kN4 ztsJXM$s1fvyq2N{Ek$=H*B%WSdois>`0iDcIehdx$t*Js8twjPs6J4T}XSb|xat~s+d=t^txp)EK zIFC0SOQ5)O#p6GWdvA24c;INzpiGo|+58$a3Y_Jd-1mXp&7Jl;r5wzLO8b!xDNh!%NxDYdJW-vCWUA(KbzZr zZYC!TmIJQGH`PjK|BH&OaW(lBrhSiuWd+A{4joS&=@jmZsy*h#&wZ%eL(@Zv-;#4b zXGZfqi38nqT-_|{Vz8sR)jAmkL~Q=2GKU*$($%i5ku7hky!F*ot`6 z8pw>UNG7uEC%ebW9=s@FD&kwnPb;|#k=v6UneS8GSJk!Ce3H1!QT3N}?%j|4{><^s zwL(|y1xe@qA;stMG%1hkWY-OVU3j_?A+iVDPy{D1T_MN}93@OYugL1w;w)%cMSg-7 zDKyVgG^qJN$RPM1ShP_^vr3eQtU-(?=L23g1jZhMHL z=lxUqN{OYeVoC*I?{u2k?JFslb$DQ@haVvd8?b@1zOue#=t{NFBydu0p?v9{m=D#Z5^79sZy(@+J{`O)pn?no7$UDYqzQQReedj90i;1)0;Fp`%&@L6%PLu5we|0|cqKR;Q~7&yRG zJKjd`y}+fq$7%vn^G_;QSAY|$(D!ruEZeu@EkZVFPfo!iuZBY-l)gPp!R&rUBw^(Z z=#Ru;+hpjkdElCVq_pJ*G>6$MPxv_Wk!wu}PEoOGe_-sfW{gIZKWZ5%vC|pYkT@6C z)>xNIh0}D>YoDw|`zWuaPHrEV>jU-DIK0ARGq8)!QB^uW4mi_X{&^zw+T~jNSOq_; z^S|9~cGn5>MUmoD0uLoP`vJ>F-@ZjQm{gXeYK=?%pmVL)79MX>)7BooOxWsAJrpNV zRv;SwJk2`k-e~s?2ACHVeIrc6R=pO%L-I+3!>%+Q|DK4ZzXbaGzO{8Y2!G^A>4z6q z0AtxxyM`-s-1ZXqNSO3zE;zA_(GF+nAS33FY<*r*>(o|^mUBh){c{;ifXwBG&emsT z>)AaAY+9pvGXM7K<&mYjPV#aO4rD$Q~6hLXsAM*ejHX zg_jvJ4b+N6>Q-Gp`Vm;n;W%|YS0tn^guO;}x7)HMggbt?m%xT*6ZS+Fo}8#cDm+o> zIdJe<5<`yTal5YG_fm^<^3Of|K>l8GmpEP1CM{{;C{Bi#&25Tc7jYj3idZ>}w>t4) z2-tp*hhwg1GciP*rTMQ+f#Z2eM1y1i3 zjHJr(WVc-sLDb$X^04-h={P#C8pn*$I($60GgcxzYcvOw6crzaYb3@;cQbjcVIY!b zm~2V`+TpgANa^1D;mm-H8~8JkVjyIh4G#%psTuGeD4)dI#lafJ3dRGEeU9l2cMayz z{~q+NKqC-tk8#w$x;SOt2UMVunT&`r!n0%^A3&PDT+24oXA3wn4O(b|M3yGCGOqIa z)7~ejnoTm=*0E`=CraePms!QMsMF2k@b6%R1wHjZ>-__Tw7gYB%T@31LBCNn3ehTk_}hK0am|5{DVk14wJgq=)Hn zM8n6LB11gj5USWf`ro!3HLk~P;N7sc-2UB3)>1!-Gwu4GEHsoT4bt) zlCF^}y0}IWOjE9W`elWbj~}VvLX>QhF{Z&x99VR9%|54t+Gk!As|YZ(`hb}o#?uOp z(EAUs_SWS>Izw|ZRJL6aN~fvh1?dFCB$Gmg`$JL~`pucKc0$zaoUb5 zMgPpLfV~F`XbH?UdB(f?DB#Y~2A%%$CS)c>8;@Iu1k5^w0<-X_uHT*8hEr@du`(4v zXzr(u*Lgh>L5i|n;mE8HQ>TBNcWLYjf#JJLH3Opd%W;jI-WzKqR+hxWSb}rR`5hFs zgXg6Lki z4*yTHLeD|nn-h27>lXNFit^EE0#kiI=nKlXT#Q;XW9JB=*yYuY*L1fb@BkIsBP-o- zu;YtE9c`?_X{ejd9+WKbv9dk982-6^`PLU(6t8#~!PKMOD;B@dfqfa+PL1T|?n{T@ zpY~Y^1)r73t=?d<Tts1NhxQd?%L$--BG<@2qr8e)NU zcpJ6^1a_uN`gr}OEnZsgW_ab5j*>DLF*MIS$;IjyF$B9<{ltX8n`(mQE)lzo)uBYr zXQM-4toErR!u0!RsFY}kTCO)W0c0nbCYMOl#Cu4LcSqtG?UD}p%5}XK^lUxx@5_9Z zm>!jpeVpw=pny1Rj9W8y%BYLs&As#5$F6)w_@eW0lEiqTO%s&wBqc=_CG9SxntB0L?|g z#!ZY$etf)YlKCu5HN)1c9r;A*EWocS)B5}kKDo3mBa4~B%$$Qlemijse(`irwsDw| z;yc|q;2KH#>re2QBVTltLQunyN|QSY19OQf)n%1%gAI>}yy@}~nZu#4vDjCvdkjCr z<~-?6Y|-jRSowZe;9`On)0$*vUKvoO*o#drr*Rf6k%NgiVy-h%9d6VFiV|Mn#(#I7 z@ej1q`BzxwuAqglP^IY$*1_>gI$;2IT3>D{Crni!MW8!ON9h&>2Ls~L#^@1RK$My` z_?AhO){=BW6k{~ttpNI`Tw5yVgDrJ4T(w5Q`IqU;*pWDu(Ie`dIZMazfX5qV)km0t zMXl67PNAx?Cj#{AKjR81q2nCAtDl$IdR5S03ns>*kOLgj zJZ;z@PzF0|W(X9k;a#a5`Itzs4EJ`SmK@?MoipD3dlH38$>l09o@gNMc)oBBTg4?< zx03H(*5ogH+2{~Sahc{%XYk)xEFaO9PzwJR!MdjSaI>~Hfba%7Toh)@Ed4{g(X{x} zn3~Q<HRh(>Kga|Jh>SCeYUSkaRe z(tUCGx==4-GxJi(+5Q7wn=#caEX_{Cv}piKK(xPZ`on&DgxMJq7s1?g3jhXz24&?f z(&``L3obijFt<35C=roy2Q-g)4Z++!3Y#NXMAd>3&k6K(#XivWlv-J)v&Pn^ZtNvr zHf%r%I-nYjlYf<%8##Oh706s1CQ>dP5!eY_zaKe(=(C^+DLUN80K~WNAsh26h?u#u zmJqJHgcch=a|VJ9h<>=3y{AeQ;s&$CH5R;$xvT&IJ4Z9&@x6dmyYvA`tV@_W>g_T{ zDDV%O4g{HSVGF)2EC>b70MF?cDK;5d!SZtYprUZ&Z_b*cB3+e@(2Q<$_noLYO#x)hI(iCYm$`M~tkU-yp0>p{DeJ)PgYCaIu&pN}Of)Goj6N=Q2c4CvAL_(ZCqUI!0mZME$Io;d_*`pqnz zoSUKQAhy-^wK>qx-?iVKX@}{ih_}?Ijs?mo$wW*_h)ztBqnPi08SK2|wgXqZDH^GS z2U44e(Kc6qQAxij8NQdti+N)Q2(6qYfLY{J2JNv-2Pi^cm{(iFLD zW$dSklp3h;bP1TJ3s4H59OO&=`LL-v?lA@pl$uz$ZwPKmsVE@2F_`vY_5r$CA{9}Y z?vsr(NUoNv?~FEdLTmRdDF4yIejKi>M^!E4)R(v zjk2soy1*z4!~w-_k*Ag{sc=MF8!`5{qts;3=Zb{=#fg7u=TQDB5Zy1qoGkWbx=9!v zia$u-h1Pl5AJ4|3Br827_kKXbqk%uR!Ir3VzGsopxfB^_jC3W&kVRo) zmLQ0pQXx5D^(|Sihz*k|HSV&HjEWlf^zxd|83#+`m#_&J;#`tBMQzb;kuZ#k20n$@ z7o0eaqDBhB)DfFS#(&2T2*!UoftdsKdkd6wE#yPCg>Vw8<)!s*-)zYlCZQACz0VQRk3~u!ut&cu(O{I^ODiN6`A)I1S3CQQ}ZP9?^3>B9b#676UCi z4KitZaXuu1oDQxfmU?uzL@CC1VK8#>&ksss;D)cE3x%9;#ImierpQ;2+!Hm3$uD}F z9f>jqcBDT>A_h1vd!v^&(jyET#V>Km3E7JPs~Jb$i{3RCx?@Sg#ns)*xUmD^CrsbYfa!azTHI@BK2$_eX- ziS}4>kF=SBd3~U1IdB?5MmBVvp>o24B%qv(@%wie;{8NMsyo! zjmV0YqKZfsnq^Y6Ur&i6-?FwkSk7Qow1;BJD(U=uZ^5ian{xzlxWA$0qm|f-B9;aC zv}!+cmYx$2L2pV2dugYb52s}^#m7QL=h#HX?O+qKQ&S=gP=lT}kd1pb$ z&_Z|5dRC6FrTcs=&wR69awVA$vkv!zj-kmc#kH<`EArdJOrk>idjnQ?^BM1f#4YCr zBS?lOe-QN%vMR2avJo=g4pj_@ai^P#l(=?7 zxle{yAHvqO%xqK-i0+#DzA$a#`eO((8L={YeMex~-jUyoBYJb7&XLF=)RiJ}a0O+h zL^K6Mq6jrPB1MB!@=y!reafm8Fd#a`35;)wnp|Nkr41a+=g6ILN^! zL`sYpo`NZMeAx=F3@U|_Tu~4zu&)z%)J3(_{SkfaD)!bNu10tm=7ZG+rtV4zv_Gmt zr^YHxekObJH|EA34WCK*HW3ALt~*-$vQ?uVDpWX?WSIra%~6@m#CqQY_G|@@yc@?| z>PT!^hnfp2pMJ2Yd&tRZgjVpYq7dy`Q7miXBI!x-B-i19BWqlf3YkhJ+t&=nIBNX& zdy_;ny=AyNfY?cM7wY+K#JnmXAoMU9?MF53#JH3Ur-gV=7g&uFbQ})vwZZOyDr!y@ zyz*GKzcZn8b~8^R6y~L{V#nt$=De@0^z)SN`rfn@nM*4_vv|)+<#f0lIkPD_-!TfP zIUh2}1o;e_MK?Dwu{k_Q79rf7u&(gd8hyHio4^TdmvW>4sjX*pvxHF)B3+SVB>vq# z2js2mtAa4^Y;i1wlCvxbi+7Bb2hUvqpy-S-tMxMB+igL^;;6S%ZBW_^+W+7(g)ulD z3Ol-#rikH>w5iz-vEUYPV5s?z1L*c`Vgp5lxlnk1cUSD0p6a(?vh6FkuHk{N+%_+1 z#Nc+_0~nbM3}pmjS$h{N>LUHstJ*a-$E>SgZXh22k^tiTPly`9qfXZTa?Le&c_(ZB zJ{_DC##hGS$oqIuOkB2Eq$oU{28A{MK>AJtOT!;aNc0&gu5%s`j<%F{_R4QLkJJ`7 z_`zlXu-YHhf$p#^44tH*2DrVrQZv|2>e6e;-By?J0O5+F>E_UlCsXWx94I`T|6i=c zK<(~$X;CLdFZsR|;qGLir`V7K*#65ZYDyT8#Jv4#vFe&;luv?_Qzm`?0r|wY3*#^) zonbSbAbEq~0uYR;Mf2e>dI4g;!$K1R9-8>cE8rd0F*g)|A=6kJ;qry}8(-|KepKdf zE4?70PyA9%g6K?b1nc$%q(;Fn#K@(dD>*T<6Ok?p_H`L}nw@VCqvPcFjv!5)yNi{cTTmD#MY~>79EQs8{PI4fO^;EisN_YbRagNGd07^3Key3VG>%PYEDpBsj38YOeA*1k)hi$mPH{5!=*fS$We0bV^KG|YUT577abBd-YtHp z<#N$lM>zINOm0SuLx;1pROo8MMgaEllz}cM44-Dp`((bYRKwP@0lPp@DzkKJRVLX`;r#zgCYfC!Pjzw;0_EMYg>iI4SBSVkgGIh}3CIin$%`f(cL7WL>e{5DV4L-dLvC zHo?46%d7R~svuzAKN4cW<|Vyxgn*b>VQ^M?nYbIVjQjauzLFLYB8{!)jrHPdojQ5)EiQ9yHV5A3D{R>qifimh6 z=CPy>`4V!4^Khg>Qcb5@m1CPSyDYqM8*5$w(_yRZ$pcEOH=L$q>-UjJf(tUeSDVzo zgPAog&m(lJRG4ECFmDCuozw{E=E46SY^)CrSvC?+fS-H+nl9U#gvSM9jq-pS%4^7O z7MK^|AI|$F=ksT#b?RRN}%AC)NEVfDtrTNRmLfY8I+~kPMu~uS9Q+4DH zb)C$7I72PsD`JYOhif$RYzr$$nqQ-lKOIvg2JNSSh>d+JPC$`{c_LTAk2Cz)(#J@4 zN&AIDR|fm@t1(UM;(WoUq<{l*qxMU4t6GzKZz&UK(v*YU1B%ODp)BvLg2-+rGcI}# zw_W_N65t3u<+g=(dbQP@WX?rGi161~w?BY7@=xRnMS&VN#=!rA=qfS<4TV`}(I@otK8i`W2jpiH{Sp7SvDocztVEhB&nJ?8s|1>v%9GTh zHsZyWlg0s1Kr*-kSS%~of42W-c+3X*zaMUwb$l9mm zle>F&aA69s-R>rN3Gkji2=1vjcCH&`EgG{mnWn)zZT@7c6%xt1$GLya++MI0^sBf^ z?lNs6rWD6iv0lrDpX-;sUKM2;evOL2P3RRVaR{{zG!2uOxEo1-7e4dp+i)8;6k^=^ z1-qc3w9KMSiHeY}P|jGkHIvcCmhx3`PrAB$dHrCawVzH_&gmmo;R68H->g!dvEYlL zXjxVYwzi#l}!Ke+cakqi;Dy$hUIOO|N8 zx}@i(_7{~-Uq^qTA4e_VnJR(aMfR*Jj{W3`*QXP)FkA4VL$Q8HBh=YtihVdW#1KX1 zi$A@*-u)?8LQ4_&=w!^Bhv$*{I{)n?lg9f_SeY`&rfE7PV_{17hgedq8xpTO}LigE8RytI9U#XwdiwXh@N;8&#DDaQVE%u!6&aKbLQYIuQt zI4?{}+CdMkTi3Oaq6o)6&BulHHaHe=w8S0SYozV&z`Iv^cpHm)98*`3kflyhdhV=*Ib8TQUqBep%JaYxQ z(=TiAJb6k}qsHsCS*JYFFN?1ZlqbtDR`+}d(vhI`Om?l)ZGM$7W}(VLE1Vrb+QV5( zL3tc_DNu14GMfwG%?oy(gwi&Cl*L${vJRWG~Pu0r>1 zGmd{^Ch1z}kp(enIHgLvm(l2L@g{fSm;E%YBcHSer>lmbPr3$H-@L)5$OE%gb6id- zY{1rTUy*kLj%*%?VZ#cMxTyfiI8{Z%qyQe;Dw8FjE`d9ZgJ~L{9lX z=q=8TwsH-g>eW@LRW#xolM$_|qV54BMm5RGjG(9}R|sP5%nYmRKCP_67DWl`)+x!u>WK3`(VjBZ0F2 zeCi)O&?g%kl!xnOxt(7W54XIEY7~p5k}!n97kITZy-TDXuV^3v%+Ln(hS?S&yGAks zw#-%sI3LvsBL*UeortnCc;}=GLRpagK}1E2TdBi1+z`7d zSX`mc0+zwZ@?@QIQXZAm z1>MI+5I9ZW*id@2Jg9NveD|;LNEpsXG>mI{(@RH6j6O8u;-ZBwKM}P1e72@mh7E;m z-OTNek##61smc6Szy27uF-u%(bk@xevr!vEA-AD!i(UUOH9?NfeCg}oIHRA6ej>8C zlkI6ghqPFw-_jl+WOSeFA-r^5gESro67M=qrjJ{H=pNj3AX_ySShm5?cf>POvR4hg z0d*G$@qO@Te$VM?B!2^<50s}`#BQMBR*`jkS(u^^OS}v#&+-7mer|`nw~M?r?g^Iz z46vT@n;unrx6ZzMZ~alFA3>Y*NFr_8yJPLqvPqRf((A1&9qF1jOm{K+iCnyx1!R6T z_^7toKrY9{i^(PGu?WH^)L;#gBGr`hyh~`n&^?w<&XX|1mt!g0PU?*mNc4KlRd1$&SKrp$8Pn1fyezH+&Vlf7Q`^eGE(x$Y9!>h%V6A7}&cm>gL zNeih0zcxAHw4jjh3NQm^b7WKq?H-k~U8J^bHkt~Q174sAg1k#ZMs2wabS!oC7CRLc zUj-cD6ffarA5}YBMMB;zBBI4w$!6#^mL}L3T-R|1RnhKZ-KaZNET6oIY2a^Ny5L2-V&E%ZB4}M{AdoYiKr!FlT)t53iN-D&?pS#pneu! zxB=D0MXK6avGN%N6VuuYQJZ*qA&!*zKr1t{-pqu@Ah4A5yG;?7NXYo@0M1a;wlAD@ zTqvhEASn+QjfogFH*J{0Yibf`j;X79K>S!Xr@YLyZKe?rV9^n5qOdXe)Z{YUwkG%6 z=f}A7^jB8R9`cy-E;#CS`OlXlg8(}kxt{Txfr7i)ou$*{pxziRL!aQfR=WRrr{c|k zyDw}{6S6BAObc)?ZKFqbbbkCS|X6R>rCK!k4k((Lfh!~l<# zzcV3YXu=YcV;cwWkfb0w^8{&_G$4A-hW6l%_sk{WC)iJgk^mdH=5cDP`nUTT7Fxii zJ|8G#{Bfo)he4LVWv1oM)+6~f+nbYHDS%0%jutmVEi>@?TbI0GT9}}tb2H-(E>SFP2&Z#EE^;YC3!Wxs}qF6+4H$>>U*iH>BkWIjs9f-p`F z@YS!@!iX+To4x!LB1P$!|C80`t$v-3kZ9Wr_nnGK>l|}Sv1_`oWEw>qd=PgENdp9t z97}7IjdI`}bRL?-FxW5&YZ!D;Lq4vrtL555>-rYY{xL4H+udt>G2&xT<`|WwpmH%!g9fK^J*m0( zxvG~D>Xb0Or^>8P!2?_Ds{$8nwzw0c(kHR+Ub{C-;aNALM8NiZM`PSiQSqY%HUUjn z2v;X(B)}u;Qdd;YA0|Yx!<;Z_q3*tn!oWxjZYQYp&=KXeyO@3+P9={$3X7*-2bE|k zOeN&yV;vg?ak&g-)`?*&v}ba!y`p+3!DfTTLv$y_oVu6#N~ym{l%`t9H_hO~ftRx0 z`O$qt4Fq@hAub6MWf?+VCBg39VN8wei?*WPLp;B_aq^Lg$JWxd0wXG_hR|LN+SFUn z8Q=|2SFD=Ktvkr{AAx>kkc@m!jw3WtH+#eGi1fr?b8A0mF9bM<__B_&rt31A<|`iD zKe6J;c(f@730jlLX3IbEDtSAo2jiqe+Q%2alI{LoO( zn2)m>{kNvX!DXmDR@V}0#_Hdym5&Njs1_gNX^r5OmZZ1dp(2=vD7Eu03-HewNbvN$ z6t#)5bPm?-=`M}dn1L7<(6%bhz^=T8W72bMw^)m@>?(Qs-l!=3R_!z%umR;Rc8taR^fou)8^@G91zS8sNocNFkRhfAgOgvqGO*3m<}UX|np?7O(p8uU6Y#9WPAT-0C%OYZoLF4~daUmzDDG&RfmW0-Sg zFrh9{1zlwe`$rl;v2hfMTs%a|m=0Opkmz~i6#kP&nzm9Ft%RPkF|j%H4S2p^?bzM0 zge?cMcU2IN&T*r~jU3K;O*mkG!jn^z#v!RJhE05HBc+GZ#LeM(N(R!(_8^gY{A4k7 z`=rk#@YV*g9tg(x=VtK`oxo;sYV1WWB{L}9u=JNuzaCOkq7c4L^mVN%?hf*8+Jbj> z%7%7ud+~3HYASqb=kENjj^W(DYhLGF7coYhO8b#&@DoOp6SEl2qcwKH!M# zpen<3pB`yK%FrIeHT3-`cJD|Rh_l;dlih`A?2D-E2eaw(zSih(C~qFW_~1kLka=O_ zf&Ig{CUyYa4vG{{0&=fPrXKp+H47IpCUW_Fqo3+eK@6SL4-vzDHZiij-Fxta77Aza z9B(E(TU0_6Kl!rm*aIO42rlw=*GO@`ylN5h3F5oEAK(aKC_WT;Rsk}Cc?{1%jk2smRmZ@-tI|=#>me<_*|neWY66Ewm%g9 z`!{f!#$iB{aHA&-(AJl7BwYBZMnN1Ge@F$~`G$_bV4MfGiSqP7>xBl=OoQZC2#uvg zc5#ltmtg}NcuvySJhtBFQ{^8=$kK(Dbl9_vA;aJ=kG$+X^)}h0a37O*tC;`T1w1A< zwj6Q0?0`G@GD~{?Dg}ixg8Uv&PO#FX~W?J2^H|V2HIuaAJuc_@)lqx;u zun~_y;VkRpXrM2K0|evhi14ytMC!q7Y23}BwB<=0;l$Q}lmY#K8csSO8q(Uzw1;RA zjLDYhQ38^$IR5ndW48STo&lfGE}0jn(Y5@`#sE6p4AC2(iBG?Ch@(!n4@4ScI$}kTu!*4EO&@orL01yx3^?EGcgQSK-2j zWN`_c#)fkpkN$_za=>!eq%7_YZ!UcOG#{qhe8Q0XBk-1H2#4f8!~$!j-&~mIjRUVe z-|TRm2ievL6MOZiu#2Ulvs6I+^ZhB9Ez71ZAVPDg8geQCLTr+v>=7Vl+4mNo-8YU1 zD>BB#{K@wB0!P1qYmv-5kP5xQeF}tB7B)oX*u)@1iPd;@eI==KD-UMcDYG z>Rq_NNy7BQop;a1u5i_nM!0sE3U{DZ^cel8B{TSB!Ju~u6+3#oJgjT1?PBMmNl$s& zTweVGvJqr!0gbitnNg8o>1EF??lKC^Lo5uo{pj5?sODx9rDvydg8H0Bl_yi=>LxnQ z9!>_QFa^cQPvi%jN%omW)()W(=!Sp9NVqNv>0f+zP$I~9G1G5-DM809ixt%B*z;k` z0#6xqqCi8z$kc@rY|&-RW0L$ps0qyA(hc)$)*`{>SIALp;E-h(S7r#>Xd(Tp_bdQ_ z_-VQ3*BSqcRD6u={utjd{Py<%r=oA~`0>UQf!13)Y3T!sWKYs zc3^C;`J5~>W8m6Ww9es{^1f>fhK&Iqbx4?FE!=-2PifcdFjp$|W;4o9adsc!N@jv; zeIt9xtzfehU^bTiSp>W}3+Zca7j|ezrUQ-z@CVIA#dkcfCI|G!FNZvCbH3=3h}9qO z@cPy@q2}l}J>cSrX&Q5SH?GNj0FrLRRf&7ZxBwc6B{J=oG!S?srzup(qLtF8)f`>1 zJ?AKa_Ufy9Ghq(`V(mNv$8C;(N_Y9o&o^J+MnF0<)cjCXcmC9k?6~#Kr1szOGF9=o z($>y~|GpgZh6ql2y)BADcHG)cDkMGjl^e1P5fB;PFO;eSGa9VD=loK)3zB zp}X14Y;xidUjPnE2Geb5IiN+u3-Lp#&YO?~a%G9oUZ!Cvu|}o$$z}xo?|WjOxaQ(w z4GsUSe}mZm_Y9D{hKz4l2S2?o_7F=BZaRqX_dR`@kz`ZaQBVr`N0paP+~l_K=l@w{ zyH2uz{tMK`Ba<5Qb-=ZG?b4t6jfYbiPnTeJJ4s>>lBQnd%XcPkeJ2-#K7Yn0Y9^7@ zcP(&Sp~9tT_vcXZyNROaW&0Q4qXTiKi(QbdQ)$Ecd%p3y6=hh*vm4IvCojCQ(wk7|M+Py5y?^fzngn!r) zS|oV@5ZY}f?}LQwXe!8aNO(X09`Qwq`yWq_Uih8xD|AKHNoRE2$*k) zEl^A|)gZKa@DcY=aRbJwlUlh^VV~oV&%OS(UZ$6DMG|UwNB3L6BFa#F$C(%Z6SS+9 z$|rI4OJe_gd4Zeo@S_8#fo%tQT(A>B=mgAPE88U&TDG#0x`k#Gpt* z+`%N9$ zsAY5Z)0{EBwA}$6g0v2+(?3wSOu2c(;2)*u8ZVn1+CelZ=w%*KvBZAB_#jXUXk12C zwc+ASY<;Fwk!4R!|ASczi_bPmq(8SwL(?qARamw>!bWrSy0#3vM|mmhd(q|Q=#iT`dG!)PMIXJttfGhlx+js(X_}dT^d$# zBe0W*kIzyJIs&5r>VNqSgK7`}ixf*__3^p=@$bop6=A!y7qiFJYn2x{mewvR)UoML z^G*>SC-jT?BGBb!kt`XOncm9;PT-*mhiu?+Sr!sNa^y|_*VEs0HWFYX)p!tYqaXi9 zO?sC@#eV~CWK;F~On~ifMDhWwWkKnnFl)}S#p(V9>wID4LcG!f9=r#% zZ-Cod&I0yc=@szJ+@slQ-EkI^LR_zdg)mGd-5;F219RYK%?zfvy;*8br6*G?4)?u4 zO&o-l#E!Vk=fmxc84EFT>`*XP7tJ_GdCn^e=3deYrS|fNpPwGfvRP6}!QG%z7TXuL z=OCyg3*BITynzAFDWy@X`8H?Y95m|A)}X!e`lhr%mjnfA48;OANWp}jmH@P=gxd(P zIi<8%b^o}A)Q)z~lA>t~j<7l;b)c|tdkwx8T(j6v*V#19fj^FmSnKWK$f*LWm;ty} z2Id#$?=;WH=+QBc!jtsM;R&Cq0^GeEfEmf***^ukoHk94=Yn4-eD#6IOPTc@x4@I2 z9hl#){z?<+0by&pV`P4RsBmvdG{TBj-$HxB*5)t^nngfl*y>L?s^7JRPb@0cpR@MG znIGh4r>nFGn_;!xf+QgF3S;p)p_`DpJejmLhfby=dMDR=24Aq3jj|$NFGYN8RP+Wd zep&XY3-t=zv>GyHR57#$BtJDI07 z>KDUUU-%#q%zT(o!%*5cPYimvsp1oEVI_yFn#hO`Y$P{{ZBdk$>ZqCkmS%w2*_><= zN;@2$g*aEz`t7`qUUBF};IX4;>J$^CzO&0McY-WSPSTF#+uI%im`Bh#6oj{K(7+B` zSIE9(Q7Ug^zt#=WY|q~}oSl{A`kG%h7_)m6A6+m{#MO@DK56!zcnL=Q3Zh0(^h~+Gfj1aL}`$e>8n}h!VaGei9dE z-H{icQKq7pD>A_j0QE_vp>n9Gb;TABw%RS0TP+yBUVx7h-$)i4dLuM{JG+ud!AJsB zhq*dnXt*nNwRFS;_FESW?J)lw`sd3B+N?RKEpu!BUROeIeNe8y&7mC+I<9HZIhtfM zkCY7MC~iRaUYP|fFq#O)ibx42d@w3pVv@nB5E+Y`C&m{c=rAf0k4Fgn0Bq~2P82HK zz~5%Nqw1#KUR;bl@(&917{NqVaH$;ciMW3*wmHO?2|Qz0D4$Z5&^tn#*Xv6AJ(|HW zIa6VhS4c2eFLVdEM)UF_OydzBP6+az*P!>>h1~KMV8w^AkX zEpIZK=h&0@y{6JQL&bI<()V{~8$}?AlVF$+)Z&*k39_f_9O7|qm`60_GDo0zms5_6 z67G+W&D(Ll&|C_Ga?4;pNyhX&e-IH#&J$1~9dYSMk)_hsLt(h1oL{Y`lOS{VR^(7o`$+7?C_bK z1!U>fF_1`c)hs<~TN@dq=7?t9JuOXnr>w>9{D(eHHrEwbSw_}HbaNx7k4kXQ?XiY} z*z@VUKIZ9JD$We901S{C&{h0vS0>7;``{j9CDbli))`W zk!&#!^T1<#=TyW*%f1)ZWfd-cAwkB))G=2chWGd5jJd`P%g;*Rz{=(Raw4GsB1Xkj zu;s}bx2s(vcF%(L{3WbrT_sGvVA;@$zh>zNGYYRYG^m{x8n2nb90{I2ll9!C%i5Ul)v*wS629#YM~?2NG~uCRj~np z&H<2*)L#LPh1uOqQ}Fv1w@a)*N*1k}f;~IzP0Tax(#`_YE-nMC?rR&Sc`5(G3tMC{ z_Ol)YUyMUk_RDBPyIX)+)0m+Xz4>7W&;vlESAP31N!_Q%|>cBQ+|G5kQdv%Sld_7InWt3MYdQg4;mb5)uA%Hw3>w}85t$$CU_Rw%Q2rNlPsU> z?5!r?VWN;kAVYnpGLvHqy$8f-+q`pFI814N)%(MKkU0!FOc`Aw_8D-ym%E9zFD-X{ z(h5A8I7dM9z6MsI?EfYn?zZjbIml_eSvk7se@(o@(OB)qzUE{jI$%FFWae{Gh(goV zeb^ZGT!Hz_`ufm~XuOz0zVCof`G;Nz(Wov#k%uFcDfuB48=Gg=T030MysUcMO?#`7 z%B4Rqs>L0uMPW2ZtHkRM@qthLM){JsI}NrvcmklJ8f&R|CLNM@T~b0W*zYa94E!QG5)$36r!~r5^SuQ&05%Jf%xJ69K=yF3q|2 zRW6|>Hq^{qa&kaHjW&?G6Mf9L-Wd#r zGlTPyd3W8eWUreY*U6e}4=Dp@H}Fj!y!1S1T$REIz{K zab9Y66M>y#fiyi)Zi^OJM)X0Vh?$C9gFJ++^Hq5W6{9QvjEVtmIc4kLb>uE*MiHkaw1b_3DpTTlj#Q`*7XVu66(01~rr1Oq9b!)6HD77RGi#$Z0-XRh;G zW1eH0N7m+XJlj)udIjKmfIp1jF3{Mn&+#6ftr|5@PcynvWXpF#n}9IY*{NdS@?xsa zn|gC3w~>m*jyM(=dsrd3!qs`EDR!{8S=8J@!8n@$LDEIqi)UTr#XTd!GOZx_{FGvN z^-yJkfB-Hw^clF1;cF}^-Je9`4R}U4rxO^O$+YxH-%gG7K)+BH2dIFv^z1p9MmD7N zblGsP3N4BqWL8Cal&J`+;MjIjSpDg5*Q+$_GS6B^9hT-S7&%?ZX#5g&r{M@ywP{<1 zRwiYwFB-TStE#`ad*#&=(BfKQSq^j7o;4apAnM#Y8C@c+xC9ME8C%0rF&O&b3QTJ< z-^%w1EczKd{il^1XJO2bzCgqfwS73u^aQCuU1Lj5`aG{+hZ)3aL@M1#RoZ^-_(`xp zT}P=iGx-L7Vb3Yk9kG>NtxTVzai({j?u&%jXr|c0ff?Rb*E=*CyP==$I#!$cV?Tx(uPAZSr=yiFro^Q1{@xFJ z+1}xi4f9J@2TAUcH9Mcw5w$EO%uCFK2VDGbOVHLUAJNu}M<3V(c(wX6%~bXudfA~$ zr2Ry!v_o;qX+%niqJ%_=EU-87DWMBF%TC<|-WMZ0r;$KPNIsi?ggh9gH#;5Fya4^< z-LZ(%$nmviHuCsChPKv0Ph;^2CZ}GFB1a)obj9`j&(Z<*4KQ+xt=h4v#hJrm==`EvZx=3oTk7<@&tV*;|m zzd{9?4xhagSf9#m)z=6u^w(m)HYmfJ2qCHDI!O`XgypN-{(crI=brC$Xp&@|?o{8{y$a12<|WCG{g163W6tI6e{Mc_QECui zdC9$M?DV=^vUN|T!Ecg|8Zl%`>vi;03y57>EgA)kyh0#z&d#dVYYtVoM6?=A6dV0S1a>WF@--&wr zGc0A`DUNk5^QTmw+j3}NaYMFHdtm#*Lvf9sn_(A%o-|&hs8-68tw9Ibble`FY%C`OBNy@`% ztxRG)=N?0a~YDltT1G;BO?Rsp1c7Y`@WDC>G1 z;1#SJLTxEAe=zFV$TObc)@B#&$3Qql-4DJ~7AK&>E@C^`e@3BhMuH!c&93;_-nsI7 zihg!Bjk&)4yJ*L4Rjh^G5%uF_hsT}A4rik=aj+iR$D|&&!Kg`$smhB6eE}!E;8X}< z)A76(vIMhQMQ*NbVAl{330M*$XQAKADU4JDOv$mFfrcGQW~L!I4P9}R#V+|?+(#wT zj}Ncc>(O_a(9~F=1P<+^o>nU&Rxsw2;fbEx@aBvD)a4!PNlxc>oN)&n>Z9AQGBdY( zQ2jn{JDM>jh>}&^qkf9B>`hY9k?2%F-4-q99_Ofe;r^mzlRB=Nt>xQ1S zKzpUUgurP&D}_u6#Qtf4DCgKMys@l_{T~9DY+BGuuZ%_9tuyAO4t7ce;q_sm}R3C+@@E z=6$*J{O!vuY_Ftg^qg1==?;3XufFPU*i3g&eC%oKII@C5`m*w`aT`YljVzKPK}PfF zUcU4f!cn!k2)VX&A1S`)?$(W%Fyz$(*SQtG*h>SV{0pZ39Aie2oghMt-l3R^SIpgP zX!x~?=CQb>P2RCrw*q%uBQ6X|>^Y!>vMFGR{AAeXwT^QWb zIIh(NzTF*SaVH`o&{_niQghfgpwZtgcjY_Ocl}YG-d{J>25IByH|GqLr=QuRT>&!E zJC&f=qVDCe$d=lnUbI#MFONwDM@7}pKdt#nbjwdqd0(xF@InIh*tRlr8Qe!AFlwjU0W}n-gf%spa&y0L*}LKfkyu zN(fc?g_-coBk9Q@WL{1bU3i-f8GZRnN@_^Ig_yYCZUMvyDU2ijAK|~aoPW79%JA@R zsj26!G2hZYcq4z7v&r@5Od&z$l~k}3SJAY*##45s^7tLFPlPsl{q@X=bZSjc14`Po zD{-9&xLB_GQli*UM^y9oD402*_6PPkTr%@pl)hF|sp6!Wi)esw7hRDAv7hzJjFnnJ z(_^2QfrYMVwAYk|JzRjuGg_=ciAiim6#vg&X)@6)VwtZRtkuGzj^1r`*CpQ&q4_!O z7&c)#4b3EOZ_o3GG_sDVa3Ra415Kv&t#}uc0K)B95#4_Y#aJU9xuW zBEN2wd!dryAg?sbC2nI*o%GY}OMfDD4es=5uYoU3eIOaR z8eV)b%6gdmIe0+;cM6q$Bc1sY`u_EC6kL zH(a`5$8Zg@%Z!BJyFb-x&l~(kOI@@3AazkG|48 zQ)M#hJxk1ne^`=0gtgmUKDmm$(t@DctX7&Z_e^)a++f=DR=mZENy^eWbvMcZ`OT8D zB>$=i-10=^8;tG&U>j0yY;&Fc(jPxqK<<@Q+{$Ibk#{r_k5w*_a%5&O7n4Ye;oQ1C zKEL{b_DU!4^-2x+>c_ny?`bON*`n124J=>FBy=sR69G&Y<6y2iN{h1LFJq5#e8h2) z6{u$`tVGiHO)pl^v*1Be(Q$cmpk+r8wKu39R5mbIGh2!<&GRcbS1caOs9X`db}bWV zkmP`h)2D>=(%o4IS3qPyhhv2%Kf#$*bYn{?xs#)xydz{|Xwq9b!RP+~;Ai){%mtrI zaYrcEKJ@dnwh-wo-E;Ol1NQw;)vxom8N!Q&!PeH+pH9@RZW0hGJ)%*&j6J$E8adA~ z_4I*bS<1N@+iLwe2#)@?-Y8L0sn5vd2-f5zhUQq z=pG!s51N&~xjt`Jk3>>Gr4A6Umru;C885^FM6)!*Kq#g#p{5js$F%&*dEU|1YrNUH z1|XuZ_R)UyA^Qm2Wuf9980?N1rdUy-yWifE@l3P@fIwP4FM}arKC5J4r_(^sN(JI( z*#6E#??)8R;D2&Jtvtn~9-xlRH_h@*=BsR2Kab4MRb2yof(;T95rYAj%-J^I-6UcS z;|q3p8mVn_m{H>|1>I82G^@97X7+D@e$8VE!CeY#KKHoY>TW@U;|+k!eg`O`zESX)FqoLLFh>tMcE-I2s?`WZoc1a z=LCedd(+!!T2PK__3y)!Gz>o-p8r9eLAwf0=0TR`kNyZN{`aTSLeVT{1JEnJ{W@NO zE|%|GOCpxtilIq;7{+^A$|wy%R1Z_8bAU*S#M9As0X(sot61+gD1^@ubJ-Ije~Id( zNMCG({LwV4@k8aerk80~`#`fAr3!BFmfXks77?HL<=d;20vA*|tc=#VQF?!7U=GK5 zZ#Ro&!zLH(ThTQxbPUlRIgdo${!;>Lbf()Ay;x zP!$oY}Y!v_+?K+bNVQP z`W9=$~JYsiw_5c(2rPu{50!f1%&KhODGNqk$c1& z&gg=hZD;tuhV5WuxqKiXkf(r!VtuW}Ms` z4xqKEdjw3O`Kc@{v^^*1l3fFMCvs4SSWaQ=j1^d(`9+|bM=B$=UPQ=^b}>|&0MoSK z_OmOXW68-joJ3X%BO7vTxUp;4zD>Pu7VU0V?qgUU=#Q?0jG*{;l>K@%9`p`rdyC;+G1}+ z9|}aPRoZLB?AhBzJb&n<+w>z9{}EwkdNmsZzxg|oG~4PKY;vsTUhuJo(Kd+6QK2$+ zham?qHxwQAE#i9;?S-Zv_W?bOxj35;_PWOkDliE*Sl^F=G+O*>FyC~tUevl0wuRDu zAnV*W_P7rLT8J0x*rRPw;M(!k#oQRT5=Iu?-lf91!XKgTP&@Yu-41j4NkAxobyY0| z0*wAcXk*bC%$JKYSRY?+)+@ z$ezu@;hZoyj&}Z4Jtvg_vIN|fE2hjEN{SH|g1fCr4WYR^aI%DkBS9SEo^zJqB%eaI zw#E+=)RrJ&qkg2hXtf-~QzJx6TWJXtU`>_xg&%Hn+XrBA$^2~HE7m@T(dlBp;yYl0<@9?IQ zLu-jl*vkyG3R+{%tIG$)6~qwr{}OD;UBwtDI59U|na^gUtdzt0`ZYLl|} zqmk8$+}2%yui^LK*$)$U37*b5XH!XKXH4gbsjA z?1ys<|L0IYt&1Csm=rrO1d&Z{`~4iqcV?E~;y3|8Mdehc%FQvZB%29r)CfAB)6Kx} zn=8~Z$Y)QU5zt_(|LDQ{+44Mjw1Ek4a?5g zJ_gT>YI5@6%sI-Sgtx5>c@-GVm?faM2I+I?fJd1ky&2nJ*c;vn(rJ&X%e~z9DJ2t~ ztcAVX2V{_0gS_zY8FNO7;4Xa}wjEZsJ?Z)cQK6L$g@kVx&FB3=+II{^DKU5v^`QSj zn?VlC09{u2+k-Hp9BU@RMl{&wa-b}?WWf5gV4h}sMj#x%s#a(R;#zXag`TVsnt&MWM%S$8t8}F&ioD8AGgS6H1 z;D9%Z9w8Sn8VGW9#>({0S9`-c=otw5)$HtC0UlR1#5rfFl0uCr-)o6)Z5w|khEae& zqh6q&yZa_*qbueP2Yd5$=L!vGP+Vy;dnL=3Jq_dr%77uj<RLHT`E0!Ha(6O#WT5e>CSi4PUBif~t!wPL~LC2Z~XEk4KgsOz=!s>i<<+;RV5 z>26J@)l+O}XuIoCD@A5Q5;y9X(n2-`)BZMtwPbLaI0no4LEaqzO;*?O5lO@TtCY*c z?1osa4WNlw*cmV(fJto|zWw1XZnB(2#ql18tdRX~OD4gbe+n$AGi5j0@_ZEl^PwX6Lz+gyS9!!=A-|E%D)J?q@*|YXQz;k;YzdvG5NKqIpDm$i7CB9XHK?8Y%=J>nhE#U5{(~K_vBUQU z4&#cCajl0+Fvz?Q7-^#MSr(4B`ciVre$h>YK=H!dinG^RN`0?**ZHpfU1a?!W)i*+ zJo0GM$JJj!>cFuSo78c1Evz-ChR55{oDgp&G5Sos3O)se`{%PK4V9P4XBN5 za+novvK{C!z*l>IqLZX?39PKg6);KfC=JDfTvd^wat1#gzltiV{Od+dXsjB+SzM25dZZXV$UmE)0_<-r6>11A`&CVNwlAoW(X@6{oUwk*KQS+}gdwHo2 zHHi^s9$`y< z(ZYu8gGZFyAmuN=w`QOCoVR&ba;dhteEYok3URJ8EtRdOH9Q{Rjma?}I^mJ`(FXfA z3nG7M{3eE*0r_8qxU`_BEaag;NFV!r0;q?uVX3lEQUzm+jO-KFP3tGry@3b1@O`64 zbTEt05qv?F*GQ$~g5#QslGPG9GCMD!h=f5ArqzGRzRI^e`u*Q^+@cG!2p!f(W9{W9 zwhs*qzv7?PJ^=x40h@|&h8H2T!wG&MF@(zYj5?jCPtxJH%wLKFGfEa>Rk$+x4RGG= zdFLzzqGjrmcJUd*#xaPaj;>3)wBLdf=M5@Jo#gjkpY)_QMhet!K$_@Wypt{_xUu2R z-+7^hu%Rf6?0SUf;j`{?rOC#%n*VQl60r!yBR!VUE2Nrs(RD^iN3Tn<%S(Nydy|j2 zpAp8=DrT5kp{a+icLUBDn2VPB`#LLtH$!*h*bOz4QK2Napo~p ze zQ<<^I^BR3bX}1?d32WdSXjN>|&DBx6b|AY;UcZC9mGzY8^p>Q`lJv>x-=Z`l(|#z% zoos6n;9^&htNJKUszrR79cvZ+A_5C32KKtzI0XPy{I3vRD{wBG7cKcy9^vXSKvOj_ zBZ8Pog!^uB^ExZ5x{f!{$ktH`JA(K&exRRJGN3c;h+=`D3!WXAG7@kXZ`vR#NC{W7 zRg9n;P2ZcBqr9Uz4{Y*lY$Ek*N33A1(aFjFsFgeEuP%OivJ;&rf=5y$6~UfJrP-%l zSRqx9N1Igzkavclz}1o^TDP<4LNl58EnKKEKZozw*ygki@!Tg>YWR;vd7YV_Au0cf z#CA_>dvOYOlmkiuYbxOHS5C@~9zoof4&rR`)b>DTvG+>D7h&(uCu{l?%79o3mJ}%$ z(VVqV6)JuHlC_}m$}mpGC-Pb`&zAjX$h-;&Q-8MWhX7ynb;vqC(RqD#nMCoxizHP@z)Wb?K~OHO`3UE>z_j5i8|*lm^N$;h%d7`d6;hUZkMOe zcdt`Dis?ut0QBL4>qcByBe7^`bUxdxj)Tsp%lV>8S^BV7S?_lkb4UP@;9}N;O|g@P zxSTyh@%Y10>{p}!FwDT_K+?jFj5g8B%WC6g)|GBUFwwDsqR z!a13EnNL0w<7<;=+xJLtVUT*kEMYT+w^F^9SBb`27(Qwx;H*ls_?sC52s+rGmH0wY zWPIX09lf$`j%eQ_;~b7zaiwm{=lO^G5zgZSTsPyswUG^fRq4K|fOq)2wOUYjHPY=N z*b(jC=-SxGid+M;`k>K5=%JTn0wZvJDcH}k~+z%`K;oTXxR3Y*tPCR?~n*b zQT)ZmHi2%_m49R#*P~n~k@~5biM<%uwS4`KH4Y@y$l*1*3@!50hY$W=9cXSw}2SD8XDw{o5n zz7u0Fh=g0BL9ta8%4ijm@y+6(&42cLBKGb8V4Xghz!>`)LZjLjPC zgvUG>s}Y%maX*ZYdyCOnPi3Qz|DOZAB*1EviglZM7!Kxwn+}#_#=ZmjkcTPxVey4$ zNcqD21|jG;94?<}@aD=4&5>dgWrWl%)%k7Z?V|wINx)fTl*~!S>}hL_z!dw9qzRqo zp|>bwjju7xl`tpU$PxIl%|mzBOWx64#Qo=6_!k04r)*7_Mn_ufGs;)f!)e`ERA=v+ z!jrNOET{xdWHK13*>sVKC3ju=pWG|Ar#X7v{5U@~^RgHl?PdDV<;;7kKWgKU$Q?!B z(I2tqwe7^RDK=cr*#Zj|P@y2?*J<3^9o=RIBu+oAoox7(kJOhE{Une6VXfCq*#1%o9Lk9q29rxFx3)vqs>_>=rG zxH`>saw)NXDpTYG@uWNUxMH#IX1(5ReRb2pZa^I5J&GEyfUdL!Zze5d8nPEXbUe0t zZ-e=+6efM%Vn{1(h-F{orN=|U{PC1Am_n~>Txn9Kw1=E)iFBe&?p=IePPr_f9dgIC z*J*G+Ham~L!Tb`=b<=KnoiI5Gk5|98-rf>;rF%G6F{1Tf5T4c1o@IQu4W=Jp=Bjxq z>FW&cUR1eP8HH?pZqu2KhQ5@otn~Scug3X<&kTbkqxDnPS(+O(e=7RLpg&p2glR+{ zfPFy(V=6F99|)mGt^WG#X>)JSHo&w|>}=I*n%^s^e`lGpL1-Xm#tPL8(X;6;IpTfq zSf3-&CrUf7U^eaPNK>_yi%>Gr9L>i57pzyfW=G%vhVHFA6eE*WzR7t;(=qR-wfK0< zVtJnw#8P3Dm%4qXobiUlW}#_d~R1nf9JP76|yc5OlvIn(^~(9HqU2Nf476zWT8ERvVCau9s@kv=qAja# zXb28b1OAPj_To=a&ugV_D}`^|ORr(1Mhuv_L>;gPU9T5aIqMG}pyK4R_1Egcu8HNG zpProJ(_tTwwovw5zV%BS@kom=T30;HGi|dO{Vvrcp_Lx8SS=qMI!gN3&1lyG-z(f* zRxx9s*jPA<&^<>J4zA)%TSb%|=Ly4BA6i(~94du+6Z}oskJ)qU%Eq<{aYV9vL(bN8 zy2of;s4AHrgzYY!Xi%izYlu{}37Y3l9cB~x3t<@phxx5BDQb=I$+ehD5<^ZXRKz)0Gth5?WbSmb-QR^Y8QPmA zWdjlS$>5lLaN;h_%W1UzVmbfh=?F)?W&3t@{Ldp2W;n@EdHolO#} ztS%Uee}egeM-6aQHVh%P0b%Z8d8MfldOyV^ex!lYz-2=~atgK8Zm*9}rIP*AJKnl~ zj=L_{F%4Hp>v=YYzx}iQh-oPrn3D z|6^QZ2ntm0F+8&gZ|ys3 z#7aNn3TE88k2@rsty>AoZhm+CM~VH`7`O>YU5BIajK$X4_E0OH0amk|nmeu97TeEceA}GwTcc90)0UlvEksdhSu*Ta>I@@{xu(bmb|<0N($g^TV}CNotj1x z=K{a=VYo)WNgl@+Zg+e3bf8oU#}&XOa2JDa7$+yVj<~$BpiSEEsbVt;x8F+e1hjfa zCq!cLD*p`>6hSze%K%ZQ2@lN<)^I9KPA0kLVW~U0x!T2(Zz_bA5q4lVm$U4!hc3qF ztsLbhpbMAB9iylAe7CkvhhT(X_xd)t-RL}?k!Na&FpX;w64%dni(qq5Qho=I99*g! zZG?RC3VEKRze{q{;$))zn%*!OXKUn_*M56GlYU$=tHIia>HYn59z29UmgIFEtsVw| zn!{Z~6BjLLwaKHKKhIe>h5>||xbc9VrLtMgjLgw{TC*b=@sV->asuJ)I$ZFdrtm^Zv$S6lS86fu;tq zUab)%TZ5gOz=hK*)sGmJxiD7N0}S7JI&iaFfCP5oo9<6;2eDj9imX5Ylt)ZbCc3pztg zFnA>!WwyTm`qgcn{kG)^%R}~j2eJ*&S!kY3b`Z#j6!1e8pTFa48V8#3Xxtb3Wl*t$ z=-i=dp&hBQ(>QoOZE-WMl{)xyxll7%nOtIVezT$*l8wKKLV9^i3Ggts#nnKfaR#I7 zV#p_1Dx(7RLLnDK9)9m45BmHow46pcM*}>{wcKEq!8>OsIvL#QsB$4l`TM2q%dZ{d zJY%2_*@^*N>Wt$xg`2#l5oG7XnDxv=b&at{{Q~v zThn#4q`0Hb5uzfta;v~sRl#h(^;x@Wv$>69>fiM2OK{0j&TjP8F&+bDND$&(YEK_? zr3)k+%Y@F+CI!waLc37wxtfRT;ni~=CNyliQ{=d$F{jA#^2T@NYo@|z)HzHy8gD8{ zJ(SvC4vc<8r(tL?5mk^L@O%|8ppr`@*YURT)zch8W^8{)t?_U1suvme@!9iE<4)1( z5rC~4Bo+1*0%(LK9AAuRmRUfNVjZ2sFs|fkN2FI)KO%2?Y=52s6FA_i{5J>_c;iU0cdDVOsu_pTK}Vgt-|uN0+ceu#_%Ck4_K(bo^C z)r&G*+HPOAzt=qv=)p$E=VIS8d6?($!)(=A19^3HgB6g=q5qMEa!;ULW4xZKBb)7n z0I~pCCHnFeVx?8KVfqsXR-kMBBq^9O`?@GCh32pEb2447%-Fao2Mkx63a$!ODzcJ! zR&y!-|LKHboODR&nytEl4UMp6zr|;#pH_?Up?-_;LtMFa;W4_!ZE+zj$3tf9S~@p6 zMMoyodP<$C@Yjp&C`}ujk1-dX7S??a0x)Q0qLikXUlYCWM!mTUWO; zEHg$gz1f~VelSAr07pG}r4h=#@m@*=0W0spw64{sf|+Lf6k9<6pbtKGY*)34z!s|^ z#vcUG4QJiJ3zU6H^35x7WVqy~uv2D?(u$n}o|%$EZB=p+#uRFmq3?W14Vxy{W4!^X z#v8-ra>ChOd@u4R?*-JaOrLVJSjzJO=oz|qQdL}_Ux;GIouql@E4(JZkFSM|>lo6~ z&GMJS#$pR7wQ*_HwP2})azTPb24mI}N~)vbgXWxJy5AY7-sSOGizF;@*Xwg@qws0Z z%bHCgoSy6`_=V+e5Th}U7Ix_Qnh_(q55s_LKX|M@JOTa*#=A6kF@loFK|LFE3JNJh z%?xW6MxgA|9ds7jb=kZrRLpsE4jl72!V-zlAP$iaZMZs*HRD+=8Oi{PuEQTT` z^I^XNw}&E8gO%?|6?DaRQW>4dhDrNx?r)ULg09`DT$C7|c3hJ&#+IK>pZYsDG3;Z< z)x9*3lj#ri_G$B8V!q{hz(e94gh+?2`9k@I!BV)cZOcqL?y>4a>$YD8&for)E3Fw3 zvcDBr6B+@0{LwaFYbo`-RMlAC)ipz)e!BlOg>TYdnKC4H_d=C(TB12hcUvRxQy_DgbdwWsl(S5A9 zun)0}IgVsv#N-rBaW)|DYV-Z|ra`$b9uneGdC}eXSHtQQtg$XXT(4e5nHm{AH&q*g zh1UeYY|mFAEsYmmX3gQSH`Vhwm#Hq6f;jnCU!=-KwbX+qGya&}G`xpHjpTk>F#IE3 zIka<=kamD`ir3Ecc}^0<^$)BDk*)B>E_zwYG_6xp5KvnT@L8@PVe23Qx4!|M4!@pd zmtd^3+uaknbio6Ogqx`&{LBLtLy7?eXP4`jv&~jOQM9SZbLnTNYT%EmLz1kmA=5JZ znn!%s6VjZX;C#~unW27>jgv!a=TxX4KpV>R{tP!QLqpHe0oW$RQ8Cbo)BdX2`AXVp zV>bI0S}wJ4`%XV3Ur$6}a%xOJVY`%8FHs4LrAa z)ubt2Z}Xs38;-#fzU8cBM`0(fK=UJSfgVDt&~7OijzB}!)CFKDX`it`Clo``msM#-}nRQa`gt82A@xVuw7)y6NlRmrrZ_ z`&huj?z2IB8}9aV5&a218ZA*0J?9S0Yi5-NCx}hA%J@WsFP@MCfeDqS zJtvWs!yYRicUs$7wdbxH(6h3l299~`>xQ%F&2)(6A7nBd|NOd&{(c#Ht@|syOyEoF zj$}%M$jAEkPNn_|7jIQ1N4GBPuu)!JfKp)aoKSCvpC7XA1tDw%Dg*#zxzDA?fkmpM zpyvz_5#8c!-0!Jubp@=M3lRy^PA)2n+IGAnAWEy7fS-r~@PrfxNIjYM0VN=-br^-5 zH$F1YNirBJT8PV3OLpYrDM|iubsVeK-aF^rsmO&HBYAf^ETg-I;iuf;hwkIiW1X^S zw4^r)pNi%!Lr%n=p4lcd9d^jGQy%0AMN045+bv6$a(t2CtannDpwQ;xkFQijh)F@r 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:1:23(13) ``` -The pruning behaviour, and consequently the state availability and tracing capability of -a node depends on its sync and pruning configuration. The 'oldest' block after which -state is immediately available, and before which state is not immediately available, -is known as the "pivot block". There are then several possible cases for a trace request -on a Geth node. +The pruning behaviour, and consequently the state availability and tracing capability of a node depends on its sync and pruning configuration. The 'oldest' block after which state is immediately available, and before which state is not immediately available, is known as the "pivot block". There are then several possible cases for a trace request on a Geth node. -For tracing a transaction in block `B` where the pivot block is `P` can regenerate the desired -state by replaying blocks from the last : +For tracing a transaction in block `B` where the pivot block is `P` can regenerate the desired state by replaying blocks from the last: -1. a fast-sync'd node can regenerate the desired state by replaying blocks from the most recent -checkpoint between `P` and `B` as long as `P` < `B`. If `P` > `B` there is no available checkpoint -and the state cannot be regenerated without replying the chain from genesis. +1. a fast-sync'd node can regenerate the desired state by replaying blocks from the most recent checkpoint between `P` and `B` as long as `P` < `B`. If `P` > `B` there is no available checkpoint and the state cannot be regenerated without replying the chain from genesis. -2. a fully sync'd node can regenerate the desired state by replaying blocks from the last available -full state before `B`. A fully sync'd node re-executes all blocks from genesis, so checkpoints are available -across the entire history of the chain. However, database pruning discards older data, moving `P` to a more -recent position in the chain. If `P` > `B` there is no available checkpoint and the state cannot be -regenerated without replaying the chain from genesis. +2. a fully sync'd node can regenerate the desired state by replaying blocks from the last available full state before `B`. A fully sync'd node re-executes all blocks from genesis, so checkpoints are available across the entire history of the chain. However, database pruning discards older data, moving `P` to a more recent position in the chain. If `P` > `B` there is no available checkpoint and the state cannot be regenerated without replaying the chain from genesis. -3. A fully-sync'd node without pruning (i.e. an archive node configured with `--gcmode=archive`) -does not need to replay anything, it can immediately load up any state and serve the request for any `B`. +3. A fully-sync'd node without pruning (i.e. an archive node configured with `--gcmode=archive`) does not need to replay anything, it can immediately load up any state and serve the request for any `B`. -The time taken to regenerate a specific state increases with the distance between `P` and `B`. If the distance -between `P` and `B` is large, the regeneration time can be substantial. +The time taken to regenerate a specific state increases with the distance between `P` and `B`. If the distance between `P` and `B` is large, the regeneration time can be substantial. ## Summary -This page covered the concept of EVM tracing and how to generate traces with the default opcode-based tracers using RPC. -More advanced usage is possible, including using other built-in tracers as well as writing [custom tracing](/docs/dapp/custom-tracer) code in Javascript -and Go. The API as well as the JS tracing hooks are defined in [the reference](/docs/rpc/ns-debug#debug_traceTransaction). +This page covered the concept of EVM tracing and how to generate traces with the default opcode-based tracers using RPC. More advanced usage is possible, including using other built-in tracers as well as writing [custom tracing](/docs/dapp/custom-tracer) code in Javascript and Go. The API as well as the JS tracing hooks are defined in [the reference](/docs/rpc/ns-debug#debug_traceTransaction). -[transactions]: https://ethereum.org/en/developers/docs/transactions -[evm]: https://ethereum.org/en/developers/docs/evm + +[evm]: From 0bb421adc57eb63b479e7134610d401137173d3a Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 17 Aug 2022 09:48:51 +0100 Subject: [PATCH 036/432] update geth-developers docs - md formatting --- content/docs/developers/contributing.md | 23 ++---- .../geth-developer/Private-Network.md | 19 ++--- .../geth-developer/code-review-guidelines.md | 77 +++++-------------- .../developers/geth-developer/dev-mode.md | 2 +- .../developers/geth-developer/devguide.md | 47 ++++------- .../geth-developer/dns-discovery-setup.md | 51 ++++-------- .../geth-developer/issue-handling-workflow.md | 25 +++--- .../geth-developer/vulnerabilities.md | 53 ++++--------- 8 files changed, 89 insertions(+), 208 deletions(-) diff --git a/content/docs/developers/contributing.md b/content/docs/developers/contributing.md index 44d4a9a33f..126395d0a5 100644 --- a/content/docs/developers/contributing.md +++ b/content/docs/developers/contributing.md @@ -1,17 +1,13 @@ --- title: Contributing +description: Guidlines for contributing to Geth --- We welcome contributions from anyone on the internet, and are grateful for even the smallest of fixes! ## Contributing to the Geth source code -If you'd like to contribute to the Geth source code, please fork the -[Github repository](https://github.com/ethereum/go-ethereum), fix, commit and send a pull request for the -maintainers to review and merge into the main code base. If you wish to submit more complex changes -though, please check up with the core devs first on our Discord Server to ensure those changes are in -line with the general philosophy of the project and/or get some early feedback which can make both your -efforts much lighter as well as our review and merge procedures quick and simple. +If you'd like to contribute to the Geth source code, please fork the [Github repository](https://github.com/ethereum/go-ethereum), fix, commit and send a pull request for the maintainers to review and merge into the main code base. If you wish to submit more complex changes though, please check up with the core devs first on our Discord Server to ensure those changes are in line with the general philosophy of the project and/or get some early feedback which can make both your efforts much lighter as well as our review and merge procedures quick and simple. Please make sure your contributions adhere to our coding guidelines: @@ -21,22 +17,15 @@ Please make sure your contributions adhere to our coding guidelines: * Commit messages should be prefixed with the package(s) they modify. E.g. "eth, rpc: make trace configs optional" +Pull requests generally need to be based on and opened against the `master` branch, unless by explicit agreement because the work is contributing to some more complex feature branch. -Pull requests generally need to be based on and opened against the `master` branch, -unless by explicit agreement because the work is contributing to some more complex -feature branch. +All pull requests will be reviewed according to the [Code Review guidelines](/content/docs/developers/geth-developer/code-review-guidelines.md). -All pull requests will be reviewed according to the -[Code Review guidelines](/content/docs/developers/geth-developer/code-review-guidelines.md). - -We encourage an early pull request approach, meaning pull requests are created as early -as possible even without the completed fix/feature. This will let core devs and other -volunteers know you picked up an issue. These early PRs should indicate 'in progress' status. +We encourage an early pull request approach, meaning pull requests are created as early as possible even without the completed fix/feature. This will let core devs and other volunteers know you picked up an issue. These early PRs should indicate 'in progress' status. ## Contributing to the Geth website -The Geth website is hosted separately from Geth itself. The contribution guidelines are the same. Please -for the Geth website Github repository and raise pull requests for the maintainers to review and merge. +The Geth website is hosted separately from Geth itself. The contribution guidelines are the same. Please for the Geth website Github repository and raise pull requests for the maintainers to review and merge. ## License diff --git a/content/docs/developers/geth-developer/Private-Network.md b/content/docs/developers/geth-developer/Private-Network.md index e54dabcdac..ed1d6f7cf5 100644 --- a/content/docs/developers/geth-developer/Private-Network.md +++ b/content/docs/developers/geth-developer/Private-Network.md @@ -1,13 +1,13 @@ --- title: Private Networks -sort_key: D +description: Tutorial on setting up private Ethereum networks --- This guide explains how to set up a private network of multiple Geth nodes. An Ethereum network is private if the nodes are not connected to the main network. In this context private only means reserved or isolated, rather than protected or secure. A fully controlled, private Ethereum network is useful as a backend for core developers working on issues relating to networking/blockchain syncing etc. Private networks are also useful for Dapp developers testing multi-block and multi-user scenarios. ## Prerequisites -To follow the tutorial on this page it is necessary to have a working Geth installation (instructions [here](/docs/install-and-build/installing-geth)). It is also helpful to understand Geth fundamentals (see [Getting Started](/docs/getting-started)). +To follow the tutorial on this page it is necessary to have a working Geth installation (instructions [here](content/docs/getting_started/Installing-Geth.md)). It is also helpful to understand Geth fundamentals (see [Getting Started](/content/docs/getting_started/getting_started.md)). ## Private Networks @@ -34,10 +34,7 @@ Geth's PoW algorithm, [Ethhash](https://ethereum.org/en/developers/docs/consensu #### Clique -Clique consensus is a PoA system where new blocks can be created by authorized 'signers' only. The clique consenus protocol is specified in [EIP-225][clique-eip]. The initial set of authorized signers is configured in the genesis block. Signers can be authorized and de-authorized using a voting mechanism, thus allowing the set of signers to change while the blockchain operates. Clique can be configured to target any block time (within reasonable limits) since it isn't tied to the difficulty adjustment. - - -[clique-eip]: https://eips.ethereum.org/EIPS/eip-225 +Clique consensus is a PoA system where new blocks can be created by authorized 'signers' only. The clique consenus protocol is specified in [EIP-225](https://eips.ethereum.org/EIPS/eip-225). The initial set of authorized signers is configured in the genesis block. Signers can be authorized and de-authorized using a voting mechanism, thus allowing the set of signers to change while the blockchain operates. Clique can be configured to target any block time (within reasonable limits) since it isn't tied to the difficulty adjustment. ### Creating The Genesis Block @@ -46,7 +43,7 @@ Every blockchain starts with a genesis block. When Geth is run with default sett - Ethereum platform features enabled at launch (`config`). Enabling and disabling features once the blockchain is running requires scheduling a [hard fork](https://ethereum.org/en/glossary/#hard-fork). -- Initial block gas limit (`gasLimit`). This impacts how much EVM computation can happen within a single block. Mirroring the main Ethereum network is generally a [good choice][gaslimit-chart]. The block gas limit can be adjusted after launch using the `--miner.gastarget` command-line flag. +- Initial block gas limit (`gasLimit`). This impacts how much EVM computation can happen within a single block. Mirroring the main Ethereum network is generally a [good choice](https://etherscan.io/chart/gaslimit). The block gas limit can be adjusted after launch using the `--miner.gastarget` command-line flag. - Initial allocation of ether (`alloc`). This determines how much ether is available to the addresses listed in the genesis block. Additional ether can be created through mining as the chain progresses. @@ -55,7 +52,7 @@ Every blockchain starts with a genesis block. When Geth is run with default sett Below is an example of a `genesis.json` file for a PoA network. The `config` section ensures that all known protocol changes are available and configures the 'clique' engine to be used for consensus. Note that the initial signer set must be configured through the `extradata` field. This field is required for Clique to work. -The signer account keys can be generated using the [geth account](./managing-your-accounts) command (this command can be run multiple times to create more than one signer key). +The signer account keys can be generated using the [geth account](/content/docs/fundamentals/account-management.md) command (this command can be run multiple times to create more than one signer key). ```shell geth account new --datadir data @@ -474,8 +471,4 @@ The same steps can then be repeated to attach a console to Node 2. ## Summary -This page explored the various options for configuring a local private network. A step by step guide showed how to set up and launch a private network, unlock the associated accounts, attach a console to check the network status and make some basic interactions. - - - -[gaslimit-chart]: https://etherscan.io/chart/gaslimit +This page explored the various options for configuring a local private network. A step by step guide showed how to set up and launch a private network, unlock the associated accounts, attach a console to check the network status and make some basic interactions. \ No newline at end of file diff --git a/content/docs/developers/geth-developer/code-review-guidelines.md b/content/docs/developers/geth-developer/code-review-guidelines.md index bdb4e12ab7..873cb64919 100644 --- a/content/docs/developers/geth-developer/code-review-guidelines.md +++ b/content/docs/developers/geth-developer/code-review-guidelines.md @@ -1,107 +1,72 @@ --- title: Code Review Guidelines -sort_key: B +description: Explanation of how code PRs are reviewed --- -The only way to get code into Geth is to submit a pull request (PR). Those pull requests -need to be reviewed by someone. This document is a guide that explains our expectations -around PRs for both authors and reviewers. +The only way to get code into Geth is to submit a pull request (PR). Those pull requests need to be reviewed by someone. This document is a guide that explains our expectations around PRs for both authors and reviewers. ## Terminology -* The **author** of a pull request is the entity who wrote the diff and submitted it to - GitHub. +* The **author** of a pull request is the entity who wrote the diff and submitted it to GitHub. * The **team** consists of people with commit rights on the go-ethereum repository. -* The **reviewer** is the person assigned to review the diff. The reviewer must be a team - member. +* The **reviewer** is the person assigned to review the diff. The reviewer must be a team member. * The **code owner** is the person responsible for the subsystem being modified by the PR. ## The Process -The first decision to make for any PR is whether it's worth including at all. This -decision lies primarily with the code owner, but may be negotiated with team members. +The first decision to make for any PR is whether it's worth including at all. This decision lies primarily with the code owner, but may be negotiated with team members. -To make the decision we must understand what the PR is about. If there isn't enough -description content or the diff is too large, request an explanation. Anyone can do this -part. +To make the decision we must understand what the PR is about. If there isn't enough description content or the diff is too large, request an explanation. Anyone can do this part. -We expect that reviewers check the style and functionality of the PR, providing comments -to the author using the GitHub review system. Reviewers should follow up with the PR until -it is in good shape, then **approve** the PR. Approved PRs can be merged by any code owner. +We expect that reviewers check the style and functionality of the PR, providing comments to the author using the GitHub review system. Reviewers should follow up with the PR until it is in good shape, then **approve** the PR. Approved PRs can be merged by any code owner. When communicating with authors, be polite and respectful. ### Code Style -We expect `gofmt`ed code. For contributions of significant size, we expect authors to -understand and use the guidelines in [Effective Go][effgo]. Authors should avoid common -mistakes explained in the [Go Code Review Comments][revcomment] page. +We expect `gofmt`ed code. For contributions of significant size, we expect authors to understand and use the guidelines in [Effective Go](https://golang.org/doc/effective_go.html). Authors should avoid common mistakes explained in the [Go Code Review Comments](https://github.com/golang/go/wiki/CodeReviewComments) page. ### Functional Checks -For PRs that fix an issue, reviewers should try reproduce the issue and verify that the -pull request actually fixes it. Authors can help with this by including a unit test that -fails without (and passes with) the change. +For PRs that fix an issue, reviewers should try reproduce the issue and verify that the pull request actually fixes it. Authors can help with this by including a unit test that fails without (and passes with) the change. -For PRs adding new features, reviewers should attempt to use the feature and comment on -how it feels to use it. Example: if a PR adds a new command line flag, use the program -with the flag and comment on whether the flag feels useful. +For PRs adding new features, reviewers should attempt to use the feature and comment on how it feels to use it. Example: if a PR adds a new command line flag, use the program with the flag and comment on whether the flag feels useful. -We expect appropriate unit test coverage. Reviewers should verify that new code is covered -by unit tests. +We expect appropriate unit test coverage. Reviewers should verify that new code is covered by unit tests. ### CI -Code submitted must pass all unit tests and static analysis ("lint") checks. We use Travis -CI to test code on Linux, macOS and AppVeyor to test code on Microsoft Windows. +Code submitted must pass all unit tests and static analysis ("lint") checks. We use Travis CI to test code on Linux, macOS and AppVeyor to test code on Microsoft Windows. -For failing CI builds, the issue may not be related to the PR itself. Such failures are -usually related to flakey tests. These failures can be ignored (authors don't need to fix -unrelated issues), but please file a GH issue so the test gets fixed eventually. +For failing CI builds, the issue may not be related to the PR itself. Such failures are usually related to flakey tests. These failures can be ignored (authors don't need to fix unrelated issues), but please file a GH issue so the test gets fixed eventually. ### Commit Messages -Commit messages on the master branch should follow the rule below. PR authors are not -required to use any particular style because the message can be modified at merge time. -Enforcing commit message style is the responsibility of the person merging the PR. +Commit messages on the master branch should follow the rule below. PR authors are not required to use any particular style because the message can be modified at merge time. Enforcing commit message style is the responsibility of the person merging the PR. The commit message style we use is similar to the style used by the Go project: -The first line of the change description is conventionally a one-line summary of the -change, prefixed by the primary affected Go package. It should complete the sentence "This -change modifies go-ethereum to _____." The rest of the description elaborates and should -provide context for the change and explain what it does. +The first line of the change description is conventionally a one-line summary of the change, prefixed by the primary affected Go package. It should complete the sentence "This change modifies go-ethereum to _____." The rest of the description elaborates and should provide context for the change and explain what it does. Template: ```text package/path: change XYZ -Longer explanation of the change in the commit. You can use -multiple sentences here. It's usually best to include content -from the PR description in the final commit message. - +Longer explanation of the change in the commit. You can use multiple sentences here. It's usually best to include content from the PR description in the final commit message. + issue notices, e.g. "Fixes #42353". ``` ### Special Situations And How To Deal With Them -Reviewers may find themselves in one of the sitations below. Here's how to deal -with them: +Reviewers may find themselves in one of the sitations below. Here's how to deal with them: -* The author doesn't follow up: ping them after a while (i.e. after a few days). If there - is no further response, close the PR or complete the work yourself. +* The author doesn't follow up: ping them after a while (i.e. after a few days). If there is no further response, close the PR or complete the work yourself. -* Author insists on including refactoring changes alongside bug fix: We can tolerate small - refactorings alongside any change. If you feel lost in the diff, ask the author to - submit the refactoring as an independent PR, or at least as an independent commit in the - same PR. +* Author insists on including refactoring changes alongside bug fix: We can tolerate small refactorings alongside any change. If you feel lost in the diff, ask the author to submit the refactoring as an independent PR, or at least as an independent commit in the same PR. -* Author keeps rejecting feedback: reviewers have authority to reject any change for technical reasons. -If you're unsure, ask the team for a second opinion. The PR can be closed if no consensus can be reached. - -[effgo]: https://golang.org/doc/effective_go.html -[revcomment]: https://github.com/golang/go/wiki/CodeReviewComments +* Author keeps rejecting feedback: reviewers have authority to reject any change for technical reasons. If you're unsure, ask the team for a second opinion. The PR can be closed if no consensus can be reached. diff --git a/content/docs/developers/geth-developer/dev-mode.md b/content/docs/developers/geth-developer/dev-mode.md index e8d131c876..7e3273150d 100644 --- a/content/docs/developers/geth-developer/dev-mode.md +++ b/content/docs/developers/geth-developer/dev-mode.md @@ -1,6 +1,6 @@ --- title: Developer mode -sort_key: B +description: Instructions for setting up Geth in developer mode --- It is often convenient for developers to work in an environment where changes to client or application software can be deployed and tested rapidly and without putting real-world users or assets at risk. For this purpose, Geth has a `--dev` flag that spins up Geth in "developer mode". This creates a single-node Ethereum test network with no connections to any external peers. It exists solely on the local machine. Starting Geth in developer mode does the following: diff --git a/content/docs/developers/geth-developer/devguide.md b/content/docs/developers/geth-developer/devguide.md index 6df219959c..bcf0d7d9fc 100644 --- a/content/docs/developers/geth-developer/devguide.md +++ b/content/docs/developers/geth-developer/devguide.md @@ -1,27 +1,20 @@ --- title: Getting Started -sort_key: A +description: Entry point for developers working on Geth --- -This document is the entry point for developers who wish to work on Geth. -Developers are people who are interested to build, develop, debug, submit +This document is the entry point for developers who wish to work on Geth. Developers are people who are interested to build, develop, debug, submit a bug report or pull request or otherwise contribute to the Geth source code. -Please see [Contributing](/content/docs/developers/contributing.md) for the -Geth contribution guidelines. +Please see [Contributing](/content/docs/developers/contributing.md) for the Geth contribution guidelines. ## Building and Testing -Developers should use a recent version of Go for building and testing. We use the go -toolchain for development, which you can get from the [Go downloads page][go-install]. - -Geth is a Go module, and uses the [Go modules system][go-modules] to manage -dependencies. Using `GOPATH` is not required to build go-ethereum. +Developers should use a recent version of Go for building and testing. We use the go toolchain for development, which you can get from the [Go downloads page](https://golang.org/doc/install). Geth is a Go module, and uses the [Go modules system](https://github.com/golang/go/wiki/Modules) to manage dependencies. Using `GOPATH` is not required to build go-ethereum. ### Building Executables -Switch to the go-ethereum repository root directory. -All code can be built using the go tool, placing the resulting binary in `$GOPATH/bin`. +Switch to the go-ethereum repository root directory. All code can be built using the go tool, placing the resulting binary in `$GOPATH/bin`. ```text go install -v ./... @@ -49,8 +42,7 @@ Running an individual test: go test -v ./eth -run TestMethod ``` -**Note**: here all tests with prefix _TestMethod_ will be run, so if TestMethod and -TestMethod1 both exist then both tests will run. +**Note**: here all tests with prefix _TestMethod_ will be run, so if TestMethod and TestMethod1 both exist then both tests will run. Running benchmarks, eg.: @@ -58,19 +50,13 @@ Running benchmarks, eg.: go test -v -bench . -run BenchmarkJoin ``` -For more information, see the [go test flags][testflag] documentation. +For more information, see the [go test flags](https://golang.org/cmd/go/#hdr-Testing_flags) documentation. ### Stack Traces -If Geth is started with the `--pprof` option, a debugging HTTP server is made available -on port 6060. Navigating to displays the heap, -running routines etc. By clicking "full goroutine stack dump" a trace can be generated -that is useful for debugging. +If Geth is started with the `--pprof` option, a debugging HTTP server is made available on port 6060. Navigating to displays the heap, running routines etc. By clicking "full goroutine stack dump" a trace can be generated that is useful for debugging. -Note that if multiple instances of Geth exist, port `6060` will only work for the first -instance that was launched. To generate stacktraces for other instances, -they should be started up with alternative pprof ports. Ensure `stderr` is being -redirected to a logfile. +Note that if multiple instances of Geth exist, port `6060` will only work for the first instance that was launched. To generate stacktraces for other instances, they should be started up with alternative pprof ports. Ensure `stderr` is being redirected to a logfile. ``` geth -port=30300 -verbosity 5 --pprof --pprof.port 6060 2>> /tmp/00.glog @@ -78,8 +64,7 @@ geth -port=30301 -verbosity 5 --pprof --pprof.port 6061 2>> /tmp/01.glog geth -port=30302 -verbosity 5 --pprof --pprof.port 6062 2>> /tmp/02.glog ``` -Alternatively to kill the clients (in case they hang or stalled syncing, etc) -and have the stacktrace too, use the `-QUIT` signal with `kill`: +Alternatively to kill the clients (in case they hang or stalled syncing, etc) and have the stacktrace too, use the `-QUIT` signal with `kill`: ``` killall -QUIT geth @@ -87,10 +72,8 @@ killall -QUIT geth This will dump stack traces for each instance to their respective log file. -[install-guide]: ../install-and-build/installing-geth -[code-review]: ../developers/code-review-guidelines -[cross-compile]: ../install-and-build/cross-compile -[go-modules]: https://github.com/golang/go/wiki/Modules -[discord]: https://discord.gg/invite/nthXNEv -[go-install]: https://golang.org/doc/install -[testflag]: https://golang.org/cmd/go/#hdr-Testing_flags + +## Where to go next + +Read the remaning pages in the Geth developer section, and get building! + diff --git a/content/docs/developers/geth-developer/dns-discovery-setup.md b/content/docs/developers/geth-developer/dns-discovery-setup.md index d13a4bf8cf..26186c082a 100644 --- a/content/docs/developers/geth-developer/dns-discovery-setup.md +++ b/content/docs/developers/geth-developer/dns-discovery-setup.md @@ -1,27 +1,21 @@ --- title: DNS Discovery Setup Guide -sort_key: C +description: Instructions for setting up DNS discovery --- -This document explains how to set up an [EIP 1459][dns-eip] node list using the devp2p -developer tool. The focus of this guide is creating a public list for the Ethereum mainnet -and public testnets, but it may also be helpful for setting up DNS-based discovery for a -private network. +This document explains how to set up an [EIP 1459](https://eips.ethereum.org/EIPS/eip-1459) node list using the devp2p developer tool. The focus of this guide is creating a public list for the Ethereum mainnet and public testnets, but it may also be helpful for setting up DNS-based discovery for a private network. -DNS-based node lists can serve as a fallback option when connectivity to the discovery DHT -is unavailable. In this guide, node lists will be created by crawling the discovery DHT, then -publishing the resulting node sets under chosen DNS names. +DNS-based node lists can serve as a fallback option when connectivity to the discovery DHT is unavailable. In this guide, node lists will be reated by crawling the discovery DHT, then publishing the resulting node sets under chosen DNS names. ### Installing the devp2p command -`cmd/devp2p` is a developer utility and is not included in the Geth distribution. You can -install this command using `go get`: +`cmd/devp2p` is a developer utility and is not included in the Geth distribution. You can install this command using `go get`: ```shell go get github.com/ethereum/go-ethereum/cmd/devp2p ``` -To create a signing key, you might also need the `ethkey` utility. +To create a signing key, the `ethkey` utility is needed. ```shell go get github.com/ethereum/go-ethereum/cmd/ethkey @@ -29,9 +23,7 @@ go get github.com/ethereum/go-ethereum/cmd/ethkey ### Crawling the v4 DHT -Our first step is to compile a list of all reachable nodes. The DHT crawler in cmd/devp2p -is a batch process which runs for a set amount of time. You should should schedule this command -to run at a regular interval. To create a node list, run +Our first step is to compile a list of all reachable nodes. The DHT crawler in cmd/devp2p is a batch process which runs for a set amount of time. You should should schedule this command to run at a regular interval. To create a node list, run ```shell devp2p discv4 crawl -timeout 30m all-nodes.json @@ -73,53 +65,36 @@ The following filter flags are available: ### Creating DNS trees -To turn a node list into a DNS node tree, the list needs to be signed. To do this, you -need a key pair. To create the key file in the correct format, you can use the cmd/ethkey -utility. Please choose a good password to encrypt the key on disk. +To turn a node list into a DNS node tree, the list needs to be signed. To do this, a key pair is required. To create the key file in the correct format, the cmd/ethkey utility should be used. Choose a strong password to encrypt the key on disk! ```shell ethkey generate dnskey.json ``` -Now use `devp2p dns sign` to update the signature of the node list. If your list's -directory name differs from the name you want to publish it at, please specify the DNS -name the using the `-domain` flag. This command will prompt for the key file password and -update the tree signature. +Now use `devp2p dns sign` to update the signature of the node list. If the list's directory name differs from the name it will be published at,specify the DNS name the using the `-domain` flag. This command will prompt for the key file password and update the tree signature. ```shell devp2p dns sign mainnet.nodes.example.org dnskey.json ``` -The resulting DNS tree metadata is stored in the -`mainnet.nodes.example.org/enrtree-info.json` file. +The resulting DNS tree metadata is stored in the `mainnet.nodes.example.org/enrtree-info.json` file. ### Publishing DNS trees -Now that the tree is signed, it can be published to a DNS provider. cmd/devp2p currently -supports publishing to CloudFlare DNS and Amazon Route53. You can also export TXT records -as a JSON file and publish them yourself. +Now that the tree is signed, it can be published to a DNS provider. cmd/devp2p currently supports publishing to CloudFlare DNS and Amazon Route53.TXT records can also be exported as a JSON file and published independently. -To publish to CloudFlare, first create an API token in the management console. cmd/devp2p -expects the API token in the `CLOUDFLARE_API_TOKEN` environment variable. Now use the -following command to upload DNS TXT records via the CloudFlare API: +To publish to CloudFlare, first create an API token in the management console. cmd/devp2p expects the API token in the `CLOUDFLARE_API_TOKEN` environment variable. Now use the following command to upload DNS TXT records via the CloudFlare API: ```shell devp2p dns to-cloudflare mainnet.nodes.example.org ``` -Note that this command uses the domain name specified during signing. Any existing records -below this name will be erased by cmd/devp2p. +Note that this command uses the domain name specified during signing. Any existing records below this name will be erased by cmd/devp2p. ### Using DNS trees with Geth -Once your tree is available through a DNS name, you can tell geth to use it with the -`--discovery.dns` command line flag. Node trees are referenced using the `enrtree://` URL -scheme. You can find the URL of your tree in the `enrtree-info.json` file created by -`devp2p dns sign`. Just pass the URL as an argument to the flag in order to make use of -the published tree. +Once a tree is available through a DNS name, Geth can use it with the `--discovery.dns` command line flag. Node trees are referenced using the `enrtree://` URL scheme. The URL of the tree can be found in the `enrtree-info.json` file created by `devp2p dns sign`. Pass the URL as an argument to the flag in order to make use of the published tree. ```shell geth --discovery.dns "enrtree://AMBMWDM3J6UY3M32TMMROUNLX6Y3YTLVC3DC6HN2AVG5NHNSAXDW6@mainnet.nodes.example.org" ``` - -[dns-eip]: https://eips.ethereum.org/EIPS/eip-1459 diff --git a/content/docs/developers/geth-developer/issue-handling-workflow.md b/content/docs/developers/geth-developer/issue-handling-workflow.md index 9fb2bdc180..bc348b186f 100644 --- a/content/docs/developers/geth-developer/issue-handling-workflow.md +++ b/content/docs/developers/geth-developer/issue-handling-workflow.md @@ -1,19 +1,19 @@ --- title: Issue Handling Workflow -sort_key: B +description: Instructions for managing Github issues --- -### (Draft proposal) +### Draft proposal -Keep the number of open issues under 820 +* Keep the number of open issues under 820 -Keep the ratio of open issues per all issues under 13% +* Keep the ratio of open issues per all issues under 13% -Have 50 issues labelled [help wanted](https://github.com/ethereum/go-ethereum/labels/help%20wanted) and 50 [good first issue](https://github.com/ethereum/go-ethereum/labels/good%20first%20issue). +* Have 50 issues labelled [help wanted](https://github.com/ethereum/go-ethereum/labels/help%20wanted) and 50 [good first issue](https://github.com/ethereum/go-ethereum/labels/good%20first%20issue). -Use structured labels of the form `:

/`, for example `area: plugins/foobuzzer`. +* Use structured labels of the form `:
/`, for example `area: plugins/foobuzzer`. -Use the following labels. Areas and statuses depend on the application and workflow. +* Use the following labels. Areas and statuses depend on the application and workflow. - area - `area: android` - `area: clef` @@ -46,12 +46,15 @@ It's ok to not set a due date for a milestone, but once you release it, close it Optionally, use a project board to collect issues of a larger effort that has an end state and overarches multiple releases. ## Workflow -We have a weekly or bi-weekly triage meeting. Issues are preselected by [labelling them "status:triage" and sorted the oldest ones first](https://github.com/ethereum/go-ethereum/issues?q=is%3Aopen+is%3Aissue+label%3Astatus%3Atriage+sort%3Acreated-asc). This is when we go through the new issues and do one of the following + +The Geth core team hold a weekly or bi-weekly triage meeting. Issues are preselected by [labelling them "status:triage" and sorted the oldest ones first](https://github.com/ethereum/go-ethereum/issues?q=is%3Aopen+is%3Aissue+label%3Astatus%3Atriage+sort%3Acreated-asc). This is when the team goes through the new issues and do one of the following + 1. Close it. -1. Assign it to "Coming soon" milestone which doesn't have an end date. -1. Move it to the "Future" milestone. -1. Change its status to "Need:\". +2. Assign it to "Coming soon" milestone which doesn't have an end date. +3. Move it to the "Future" milestone. +4. Change its status to "Need:\". Optional further activities: + * Label the issue with the appropriate area/component. * Add a section to the FAQ or add a wiki page. Link to it from the issue. diff --git a/content/docs/developers/geth-developer/vulnerabilities.md b/content/docs/developers/geth-developer/vulnerabilities.md index 05165b4be9..fb4a96ff3c 100644 --- a/content/docs/developers/geth-developer/vulnerabilities.md +++ b/content/docs/developers/geth-developer/vulnerabilities.md @@ -1,49 +1,31 @@ --- title: Vulnerability disclosure -sort_key: A +description: Instructions for disclosing vulnerabilities to the Geth team --- -In the software world, it is expected for security vulnerabilities to be immediately -announced, thus giving operators an opportunity to take protective measure against -attackers. +In the software world, it is expected for security vulnerabilities to be immediately announced, thus giving operators an opportunity to take protective measure against attackers. Vulnerabilies typically take two forms: -1. Vulnerabilies that, if exploited, would harm the software operator. In the case of - Geth, examples would be: +1. Vulnerabilies that, if exploited, would harm the software operator. In the case of Geth, examples would be: - A bug that would allow remote reading or writing of OS files, or - Remote command execution, or - Bugs that would leak cryptographic keys -2. Vulnerabilies that, if exploited, would harm the Ethereum mainnet. In the case of - Geth, examples would be: +2. Vulnerabilies that, if exploited, would harm the Ethereum mainnet. In the case of Geth, examples would be: - Consensus vulnerabilities, which would cause a chain split, - Denial-of-service during block processing, whereby a malicious transaction could cause the geth-portion of the network to crash. - Denial-of-service via p2p networking, whereby portions of the network could be made inaccessible due to crashes or resource consumption. -In most cases so far, vulnerabilities in Geth have been of the second type, where the -health of the network is a concern, rather than individual node operators. For such -issues, we reserve the right to silently patch and ship fixes in new releases. +In most cases so far, vulnerabilities in Geth have been of the second type, where the health of the network is a concern, rather than individual node operators. For such issues, Geth reserves the right to silently patch and ship fixes in new releases. ### Why silent patches -In the case of Ethereum, it takes a lot of time (weeks, months) to get node operators to -update even to a scheduled hard fork. If we were to highlight that a release contains -important consensus or DoS fixes, there is always a risk of someone trying to beat node -operators to the punch, and exploit the vulnerability. Delaying a potential attack -sufficiently to make the majority of node operators immune may be worth the temporary loss -of transparency. +In the case of Ethereum, it takes a lot of time (weeks, months) to get node operators to update even to a scheduled hard fork. If we were to highlight that a release contains important consensus or DoS fixes, there is always a risk of someone trying to beat node operators to the punch, and exploit the vulnerability. Delaying a potential attack sufficiently to make the majority of node operators immune may be worth the temporary loss of transparency. -The primary goal for the Geth team is the health of the Ethereum network as a whole, and -the decision whether or not to publish details about a serious vulnerability boils down to -minimizing the risk and/or impact of discovery and exploitation. +The primary goal for the Geth team is the health of the Ethereum network as a whole, and the decision whether or not to publish details about a serious vulnerability boils down to minimizing the risk and/or impact of discovery and exploitation. -At certain times, it's better to remain silent. This practice is also followed by other -projects such as -[Monero](https://www.getmonero.org/2017/05/17/disclosure-of-a-major-bug-in-cryptonote-based-currencies.html), -[ZCash](https://electriccoin.co/blog/zcash-counterfeiting-vulnerability-successfully-remediated/) -and -[Bitcoin](https://www.coindesk.com/the-latest-bitcoin-bug-was-so-bad-developers-kept-its-full-details-a-secret). +At certain times, it's better to remain silent. This practice is also followed by other projects such as [Monero](https://www.getmonero.org/2017/05/17/disclosure-of-a-major-bug-in-cryptonote-based-currencies.html), [ZCash](https://electriccoin.co/blog/zcash-counterfeiting-vulnerability-successfully-remediated/) and [Bitcoin](https://www.coindesk.com/the-latest-bitcoin-bug-was-so-bad-developers-kept-its-full-details-a-secret). ### Public transparency @@ -53,26 +35,19 @@ As of November 2020, our policy going forward is: - After 4-8 weeks, we will disclose that `X` contained a security-fix. - After an additional 4-8 weeks, we will publish the details about the vulnerability. -We hope that this provides sufficient balance between transparency versus the need for -secrecy, and aids node operators and downstream projects in keeping up to date with what -versions to run on their infrastructure. +We hope that this provides sufficient balance between transparency versus the need for secrecy, and aids node operators and downstream projects in keeping up to date with what versions to run on their infrastructure. In keeping with this policy, we have taken inspiration from [Solidity bug disclosure](https://solidity.readthedocs.io/en/develop/bugs.html) - see below. ## Disclosed vulnerabilities -On the Geth Github can find a JSON-formatted list ([`vulnerabilities.json`](vulnerabilities.json)) -of some of the known security-relevant vulnerabilities concerning Geth. +On the Geth Github can find a JSON-formatted list ([`vulnerabilities.json`](vulnerabilities.json)) of some of the known security-relevant vulnerabilities concerning Geth. -As of version `1.9.25`, Geth has a built-in command to check whether it is affected by any publically disclosed vulnerability, -using the command `geth version-check`. This command will fetch the latest json file (and the accompanying -[signature-file](vulnerabilities.json.minisig), and cross-check the data against it's own -version number. +As of version `1.9.25`, Geth has a built-in command to check whether it is affected by any publically disclosed vulnerability, using the command `geth version-check`. This command will fetch the latest json file (and the accompanying [signature-file](vulnerabilities.json.minisig), and cross-check the data against it's own version number. The list of vulnerabilities was started in November 2020, and covers mainly `v1.9.7` and forward. -The JSON file of known vulnerabilities below is a list of objects, one for each -vulnerability, with the following keys: +The JSON file of known vulnerabilities below is a list of objects, one for each vulnerability, with the following keys: - `name` - Unique name given to the vulnerability. @@ -101,8 +76,6 @@ vulnerability, with the following keys: ### What about Github security advisories -We prefer to not rely on Github as the only/primary publishing protocol for security -advisories, but we plan to use the Github-advisory process as a second channel for -disseminating vulnerability-information. +We prefer to not rely on Github as the only/primary publishing protocol for security advisories, but we plan to use the Github-advisory process as a second channel for disseminating vulnerability-information. Advisories published via Github can be accessed [here](https://github.com/ethereum/go-ethereum/security/advisories?state=published). From f3026eacf3d81bab4d0573b944ee93fc7e1e877c Mon Sep 17 00:00:00 2001 From: Joe Date: Fri, 19 Aug 2022 15:19:46 +0100 Subject: [PATCH 037/432] more markdown formatting --- content/docs/fundamentals/Backup--restore.md | 26 +--- .../docs/fundamentals/Command-Line-Options.md | 8 +- .../docs/fundamentals/account-management.md | 142 ++++-------------- content/docs/fundamentals/les.md | 2 +- .../docs/fundamentals/node-architecture.md | 37 +---- content/docs/fundamentals/peer-to-peer.md | 19 +-- content/docs/fundamentals/security.md | 7 +- content/docs/tools/Clef/CliqueSigning.md | 44 +++--- 8 files changed, 81 insertions(+), 204 deletions(-) diff --git a/content/docs/fundamentals/Backup--restore.md b/content/docs/fundamentals/Backup--restore.md index 1534d360a4..dbbd005a98 100644 --- a/content/docs/fundamentals/Backup--restore.md +++ b/content/docs/fundamentals/Backup--restore.md @@ -1,30 +1,23 @@ --- title: Backup & Restore +description: How to backup and restore keyfiles and blockchain data --- **Keep secure backups of your keystore and password!** ## Data Directory -All data relating to a specific Geth instance gets written inside a data directory. -The default data directory locations are platform specific: +All data relating to a specific Geth instance gets written inside a data directory. The default data directory locations are platform specific: * Mac: `~/Library/Ethereum` * Linux: `~/.ethereum` * Windows: `%LOCALAPPDATA%\Ethereum` -Accounts are stored in the `keystore` subdirectory. The contents of this directories -should be transportable between nodes, platforms, and client implementations. +Accounts are stored in the `keystore` subdirectory. The contents of this directories should be transportable between nodes, platforms, and client implementations. -To configure the location of the data directory, the `--datadir` parameter can be -specified. See [CLI Options](../interface/command-line-options) for more details. -There may exist multiple data directories for multiple networks (e.g. a separate directory -for Ethereum Mainnet and the Goerli testnet). Each would have subdirectories for their -blockchain data and keystore. +To configure the location of the data directory, the `--datadir` parameter can be specified. See [CLI Options](../interface/command-line-options) for more details. There may exist multiple data directories for multiple networks (e.g. a separate directory for Ethereum Mainnet and the Goerli testnet). Each would have subdirectories for their blockchain data and keystore. -It is important to backup the files in the keystore securely. These files are encrypted -using an account password. This needs to be securely backed up too. There is no way to -decrypt the keys without the password! +It is important to backup the files in the keystore securely. These files are encrypted using an account password. This needs to be securely backed up too. There is no way to decrypt the keys without the password! ## Cleanup @@ -34,8 +27,7 @@ Geth's blockchain and state databases can be removed with: geth removedb ``` -This is useful for deleting an old chain and sync'ing to a new one. It only affects data -directories that can be re-created on synchronisation and does not touch the keystore. +This is useful for deleting an old chain and sync'ing to a new one. It only affects data directories that can be re-created on synchronisation and does not touch the keystore. ## Blockchain Import/Export @@ -45,15 +37,13 @@ Export the blockchain in binary format with: geth export ``` -Or if you want to back up portions of the chain over time, a first and last block can be -specified. For example, to back up the first epoch: +Or if you want to back up portions of the chain over time, a first and last block can be specified. For example, to back up the first epoch: ```sh geth export 0 29999 ``` -Note that when backing up a partial chain, the file will be appended rather than -truncated. +Note that when backing up a partial chain, the file will be appended rather than truncated. Import binary-format blockchain exports with: diff --git a/content/docs/fundamentals/Command-Line-Options.md b/content/docs/fundamentals/Command-Line-Options.md index c0c610948b..8d88c272d4 100644 --- a/content/docs/fundamentals/Command-Line-Options.md +++ b/content/docs/fundamentals/Command-Line-Options.md @@ -1,12 +1,10 @@ --- title: Command-line Options -sort_key: A +description: A list of commands for Geth --- -Geth is primarily controlled using the command line. Geth is started using the `geth` command. -Geth is stopped by pressing `ctrl-c`. There are then many combinations of commands that configure -precisely how geth will run. These commands are displayed below. The same information can be -obtained at any time from your Geth instance by running +Geth is primarily controlled using the command line. Geth is started using the `geth` command. Geth is stopped by pressing `ctrl-c`. There are then many combinations of commands that configure precisely how geth will run. These commands are displayed below. The same information can be +obtained at any time from your Geth instance by running: ```sh geth --help diff --git a/content/docs/fundamentals/account-management.md b/content/docs/fundamentals/account-management.md index b38ee22293..ff990d2a92 100644 --- a/content/docs/fundamentals/account-management.md +++ b/content/docs/fundamentals/account-management.md @@ -1,18 +1,14 @@ --- title: Account Management -sort_key: C +description: Guide to basic account management using Geth's built-in tools --- -The recommended practise for managing accounts in Geth is to use Clef. However, Geth also has its own, convenient -account management tools. Eventually, these built in tools will be deprecated in favour of using Clef as the -default account manager. This page describes account management using Geth's built-in tools. It is recommended to -also visit the following pages that explain how to use Clef. +The recommended practise for managing accounts in Geth is to use Clef. However, Geth also has its own, convenient account management tools. Eventually, these built in tools will be deprecated in favour of using Clef as the default account manager. This page describes account management using Geth's built-in tools. It is recommended to also visit the following pages that explain how to use Clef. - [Getting started with Clef](/content/docs/getting_started/getting-started-with-clef.md) - [Introduction to Clef](/content/docs/tools/Clef/Introduction.md) - [Clef tutorial](/content/docs/tools/Clef/Tutorial.md) - ## Account command Geth's `account` command is used to interact with accounts: @@ -21,13 +17,7 @@ Geth's `account` command is used to interact with accounts: geth account [options...] [arguments...] ``` -The account command enables the user to create new accounts, list existing -accounts, import private keys into a new account, update key formats and update -the passwords that lock each account. In interactive mode, the user is prompted -for passwords in the console when the `account` functions are invoked, whereas -in non-interactive mode passwords to unlock accounts are saved to text files -whose path is passed to Geth at startup. Non-interactive mode is only intended -for use on private networks or known safe environments. +The account command enables the user to create new accounts, list existing accounts, import private keys into a new account, update key formats and update the passwords that lock each account. In interactive mode, the user is prompted for passwords in the console when the `account` functions are invoked, whereas in non-interactive mode passwords to unlock accounts are saved to text files whose path is passed to Geth at startup. Non-interactive mode is only intended for use on private networks or known safe environments. The `account` subcommands are: @@ -39,8 +29,7 @@ COMMANDS: import Import a private key into a new account ``` -Information about the subcommands can be displayed in the terminal using -`geth account --help`. For example, for the `list` subcommand: +Information about the subcommands can be displayed in the terminal using `geth account --help`. For example, for the `list` subcommand: ``` $ geth account list --help @@ -53,14 +42,11 @@ OPTIONS: --keystore Directory for the keystore (default = inside the datadir) ``` - ## Creating new accounts -New accounts can be created using `account new`. This generates a new key -pair and adds them to the `keystore` directory in the `datadir`. To +New accounts can be created using `account new`. This generates a new key pair and adds them to the `keystore` directory in the `datadir`. To create a new account in the default data directory: - ```shell $ geth account new ``` @@ -74,28 +60,19 @@ Repeat Passphrase: Address: {168bc315a2ee09042d83d7c5811b533620531f67} ``` -It is critical to backup the account password safely and securely as it cannot -be retrieved or reset. +It is critical to backup the account password safely and securely as it cannot be retrieved or reset. -{% include note.html content=" If the password provided on account creation is lost -or forgotten, there is no way to retrive it and the account will simply stay locked -forever. The password MUST be backed up safely and securely! +{% include note.html content=" If the password provided on account creation is lost or forgotten, there is no way to retrive it and the account will simply stay locked forever. The password MUST be backed up safely and securely! **IT IS CRITICAL TO BACKUP THE KEYSTORE AND REMEMBER PASSWORDS**" %} -The newly generated key files can be viewed in `/keystore/`. The file naming -format is `UTC----
` where `date` is the date and time of key creation -formatted according to [UTC 8601](https://www.iso.org/iso-8601-date-and-time-format.html) -with zero time offset and seconds precise to eight decimal places. `address` is the 40 -hexadecimal characters that make up the account address without a leading `0x`, for example: +The newly generated key files can be viewed in `/keystore/`. The file naming format is `UTC----
` where `date` is the date and time of key creation formatted according to [UTC 8601](https://www.iso.org/iso-8601-date-and-time-format.html) with zero time offset and seconds precise to eight decimal places. `address` is the 40 hexadecimal characters that make up the account address without a leading `0x`, for example: `UTC--2022-05-19T12-34-36.47413510Z--0b85e5a13e118466159b1e1b6a4234e5f9f784bb` ## Listing Accounts -Listing all existing accounts is achieved using the `account list` command. If the -keystore is located anywhere other than the default location its path should be -included with the `keystore` flag. For example, if the datadir is `some-dir`: +Listing all existing accounts is achieved using the `account list` command. If the keystore is located anywhere other than the default location its path should be included with the `keystore` flag. For example, if the datadir is `some-dir`: ```shell geth account list --keystore some-dir/keystore @@ -108,27 +85,15 @@ Account 0: {5afdd78bdacb56ab1dad28741ea2a0e47fe41331} keystore:///tmp/mykeystore Account 1: {9acb9ff906641a434803efb474c96a837756287f} keystore:///tmp/mykeystore/UTC--2017-04-28T08-46-52.180688336Z--9acb9ff906641a434803efb474c96a837756287f ``` -The ordering of accounts when they are listed is lexicographic, but is effectively -chronological based on time of creation due to the timestamp in the file name. It is -safe to transfer the entire `keystore` directory or individual key files between -Ethereum nodes. This is important because when accounts are added from other nodes -the order of accounts in the keystore may change. It is therefore important not to -rely on account indexes in scripts or code snippets. +The ordering of accounts when they are listed is lexicographic, but is effectively chronological based on time of creation due to the timestamp in the file name. It is safe to transfer the entire `keystore` directory or individual key files between Ethereum nodes. This is important because when accounts are added from other nodes the order of accounts in the keystore may change. It is therefore important not to rely on account indexes in scripts or code snippets. ## Importing accounts ### Import a keyfile -It is also possible to create a new account by importing a private key. For example, -a user might already have some ether at an address they created using a browser wallet -and now wish to use a new Geth node to interact with their funds. In this case, the -private key can be exported from the browser wallet and imported into Geth. Geth requires -the private key to be stored as a file which contains the private key as unencrypted -canonical elliptic curve bytes encoded into hex (i.e. plain text key without leading 0x). -The new account is then saved in encrypted format, protected by a passphrase the user -provides on request. As always, this passphrase must be securely and safely backed -up - there is no way to retrieve or reset it if it is forgotten! +It is also possible to create a new account by importing a private key. For example, a user might already have some ether at an address they created using a browser wallet and now wish to use a new Geth node to interact with their funds. In this case, the private key can be exported from the browser wallet and imported into Geth. Geth requires the private key to be stored as a file which contains the private key as unencrypted +canonical elliptic curve bytes encoded into hex (i.e. plain text key without leading 0x). The new account is then saved in encrypted format, protected by a passphrase the user provides on request. As always, this passphrase must be securely and safely backed up - there is no way to retrieve or reset it if it is forgotten! ```shell $ geth account import --datadir /some-dir ./keyfile @@ -143,19 +108,14 @@ Repeat Passphrase: Address: {7f444580bfef4b9bc7e14eb7fb2a029336b07c9d} ``` -This import/export process is not necessary for transferring accounts between Geth -instances because the key files can simply be copied directly from one keystore to another. +This import/export process is not necessary for transferring accounts between Geth instances because the key files can simply be copied directly from one keystore to another. -It is also possible to import an account in non-interactive mode by saving the account -password as plaintext in a `.txt` file and passing its path with the `--password` flag -on startup. +It is also possible to import an account in non-interactive mode by saving the account password as plaintext in a `.txt` file and passing its path with the `--password` flag on startup. ```shell geth account import --password path/password.txt path/keyfile ``` -In this case, it is important to ensure the password file is not readable by anyone but -the intended user. This can be achieved by changing the file permissions. On Linux, the -following commands update the file permissions so only the current user has access: +In this case, it is important to ensure the password file is not readable by anyone but the intended user. This can be achieved by changing the file permissions. On Linux, the following commands update the file permissions so only the current user has access: ```shell chmod 700 /path/to/password @@ -165,20 +125,15 @@ cat > /path/to/password ### Import a presale wallet -Assuming the password is known, importing a presale wallet is very easy. The `wallet import` -commands are used, passing the path to the wallet. +Assuming the password is known, importing a presale wallet is very easy. The `wallet import` commands are used, passing the path to the wallet. ```shell geth wallet import /path/presale.wallet ``` - ## Updating accounts -The `account update` subcommand is used to unlock an account and migrate it to the newest -format. This is useful for accounts that may have been created in a format that has since -been deprecated. The same command can be used to update the account password. The current -password and account address are needed in order to update the account, as follows: +The `account update` subcommand is used to unlock an account and migrate it to the newest format. This is useful for accounts that may have been created in a format that has since been deprecated. The same command can be used to update the account password. The current password and account address are needed in order to update the account, as follows: ```shell geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b @@ -197,53 +152,37 @@ Repeat Passphrase: 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b ``` -Alternatively, in non-interactive mode the path to a password file containing the account -password in unencrypted plaintext can be passed with the `--password` flag: +Alternatively, in non-interactive mode the path to a password file containing the account password in unencrypted plaintext can be passed with the `--password` flag: ```shell geth account update a94f5374fce5edbc8e2a8697c15331677e6ebf0b --password path/password.txt ``` -Updating the account replaces the original file with a new one - this means the original -file is no longer available after it has been updated. +Updating the account replaces the original file with a new one - this means the original file is no longer available after it has been updated. ## Unlocking accounts -In Geth, accounts are locked unless they are explicitly unlocked. If an account is intended -to be used by apps connecting to Geth via RPC then it can be unlocked in non-interactive -mode by passing the `--unlock` flag with a comma-separated list of account addresses -(or keystore indexes) to unlock. This unlocks the accounts for one session only. Including -the `--unlock` flag without any account addresses defaults to unlocking the first account +In Geth, accounts are locked unless they are explicitly unlocked. If an account is intended to be used by apps connecting to Geth via RPC then it can be unlocked in non-interactive mode by passing the `--unlock` flag with a comma-separated list of account addresses (or keystore indexes) to unlock. This unlocks the accounts for one session only. Including the `--unlock` flag without any account addresses defaults to unlocking the first account in the keystore. ```shell geth --unlock 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b ``` -Geth will start and prompt the user to input the account password in the terminal. -Alternatively, the user can provide a password as a text file and pass its path to `--password`: +Geth will start and prompt the user to input the account password in the terminal. Alternatively, the user can provide a password as a text file and pass its path to `--password`: ```shell geth --unlock 0xa94f5374fce5edbc8e2a8697c15331677e6ebf0b --password path/password.txt ``` -{% include note.html content=" By default, -account **unlocking is forbidden when HTTP or Websocket access is enabled** (i.e. by -passing `--http` or `ws` flag). This is because an attacker that manages to access -the node via the externally-exposed HTTP/WS port can then control the unlocked account. -It is possible to force account unlock by including the `--allow-insecure-unlock` -flag but this is unsafe and **not recommended** except for expert users that completely -understand how it can be used safely. This is not a hypothetical risk: -**there are bots that continually scan for http-enabled Ethereum nodes to attack**" %} +{% include note.html content=" By default, account **unlocking is forbidden when HTTP or Websocket access is enabled** (i.e. by passing `--http` or `ws` flag). This is because an attacker that manages to access the node via the externally-exposed HTTP/WS port can then control the unlocked account. +It is possible to force account unlock by including the `--allow-insecure-unlock` flag but this is unsafe and **not recommended** except for expert users that completely understand how it can be used safely. This is not a hypothetical risk: **there are bots that continually scan for http-enabled Ethereum nodes to attack**" %} ## Accounts in the Javascript console -Account management can also be achieved in the Javascript console attached to a -running Geth instance. Assuming Geth is already running, in a new terminal attach -a Javascript console using the `geth.ipc` file. This file can be found in the data -directory. Assuming the data directory is named `data` the console can be started using: +Account management can also be achieved in the Javascript console attached to a running Geth instance. Assuming Geth is already running, in a new terminal attach a Javascript console using the `geth.ipc` file. This file can be found in the data directory. Assuming the data directory is named `data` the console can be started using: ```shell geth attach data/geth.ipc @@ -251,18 +190,13 @@ geth attach data/geth.ipc ### New accounts -New accounts can be generated using the Javascript console using `personal.newAccount()`. -A new password is requested in the console and successful account creation is confirmed -by the new account address being displayed. +New accounts can be generated using the Javascript console using `personal.newAccount()`. A new password is requested in the console and successful account creation is confirmed by the new account address being displayed. ```shell personal.newAccount() ``` -Accounts can also be created by importing private keys directly in the Javascript console. -The private key is passed as an unencrypted hex-encoded string to `personal.importRawKey()` -along with a passphrase that will be used to encrypt the key. A new key file will be -generated from the private key and saved to the keystore. +Accounts can also be created by importing private keys directly in the Javascript console. The private key is passed as an unencrypted hex-encoded string to `personal.importRawKey()` along with a passphrase that will be used to encrypt the key. A new key file will be generated from the private key and saved to the keystore. ```shell personal.importRawKey("hexstringkey", "password") @@ -270,8 +204,7 @@ personal.importRawKey("hexstringkey", "password") ### Listing accounts -The `accounts` function in the `eth` namespace can be used to list the accounts that -currently exist in the keystore.: +The `accounts` function in the `eth` namespace can be used to list the accounts that currently exist in the keystore.: ``` eth.accounts @@ -299,28 +232,19 @@ Passphrase: true ``` -This unlocked account can now be used to sign and send transactions. it is also possible to -pass the passphrase as an argument to `personal.unlockAccount()` along with a duration -after which the accout will automatically re-lock (in seconds), as follows: +This unlocked account can now be used to sign and send transactions. it is also possible to pass the passphrase as an argument to `personal.unlockAccount()` along with a duration after which the accout will automatically re-lock (in seconds), as follows: ```shell personal.unlockAccount(eth.accounts[1], "passphrase", 60) ``` -This unlocks the account for 60 seconds. However, this is not recommended because the -command history is logged by the Javascript console which could compromise the security -of the account. An unlocked account can be manually re-locked using `personal.lockAccount()`, -passing the address as the sole argument. +This unlocks the account for 60 seconds. However, this is not recommended because the command history is logged by the Javascript console which could compromise the security of the account. An unlocked account can be manually re-locked using `personal.lockAccount()`, passing the address as the sole argument. ### Unlocking for transactions -Sending transactions from the Javascript console also requires the sender account to be -unlocked. There are two ways to send transactions: `eth.sendTransaction` and `personal.sendTransaction`. -The difference between these two functions is that `eth.sendTransaction` requires the account to be -unlocked globally, at the node level (i.e., by unlocking it on the command line at the start of -the Geth session). On the other hand, `personal.sendTransaction` takes a passphrase argument -that unlocks the account temporarily in order to sign the transaction, then locks it again +Sending transactions from the Javascript console also requires the sender account to be unlocked. There are two ways to send transactions: `eth.sendTransaction` and `personal.sendTransaction`. The difference between these two functions is that `eth.sendTransaction` requires the account to be +unlocked globally, at the node level (i.e., by unlocking it on the command line at the start of the Geth session). On the other hand, `personal.sendTransaction` takes a passphrase argument that unlocks the account temporarily in order to sign the transaction, then locks it again immediately afterwards. For example, to send 5 ether between two accounts in the keystore: ```shell @@ -335,6 +259,4 @@ personal.sendTransaction(tx, "password") ## Summary -This page has demonstrated how to use Geth's built-in account management tools, both on the -command line and in the Javascript console. Accounts are stored encrypted by a password. -It is critical that the account passwords and the keystore directory are safely and securely backed up. +This page has demonstrated how to use Geth's built-in account management tools, both on the command line and in the Javascript console. Accounts are stored encrypted by a password. It is critical that the account passwords and the keystore directory are safely and securely backed up. \ No newline at end of file diff --git a/content/docs/fundamentals/les.md b/content/docs/fundamentals/les.md index ba84a7d52a..de9df11bdb 100644 --- a/content/docs/fundamentals/les.md +++ b/content/docs/fundamentals/les.md @@ -1,6 +1,6 @@ --- title: Light client -sort_key: B +description: Intriduction to Geth's light sync mode --- Running a full node is the most trustless, private, decentralized and censorship resistant way to interact with Ethereum. It is also the best choice for the health of the network, because a decentralized network relies on having many individual nodes that independently verify the head of the chain. In a full node a copy of the blockchain is stored locally enabling users to verify incoming data against a local source of truth. However, running a full node requires a lot of disk space and non-negligible CPU allocation and takes hours (for snap sync) or days (for full sync) to sync the blockchain from genesis. Geth also offers a light mode that overcomes these issues and provides some of the benefits of running a node but requires only a fraction of the resources. diff --git a/content/docs/fundamentals/node-architecture.md b/content/docs/fundamentals/node-architecture.md index 94e55f4ca8..dbe318412e 100644 --- a/content/docs/fundamentals/node-architecture.md +++ b/content/docs/fundamentals/node-architecture.md @@ -1,52 +1,29 @@ --- title: Node architecture -root: .. +description: Introduction to how Ethereum nodes are organized and where Geth fits. --- ## Node architecture -Geth is an [execution client](https://ethereum.org/en/developers/docs/nodes-and-clients/#execution-clients). -Originally, an execution client alone was enough to run a full Ethereum node. -However, ever since Ethereum turned off [proof-of-work](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/) and implemented [proof-of-stake](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/), -Geth has needed to be coupled to another piece of software called a -[“consensus client”](https://ethereum.org/en/developers/docs/nodes-and-clients/#consensus-clients) in order to -keep track of the Ethereum blockchain. +Geth is an [execution client](https://ethereum.org/en/developers/docs/nodes-and-clients/#execution-clients). Originally, an execution client alone was enough to run a full Ethereum node. However, ever since Ethereum turned off [proof-of-work](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/) and implemented [proof-of-stake](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/), Geth has needed to be coupled to another piece of software called a [“consensus client”](https://ethereum.org/en/developers/docs/nodes-and-clients/#consensus-clients) in order to keep track of the Ethereum blockchain. -The execution client is responsible for transaction handling, transaction gossip, state management and supporting -the Ethereum Virtual Machine ([EVM])(https://ethereum.org/en/developers/docs/evm/). However, Geth is **not** -responsible for block building, block gossiping or handling consensus logic. These are in the remit of the -consensus client. +The execution client is responsible for transaction handling, transaction gossip, state management and supporting the Ethereum Virtual Machine ([EVM])(https://ethereum.org/en/developers/docs/evm/). However, Geth is **not** responsible for block building, block gossiping or handling consensus logic. These are in the remit of the consensus client. -The relationship between the two Ethereum clients is shown in the schematic below. The two clients each -connect to their own respective peer-to-peer (P2P) networks. This is because the execution clients gossip -transactions over their P2P network enabling them to manage their local transaction pool. The consensus clients -gossip blocks over their P2P network, enabling consensus and chain growth. +The relationship between the two Ethereum clients is shown in the schematic below. The two clients each connect to their own respective peer-to-peer (P2P) networks. This is because the execution clients gossip transactions over their P2P network enabling them to manage their local transaction pool. The consensus clients gossip blocks over their P2P network, enabling consensus and chain growth. ![node-architecture](/assets/node_architecture.png) -For this two-client structure to work, consensus clients must be able to pass bundles of transactions to -Geth to be executed. Executing the transactions locally is how the client validates that the transactions -do not violate any Ethereum rules and that the proposed update to Ethereum’s state is correct. Likewise, -when the node is selected to be a block producer the consensus client must be able to request bundles of -transactions from Geth to include in the new block. This inter-client communication is handled by a local -RPC connection using the [engine API](https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md) -which is exposed internally over port 8551 by default. +For this two-client structure to work, consensus clients must be able to pass bundles of transactions to Geth to be executed. Executing the transactions locally is how the client validates that the transactions do not violate any Ethereum rules and that the proposed update to Ethereum’s state is correct. Likewise, when the node is selected to be a block producer the consensus client must be able to request bundles of transactions from Geth to include in the new block. This inter-client communication is handled by a local RPC connection using the [engine API](https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md) which is exposed internally over port 8551 by default. ## What does Geth do? -As an execution client, Geth is responsible for creating the execution payloads - the bundles of transactions - -that consensus clients include in their blocks. Geth is also responsible for re-executing transactions that arrive -in new blocks to ensure they are valid. Executing transactions is done on Geth's embedded computer, known as the -Ethereum Virtual Machine (EVM). +As an execution client, Geth is responsible for creating the execution payloads - the bundles of transactions - that consensus clients include in their blocks. Geth is also responsible for re-executing transactions that arrive in new blocks to ensure they are valid. Executing transactions is done on Geth's embedded computer, known as the Ethereum Virtual Machine (EVM). -Geth also offers a user-interface to Ethereum by exposing a set of RPC methods that enable users to query the -Ethereum blockchain, submit transactions and deploy smart contracts using the command line, programmatically -using Geth's built-in console, web3 development frameworks such as Hardhat and Truffle or via web-apps and wallets. +Geth also offers a user-interface to Ethereum by exposing a set of RPC methods that enable users to query the Ethereum blockchain, submit transactions and deploy smart contracts using the command line, programmatically using Geth's built-in console, web3 development frameworks such as Hardhat and Truffle or via web-apps and wallets. In summary, Geth is: - a user gateway to Ethereum - home to the Ethereum Virtual Machine, Ethereum's state and transaction pool. - Read more about [proof-of-stake](https://ethereum.org/en/developers/docs/consensus-mechanisms/pos/). diff --git a/content/docs/fundamentals/peer-to-peer.md b/content/docs/fundamentals/peer-to-peer.md index 8a4d4614d0..52b6da5840 100644 --- a/content/docs/fundamentals/peer-to-peer.md +++ b/content/docs/fundamentals/peer-to-peer.md @@ -1,9 +1,9 @@ --- title: Connecting To The Network -sort_key: B +description: Guide to connecting Geth to a peer-to-peer network --- -The default behaviour for Geth is to connect to Ethereum Mainnet. However, Geth can also connect to public testnets, [private networks](/docs/getting-started/private-net) and [local testnets](/docs/getting-started/dev-mode). Command line flags are provided for connecting to the popular public testnets: +The default behaviour for Geth is to connect to Ethereum Mainnet. However, Geth can also connect to public testnets, [private networks](/content/docs/developers/geth-developer/Private-Network.md) and [local testnets](/docs/getting-started/dev-mode). Command line flags are provided for connecting to the popular public testnets: - `--ropsten`, Ropsten proof-of-work test network - `--rinkeby`, Rinkeby proof-of-authority test network @@ -15,13 +15,11 @@ Providing these flags at startup instructs Geth to connect to the specific publi **Note:** network selection is not persisted in the config file. To connect to a pre-defined network you must always enable it explicitly, even when using the `--config` flag to load other configuration values. For example: ```shell - # Generate desired config file. You must specify testnet here. geth --goerli --syncmode "full" ... dumpconfig > goerli.toml # Start geth with given config file. Here too the testnet must be specified. geth --goerli --config goerli.toml - ``` ## Finding peers @@ -31,9 +29,7 @@ Geth continuously attempts to connect to other nodes on the network until it has A new node entering the network for the first time gets introduced to a set of peers by a bootstrap node ("bootnode") whose sole purpose is to connect new nodes to peers. The endpoints for these bootnodes are hardcoded into Geth, but they can also be specified by providing the `--bootnode` flag along with comma-separated bootnode addresses in the form of [enodes](https://ethereum.org/en/developers/docs/networking-layer/network-addresses/#enode) on startup. For example: ```shell - geth --bootnodes enode://pubkey1@ip1:port1,enode://pubkey2@ip2:port2,enode://pubkey3@ip3:port3 - ``` There are scenarios where disabling the discovery process is useful, for example for running a local test node or an experimental test network with known, fixed nodes. This can be achieved by passing the `--nodiscover` flag to Geth at startup. @@ -47,24 +43,22 @@ There are occasions when Geth simply fails to connect to peers. The common reaso - Some firewall configurations can prohibit UDP traffic. The static nodes feature or `admin.addPeer()` on the console can be used to configure connections manually. -- Running Geth in [light mode](/docs/interface/les) often leads to connectivity issues because there are few nodes running light servers. There is no easy fix for this except to switch Geth out of light mode. +- Running Geth in [light mode](/content/docs/fundamentals/les.md) often leads to connectivity issues because there are few nodes running light servers. There is no easy fix for this except to switch Geth out of light mode. - The public test network Geth is connecting to might be deprecated or have a low number of active nodes that are hard to find. In this case, the best action is to switch to an alternative test network. ## Checking Connectivity -The `net` module has two attributes that enable checking node connectivity from the [interactive Javascript console](/docs/interface/javascript-console). These are `net.listening` which reports whether the Geth node is listening for inbound requests, and `peerCount` which returns the number of active peers the node is connected to. +The `net` module has two attributes that enable checking node connectivity from the [interactive Javascript console](/content/docs/interacting_with_geth/JavaScript-Console.md). These are `net.listening` which reports whether the Geth node is listening for inbound requests, and `peerCount` which returns the number of active peers the node is connected to. ```javascript - > net.listening true > net.peerCount 4 - ``` Functions in the `admin` module provide more information about the connected peers, including their IP address, port number, supported protocols etc. Calling `admin.peers` returns this information for all connected peers. @@ -117,7 +111,7 @@ The `admin` module also includes functions for gathering information about the l ## Custom Networks -It is often useful for developers to connect to private test networks rather than public testnets or Etheruem mainnet. These sandbox environments allow block creation without competing against other miners, easy minting of test ether and give freedom to break things without real-world consequences. A private network is started by providing a value to `--networkid` that is not used by any other existing public network ([Chainlist](https://chainlist.org)) and creating a custom `genesis.json` file. Detailed instructions for this are available on the [Private Networks page](/docs/interface/private-network). +It is often useful for developers to connect to private test networks rather than public testnets or Etheruem mainnet. These sandbox environments allow block creation without competing against other miners, easy minting of test ether and give freedom to break things without real-world consequences. A private network is started by providing a value to `--networkid` that is not used by any other existing public network ([Chainlist](https://chainlist.org)) and creating a custom `genesis.json` file. Detailed instructions for this are available on the [Private Networks page](content/docs/developers/geth-developer/Private-Network.md). ## Static nodes @@ -134,9 +128,7 @@ Geth also supports static nodes. Static nodes are specific peers that are always Static nodes can also be added at runtime in the Javascript console by passing an enode address to `admin.addPeer()`: ```javascript - admin.addPeer("enode://f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0@33.4.2.1:30303") - ``` ## Peer limit @@ -159,7 +151,6 @@ Nodes can be added using the `admin.addTrustedPeer()` call in the Javascript con admin.addTrustedPeer("enode://f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0@33.4.2.1:30303") ``` - ## Summary Geth connects to Ethereum Mainnet by default. However, this behaviour can be changed using combinations of command line flags and files. This page has described the various options available for connecting a Geth node to Ethereum, public testnets and private networks. diff --git a/content/docs/fundamentals/security.md b/content/docs/fundamentals/security.md index 698d0523e1..239c568691 100644 --- a/content/docs/fundamentals/security.md +++ b/content/docs/fundamentals/security.md @@ -1,14 +1,11 @@ --- title: Security -root: .. +description: A primer on Geth security best practice. --- ## Downloading Geth -Download Geth using the links on our [Downloads](/downloads) page. The SHA256 hashes of the downloaded files -can be compared to ours to ensure precise consistency with our releases. This protects against malicious code being -inadvertently downloaded from an adversarial source. The same measures should also be taken to download trusted -consensus client software. +Download Geth using the links on our [Downloads](/downloads) page. The SHA256 hashes of the downloaded files can be compared to ours to ensure precise consistency with our releases. This protects against malicious code being inadvertently downloaded from an adversarial source. The same measures should also be taken to download trusted consensus client software. ## Networking security diff --git a/content/docs/tools/Clef/CliqueSigning.md b/content/docs/tools/Clef/CliqueSigning.md index b523badc46..d8af10b126 100644 --- a/content/docs/tools/Clef/CliqueSigning.md +++ b/content/docs/tools/Clef/CliqueSigning.md @@ -16,7 +16,7 @@ It is useful to have basic knowledge of private networks and Clef. These topics ## Prepping a Clique network -First of all, set up a rudimentary testnet to have something to sign. Create a new keystore (password `testtesttest`): +First of all, set up a rudimentary testnet to have something to sign. Create a new keystore (password `testtesttest`) ```terminal $ geth account new --datadir ./ddir @@ -75,16 +75,16 @@ INFO [06-16|11:14:54.125] Persisted trie from memory database nodes=1 size= INFO [06-16|11:14:54.125] Successfully wrote genesis state database=lightchaindata hash=187412..4deb98 ``` -At this point a Clique network exists with blocks that can be signed. +At this point a Geth has been initiated with a genesis configuration. ## Prepping Clef -In order to make use of Clef for signing: +In order to make use of `clef` for signing: -1. Ensure Clef knows the password for the keystore. -2. Ensure Clef auto-approves clique signing requests. +1. Ensure `clef` knows the password for the keystore. +2. Ensure `clef` auto-approves clique signing requests. -These two things are independent of each other. First of all, however, Clef must be initiated (for this example the password is `clefclefclef`) +These two things are independent of each other. First of all, however, `clef` must be initiated (for this example the password is `clefclefclef`) ``` $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn init @@ -110,7 +110,7 @@ After this operation, `clef` has it's own vault where it can store secrets and a ## Storing passwords in `clef` -With that done, Clef can be made aware of the password. To do this `setpw
` is invoked to store a password for a given address. Clef asks for the password, and it also asks for the Clef master-password, in order to update and store the new secrets inside Clef vault. +With that done, `clef` can be made aware of the password. To do this `setpw
` is invoked to store a password for a given address. `clef` asks for the password, and it also asks for the master-password, in order to update and store the new secrets inside the vault. ``` $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn setpw 0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 @@ -128,7 +128,7 @@ At this point, if Clef is used as a sealer, each block would require manual appr ### Testing stored password -To test that the stored password is correct and being properly handled by Clef, first start Clef: +To test that the stored password is correct and being properly handled by Clef, first start `clef`: ```sh $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn @@ -160,13 +160,13 @@ Approve? [y/N]: DEBUG[06-16|11:36:42.499] Served account_list reqid=2 duration=3.213768195s ``` -After this, Get will start asking Clef to sign things: +After this, Geth will start asking `clef` to sign things: ``` -------- Sign data request-------------- Account: 0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 [chksum ok] messages: -  Clique header [clique]: "clique header 1 [0x9b08fa3705e8b6e1b327d84f7936c21a3cb11810d9344dc4473f78f8da71e571]" + Clique header [clique]: "clique header 1 [0x9b08fa3705e8b6e1b327d84f7936c21a3cb11810d9344dc4473f78f8da71e571]" raw data: "\xf9\x02\x14\xa0\x18t\x12:\x91f\xa2\x90U\b\xf9\xac\xc02i\xffs\x9f\xf4\xc9⮷!\x0f\x16\xaa?#M똠\x1d\xccM\xe8\xde\xc7]z\xab\x85\xb5g\xb6\xcc\xd4\x1a\xd3\x12E\x1b\x94\x8at\x13\xf0\xa1B\xfd@ԓG\x94\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xa0]1%\n\xfc\xee'\xd0e\xce\xc7t\xcc\\?\t4v\x8f\x06\xcb\xf8\xa0P5\xfeN\xea\x0ff\xfe\x9c\xa0V\xe8\x1f\x17\x1b\xccU\xa6\xff\x83E\xe6\x92\xc0\xf8n[H\xe0\x1b\x99l\xad\xc0\x01b/\xb5\xe3c\xb4!\xa0V\xe8\x1f\x17\x1b\xccU\xa6\xff\x83E\xe6\x92\xc0\xf8n[H\xe0\x1b\x99l\xad\xc0\x01b/\xb5\xe3c\xb4!\xb9\x01\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x02\x01\x83z0\x83\x80\x84b\xaa\xf9\xaa\xa0\u0603\x01\n\x14\x84geth\x88go1.18.1\x85linux\x00\x00\x00\x00\x00\x00\x00\xa0\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x88\x00\x00\x00\x00\x00\x00\x00\x00" data hash: 0x9589ed81e959db6330b3d70e5f8e426fb683d03512f203009f7e41fc70662d03 @@ -185,7 +185,6 @@ And indeed, after approving with `y`, the password is not required - the signed ```terminal INFO [06-16|11:36:46.714] Successfully sealed new block number=1 sealhash=9589ed..662d03 hash=bd20b9..af8b87 elapsed=4.214s ``` - This mode of operation offers quite a poor UX because each block to be sealed requires manual approval. That is fixed in the following section. ## Using rules to approve blocks @@ -217,13 +216,13 @@ Password: INFO [06-16|13:49:00.298] Ruleset attestation updated sha256=54aae496c3f0eda063a62c73ee284ca9fae3f43b401da847ef30ea30e85e35d1 ``` -And Clef can be started, pointing out the `rules.js` file. +And `clef` can be started, pointing out the `rules.js` file. ```sh $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn --rules ./rules.js ``` -Once Geth starts asking Clef to seal blocks, the data will be displayed. From that data, rules can be defined that allow signing clique headers but nothing else. +Once Geth starts asking `clef` to seal blocks, the data will be displayed. From that data, rules can be defined that allow signing clique headers but nothing else. The actual data that gets passed to the js environment (and which the ruleset display in the terminal) looks as follows: ```json @@ -272,7 +271,7 @@ To create an extremely trustless ruleset, the `raw_data` could be verified to en 0000000000000000, ] ``` -However, `messages` could also be used. They do not come from the external caller, but are generated from the Clef internals: Clef parsed the incoming request and verified the Clique wellformedness of the content. The following simply checks for such a message: +However, `messages` could also be used. They do not come from the external caller, but are generated inernally: `clef` parsed the incoming request and verified the Clique wellformedness of the content. The following simply checks for such a message: ```js function OnSignerStartup(info){} @@ -307,7 +306,7 @@ Decrypt master seed of clef Password: INFO [06-16|14:18:53.476] Ruleset attestation updated sha256=7d5036d22d1cc66599e7050fb1877f4e48b89453678c38eea06e3525996c2379 ``` -Run clef: +Run `clef`: ```sh $ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn --rules ./rules.js @@ -317,7 +316,7 @@ Run Geth: ```sh $ geth --datadir ./ddir --signer ./clef/clef.ipc --mine ``` -And Clef should now happily sign blocks: +And `clef` should now happily sign blocks: ```terminal DEBUG[06-16|14:20:02.136] Served account_version reqid=1 duration="131.38µs" @@ -334,7 +333,11 @@ DEBUG[06-16|14:20:33.584] Served account_signData reqid=5 durat ## Refinements -If an attacker finds the Clef "external" interface (which would only happen if you start it with `--http` enabled), they cannot sign arbitrary data or transactions. However, they could still make it sign e.g. 1000 versions of a certain block height, making the chain very unstable. +If an attacker find the Clef "external" interface (which would only happen if you start it with `http` enabled), they +- cannot make it sign arbitrary transactions, +- cannot sign arbitrary data message, + +However, they could still make it sign e.g. 1000 versions of a certain block height, making the chain very unstable. It is possible for rule execution to be stateful (i.e. storing data). In this case, one could, for example, store what block heights have been sealed and reject sealing a particular block height twice. In other words, these rules could be used to build a miniature version of an execution layer slashing-db. @@ -377,13 +380,12 @@ JS:> number 46 latest 45 INFO [06-16|22:26:44.313] Op approved DEBUG[06-16|22:26:45.317] Served account_signData reqid=4 duration=1.010612774s ``` +This might be a bit over-the-top, security-wise, and may cause problems if, for some reason, a clique-deadlock needs to be resolved by rolling back and continuing on a side-chain. It is mainly meant as a demonstration that rules can use Javascript and statefulness to construct very intricate signing logic. -This might be a bit over-the-top security-wise, and may cause problems if, for some reason, a clique-deadlock needs to be resolved by rolling back and continuing on a side-chain. It is mainly meant as a demonstration that rules can use Javascript and statefulness to construct very intricate signing logic. ## TLDR quick-version Creation and attestation is a one-off event: - ```sh ## Create the rules-file cat << END > rules.js @@ -411,7 +413,7 @@ clef --keystore ./ddir/keystore \ --suppress-bootwarn --signersecret ./clefpw \ attest `sha256sum rules.js | cut -f1` ``` -The normal startup command for Clef: +The normal startup command for `clef`: ```sh clef --keystore ./ddir/keystore \ --configdir ./clef --chainid 15 \ @@ -422,4 +424,4 @@ For Geth, the only change is to provide `--signer `. ## Summary -Clef can be used as a signer that automatically seals Clique blocks. This is a much more secure option than unlocking accounts using Geth's built-in account manager. +Clef can be used as a signer that automatically seals Clique blocks. This is a much more secure option than unlocking accounts using Geth's built-in account manager. \ No newline at end of file From ecff17c740e6b0991ae031045c07c770f10e76f7 Mon Sep 17 00:00:00 2001 From: Joe Date: Fri, 19 Aug 2022 16:03:25 +0100 Subject: [PATCH 038/432] update md formatting --- content/docs/fundamentals/security.md | 2 +- .../docs/getting_started/Installing-Geth.md | 48 +--- .../getting-started-with-clef.md | 261 ++++-------------- .../docs/getting_started/getting_started.md | 239 +++------------- 4 files changed, 112 insertions(+), 438 deletions(-) diff --git a/content/docs/fundamentals/security.md b/content/docs/fundamentals/security.md index 239c568691..97f6cdbf8f 100644 --- a/content/docs/fundamentals/security.md +++ b/content/docs/fundamentals/security.md @@ -21,7 +21,7 @@ Account security comes down to keeping private keys and account passwords backed Geth has built-in account management tools that are sufficiently secure for most purposes. However, Clef is recommended as an external account management and signing tool. It can be run decoupled from Geth and can even be run on dedicated secure external hardware such as a VM or a secure USB drive. This is considered best practise because the user is required to manually review all actions that touch sensitive data, except where specific predefined rules are implemented. Signing is done locally to Clef rather than giving key access to a node. -Geth allows account unlocking by passing account passwords at startup. This unlocks the account all the while that Geth is running. This is not allowed when `http` traffic is enabled, even with appropriate firewall setings. The combination of `http` and `-unlock` poses too much of a security risk because an attacker able to access the node over the exposed HTTP port would be able to make JSON-RPC requests to the node from the unlocked account, including sending funds to other addresses. +Geth allows account unlocking by passing account passwords at startup. This unlocks the account all the while that Geth is running. This is not allowed when `http` traffic is enabled, even with appropriate firewall settings. The combination of `http` and `-unlock` poses too much of a security risk because an attacker able to access the node over the exposed HTTP port would be able to make JSON-RPC requests to the node from the unlocked account, including sending funds to other addresses. **back up your keystore and passwords safely and securely!** diff --git a/content/docs/getting_started/Installing-Geth.md b/content/docs/getting_started/Installing-Geth.md index f82d577cca..0d1ce82b53 100644 --- a/content/docs/getting_started/Installing-Geth.md +++ b/content/docs/getting_started/Installing-Geth.md @@ -1,15 +1,11 @@ --- title: Installing Geth -sort_key: A +description: Guide to installing Geth --- -There are several ways to install Geth, including via a package manager, downloading a pre-built bundle, running as a docker container or building from downloaded source code. On this page the various installation options are explained for several major operating systems. Users prioritizing ease of installation should choose to use a package manager or prebuilt bundle. Users prioritizing customization should build from source. It is important to run the latest version of Geth because each release includes bugfixes and improvement over the previous versions. The stable releases are recommended for most users because they have been fully tested. A list of stable releases can be found [here][geth-releases]. Instructions for updating existing Geth installations are also provided in each section. +There are several ways to install Geth, including via a package manager, downloading a pre-built bundle, running as a docker container or building from downloaded source code. On this page the various installation options are explained for several major operating systems. Users prioritizing ease of installation should choose to use a package manager or prebuilt bundle. Users prioritizing customization should build from source. It is important to run the latest version of Geth because each release includes bugfixes and improvement over the previous versions. The stable releases are recommended for most users because they have been fully tested. A list of stable releases can be found [here](https://github.com/ethereum/go-ethereum/releases). Instructions for updating existing Geth installations are also provided in each section. -{:toc} - -- this will be removed by the toc - ## Package managers ### MacOS via Homebrew @@ -20,7 +16,7 @@ The easiest way to install go-ethereum is to use the Geth Homebrew tap. The firs brew -v ``` -If a version number is returned, then Homebrew is installed. If not, Homebrew can be installed by following the instructions [here][brew]. With Homebrew installed, the following commands add the Geth tap and install Geth: +If a version number is returned, then Homebrew is installed. If not, Homebrew can be installed by following the instructions [here](https://brew.sh/). With Homebrew installed, the following commands add the Geth tap and install Geth: ```shell @@ -34,7 +30,7 @@ The previous command installs the latest stable release. Developers that wish to brew install ethereum --devel ``` -These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here](/content/docs/fundamentals/Command-Line-Options.md) or in the terminal by running `geth --help`. Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: @@ -71,7 +67,7 @@ sudo apt-get update sudo apt-get install ethereum-unstable ``` -These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. +These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. The full list of command line options can be viewed [here](/content/docs/fundamentals/Command-Line-Options.md) or in the terminal by running `geth --help`. Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: @@ -87,7 +83,7 @@ When the node is started again, Geth will automatically use all the data from th ### Windows -The easiest way to install Geth is to download a pre-compiled binary from the [downloads][geth-dl] page. The page provides an installer as well as a zip file containing the Geth source code. The install wizard offers the user the option to install Geth, or Geth and the developer tools. The installer adds `geth` to the system's `PATH` automatically. The zip file contains the command `.exe` files that can be run from the command prompt. The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. +The easiest way to install Geth is to download a pre-compiled binary from the [downloads](/content/downloads.md) page. The page provides an installer as well as a zip file containing the Geth source code. The install wizard offers the user the option to install Geth, or Geth and the developer tools. The installer adds `geth` to the system's `PATH` automatically. The zip file contains the command `.exe` files that can be run from the command prompt. The full list of command line options can be viewed [here](/content/docs/fundamentals/Command-Line-Options.md) or in the terminal by running `geth --help`. Updating an existing Geth installation can be achieved by stopping the node, downloading and installing the latest version following the instructions above. When the node is started again, Geth will automatically use all the data from the previous version and sync the blocks that were missed while the node was offline. @@ -101,7 +97,7 @@ pkg install go-ethereum These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. -The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. +The full list of command line options can be viewed [here](/content/docs/fundamentals/Command-Line-Options.md) or in the terminal by running `geth --help`. Updating an existing Geth installation to the latest version can be achieved by stopping the node and running the following commands: @@ -124,7 +120,7 @@ make install These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/local/bin/`. -The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. +The full list of command line options can be viewed [here](/content/docs/fundamentals/Command-Line-Options.md) or in the terminal by running `geth --help`. Updating an existing Geth installation can be achieved by stopping the node and running the following command: @@ -137,7 +133,7 @@ When the node is started again, Geth will automatically use all the data from th ### Arch Linux via pacman -The Geth package is available from the [community repo][geth-archlinux]. It can be installed by running: +The Geth package is available from the [community repo](https://www.archlinux.org/packages/community/x86_64/geth/). It can be installed by running: ```shell pacman -S geth @@ -145,7 +141,7 @@ pacman -S geth These commands install the core Geth software and the following developer tools: `clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`. The binaries for each of these tools are saved in `/usr/bin/`. -The full list of command line options can be viewed [here][geth-cl-options] or in the terminal by running `geth --help`. +The full list of command line options can be viewed [here](/content/docs/fundamentals/Command-Line-Options.md) or in the terminal by running `geth --help`. Updating an existing Geth installation can be achieved by stopping the node and running the following command: @@ -166,9 +162,9 @@ The following standalone bundles are available: - 32bit and 64bit archives (`.zip`) and installers (`.exe`) on Windows -Some archives contain only Geth, while other archives containing Geth and the various developer tools (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`). More information about these executables is available at the [`README`][geth-readme-exe]. +Some archives contain only Geth, while other archives containing Geth and the various developer tools (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`). More information about these executables is available at the [`README`](https://github.com/ethereum/go-ethereum#executables). -The standalone bundles can be downloaded from the [Geth Downloads][geth-dl] page. To update an existing installation, download and manually install the latest version. +The standalone bundles can be downloaded from the [Geth Downloads](content/downloads.md) page. To update an existing installation, download and manually install the latest version. ## Docker container @@ -216,7 +212,7 @@ docker run -it -p 30303:30303 ethereum/client-go ### Most Linux systems and macOS -Geth is written in [Go][go], so building from source code requires the most recent version of Go to be installed. Instructions for installing Go are available at the [Go installation page][go-install] and necessary bundles can be downloaded from the [Go download page][go-dl]. +Geth is written in [Go](https://golang.org/), so building from source code requires the most recent version of Go to be installed. Instructions for installing Go are available at the [Go installation page](https://golang.org/doc/install) and necessary bundles can be downloaded from the [Go download page](https://golang.org/dl/). With Go installed, Geth can be downloaded into a `GOPATH` workspace via: @@ -258,7 +254,7 @@ go get -u github.com/ethereum/go-ethereum ### Windows -The Chocolatey package manager provides an easy way to install the required build tools. Chocolatey can be installed by following these [instructions][chocolatey]. Then, to install the build tool the following commands can be run in an Administrator command prompt: +The Chocolatey package manager provides an easy way to install the required build tools. Chocolatey can be installed by following these [instructions](https://chocolatey.org). Then, to install the build tool the following commands can be run in an Administrator command prompt: ``` @@ -334,23 +330,9 @@ git pull make geth ``` -Additionally all the developer tools provided with Geth (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`) can be compiled by running `make all`. More information about these tools can be found [here][geth-readme-exe]. - -Instructions for cross-compiling to another architecture are available in the [cross-compilation guide](./cross-compile). +Additionally all the developer tools provided with Geth (`clef`, `devp2p`, `abigen`, `bootnode`, `evm`, `rlpdump` and `puppeth`) can be compiled by running `make all`. More information about these tools can be found [here](https://github.com/ethereum/go-ethereum#executables). To build a stable release, e.g. v1.9.21, the command `git checkout v1.9.21` retrieves that specific version. Executing that command before running `make geth` switches Geth to a stable branch. -[brew]: https://brew.sh/ -[go]: https://golang.org/ -[go-dl]: https://golang.org/dl/ -[go-install]: https://golang.org/doc/install -[chocolatey]: https://chocolatey.org -[geth-releases]: https://github.com/ethereum/go-ethereum/releases -[geth-readme-exe]: https://github.com/ethereum/go-ethereum#executables -[geth-cl-options]: https://geth.ethereum.org/docs/interface/command-line-options -[geth-archlinux]: https://www.archlinux.org/packages/community/x86_64/geth/ -[geth-dl]: ../../downloads/ - - diff --git a/content/docs/getting_started/getting-started-with-clef.md b/content/docs/getting_started/getting-started-with-clef.md index 37078b7a2e..d6e19e86c1 100644 --- a/content/docs/getting_started/getting-started-with-clef.md +++ b/content/docs/getting_started/getting-started-with-clef.md @@ -1,88 +1,47 @@ --- title: Geth and Clef -permalink: docs/getting-started/geth-and-clef -sort_key: B +description: Guide to getting up and running with Geth using Clef as an external account management and signing tool. --- -This page explains how to set up Geth and execute some basic tasks using the command line tools. -In order to use Geth, the software must first be installed. There are several ways Geth can be -installed depending on the operating system and the user's choice of installation method, for -example using a package manager, container or building from source. Instructions for installing -Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. Geth -also needs to be connected to a consensus client in order to function as an Ethereum node. -The tutorial on this page assumes Geth and a consensus client have been installed successfully and -that a firewall has been configured to block external traffic to the JSON-RPC port `8545` see -[Security](/content/docs/fundamentals/security.md). +This page explains how to set up Geth and execute some basic tasks using the command line tools. In order to use Geth, the software must first be installed. There are several ways Geth can be installed depending on the operating system and the user's choice of installation method, for example using a package manager, container or building from source. Instructions for installing Geth can be found on the ["Install and Build"](content/docs/getting_started/Installing-Geth.md) pages. Geth also needs to be connected to a consensus client in order to function as an Ethereum node. The tutorial on this page assumes Geth and a consensus client have been installed successfully and that a firewall has been configured to block external traffic to the JSON-RPC port `8545` see [Security](/content/docs/fundamentals/security.md). -This page provides step-by-step instructions covering the fundamentals of using Geth. This -includes generating accounts, joining an Ethereum network, syncing the blockchain and sending ether -between accounts. This tutorial also uses [Clef](/docs/clef/tutorial). Clef is an account management tool -external to Geth itself that allows users to sign transactions. It is developed and maintained by -the Geth team and is intended to eventually replace the account management tool built in to Geth. +This page provides step-by-step instructions covering the fundamentals of using Geth. This includes generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. This tutorial also uses [Clef](/content/docs/tools/Clef/Tutorial.md). Clef is an account management tool external to Geth itself that allows users to sign transactions. It is developed and maintained by the Geth team and is intended to eventually replace the account management tool built in to Geth. ## Prerequisites -In order to get the most value from the tutorials on this page, the following skills are -necessary: +In order to get the most value from the tutorials on this page, the following skills are necessary: - Experience using the command line - Basic knowledge about Ethereum and testnets - Basic knowledge about HTTP and JavaScript - Basic knowledge of node architecture and consensus clients -Users that need to revisit these fundamentals can find helpful resources relating to the command -line [here][cli], Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), -http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and -Javascript [here](https://www.javascript.com/learn). Information on node architecture can be found -[here](/content/docs/fundamentals/node-architecture.md) and our guide for configuring Geth to connect to a +Users that need to revisit these fundamentals can find helpful resources relating to the command line [here](https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line), Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and Javascript [here](https://www.javascript.com/learn). Information on node architecture can be found [here](/content/docs/fundamentals/node-architecture.md) and our guide for configuring Geth to connect to a consensus client is [here](/content/docs/getting_started/consensus-clients.md). -{% include note.html content="If Geth was installed from source on Linux, `make` saves the -binaries for Geth and the associated tools in `/build/bin`. To run these programs it is -convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) -from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to -execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not -moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) -or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} +{% include note.html content="If Geth was installed from source on Linux, `make` saves the binaries for Geth and the associated tools in `/build/bin`. To run these programs it is convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not +moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} ## Background -Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. -Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being -managed by a central server. Every 12 seconds one node is randomly selected to generate a new block -containing a list of transactions that nodes receiving the block should execute. This "block proposer" node -sends the new block to its peers. On receiving a new block, each node checks that it is valid and adds -it to their database. The sequence of discrete blocks is called a "blockchain". +Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being managed by a central server. Every 12 seconds one node is randomly selected to generate a new block containing a list of transactions that nodes receiving the block should execute. This "block proposer" node sends the new block to its peers. On receiving a new block, each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called a "blockchain". -The information provided in each block is used by Geth to update its "state" - the ether -balance of each account on Ethereum and the data stored by each smart contract. There are two types of account: -externally-owned accounts (EOAs) and contract accounts. Contract accounts execute contract code when they -receive transactions. EOAs are accounts that users manage locally in order to sign and submit transactions. -Each EOA is a public-private key pair, where the public key is used to derive a unique address for the user and -the private key is used to protect the account and securely sign messages. Therefore, in order to use Ethereum, -it is first necessary to generate an EOA (hereafter, "account"). This tutorial will guide the user through -creating an account, funding it with ether and sending some to another address. +The information provided in each block is used by Geth to update its "state" - the ether balance of each account on Ethereum and the data stored by each smart contract. There are two types of account: externally-owned accounts (EOAs) and contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, where the public key is used to derive a unique address for the user and the private key is used to protect the account and securely sign messages. Therefore, in order to use Ethereum, +it is first necessary to generate an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it with ether and sending some to another address. Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). ## Step 1: Generating accounts -There are several methods for generating accounts in Geth. This tutorial demonstrates how to generate accounts -using Clef, as this is considered best practice, largely because it decouples the users' key management from Geth, -making it more modular and flexible. It can also be run from secure USB sticks or virtual machines, offering -security benefits. For convenience, this tutorial will execute Clef on the same computer that will also run Geth, -although more secure options are available (see [here](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/docs/setup.md)). +There are several methods for generating accounts in Geth. This tutorial demonstrates how to generate accounts using Clef, as this is considered best practice, largely because it decouples the users' key management from Geth, making it more modular and flexible. It can also be run from secure USB sticks or virtual machines, offering security benefits. For convenience, this tutorial will execute Clef on the same computer that will also run Geth, although more secure options are available (see [here](https://github.com/ethereum/go-ethereum/blob/master/cmd/clef/docs/setup.md)). -An account is a pair of keys (public and private). Clef needs to know where to save these keys to so that they -can be retrieved later. This information is passed to Clef as an argument. This is achieved using the following command: +An account is a pair of keys (public and private). Clef needs to know where to save these keys to so that they can be retrieved later. This information is passed to Clef as an argument. This is achieved using the following command: ```shell clef newaccount --keystore geth-tutorial/keystore ``` -The specific function from Clef that generates new accounts is `newaccount` and it accepts a -parameter, `--keystore`, that tells it where to store the newly generated keys. In this -example the keystore location is a new directory that will be created automatically: `geth-tutorial/keystore`. +The specific function from Clef that generates new accounts is `newaccount` and it accepts a parameter, `--keystore`, that tells it where to store the newly generated keys. In this example the keystore location is a new directory that will be created automatically: `geth-tutorial/keystore`. Clef will return the following result in the terminal: ```terminal @@ -102,17 +61,10 @@ Enter 'ok' to proceed: > ``` -This is important information. The `geth-tutorial/keystore` directory will soon contain a secret -key that can be used to access any funds held in the new account. If it is compromised, the funds -can be stolen. If it is lost, there is no way to retrieve the funds. This tutorial will only use -dummy funds with no real world value, but when these steps are repeated on Ethereum mainnet is -critical that the keystore is kept secure and backed up. +This is important information. The `geth-tutorial/keystore` directory will soon contain a secret key that can be used to access any funds held in the new account. If it is compromised, the funds can be stolen. If it is lost, there is no way to retrieve the funds. This tutorial will only use dummy funds with no real world value, but when these steps are repeated on Ethereum mainnet is critical that the keystore is kept secure and backed up. -Typing `ok` into the terminal and pressing `enter` causes Clef to prompt for a password. -Clef requires a password that is at least 10 characters long, and best practice would be -to use a combination of numbers, characters and special characters. Entering a suitable -password and pressing `enter` returns the following result to the terminal: +Typing `ok` into the terminal and pressing `enter` causes Clef to prompt for a password. Clef requires a password that is at least 10 characters long, and best practice would be to use a combination of numbers, characters and special characters. Entering a suitable password and pressing `enter` returns the following result to the terminal: ```terminal ----------------------- @@ -123,27 +75,13 @@ WARN [02-10|13:46:46.595] Please remember your password! Generated account 0xCe8dBA5e4157c2B284d8853afEEea259344C1653 ``` -It is important to save the account address and the password somewhere secure. -They will be used again later in this tutorial. Please note that the account address shown -in the code snippets above and later in this tutorials are examples - those generated by followers -of this tutorial will be different. The account generated above can be used as the main account -throughout the remainder of this tutorial. However in order to demonstrate transactions between -accounts it is also necessary to have a second account. A second account can be added to the -same keystore by precisely repeating the previous steps, providing the same password. +It is important to save the account address and the password somewhere secure. They will be used again later in this tutorial. Please note that the account address shown in the code snippets above and later in this tutorials are examples - those generated by followers of this tutorial will be different. The account generated above can be used as the main account throughout the remainder of this tutorial. However in order to demonstrate transactions between accounts it is also necessary to have a second account. A second account can be added to the same keystore by precisely repeating the previous steps, providing the same password. ## Step 2: Start Clef -The previous commands used Clef's `newaccount` function to add new key pairs to the keystore. -Clef uses the private key(s) saved in the keystore is used to sign transactions. In order to do -this, Clef needs to be started and left running while Geth is running simultaneously, so that the -two programs can communicate between one another. +The previous commands used Clef's `newaccount` function to add new key pairs to the keystore. Clef uses the private key(s) saved in the keystore is used to sign transactions. In order to do this, Clef needs to be started and left running while Geth is running simultaneously, so that the two programs can communicate between one another. -To start Clef, run the Clef executable passing as arguments the keystore file location, -config directory location and a chain ID. The config directory was automatically created -inside the `geth-tutorial` directory during the previous step. The [chain ID](https://chainlist.org/) -is an integer that defines which Ethereum network to connect to. Ethereum mainnet has chain ID 1. -In this tutorial Chain ID 5 is used which is that of the Goerli testnet. It is very important that -this chain ID parameter is set to 5. The following command starts Clef on Goerli: +To start Clef, run the Clef executable passing as arguments the keystore file location, config directory location and a chain ID. The config directory was automatically created inside the `geth-tutorial` directory during the previous step. The [chain ID](https://chainlist.org/) is an integer that defines which Ethereum network to connect to. Ethereum mainnet has chain ID 1. In this tutorial Chain ID 5 is used which is that of the Goerli testnet. It is very important that this chain ID parameter is set to 5. The following command starts Clef on Goerli: ```shell @@ -172,20 +110,11 @@ INFO [02-10|13:55:30.984] IPC endpoint opened url=geth-tuto * extapi_ipc : geth-tutorial/clef/clef.ipc ``` -This result indicates that Clef is running. This terminal should be left running for the duration of this -tutorial. If the tutorial is stopped and restarted later Clef must also be restarted by running the previous command. +This result indicates that Clef is running. This terminal should be left running for the duration of this tutorial. If the tutorial is stopped and restarted later Clef must also be restarted by running the previous command. ## Step 3: Start Geth -Geth is the Ethereum client that will connect the computer to the Ethereum network. In this tutorial the -network is Goerli, an Ethereum testnet. Testnets are used to test Ethereum client software and smart -contracts in an environment where no real-world value is at risk. To start Geth, run the Geth executable -file passing argument that define the data directory (where Geth should save blockchain data), -signer (points Geth to Clef), the network ID and the sync mode. For this tutorial, snap sync is recommended -(see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). The final argument -passed to Geth is the `--http` flag. This enables the http-rpc server that allows external programs to -interact with Geth by sending it http requests. By default the http server is only exposed locally using -port 8545: `localhost:8545`. +Geth is the Ethereum client that will connect the computer to the Ethereum network. In this tutorial the network is Goerli, an Ethereum testnet. Testnets are used to test Ethereum client software and smart contracts in an environment where no real-world value is at risk. To start Geth, run the Geth executable file passing argument that define the data directory (where Geth should save blockchain data), signer (points Geth to Clef), the network ID and the sync mode. For this tutorial, snap sync is recommended (see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). The final argument passed to Geth is the `--http` flag. This enables the http-rpc server that allows external programs to interact with Geth by sending it http requests. By default the http server is only exposed locally using port 8545: `localhost:8545`. The following command should be run in a new terminal, separate to the one running Clef: @@ -219,11 +148,8 @@ WARN [02-10|13:59:06.999] Failed to open wallet url=extapi:// INFO [02-10|13:59:08.793] Block synchronisation started ``` -This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers it -can request block headers from them, starting at the genesis block for the Goerli blockchain. Geth continues -to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. -This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in -the terminal with the following syntax: +This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers it can request block headers from them, starting at the genesis block for the Goerli blockchain. Geth continues to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. +This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in the terminal with the following syntax: ```terminal INFO [04-29][15:54:09.238] Looking for peers peercount=2 tried=0 static=0 @@ -239,42 +165,22 @@ the following command can be run: curl http://localhost:8545 ``` -If there is no error message reported to the terminal, everything is OK. Geth must be running in order for -a user to interact with the Ethereum network. If this terminal is closed down then Geth must be restarted -in a new terminal. Geth can be started and stopped easily, but it must be running for any interaction with -Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. To start it again, -run the previous command `geth --datadir ... ..`. +If there is no error message reported to the terminal, everything is OK. Geth must be running in order for a user to interact with the Ethereum network. If this terminal is closed down then Geth must be restarted in a new terminal. Geth can be started and stopped easily, but it must be running for any interaction with +Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. To start it again, run the previous command `geth --datadir `. -{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished you -can't use the node to transfer funds. You can also try doing a [light sync](interface/les) which will be -much quicker but depends on light servers being available to serve your node the data it needs." %} +{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished you can't use the node to transfer funds. You can also try doing a [light sync](interface/les) which will be much quicker but depends on light servers being available to serve your node the data it needs." %} ## Step 4: Get Testnet Ether -In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, -ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; -2) receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, -3) having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it -4) can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether to their account. +In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; 2) receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, 3) having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it 4) can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether to their account. -The address generated by Clef in Step 1 can be pasted into the Paradigm Multifaucet faucet -[here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of -personhood. The faucets adds ether to the given address on multiple testnets simultaneously, -including Goerli. In the next steps Geth will be used to check that the ether has been sent -to the given address and send some of it to the second address created earlier. +The address generated by Clef in Step 1 can be pasted into the Paradigm Multifaucet faucet [here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of personhood. The faucets adds ether to the given address on multiple testnets simultaneously, including Goerli. In the next steps Geth will be used to check that the ether has been sent to the given address and send some of it to the second address created earlier. ## Step 5: Interact with Geth -For interacting with the blockchain, Geth provides JSON-RPC APIs. -[JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific -tasks by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. -RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded -instructions from locations outside of those managed by Geth. It is possible to interact with Geth -by sending these JSON encoded instructions directly over Geth's exposed http port using tools like Curl. -However, this is somewhat user-unfriendly and error-prone, especially for more complex instructions. -For this reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly -interface for interacting with Geth. One of the most widely used is Web3.js. +For interacting with the blockchain, Geth provides JSON-RPC APIs. [JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific +tasks by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded instructions from locations outside of those managed by Geth. It is possible to interact with Geth by sending these JSON encoded instructions directly over Geth's exposed http port using tools like Curl. However, this is somewhat user-unfriendly and error-prone, especially for more complex instructions. For this reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly interface for interacting with Geth. One of the most widely used is Web3.js. Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in one terminal, a Javascript environment can be opened in another allowing the user to interact with Geth using Web3.js. There are three transport protocols that can be used to connect the Javascript environment to Geth: @@ -284,16 +190,13 @@ Geth provides a Javascript console that exposes the Web3.js API. This means that - Websocket: By default provides access to the `eth`, `web3` and `net` method namespaces. -This tutorial will use the HTTP option. Note that the terminals running Geth and Clef should both still be active. -In a new (third) terminal, the following command can be run to start the console and connect it to Geth -using the exposed http port: +This tutorial will use the HTTP option. Note that the terminals running Geth and Clef should both still be active. In a new (third) terminal, the following command can be run to start the console and connect it to Geth using the exposed http port: ```shell geth attach http://127.0.0.1:8545 ``` -This command causes the terminal to hang because it is waiting for approval from Clef. Approving the request -in the terminal running Clef will lead to the following welcome message being displayed in the Javascript console: +This command causes the terminal to hang because it is waiting for approval from Clef. Approving the request in the terminal running Clef will lead to the following welcome message being displayed in the Javascript console: ```terminal Welcome to the Geth JavaScript console! @@ -310,17 +213,13 @@ The console is now active and connected to Geth. It can now be used to interact ### List of accounts -In this tutorial, the accounts are managed using Clef. This means that requesting information about -the accounts requires explicit approval in Clef, which should still be running in its own terminal. -Earlier in this tutorial, two accounts were created using Clef. The following command will display the -addresses of those two accounts and any others that might have been added to the keystore before or since. +In this tutorial, the accounts are managed using Clef. This means that requesting information about the accounts requires explicit approval in Clef, which should still be running in its own terminal. Earlier in this tutorial, two accounts were created using Clef. The following command will display the addresses of those two accounts and any others that might have been added to the keystore before or since. ```javascript eth.accounts ``` -The console will hang, because Clef is waiting for approval. The following message will be -displayed in the Clef terminal: +The console will hang, because Clef is waiting for approval. The following message will be displayed in the Clef terminal: ```terminal -------- List Account request-------------- @@ -341,35 +240,24 @@ Approve? [y/N]: ``` -Entering `y` approves the request from the console. In the terminal running the Javascript console, -the account addresses are now displayed: +Entering `y` approves the request from the console. In the terminal running the Javascript console, the account addresses are now displayed: ```terminal ["0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec", "0xce8dba5e4157c2b284d8853afeeea259344c1653"] ``` -It is also possible for this request to time out if the Clef approval took too long - -in this case simply repeat the request and approval. +It is also possible for this request to time out if the Clef approval took too long - in this case simply repeat the request and approval. ### Checking account balance. -Having confirmed that the two addresses created earlier are indeed in the keystore and accessible -through the Javascript console, it is possible to retrieve information about how much ether they own. -The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance of one of -the accounts should be 1 ether and the other should be 0. The following command displays the account -balance in the console: +Having confirmed that the two addresses created earlier are indeed in the keystore and accessible through the Javascript console, it is possible to retrieve information about how much ether they own. The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance of one of the accounts should be 1 ether and the other should be 0. The following command displays the account balance in the console: ```javascript web3.fromWei(eth.getBalance("0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC"), "ether") ``` -There are actually two instructions sent in the above command. The inner one is the `getBalance` -function from the `eth` namespace. This takes the account address as its only argument. By default, -this returns the account balance in units of Wei. There are 1018 Wei to one ether. -To present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from -the `web3` namespace. Running this command should provide the following result -(for the account that received faucet funds): +There are actually two instructions sent in the above command. The inner one is the `getBalance` function from the `eth` namespace. This takes the account address as its only argument. By default, this returns the account balance in units of Wei. There are 1018 Wei to one ether. To present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from the `web3` namespace. Running this command should provide the following result (for the account that received faucet funds): ```terminal 1 @@ -383,15 +271,7 @@ Repeating the command for the other account should yield: ### Send ether to another account -The command `eth.sendTransaction` can be used to send some ether from one address to another. -This command takes three arguments: `from`, `to` and `value`. These define the sender and -recipient addresses (as strings) and the amount of Wei to transfer. It is far less error -prone to enter the transaction value in units of ether rather than Wei, so the value field can -take the return value from the `toWei` function. The following command, run in the Javascript -console, sends 0.1 ether from one of the accounts in the Clef keystore to the other. Note that -the addresses here are examples - the user must replace the address in the `from` field with -the address currently owning 1 ether, and the address in the `to` field with the address -currently holding 0 ether. +The command `eth.sendTransaction` can be used to send some ether from one address to another. This command takes three arguments: `from`, `to` and `value`. These define the sender and recipient addresses (as strings) and the amount of Wei to transfer. It is far less error prone to enter the transaction value in units of ether rather than Wei, so the value field can take the return value from the `toWei` function. The following command, run in the Javascript console, sends 0.1 ether from one of the accounts in the Clef keystore to the other. Note that the addresses here are examples - the user must replace the address in the `from` field with the address currently owning 1 ether, and the address in the `to` field with the address currently holding 0 ether. ```javascript eth.sendTransaction({ @@ -401,11 +281,7 @@ eth.sendTransaction({ }) ``` -Note that submitting this transaction requires approval in Clef. In the Clef terminal, -Clef will prompt for approval and request the account password. If the password is correctly -entered, Geth proceeds with the transaction. The transaction request summary is presented by -Clef in the Clef terminal. This is an opportunity for the sender to review the details and -ensure they are correct. +Note that submitting this transaction requires approval in Clef. In the Clef terminal, Clef will prompt for approval and request the account password. If the password is correctly entered, Geth proceeds with the transaction. The transaction request summary is presented by Clef in the Clef terminal. This is an opportunity for the sender to review the details and ensure they are correct. ```terminal --------- Transaction request------------- @@ -432,8 +308,7 @@ Please enter the password for account 0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC ``` -After approving the transaction, the following confirmation screen in displayed in -the Clef terminal: +After approving the transaction, the following confirmation screen in displayed in the Clef terminal: ```terminal ----------------------- @@ -457,34 +332,24 @@ Transaction signed: } ``` -In the Javascript console, the transaction hash is displayed. This will be used in the -next section to retrieve the transaction details. +In the Javascript console, the transaction hash is displayed. This will be used in the next section to retrieve the transaction details. ```terminal "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" ``` -It is also advised to check the account balances using Geth by repeating the instructions from -earlier. At this point in the tutorial, the two accounts in the Clef keystore should have balances -just below 0.9 ether (because 0.1 ether has been transferred out and some small amount paid in -transaction gas) and 0.1 ether. +It is also advised to check the account balances using Geth by repeating the instructions from earlier. At this point in the tutorial, the two accounts in the Clef keystore should have balances just below 0.9 ether (because 0.1 ether has been transferred out and some small amount paid in transaction gas) and 0.1 ether. ### Checking the transaction hash -The transaction hash is a unique identifier for this specific transaction that can be used -later to retrieve the transaction details. For example, the transaction details can be -viewed by pasting this hash into the [Goerli block explorer](https://goerli.etherscan.io/). -The same information can also be retrieved directly from the Geth node. The hash returned in -the previous step can be provided as an argument to `eth.getTransaction` to return the -transaction information: +The transaction hash is a unique identifier for this specific transaction that can be used later to retrieve the transaction details. For example, the transaction details can be viewed by pasting this hash into the [Goerli block explorer](https://goerli.etherscan.io/). The same information can also be retrieved directly from the Geth node. The hash returned in the previous step can be provided as an argument to `eth.getTransaction` to return the transaction information: ```javascript eth.getTransaction("0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb") ``` -This returns the following response (although the actual values for each field will vary -because they are specific to each transaction): +This returns the following response (although the actual values for each field will vary because they are specific to each transaction): ```terminal { @@ -512,23 +377,12 @@ because they are specific to each transaction): ## Using Curl -Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. -This library enables the user to send instructions to Geth using a more user-friendly interface -compared to sending raw JSON objects. However, it is also possible for the user to send these -JSON objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP -requests. This part of the tutorial demonstrates how to check account balances and send a -transaction using Curl. +Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. This library enables the user to send instructions to Geth using a more user-friendly interface compared to sending raw JSON objects. However, it is also possible for the user to send these JSON objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP requests. This part of the tutorial demonstrates how to check account balances and send a transaction using Curl. ### Checking account balance -The command below returns the balance of the given account. This is a HTTP POST request to the -local port 8545. The `-H` flag is for header information. It is used here to define the format -of the incoming payload, which is JSON. The `--data` flag defines the content of the payload, -which is a JSON object. That JSON object contains four fields: `jsonrpc` defines the spec version -for the JSON-RPC API, `method` is the specific function being invoked, `params` are the function -arguments, and `id` is used for ordering transactions. The two arguments passed to `eth_getBalance` -are the account address whose balance to check and the block to query (here `latest` is used to -check the balance in the most recently mined block). +The command below returns the balance of the given account. This is a HTTP POST request to the local port 8545. The `-H` flag is for header information. It is used here to define the format of the incoming payload, which is JSON. The `--data` flag defines the content of the payload, which is a JSON object. That JSON object contains four fields: `jsonrpc` defines the spec version for the JSON-RPC API, `method` is the specific function being invoked, `params` are the function +arguments, and `id` is used for ordering transactions. The two arguments passed to `eth_getBalance` are the account address whose balance to check and the block to query (here `latest` is used to check the balance in the most recently mined block). ```shell curl -X POST http://127.0.0.1:8545 \ @@ -542,9 +396,7 @@ A successful call will return a response like the one below: {"jsonrpc":"2.0","id":1,"result":"0xc7d54951f87f7c0"} ``` -The balance is in the `result` field in the returned JSON object. However, it is denominated in -Wei and presented as a hexadecimal string. There are many options for converting this value to a -decimal in units of ether, for example by opening a Python console and running: +The balance is in the `result` field in the returned JSON object. However, it is denominated in Wei and presented as a hexadecimal string. There are many options for converting this value to a decimal in units of ether, for example by opening a Python console and running: ```python 0xc7d54951f87f7c0 / 1e18 @@ -573,11 +425,7 @@ This requires approval in Clef. Once approved, the following information is retu ### Sending Transactions -Sending a transaction between accounts can also be achieved using Curl. Notice that the value of the -transaction is a hexadecimal string in units of Wei. To transfer 0.1 ether, it is first necessary to -convert this to Wei by multiplying by 1018 then converting to hex. 0.1 ether is -`"0x16345785d8a0000"` in hex. As before, update the `to` and `from` fields with the addresses in -the Clef keystore. +Sending a transaction between accounts can also be achieved using Curl. Notice that the value of the transaction is a hexadecimal string in units of Wei. To transfer 0.1 ether, it is first necessary to convert this to Wei by multiplying by 1018 then converting to hex. 0.1 ether is `"0x16345785d8a0000"` in hex. As before, update the `to` and `from` fields with the addresses in the Clef keystore. ```shell @@ -586,9 +434,7 @@ curl -X POST http://127.0.0.1:8545 \ --data '{"jsonrpc":"2.0", "method":"eth_sendTransaction", "params":[{"from": "0xca57f3b40b42fcce3c37b8d18adbca5260ca72ec","to": "0xce8dba5e4157c2b284d8853afeeea259344c1653","value": "0x16345785d8a0000"}], "id":1}' ``` -This requires approval in Clef. Once the password for the sender account has been provided, -Clef will return a summary of the transaction details and the terminal that made the Curl -request will display a response containing the transaction hash. +This requires approval in Clef. Once the password for the sender account has been provided, Clef will return a summary of the transaction details and the terminal that made the Curl request will display a response containing the transaction hash. ```terminal {"jsonrpc":"2.0","id":5,"result":"0xac8b347d70a82805edb85fc136fc2c4e77d31677c2f9e4e7950e0342f0dc7e7c"} @@ -596,11 +442,6 @@ request will display a response containing the transaction hash. ## Summary -This tutorial has demonstrated how to generate accounts using Clef, fund them with testnet ether and use -those accounts to interact with Ethereum (Goerli) through a Geth node. Checking account balances, sending -transactions and retrieving transaction details were explained using the web3.js library via the -Geth console and using the JSON-RPC directly using Curl. For more detailed information about Clef, please see -[the Clef docs](/docs/clef/tutorial). +This tutorial has demonstrated how to generate accounts using Clef, fund them with testnet ether and use those accounts to interact with Ethereum (Goerli) through a Geth node. Checking account balances, sending transactions and retrieving transaction details were explained using the web3.js library via the Geth console and using the JSON-RPC directly using Curl. For more detailed information about Clef, please see [the Clef docs](/content/docs/tools/Clef/Tutorial.md). -[cli]: https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line diff --git a/content/docs/getting_started/getting_started.md b/content/docs/getting_started/getting_started.md index 7f9c8f6647..eaa47aa425 100644 --- a/content/docs/getting_started/getting_started.md +++ b/content/docs/getting_started/getting_started.md @@ -1,32 +1,13 @@ --- title: Getting Started with Geth -permalink: docs/getting-started -sort_key: A +description: Instructions for getting up and running with Geth --- -This page explains how to set up Geth and execute some basic tasks using the command line tools. -In order to use Geth, the software must first be installed. There are several ways Geth can be -installed depending on the operating system and the user's choice of installation method, for -example using a package manager, container or building from source. Instructions for installing -Geth can be found on the ["Install and Build"](install-and-build/installing-geth) pages. Geth -also needs to be connected to a consensus client in order to function as an Ethereum node. -The tutorial on this page assumes Geth and a consensus client have been installed successfully and -that a firewall has been configured to block external traffic to the JSON-RPC port `8545` see -[Security](/content/docs/fundamentals/security.md). +This page explains how to set up Geth and execute some basic tasks using the command line tools. In order to use Geth, the software must first be installed. There are several ways Geth can be installed depending on the operating system and the user's choice of installation method, for example using a package manager, container or building from source. Instructions for installing Geth can be found on the ["Install and Build"](content/docs/getting_started/Installing-Geth.md) pages. Geth +also needs to be connected to a consensus client in order to function as an Ethereum node. The tutorial on this page assumes Geth and a consensus client have been installed successfully and that a firewall has been configured to block external traffic to the JSON-RPC port `8545` see [Security](/content/docs/fundamentals/security.md). -This page provides step-by-step instructions covering the fundamentals of using Geth. This includes -generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. -This page uses Geth's built in account management tool. This is the simplest method for creating and accessing -accounts in Geth, is sufficiently secure for many purposes and provides a good entry point for undersatanding -some of the basic Geth workflows. However, Geth also comes bundled with an external signer and account management -tool called [Clef](/tools/Clef/introduction). It is best practise to use Clef instead of Geth's built-in account -management tools because Clef is decoupled from Geth and can be run in a separate, secure environment. -This page should be used as an initial entry point into basic Geth and readers should plan to advance from this -page to [Getting started with Geth and Clef](/content/docs/getting_started/getting-started-with-clef.md). -Eventually, Clef is intended to replace Geth's built-in account management tools. - -{:toc} -- this will be removed by the toc +This page provides step-by-step instructions covering the fundamentals of using Geth. This includes generating accounts, joining an Ethereum network, syncing the blockchain and sending ether between accounts. This page uses Geth's built in account management tool. This is the simplest method for creating and accessing +accounts in Geth, is sufficiently secure for many purposes and provides a good entry point for understanding some of the basic Geth workflows. However, Geth also comes bundled with an external signer and account management tool called [Clef](/tools/Clef/introduction). It is best practise to use Clef instead of Geth's built-in account management tools because Clef is decoupled from Geth and can be run in a separate, secure environment. This page should be used as an initial entry point into basic Geth and readers should plan to advance from this page to [Getting started with Geth and Clef](/content/docs/getting_started/getting-started-with-clef.md). Eventually, Clef is intended to replace Geth's built-in account management tools. ## Prerequisites @@ -38,38 +19,19 @@ necessary: - Basic knowledge about HTTP and JavaScript - Basic knowledge of node architecture and consensus clients -Users that need to revisit these fundamentals can find helpful resources relating to the command -line [here][cli], Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), -http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and -Javascript [here](https://www.javascript.com/learn). Information on node architecture can be found -[here](/content/docs/fundamentals/node-architecture.md) and our guide for configuring Geth to connect to a +Users that need to revisit these fundamentals can find helpful resources relating to the command line [here](https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line), Ethereum and its testnets [here](https://ethereum.org/en/developers/tutorials/), http [here](https://developer.mozilla.org/en-US/docs/Web/HTTP) and Javascript [here](https://www.javascript.com/learn). Information on node architecture can be found [here](/content/docs/fundamentals/node-architecture.md) and our guide for configuring Geth to connect to a consensus client is [here](/content/docs/getting_started/consensus-clients.md). -{% include note.html content="If Geth was installed from source on Linux, `make` saves the -binaries for Geth and the associated tools in `/build/bin`. To run these programs it is -convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) -from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to -execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not -moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) -or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} +{% include note.html content="If Geth was installed from source on Linux, `make` saves the binaries for Geth and the associated tools in `/build/bin`. To run these programs it is convenient to move them to the top level project directory (e.g. running `mv ./build/bin/* ./`) from `/go-ethereum`. Then `./` must be prepended to the commands in the code snippets in order to execute a particular program, e.g. `./geth` instead of simply `geth`. If the executables are not +moved then either navigate to the `bin` directory to run them (e.g. `cd ./build/bin` and `./geth`) or provide their path (e.g. `./build/bin/geth`). These instructions can be ignored for other installations." %} ## Background -Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. -Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being -managed by a central server. Every 12 seconds one node is randomly selected to generate a new block -containing a list of transactions that nodes receiving the block should execute. This "block proposer" node -sends the new block to its peers. On receiving a new block, each node checks that it is valid and adds -it to their database. The sequence of discrete blocks is called a "blockchain". +Geth is an Ethereum client written in Go. This means running Geth turns a computer into an Ethereum node. Ethereum is a peer-to-peer network where information is shared directly between nodes rather than being managed by a central server. Every 12 seconds one node is randomly selected to generate a new block +containing a list of transactions that nodes receiving the block should execute. This "block proposer" node sends the new block to its peers. On receiving a new block, each node checks that it is valid and adds it to their database. The sequence of discrete blocks is called a "blockchain". -The information provided in each block is used by Geth to update its "state" - the ether -balance of each account on Ethereum and the data stored by each smart contract. There are two types of account: -externally-owned accounts (EOAs) and contract accounts. Contract accounts execute contract code when they -receive transactions. EOAs are accounts that users manage locally in order to sign and submit transactions. -Each EOA is a public-private key pair, where the public key is used to derive a unique address for the user and -the private key is used to protect the account and securely sign messages. Therefore, in order to use Ethereum, -it is first necessary to generate an EOA (hereafter, "account"). This tutorial will guide the user through -creating an account, funding it with ether and sending some to another address. +The information provided in each block is used by Geth to update its "state" - the ether balance of each account on Ethereum and the data stored by each smart contract. There are two types of account: externally-owned accounts (EOAs) and contract accounts. Contract accounts execute contract code when they receive transactions. EOAs are accounts that users manage locally in order to sign and submit transactions. Each EOA is a public-private key pair, where the public key is used to derive a unique address for the user and the private key is used to protect the account and securely sign messages. Therefore, in order to use Ethereum, +it is first necessary to generate an EOA (hereafter, "account"). This tutorial will guide the user through creating an account, funding it with ether and sending some to another address. Read more about Ethereum accounts [here](https://ethereum.org/en/developers/docs/accounts/). @@ -82,15 +44,12 @@ To generate a new account in Geth: geth account new ``` -This returns a prompt for a password. Once provided, a new account will be created and added to the -default keystore (`/datadir/keystore`). A custom keystore can also be provided by passing `--keystore `. -In this tutorial the keys will be stored in a new data directory `geth-tutorial`. Create that diredctory, then run: +This returns a prompt for a password. Once provided, a new account will be created and added to the default keystore (`/datadir/keystore`). A custom keystore can also be provided by passing `--keystore `. In this tutorial the keys will be stored in a new data directory `geth-tutorial`. Create that directory, then run: ```sh geth account new --keystore geth-tutorial/keystore ``` -The following will be returned to the console, confirming the new account has been created and -added to the keystore. +The following will be returned to the console, confirming the new account has been created and added to the keystore. ```terminal Your new account is locked with a password. Please give a password. Do not forget this password. @@ -108,33 +67,15 @@ Path of the secret key file: /home/go-ethereum/geth-tutorial/keystore/UTC--2022- - You must REMEMBER your password! Without the password, it's impossible to decrypt the key! ``` -It is important to save the account address and the password somewhere secure. They will be used -again later in this tutorial. Please note that the account address shown in the code snippets -above and later in this tutorials are examples - those generated by followers of this tutorial -will be different. The account generated above can be used as the main account throughout the -remainder of this tutorial. However in order to demonstrate transactions between accounts it is -also necessary to have a second account. A second account can be added to the same keystore by -precisely repeating the previous steps, providing the same password. +It is important to save the account address and the password somewhere secure. They will be used again later in this tutorial. Please note that the account address shown in the code snippets above and later in this tutorials are examples - those generated by followers of this tutorial will be different. The account generated above can be used as the main account throughout the remainder of this tutorial. However in order to demonstrate transactions between accounts it is +also necessary to have a second account. A second account can be added to the same keystore by precisely repeating the previous steps, providing the same password. -Notice that the path to the secret key includes a long filename that starts `UTC--`. This is the -name of the file that contains the keys for the new account. It is **extremely important** that -this file stays secure because it contains the secret key used to control access to any funds -associated with the account. The file should be backed up securely along with the password -used to encrypt it. If the file or the password is lost, then so is access to the funds in -the account. If someone else gains access to the keyfile and password, they have access to any -assets in the account. +Notice that the path to the secret key includes a long filename that starts `UTC--`. This is the name of the file that contains the keys for the new account. It is **extremely important** that this file stays secure because it contains the secret key used to control access to any funds associated with the account. The file should be backed up securely along with the password used to encrypt it. If the file or the password is lost, then so is access to the funds in the account. If someone else gains access to the keyfile and password, they have access to any assets in the account. ## Step 2: Start Geth -Geth is the Ethereum client that will connect the computer to the Ethereum network. -In this tutorial the network is Goerli, an Ethereum testnet. Testnets are used to test -Ethereum client software and smart contracts in an environment where no real-world value -is at risk. To start Geth, run the Geth executable file passing argument that define the -data directory (where Geth should save blockchain data), the network ID and the sync mode. -For this tutorial, snap sync is recommended -(see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). - -The following command should be run in the terminal: +Geth is the Ethereum client that will connect the computer to the Ethereum network. In this tutorial the network is Goerli, an Ethereum testnet. Testnets are used to test Ethereum client software and smart contracts in an environment where no real-world value is at risk. To start Geth, run the Geth executable file passing argument that define the data directory (where Geth should save blockchain data), the network ID and the sync mode. For this tutorial, snap sync is recommended +(see [here](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) for reasons why). The following command should be run in the terminal: ```shell geth --datadir geth-tutorial --goerli --syncmode snap @@ -162,76 +103,42 @@ WARN [02-10|13:59:06.998] Light client mode is an experimental feature INFO [02-10|13:59:08.793] Block synchronisation started ``` -This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers -it can request block headers from them, starting at the genesis block for the Goerli blockchain. -Geth continues to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. -This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in the -terminal with the following syntax: +This indicates that Geth has started up and is searching for peers to connect to. Once it finds peers it can request block headers from them, starting at the genesis block for the Goerli blockchain. Geth continues to download blocks sequentially, saving the data in files in `/go-ethereum/geth-tutorial/geth/chaindata/`. +This is confirmed by the logs printed to the terminal. There should be a rapidly-growing sequence of logs in the terminal with the following syntax: ```terminal - INFO [04-29][15:54:09.238] Looking for peers peercount=2 tried=0 static=0 INFO [04-29][15:54:19.393] Imported new block headers count=2 elapsed=1.127ms number=996288 hash=09f1e3..718c47 age=13h9m5s INFO [04-29][15:54:19:656] Imported new block receipts count=698 elapsed=4.464ms number=994566 hash=56dc44..007c93 age=13h9m9s - ``` These logs indicate that Geth is running as expected. -If there is no error message reported to the terminal, everything is OK. Geth must be running in -order for a user to interact with the Ethereum network. If this terminal is closed down then Geth -must be restarted again. Geth can be started and stopped easily, but it must be running for any -interaction with Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. -To start it again, run the previous command `geth --datadir ... ..`. +If there is no error message reported to the terminal, everything is OK. Geth must be running in order for a user to interact with the Ethereum network. If this terminal is closed down then Geth must be restarted again. Geth can be started and stopped easily, but it must be running for any interaction with Ethereum to take place. To shut down Geth, simply press `CTRL+C` in the Geth terminal. To start it again, run the previous command `geth --datadir `. -{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished -you can't use the node to transfer funds. You can also try doing a [light sync](interface/les) -which will be much quicker but depends on light servers being available to serve your node the data it needs." %} +{% include note.html content="Snap syncing Goerli will take some time and until the sync is finished you can't use the node to transfer funds. You can also try doing a [light sync](interface/les) which will be much quicker but depends on light servers being available to serve your node the data it needs." %} ## Step 3: Get Testnet Ether -In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, -ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; 2) -receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, -having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it -can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether -to their account. +In order to make some transactions, the user must fund their account with ether. On Ethereum mainnet, ether can only be obtained in three ways: 1) by receiving it as a reward for mining/validating; 2) receiving it in a transfer from another Ethereum user or contract; 3) receiving it from an exchange, having paid for it with fiat money. On Ethereum testnets, the ether has no real world value so it can be made freely available via faucets. Faucets allow users to request a transfer of testnet ether to their account. -The address generated by `geth account new` can be pasted into the Paradigm Multifaucet faucet -[here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of -personhood. The faucets adds ether to the given address on multiple testnets simultaneously, -including Goerli. In the next steps Geth will be used to check that the ether has been sent to -the given address and send some of it to the second address created earlier. +The address generated by `geth account new` can be pasted into the Paradigm Multifaucet faucet [here](https://fauceth.komputing.org/?chain=1115511). This requires a Twitter login as proof of personhood. The faucets adds ether to the given address on multiple testnets simultaneously, including Goerli. In the next steps Geth will be used to check that the ether has been sent to the given address and send some of it to the second address created earlier. ## Step 4: Interact with Geth For interacting with the blockchain, Geth provides JSON-RPC APIs. -[JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific tasks -by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. -RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded -instructions from locations outside of those managed by Geth. It is possible to interact with Geth -by sending these JSON encoded instructions directly to Geth using tools such as Curl. However, -this is somewhat user-unfriendly and error-prone, especially for more complex instructions. For this -reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly -interface for interacting with Geth. One of the most widely used is Web3.js. +[JSON-RPC](https://ethereum.org/en/developers/docs/apis/json-rpc/) is a way to execute specific tasks by sending instructions to Geth in the form of [JSON](https://www.json.org/json-en.html) objects. RPC stands for "Remote Procedure Call" and it refers to the ability to send these JSON-encoded instructions from locations outside of those managed by Geth. It is possible to interact with Geth by sending these JSON encoded instructions directly to Geth using tools such as Curl. However, this is somewhat user-unfriendly and error-prone, especially for more complex instructions. For this reason, there are a set of libraries built on top of JSON-RPC that provide a more user-friendly interface for interacting with Geth. One of the most widely used is Web3.js. -Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in -one terminal, a Javascript environment can be opened in another allowing the user to interact with -Geth using Web3.js. There are three transport protocols that can be used to connect the Javascript -environment to Geth: +Geth provides a Javascript console that exposes the Web3.js API. This means that with Geth running in one terminal, a Javascript environment can be opened in another allowing the user to interact with Geth using Web3.js. There are three transport protocols that can be used to connect the Javascript environment to Geth: -- IPC (Inter-Process Communication): Provides unrestricted access to all APIs, but only works when the -- console is run on the same host as the Geth node. +- IPC (Inter-Process Communication): Provides unrestricted access to all APIs, but only works when the console is run on the same host as the Geth node. - HTTP: By default provides access to the `eth`, `web3` and `net` method namespaces. - Websocket: By default provides access to the `eth`, `web3` and `net` method namespaces. -This tutorial will use the IPC option. To do this, the path to Geth's `ipc` file must be known. -By default, this is the `datadir`, in this case `geth-tutorial`. In a new terminal, the following -command can be run to start the Javascript console and connect it to Geth using the `geth.ipc` -file from the datadir: +This tutorial will use the IPC option. To do this, the path to Geth's `ipc` file must be known. By default, this is the `datadir`, in this case `geth-tutorial`. In a new terminal, the following command can be run to start the Javascript console and connect it to Geth using the `geth.ipc` file from the datadir: ```shell geth attach geth-tutorial/geth.ipc @@ -252,12 +159,9 @@ To exit, press ctrl-d or type exit The console is now active and connected to Geth. It can now be used to interact with the Ethereum (Goerli) network. - ### List of accounts -Earlier in this tutorial, at least one account was created using `geth account new`. The following -command will display the addresses of those two accounts and any others that might have been added -to the keystore before or since. +Earlier in this tutorial, at least one account was created using `geth account new`. The following command will display the addresses of those two accounts and any others that might have been added to the keystore before or since. ```javascript eth.accounts @@ -270,21 +174,13 @@ eth.accounts ### Checking account balance. -Having confirmed that the two addresses created earlier are indeed in the keystore and accessible -through the Javascript console, it is possible to retrieve information about how much ether they -own. The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance -of one of the accounts should be 1 ether and the other should be 0. The following command displays -the account balance in the console: +Having confirmed that the two addresses created earlier are indeed in the keystore and accessible through the Javascript console, it is possible to retrieve information about how much ether they own. The Goerli faucet should have sent 1 ETH to the address provided, meaning that the balance of one of the accounts should be 1 ether and the other should be 0. The following command displays the account balance in the console: ```javascript web3.fromWei(eth.getBalance("0xca57F3b40B42FCce3c37B8D18aDBca5260ca72EC"), "ether") ``` -There are actually two instructions sent in the above command. The inner one is the `getBalance` -function from the `eth` namespace. This takes the account address as its only argument. By default, -this returns the account balance in units of Wei. There are 1018 Wei to one ether. To -present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from the -`web3` namespace. Running this command should provide the following result (for the account that +There are actually two instructions sent in the above command. The inner one is the `getBalance` function from the `eth` namespace. This takes the account address as its only argument. By default, this returns the account balance in units of Wei. There are 1018 Wei to one ether. To present the result in units of ether, `getBalance` is wrapped in the `fromWei` function from the `web3` namespace. Running this command should provide the following result (for the account that received faucet funds): ```terminal @@ -299,14 +195,7 @@ Repeating the command for the other new account that was not funded from the fau ### Send ether to another account -The command `eth.sendTransaction` can be used to send some ether from one address to another. -This command takes three arguments: `from`, `to` and `value`. These define the sender and -recipient addresses (as strings) and the amount of Wei to transfer. It is far less error prone -to enter the transaction value in units of ether rather than Wei, so the value field can take the -return value from the `toWei` function. The following command, run in the Javascript console, -sends 0.1 ether from one of the accounts in the keystore to the other. Note that the addresses -here are examples - the user must replace the address in the `from` field with the address -currently owning 1 ether, and the address in the `to` field with the address currently holding 0 ether. +The command `eth.sendTransaction` can be used to send some ether from one address to another. This command takes three arguments: `from`, `to` and `value`. These define the sender and recipient addresses (as strings) and the amount of Wei to transfer. It is far less error prone to enter the transaction value in units of ether rather than Wei, so the value field can take the return value from the `toWei` function. The following command, run in the Javascript console, sends 0.1 ether from one of the accounts in the keystore to the other. Note that the addresses here are examples - the user must replace the address in the `from` field with the address currently owning 1 ether, and the address in the `to` field with the address currently holding 0 ether. ```javascript eth.sendTransaction({ @@ -316,14 +205,7 @@ eth.sendTransaction({ }) ``` -This command will return an error message indicating that `authentication is needed: password or unlock`. -This is a security feature that prevents unauthorized access to sensitive account operations. -There are two ways to unlock the account. The first is to start Geth with the account permanently -unlocked (by passing `--unlock
` at startup). This is not recommended because the account -remains unlocked all the time Geth is running, creating a security weakness. Instead, it is better -to temporarily unlock the account for the specific transaction. This requires using the `sendTransaction` -method from the `personal` namespace instead of the `eth` namespace. The password can be provided as a -string in the method call as follows: +This command will return an error message indicating that `authentication is needed: password or unlock`. This is a security feature that prevents unauthorized access to sensitive account operations. There are two ways to unlock the account. The first is to start Geth with the account permanently unlocked (by passing `--unlock
` at startup). This is not recommended because the account remains unlocked all the time Geth is running, creating a security weakness. Instead, it is better to temporarily unlock the account for the specific transaction. This requires using the `sendTransaction` method from the `personal` namespace instead of the `eth` namespace. The password can be provided as a string in the method call as follows: ```sh personal.sendTransaction({ @@ -333,31 +215,23 @@ personal.sendTransaction({ }, "password") ``` -In the Javascript console, the transaction hash is displayed. This will be used in the next section -to retrieve the transaction details. +In the Javascript console, the transaction hash is displayed. This will be used in the next section to retrieve the transaction details. ```terminal "0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb" ``` -It is also advised to check the account balances using Geth by repeating the instructions from earlier. -At this point in the tutorial, the two accounts in the keystore should have balances just below 0.9 -ether (because 0.1 ether has been transferred out and some small amount paid in transaction gas) and 0.1 ether. +It is also advised to check the account balances using Geth by repeating the instructions from earlier. At this point in the tutorial, the two accounts in the keystore should have balances just below 0.9 ether (because 0.1 ether has been transferred out and some small amount paid in transaction gas) and 0.1 ether. ### Checking the transaction hash -The transaction hash is a unique identifier for this specific transaction that can be used later to -retrieve the transaction details. For example, the transaction details can be viewed by pasting this -hash into the [Goerli block explorer](https://goerli.etherscan.io/). The same information can also -be retrieved directly from the Geth node. The hash returned in the previous step can be provided as -an argument to `eth.getTransaction` to return the transaction information: +The transaction hash is a unique identifier for this specific transaction that can be used later to retrieve the transaction details. For example, the transaction details can be viewed by pasting this hash into the [Goerli block explorer](https://goerli.etherscan.io/). The same information can also be retrieved directly from the Geth node. The hash returned in the previous step can be provided as an argument to `eth.getTransaction` to return the transaction information: ```javascript eth.getTransaction("0x99d489d0bd984915fd370b307c2d39320860950666aac3f261921113ae4f95bb") ``` -This returns the following response (although the actual values for each field will vary because they -are specific to each transaction): +This returns the following response (although the actual values for each field will vary because they are specific to each transaction): ```terminal { @@ -385,24 +259,11 @@ are specific to each transaction): ## Using Curl -Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. -This library enables the user to send instructions to Geth using a more user-friendly interface -compared to sending raw JSON objects. However, it is also possible for the user to send these JSON -objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP requests. -This part of the tutorial demonstrates how to check account balances and send a transaction using Curl. -This requires Geth to expose an HTTP port to listen for requests. This can be configured at startup -by passing the `--http` flag. If no other commands are passed with it, `--http` will expose the -default `localhost:8545` port. +Up to this point this tutorial has interacted with Geth using the convenience library Web3.js. This library enables the user to send instructions to Geth using a more user-friendly interface compared to sending raw JSON objects. However, it is also possible for the user to send these JSON objects directly to Geth's exposed HTTP port. Curl is a command line tool that sends HTTP requests. This part of the tutorial demonstrates how to check account balances and send a transaction using Curl. This requires Geth to expose an HTTP port to listen for requests. This can be configured at startup by passing the `--http` flag. If no other commands are passed with it, `--http` will expose the default `localhost:8545` port. ### Checking account balance -The command below returns the balance of the given account. This is a HTTP POST request to the local -port 8545. The `-H` flag is for header information. It is used here to define the format of the incoming -payload, which is JSON. The `--data` flag defines the content of the payload, which is a JSON object. -That JSON object contains four fields: `jsonrpc` defines the spec version for the JSON-RPC API, `method` -is the specific function being invoked, `params` are the function arguments, and `id` is used for ordering -transactions. The two arguments passed to `eth_getBalance` are the account address whose balance to check -and the block to query (here `latest` is used to check the balance in the most recently mined block). +The command below returns the balance of the given account. This is a HTTP POST request to the local port 8545. The `-H` flag is for header information. It is used here to define the format of the incoming payload, which is JSON. The `--data` flag defines the content of the payload, which is a JSON object. That JSON object contains four fields: `jsonrpc` defines the spec version for the JSON-RPC API, `method` is the specific function being invoked, `params` are the function arguments, and `id` is used for ordering transactions. The two arguments passed to `eth_getBalance` are the account address whose balance to check and the block to query (here `latest` is used to check the balance in the most recently mined block). ```shell curl -X POST http://127.0.0.1:8545 \ @@ -416,9 +277,7 @@ A successful call will return a response like the one below: {"jsonrpc":"2.0","id":1,"result":"0xc7d54951f87f7c0"} ``` -The balance is in the `result` field in the returned JSON object. However, it is denominated in Wei and -presented as a hexadecimal string. There are many options for converting this value to a decimal in units -of ether, for example by opening a Python console and running: +The balance is in the `result` field in the returned JSON object. However, it is denominated in Wei and presented as a hexadecimal string. There are many options for converting this value to a decimal in units of ether, for example by opening a Python console and running: ```python 0xc7d54951f87f7c0 / 1e18 @@ -447,19 +306,11 @@ The following information is returned to the terminal: ### Sending Transactions -It is possible to send transactions using raw curl requests too, but this requires unlocking the sender -account. It is recommended to do this using Clef to manage access to accounts or to use `ipc` instead. The -combination of HTTP and unlocked accounts pose a security risk. +It is possible to send transactions using raw curl requests too, but this requires unlocking the sender account. It is recommended to do this using Clef to manage access to accounts or to use `ipc` instead. The combination of HTTP and unlocked accounts pose a security risk. ## Summary -This tutorial has demonstrated how to generate accounts using Geth's built-in account management tool, -fund them with testnet ether and use those accounts to interact with Ethereum (Goerli) through a Geth -node. Checking account balances, sending transactions and retrieving transaction details were explained using -the web3.js library via the Geth console and using the JSON-RPC directly using Curl. Note that this is an -entry-level tutorial designed to help users get familiar with basic Geth processes, we strongly recommend -following this with the [Geth with Clef](/docs/getting-started/geth_with_clef) tutorial which will help to +This tutorial has demonstrated how to generate accounts using Geth's built-in account management tool, fund them with testnet ether and use those accounts to interact with Ethereum (Goerli) through a Geth node. Checking account balances, sending transactions and retrieving transaction details were explained using +the web3.js library via the Geth console and using the JSON-RPC directly using Curl. Note that this is an entry-level tutorial designed to help users get familiar with basic Geth processes, we strongly recommend following this with the [Geth with Clef](/content/docs/getting-started/geth_with_clef) tutorial which will help to adopt more secure account management practices than those outlined here. - - -[cli]: https://developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools/Command_line + From 8be6f085dc62a8e83c7cbc0eecf1bfdfbafe5c54 Mon Sep 17 00:00:00 2001 From: Joe Date: Mon, 22 Aug 2022 09:40:56 +0100 Subject: [PATCH 039/432] update md formating for rpc pages --- .../JavaScript-Console.md | 2 +- .../docs/interacting_with_geth/RPC/batch.md | 2 +- .../docs/interacting_with_geth/RPC/graphql.md | 8 +- .../interacting_with_geth/RPC/ns-admin.md | 59 ++------- .../interacting_with_geth/RPC/ns-clique.md | 16 +-- .../interacting_with_geth/RPC/ns-debug.md | 124 +++++++----------- .../docs/interacting_with_geth/RPC/ns-eth.md | 65 +++------ .../docs/interacting_with_geth/RPC/ns-les.md | 4 +- .../interacting_with_geth/RPC/ns-miner.md | 11 +- .../docs/interacting_with_geth/RPC/ns-net.md | 2 +- .../interacting_with_geth/RPC/ns-personal.md | 40 ++---- .../interacting_with_geth/RPC/ns-txpool.md | 40 ++---- .../docs/interacting_with_geth/RPC/objects.md | 2 +- .../docs/interacting_with_geth/RPC/pubsub.md | 13 +- .../docs/interacting_with_geth/RPC/server.md | 114 ++++------------ 15 files changed, 146 insertions(+), 356 deletions(-) diff --git a/content/docs/interacting_with_geth/JavaScript-Console.md b/content/docs/interacting_with_geth/JavaScript-Console.md index db4e49d0f8..fdd5746c84 100644 --- a/content/docs/interacting_with_geth/JavaScript-Console.md +++ b/content/docs/interacting_with_geth/JavaScript-Console.md @@ -1,6 +1,6 @@ --- title: JavaScript Console -sort_key: D +description: How to interact with Geth using Javascript --- Geth responds to instructions encoded as JSON objects as defined in the [JSON-RPC-API](/docs/rpc/server). A Geth user can send these instructions directly, for example over HTTP using tools like [Curl](https://github.com/curl/curl). The code snippet below shows a request for an account balance sent to a local Geth node with the HTTP port `8545` exposed. diff --git a/content/docs/interacting_with_geth/RPC/batch.md b/content/docs/interacting_with_geth/RPC/batch.md index 4b60c6622d..f978a5b9b3 100644 --- a/content/docs/interacting_with_geth/RPC/batch.md +++ b/content/docs/interacting_with_geth/RPC/batch.md @@ -1,6 +1,6 @@ --- title: Batch requests -sort_key: C +description: How to make batch requests using JSON-RPC API --- The JSON-RPC [specification](https://www.jsonrpc.org/specification#batch) outlines how clients can send multiple requests at the same time by filling the request objects in an array. This feature is implemented by Geth's API and can be used to cut network delays. Batching offers visible speed-ups specially when used for fetching larger amounts of mostly independent data objects. Below is an example for fetching a list of blocks in JS: diff --git a/content/docs/interacting_with_geth/RPC/graphql.md b/content/docs/interacting_with_geth/RPC/graphql.md index 1abf0a9853..d5a8d22982 100644 --- a/content/docs/interacting_with_geth/RPC/graphql.md +++ b/content/docs/interacting_with_geth/RPC/graphql.md @@ -1,9 +1,9 @@ --- title: GraphQL Server -sort_key: C +description: Documentation for Geth's GraphQL API --- -In addition to the [JSON-RPC APIs](../rpc/server), Geth supports the GraphQL API as specified by [EIP-1767](eip-1767). GraphQL lets you specify which fields of an objects you need as part of the query, eliminating the extra load on the client for filling in fields which are not needed. It also allows for combining several traditional JSON-RPC requests into one query which translates into less overhead and more performance. +In addition to the [JSON-RPC APIs](/content/docs/interacting_with_geth/RPC/server.md), Geth supports the GraphQL API as specified by [EIP-1767](https://eips.ethereum.org/EIPS/eip-1767). GraphQL lets you specify which fields of an objects you need as part of the query, eliminating the extra load on the client for filling in fields which are not needed. It also allows for combining several traditional JSON-RPC requests into one query which translates into less overhead and more performance. The GraphQL endpoint piggybacks on the HTTP transport used by JSON-RPC. Hence the relevant `--http` flags and the `--graphql` flag should be passed to Geth: @@ -31,7 +31,7 @@ GraphiQL also provides a way to explore the schema Geth provides to help you for ### Query -Reading out data from Geth is the biggest use-case for GraphQL. In addition to using the UI queries can also be sent programmatically. The official GraphQL[docs](graphql-code) explain how to find bindings for many languages, or send http requests from the terminal using tools such as Curl. +Reading out data from Geth is the biggest use-case for GraphQL. In addition to using the UI queries can also be sent programmatically. The official GraphQL[docs](https://graphql.org/code/) explain how to find bindings for many languages, or send http requests from the terminal using tools such as Curl. For example, the code snippet below shows how to obtain the latest block number using Curl. Note the use of a JSON object for the data section: @@ -61,5 +61,3 @@ request('http://localhost:8545/graphql', query, { number: '6004067' }) .catch((err) => { console.log(err) }) ``` -[eip-1767]: https://eips.ethereum.org/EIPS/eip-1767 -[graphql-code]: https://graphql.org/code/ diff --git a/content/docs/interacting_with_geth/RPC/ns-admin.md b/content/docs/interacting_with_geth/RPC/ns-admin.md index a545a226d9..d54584f5ef 100644 --- a/content/docs/interacting_with_geth/RPC/ns-admin.md +++ b/content/docs/interacting_with_geth/RPC/ns-admin.md @@ -1,6 +1,6 @@ --- title: admin Namespace -sort_key: C +description: Documentation for the JSON-RPC API "admin" namespace --- The `admin` API gives access to several non-standard RPC methods, which allows fine grained control over a Geth instance, including but not limited to network peer and RPC endpoint management. @@ -8,13 +8,9 @@ The `admin` API gives access to several non-standard RPC methods, which allows f ### admin_addPeer -The `addPeer` administrative method requests adding a new remote node to the list of tracked static -nodes. The node will try to maintain connectivity to these nodes at all times, reconnecting every -once in a while if the remote connection goes down. +The `addPeer` administrative method requests adding a new remote node to the list of tracked static nodes. The node will try to maintain connectivity to these nodes at all times, reconnecting every once in a while if the remote connection goes down. -The method accepts a single argument, the [`enode`](https://ethereum.org/en/developers/docs/networking-layer/network-addresses/#enode) -URL of the remote peer to start tracking and returns a `BOOL` indicating whether the peer was accepted -for tracking or some error occurred. +The method accepts a single argument, the [`enode`](https://ethereum.org/en/developers/docs/networking-layer/network-addresses/#enode) URL of the remote peer to start tracking and returns a `BOOL` indicating whether the peer was accepted for tracking or some error occurred. | Client | Method invocation | |:--------|------------------------------------------------| @@ -31,10 +27,7 @@ true ### admin_addTrustedPeer -Adds the given node to a reserved trusted list which allows the -node to always connect, even if the slots are full. - -It returns a `BOOL` to indicate whether the peer was successfully added to the list. +Adds the given node to a reserved trusted list which allows the node to always connect, even if the slots are full. It returns a `BOOL` to indicate whether the peer was successfully added to the list. | Client | Method invocation | |:--------|------------------------------------------------| @@ -43,8 +36,7 @@ It returns a `BOOL` to indicate whether the peer was successfully added to the l ### admin_datadir -The `datadir` administrative property can be queried for the absolute path the running Geth node -currently uses to store all its databases. +The `datadir` administrative property can be queried for the absolute path the running Geth node currently uses to store all its databases. | Client | Method invocation | |:--------|-----------------------------------| @@ -61,10 +53,7 @@ currently uses to store all its databases. ### admin_exportChain -Exports the current blockchain into a local file. -It optionally takes a first and last block number, in which case it exports only that range of blocks. - -It returns a boolean indicating whether the operation succeeded. +Exports the current blockchain into a local file. It optionally takes a first and last block number, in which case it exports only that range of blocks. It returns a boolean indicating whether the operation succeeded. | Client | Method invocation | |:--------|---------------------------------------------------------------------- | @@ -73,10 +62,7 @@ It returns a boolean indicating whether the operation succeeded. ### admin_importChain -Imports an exported list of blocks from a local file. Importing involves processing the blocks and inserting them -into the canonical chain. The state from the parent block of this range is required. - -It returns a boolean indicating whether the operation succeeded. +Imports an exported list of blocks from a local file. Importing involves processing the blocks and inserting them into the canonical chain. The state from the parent block of this range is required. It returns a boolean indicating whether the operation succeeded. | Client | Method invocation | |:--------|-------------------------------------------------------| @@ -85,11 +71,7 @@ It returns a boolean indicating whether the operation succeeded. ### admin_nodeInfo -The `nodeInfo` administrative property can be queried for all the information known about the running -Geth node at the networking granularity. These include general information about the node itself as a -participant of the [ÐΞVp2p](https://github.com/ethereum/devp2p/blob/master/caps/eth.md) P2P -overlay protocol, as well as specialized information added by each of the running application protocols -(e.g. `eth`, `les`, `shh`, `bzz`). +The `nodeInfo` administrative property can be queried for all the information known about the running Geth node at the networking granularity. These include general information about the node itself as a participant of the [ÐΞVp2p](https://github.com/ethereum/devp2p/blob/master/caps/eth.md) P2P overlay protocol, as well as specialized information added by each of the running application protocols (e.g. `eth`, `les`, `shh`, `bzz`). | Client | Method invocation | |:--------|-------------------------------------------| @@ -124,9 +106,7 @@ overlay protocol, as well as specialized information added by each of the runnin ### admin_peerEvents -PeerEvents creates an [RPC subscription](/docs/rpc/pubsub) which receives peer events from the node's p2p server. - -The type of events emitted by the server are as follows: +PeerEvents creates an [RPC subscription](/docs/rpc/pubsub) which receives peer events from the node's p2p server. The type of events emitted by the server are as follows: - `add`: emitted when a peer is added - `drop`: emitted when a peer is dropped @@ -135,11 +115,7 @@ The type of events emitted by the server are as follows: ### admin_peers -The `peers` administrative property can be queried for all the information known about the connected -remote nodes at the networking granularity. These include general information about the nodes themselves -as participants of the [ÐΞVp2p](https://github.com/ethereum/devp2p/blob/master/caps/eth.md) -P2P overlay protocol, as well as specialized information added by each of the running application -protocols (e.g. `eth`, `les`, `shh`, `bzz`). +The `peers` administrative property can be queried for all the information known about the connected remote nodes at the networking granularity. These include general information about the nodes themselves as participants of the [ÐΞVp2p](https://github.com/ethereum/devp2p/blob/master/caps/eth.md) P2P overlay protocol, as well as specialized information added by each of the running application protocols (e.g. `eth`, `les`, `shh`, `bzz`). | Client | Method invocation | |:--------|------------------------------------------| @@ -186,10 +162,7 @@ protocols (e.g. `eth`, `les`, `shh`, `bzz`). ### admin_removePeer -Disconnects from a remote node if the connection exists. - -It returns a boolean indicating validations succeeded. Note a `true` value doesn't necessarily mean -that there was a connection which was disconnected. +Disconnects from a remote node if the connection exists. It returns a boolean indicating validations succeeded. Note a `true` value doesn't necessarily mean that there was a connection which was disconnected. | Client | Method invocation | |:--------|----------------------------------------------------- | @@ -198,9 +171,7 @@ that there was a connection which was disconnected. ### admin_removeTrustedPeer -Removes a remote node from the trusted peer set, but it does not disconnect it automatically. - -It returns a boolean indicating validations succeeded. +Removes a remote node from the trusted peer set, but it does not disconnect it automatically. It returns a boolean indicating validations succeeded. | Client | Method invocation | |:--------|----------------------------------------------------- | @@ -209,8 +180,7 @@ It returns a boolean indicating validations succeeded. ### admin_startHTTP -The `startHTTP` administrative method starts an HTTP based JSON-RPC [API](/docs/rpc/server) -webserver to handle client requests. All the parameters are optional: +The `startHTTP` administrative method starts an HTTP based JSON-RPC [API](/docs/rpc/server) webserver to handle client requests. All the parameters are optional: * `host`: network interface to open the listener socket on (defaults to `"localhost"`) * `port`: network port to open the listener socket on (defaults to `8545`) @@ -234,8 +204,7 @@ true ### admin_startWS -The `startWS` administrative method starts an WebSocket based [JSON RPC](https://www.jsonrpc.org/specification) -API webserver to handle client requests. All the parameters are optional: +The `startWS` administrative method starts an WebSocket based [JSON RPC](https://www.jsonrpc.org/specification) API webserver to handle client requests. All the parameters are optional: * `host`: network interface to open the listener socket on (defaults to `"localhost"`) * `port`: network port to open the listener socket on (defaults to `8546`) diff --git a/content/docs/interacting_with_geth/RPC/ns-clique.md b/content/docs/interacting_with_geth/RPC/ns-clique.md index 98c68c5317..cd1d2344bc 100644 --- a/content/docs/interacting_with_geth/RPC/ns-clique.md +++ b/content/docs/interacting_with_geth/RPC/ns-clique.md @@ -1,6 +1,6 @@ --- title: clique Namespace -sort_key: C +description: Documentation for the JSON-RPC API "clique" namespace --- The `clique` API provides access to the state of the clique consensus engine. This API cna be used to manage signer votes and to check the health of a private network. @@ -52,8 +52,7 @@ Retrieves the state snapshot at a given block. ### clique_getSigner -Returns the signer for a specific clique block. Can be called with either a blocknumber, blockhash or an rlp encoded blob. -The RLP encoded blob can either be a block or a header. +Returns the signer for a specific clique block. Can be called with either a blocknumber, blockhash or an rlp encoded blob. The RLP encoded blob can either be a block or a header. | Client | Method invocation | |:--------|------------------------------------------------------| @@ -89,10 +88,7 @@ Returns the current proposals the node is voting on. ### clique_propose -Adds a new authorization proposal that the signer will attempt to push through. If the -`auth` parameter is true, the local signer votes for the given address to be included in -the set of authorized signers. With `auth` set to `false`, the vote is against the -address. +Adds a new authorization proposal that the signer will attempt to push through. If the `auth` parameter is true, the local signer votes for the given address to be included in the set of authorized signers. With `auth` set to `false`, the vote is against the address. | Client | Method invocation | |:--------|-----------------------------------------------------------| @@ -101,8 +97,7 @@ address. ### clique_discard -This method drops a currently running proposal. The signer will not cast -further votes (either for or against) the address. +This method drops a currently running proposal. The signer will not cast further votes (either for or against) the address. | Client | Method invocation | |:--------|-----------------------------------------------------| @@ -111,8 +106,7 @@ further votes (either for or against) the address. ### clique_status -This is a debugging method which returns statistics about signer activity -for the last 64 blocks. The returned object contains the following fields: +This is a debugging method which returns statistics about signer activity for the last 64 blocks. The returned object contains the following fields: - `inturnPercent`: percentage of blocks signed in-turn - `sealerActivity`: object containing signer addresses and the number diff --git a/content/docs/interacting_with_geth/RPC/ns-debug.md b/content/docs/interacting_with_geth/RPC/ns-debug.md index f9cbfe0d7b..db5c66feaf 100644 --- a/content/docs/interacting_with_geth/RPC/ns-debug.md +++ b/content/docs/interacting_with_geth/RPC/ns-debug.md @@ -1,6 +1,6 @@ --- title: debug Namespace -sort_key: C +description: Documentation for the JSON-RPC API "clique" namespace --- The `debug` API gives access to several non-standard RPC methods, which allow inspection, debugging and setting certain debugging flags during runtime. @@ -19,9 +19,7 @@ If `incompletes` is false, then accounts for which the key preimage (i.e: the `a ### debug_backtraceAt -Sets the logging backtrace location. When a backtrace location -is set and a log message is emitted at that location, the stack -of the goroutine executing the log statement will be printed to stderr. +Sets the logging backtrace location. When a backtrace location is set and a log message is emitted at that location, the stack of the goroutine executing the log statement will be printed to stderr. The location is specified as `:`. @@ -38,11 +36,7 @@ Example: ### debug_blockProfile -Turns on block profiling for the given duration and writes -profile data to disk. It uses a profile rate of 1 for most -accurate information. If a different rate is desired, set -the rate and write the profile manually using -`debug_writeBlockProfile`. +Turns on block profiling for the given duration and writes profile data to disk. It uses a profile rate of 1 for most accurate information. If a different rate is desired, set the rate and write the profile manually using `debug_writeBlockProfile`. | Client | Method invocation | |:--------|----------------------------------------------------------------| @@ -72,8 +66,7 @@ Returns leveldb properties of the key-value database. ### debug_cpuProfile -Turns on CPU profiling for the given duration and writes -profile data to disk. +Turns on CPU profiling for the given duration and writes profile data to disk. | Client | Method invocation | |:--------|--------------------------------------------------------------| @@ -83,8 +76,7 @@ profile data to disk. ### debug_dbAncient -Retrieves an ancient binary blob from the freezer. The freezer is a collection of append-only immutable files. -The first argument `kind` specifies which table to look up data from. The list of all table kinds are as follows: +Retrieves an ancient binary blob from the freezer. The freezer is a collection of append-only immutable files. The first argument `kind` specifies which table to look up data from. The list of all table kinds are as follows: - `headers`: block headers - `hashes`: canonical hash table (block number -> block hash) @@ -119,8 +111,7 @@ Returns the raw value of a key stored in the database. ### debug_dumpBlock -Retrieves the state that corresponds to the block number and returns a list of accounts (including -storage and code). +Retrieves the state that corresponds to the block number and returns a list of accounts (including storage and code). | Client | Method invocation | |:--------|-------------------------------------------------------| @@ -168,8 +159,7 @@ Forces garbage collection ### debug_freezeClient -Forces a temporary client freeze, normally when the server is overloaded. -Available as part of LES light server. +Forces a temporary client freeze, normally when the server is overloaded. Available as part of LES light server. | Client | Method invocation | |:--------|------------------------------------------------------| @@ -182,8 +172,7 @@ Available as part of LES light server. Returns garbage collection statistics. -See https://golang.org/pkg/runtime/debug/#GCStats for information about -the fields of the returned object. +See https://golang.org/pkg/runtime/debug/#GCStats for information about the fields of the returned object. | Client | Method invocation | |:--------|---------------------------------------------------| @@ -193,10 +182,7 @@ the fields of the returned object. ### debug_getAccessibleState -Returns the first number where the node has accessible state on disk. -This is the post-state of that block and the pre-state of the next -block. The (from, to) parameters are the sequence of blocks -to search, which can go either forwards or backwards. +Returns the first number where the node has accessible state on disk. This is the post-state of that block and the pre-state of the next block. The (from, to) parameters are the sequence of blocks to search, which can go either forwards or backwards. | Client | Method invocation | |:--------|-----------------------------------------------------------------------| @@ -206,8 +192,7 @@ to search, which can go either forwards or backwards. ### debug_getBadBlocks -Returns a list of the last 'bad blocks' that the client has seen on -the network and returns them as a JSON list of block-hashes. +Returns a list of the last 'bad blocks' that the client has seen on the network and returns them as a JSON list of block-hashes. | Client | Method invocation | |:--------|---------------------------------------------------| @@ -247,9 +232,7 @@ Returns all accounts that have changed between the two blocks specified. A chang ### debug_getModifiedAccountsByNumber -Returns all accounts that have changed between the two blocks specified. -A change is defined as a difference in nonce, balance, code hash or -storage hash. +Returns all accounts that have changed between the two blocks specified. A change is defined as a difference in nonce, balance, code hash or storage hash. | Client | Method invocation | |:--------|---------------------------------------------------------------------------------| @@ -267,8 +250,7 @@ Returns the consensus-encoding of all receipts in a single block. ### debug_goTrace -Turns on Go runtime tracing for the given duration and writes -trace data to disk. +Turns on Go runtime tracing for the given duration and writes trace data to disk. | Client | Method invocation | |:--------|-----------------------------------------------------------| @@ -288,8 +270,7 @@ Executes a block (bad- or canon- or side-), and returns a list of intermediate r Returns detailed runtime memory statistics. -See https://golang.org/pkg/runtime/#MemStats for information about -the fields of the returned object. +See https://golang.org/pkg/runtime/#MemStats for information about the fields of the returned object. | Client | Method invocation | |:--------|---------------------------------------------------| @@ -337,10 +318,7 @@ Fetches and retrieves the seed hash of the block by number ### debug_setBlockProfileRate -Sets the rate (in samples/sec) of goroutine block profile -data collection. A non-zero rate enables block profiling, -setting it to zero stops the profile. Collected profile data -can be written using `debug_writeBlockProfile`. +Sets the rate (in samples/sec) of goroutine block profile data collection. A non-zero rate enables block profiling, setting it to zero stops the profile. Collected profile data can be written using `debug_writeBlockProfile`. | Client | Method invocation | |:--------|---------------------------------------------------------------| @@ -349,8 +327,7 @@ can be written using `debug_writeBlockProfile`. ### debug_setGCPercent -Sets the garbage collection target percentage. A negative value disables garbage -collection. +Sets the garbage collection target percentage. A negative value disables garbage collection. | Client | Method invocation | |:--------|---------------------------------------------------| @@ -361,8 +338,7 @@ collection. ### debug_setHead -Sets the current head of the local chain by block number. **Note**, this is a -destructive action and may severely damage the chain. Use with *extreme* caution. +Sets the current head of the local chain by block number. **Note**, this is a destructive action and may severely damage the chain. Use with *extreme* caution. | Client | Method invocation | |:--------|---------------------------------------------------| @@ -384,9 +360,7 @@ Sets the rate of mutex profiling. ### debug_stacks -Returns a printed representation of the stacks of all goroutines. -Note that the web3 wrapper for this method takes care of the printing -and does not return the string. +Returns a printed representation of the stacks of all goroutines. Note that the web3 wrapper for this method takes care of the printing and does not return the string. | Client | Method invocation | |:--------|---------------------------------------------------| @@ -396,8 +370,7 @@ and does not return the string. ### debug_standardTraceBlockToFile -When JS-based tracing (see below) was first implemented, the intended usecase was to enable long-running tracers that could stream results back via a subscription channel. -This method works a bit differently. (For full details, see [PR](https://github.com/ethereum/go-ethereum/pull/17914)) +When JS-based tracing (see below) was first implemented, the intended usecase was to enable long-running tracers that could stream results back via a subscription channel. This method works a bit differently. (For full details, see [PR](https://github.com/ethereum/go-ethereum/pull/17914)) - It streams output to disk during the execution, to not blow up the memory usage on the node - It uses `jsonl` as output format (to allow streaming) @@ -409,12 +382,13 @@ This method works a bit differently. (For full details, see [PR](https://github. This means that this method is only 'useful' for callers who control the node -- at least sufficiently to be able to read the artefacts from the filesystem after the fact. The method can be used to dump a certain transaction out of a given block: -``` + +```sh > debug.standardTraceBlockToFile("0x0bbe9f1484668a2bf159c63f0cf556ed8c8282f99e3ffdb03ad2175a863bca63", {txHash:"0x4049f61ffbb0747bb88dc1c85dd6686ebf225a3c10c282c45a8e0c644739f7e9", disableMemory:true}) ["/tmp/block_0x0bbe9f14-14-0x4049f61f-099048234"] ``` Or all txs from a block: -``` +```sh > debug.standardTraceBlockToFile("0x0bbe9f1484668a2bf159c63f0cf556ed8c8282f99e3ffdb03ad2175a863bca63", {disableMemory:true}) ["/tmp/block_0x0bbe9f14-0-0xb4502ea7-409046657", "/tmp/block_0x0bbe9f14-1-0xe839be8f-954614764", "/tmp/block_0x0bbe9f14-2-0xc6e2052f-542255195", "/tmp/block_0x0bbe9f14-3-0x01b7f3fe-209673214", "/tmp/block_0x0bbe9f14-4-0x0f290422-320999749", "/tmp/block_0x0bbe9f14-5-0x2dc0fb80-844117472", "/tmp/block_0x0bbe9f14-6-0x35542da1-256306111", "/tmp/block_0x0bbe9f14-7-0x3e199a08-086370834", "/tmp/block_0x0bbe9f14-8-0x87778b88-194603593", "/tmp/block_0x0bbe9f14-9-0xbcb081ba-629580052", "/tmp/block_0x0bbe9f14-10-0xc254381a-578605923", "/tmp/block_0x0bbe9f14-11-0xcc434d58-405931366", "/tmp/block_0x0bbe9f14-12-0xce61967d-874423181", "/tmp/block_0x0bbe9f14-13-0x05a20b35-267153288", "/tmp/block_0x0bbe9f14-14-0x4049f61f-606653767", "/tmp/block_0x0bbe9f14-15-0x46d473d2-614457338", "/tmp/block_0x0bbe9f14-16-0x35cf5500-411906321", "/tmp/block_0x0bbe9f14-17-0x79222961-278569788", "/tmp/block_0x0bbe9f14-18-0xad84e7b1-095032683", "/tmp/block_0x0bbe9f14-19-0x4bd48260-019097038", "/tmp/block_0x0bbe9f14-20-0x1517411d-292624085", "/tmp/block_0x0bbe9f14-21-0x6857e350-971385904", "/tmp/block_0x0bbe9f14-22-0xbe3ae2ca-236639695"] @@ -433,7 +407,8 @@ INFO [10-15|13:48:34.421] Wrote trace file=/tmp/block_0x14490c57-2-0x3f4263fe-05 ``` The `options` is as follows: -``` + +```sh type StdTraceConfig struct { *vm.LogConfig Reexec *uint64 @@ -502,9 +477,7 @@ Returns the structured logs created during the execution of EVM against a block ### debug_traceBlock -The `traceBlock` method will return a full stack trace of all invoked opcodes of all transaction -that were included in this block. **Note**, the parent of this block must be present or it will -fail. +The `traceBlock` method will return a full stack trace of all invoked opcodes of all transaction that were included in this block. **Note**, the parent of this block must be present or it will fail. | Client | Method invocation | |:--------|--------------------------------------------------------------------------| @@ -553,8 +526,7 @@ References: ### debug_traceBlockByNumber -Similar to [debug_traceBlock](#debug_traceblock), `traceBlockByNumber` accepts a block number and will replay the -block that is already present in the database. +Similar to [debug_traceBlock](#debug_traceblock), `traceBlockByNumber` accepts a block number and will replay the block that is already present in the database. | Client | Method invocation | |:--------|--------------------------------------------------------------------------------| @@ -567,8 +539,7 @@ References: ### debug_traceBlockByHash -Similar to [debug_traceBlock](#debug_traceblock), `traceBlockByHash` accepts a block hash and will replay the -block that is already present in the database. +Similar to [debug_traceBlock](#debug_traceblock), `traceBlockByHash` accepts a block hash and will replay the block that is already present in the database. | Client | Method invocation | |:--------|---------------------------------------------------------------------------------| @@ -606,7 +577,8 @@ The `debug_traceCall` method enables running an `eth_call` within the context of #### Example No specific call options: -``` + +```sh > debug.traceCall(null, "0x0") { failed: false, @@ -616,7 +588,8 @@ No specific call options: } ``` Tracing a call with a destination and specific sender, disabling the storage and memory output (less data returned over RPC) -``` + +```sh debug.traceCall({ "from": "0xdeadbeef29292929192939494959594933929292", "to": "0xde929f939d939d393f939393f93939f393929023", @@ -626,9 +599,9 @@ debug.traceCall({ "latest", {"disableStorage": true, "disableMemory": true}) ``` -It is possible to supply 'overrides' for both state-data (accounts/storage) and block data (number, timestamp etc). In the example below, -a call which executes `NUMBER` is performed, and the overridden number is placed on the stack: -``` +It is possible to supply 'overrides' for both state-data (accounts/storage) and block data (number, timestamp etc). In the example below, a call which executes `NUMBER` is performed, and the overridden number is placed on the stack: + +```sh > debug.traceCall({ from: eth.accounts[0], value:"0x1", @@ -662,15 +635,14 @@ a call which executes `NUMBER` is performed, and the overridden number is placed ``` Curl example: -``` +```sh > curl -H "Content-Type: application/json" -X POST localhost:8545 --data '{"jsonrpc":"2.0","method":"debug_traceCall","params":[null, "pending"],"id":1}' {"jsonrpc":"2.0","id":1,"result":{"gas":53000,"failed":false,"returnValue":"","structLogs":[]}} ``` ### debug_traceChain -Returns the structured logs created during the execution of EVM between two blocks (excluding start) as a JSON object. -This endpoint must be invoked via `debug_subscribe` as follows: +Returns the structured logs created during the execution of EVM between two blocks (excluding start) as a JSON object. This endpoint must be invoked via `debug_subscribe` as follows: `const res = provider.send('debug_subscribe', ['traceChain', '0x3f3a2a', '0x3f3a2b'])` @@ -681,13 +653,10 @@ please refer to the [subscription page](https://geth.ethereum.org/docs/rpc/pubsu **OBS** In most scenarios, `debug.standardTraceBlockToFile` is better suited for tracing! -The `traceTransaction` debugging method will attempt to run the transaction in the exact same manner -as it was executed on the network. It will replay any transaction that may have been executed prior -to this one before it will finally attempt to execute the transaction that corresponds to the given +The `traceTransaction` debugging method will attempt to run the transaction in the exact same manner as it was executed on the network. It will replay any transaction that may have been executed prior to this one before it will finally attempt to execute the transaction that corresponds to the given hash. -In addition to the hash of the transaction it can take a secondary *optional* argument, which -specifies the options for this specific call. The possible options are: +In addition to the hash of the transaction it can take a secondary *optional* argument, which specifies the options for this specific call. The possible options are: * `disableStorage`: `BOOL`. Setting this to true will disable storage capture (default = false). * `disableStack`: `BOOL`. Setting this to true will disable stack capture (default = false). @@ -856,16 +825,15 @@ Note that several values are Golang big.Int objects, not JavaScript numbers or J Usage example, returns the top element of the stack at each CALL opcode only: - debug.traceTransaction(txhash, {tracer: '{data: [], fault: function(log) {}, step: function(log) { if(log.op.toString() == "CALL") this.data.push(log.stack.peek(0)); }, result: function() { return this.data; }}'}); - +```sh +debug.traceTransaction(txhash, {tracer: '{data: [], fault: function(log) {}, step: function(log) { if(log.op.toString() == "CALL") this.data.push(log.stack.peek(0)); }, result: function() { return this.data; }}'}); +``` ### debug_verbosity -Sets the logging verbosity ceiling. Log messages with level -up to and including the given level will be printed. +Sets the logging verbosity ceiling. Log messages with level up to and including the given level will be printed. -The verbosity of individual packages and source files -can be raised using `debug_vmodule`. +The verbosity of individual packages and source files can be raised using `debug_vmodule`. | Client | Method invocation | |:--------|---------------------------------------------------| @@ -884,8 +852,7 @@ Sets the logging verbosity pattern. #### Examples -To see messages from a particular Go package (directory) -and all subdirectories, use: +To see messages from a particular Go package (directory) and all subdirectories, use: ``` javascript > debug.vmodule("eth/*=6") @@ -921,10 +888,7 @@ Writes a goroutine blocking profile to the given file. ### debug_writeMemProfile -Writes an allocation profile to the given file. -Note that the profiling rate cannot be set through the API, -it must be set on the command line using the `--pprof.memprofilerate` -flag. +Writes an allocation profile to the given file. Note that the profiling rate cannot be set through the API, it must be set on the command line using the `--pprof.memprofilerate` flag. | Client | Method invocation | |:--------|-------------------------------------------------------------| diff --git a/content/docs/interacting_with_geth/RPC/ns-eth.md b/content/docs/interacting_with_geth/RPC/ns-eth.md index fe126eb99d..4756a1c4a1 100644 --- a/content/docs/interacting_with_geth/RPC/ns-eth.md +++ b/content/docs/interacting_with_geth/RPC/ns-eth.md @@ -1,43 +1,33 @@ --- title: eth Namespace -sort_key: C +sort_key: Documentation for the JSON-RPC API "eth" namespace --- Geth provides several extensions to the standard "eth" JSON-RPC namespace. ### eth_subscribe, eth_unsubscribe -These methods are used for real-time events through subscriptions. See the [subscription -documentation](./pubsub) for more information. +These methods are used for real-time events through subscriptions. See the [subscription documentation](/content/docs/interacting_with_geth/RPC/pubsub.md) for more information. ### eth_call -Executes a new message call immediately, without creating a transaction on the block -chain. The `eth_call` method can be used to query internal contract state, to execute -validations coded into a contract or even to test what the effect of a transaction would -be without running it live. +Executes a new message call immediately, without creating a transaction on the block chain. The `eth_call` method can be used to query internal contract state, to execute validations coded into a contract or even to test what the effect of a transaction would be without running it live. #### Parameters -The method takes 3 parameters: an unsigned transaction object to execute in read-only -mode; the block number to execute the call against; and an optional state override-set to -allow executing the call against a modified chain state. +The method takes 3 parameters: an unsigned transaction object to execute in read-only mode; the block number to execute the call against; and an optional state override-set to allow executing the call against a modified chain state. ##### 1. `Object` - Transaction call object -The *transaction call object* is mandatory. Please see [here](/docs/rpc/objects#transaction-call-object) for details. +The *transaction call object* is mandatory. Please see [here](/content/docs/interacting_with_geth/RPC/objects.md) for details. ##### 2. `Quantity | Tag` - Block number or the string `latest` or `pending` -The *block number* is mandatory and defines the context (state) against which the -specified transaction should be executed. It is not possible to execute calls against -reorged blocks; or blocks older than 128 (unless the node is an archive node). +The *block number* is mandatory and defines the context (state) against which the specified transaction should be executed. It is not possible to execute calls against reorged blocks; or blocks older than 128 (unless the node is an archive node). ##### 3. `Object` - State override set -The *state override set* is an optional address-to-state mapping, where each entry -specifies some state to be ephemerally overridden prior to executing the call. Each -address maps to an object containing: +The *state override set* is an optional address-to-state mapping, where each entry specifies some state to be ephemerally overridden prior to executing the call. Each address maps to an object containing: | Field | Type | Bytes | Optional | Description | |:------------|:-----------|:------|:---------|:------------| @@ -49,15 +39,9 @@ address maps to an object containing: The goal of the *state override set* is manyfold: - * It can be used by DApps to reduce the amount of contract code needed to be deployed on - chain. Code that simply returns internal state or does pre-defined validations can be - kept off chain and fed to the node on-demand. - * It can be used for smart contract analysis by extending the code deployed on chain with - custom methods and invoking them. This avoids having to download and reconstruct the - entire state in a sandbox to run custom code against. - * It can be used to debug smart contracts in an already deployed large suite of contracts - by selectively overriding some code or state and seeing how execution changes. - Specialized tooling will probably be necessary. + * It can be used by DApps to reduce the amount of contract code needed to be deployed on chain. Code that simply returns internal state or does pre-defined validations can be kept off chain and fed to the node on-demand. + * It can be used for smart contract analysis by extending the code deployed on chain with custom methods and invoking them. This avoids having to download and reconstruct the entire state in a sandbox to run custom code against. + * It can be used to debug smart contracts in an already deployed large suite of contracts by selectively overriding some code or state and seeing how execution changes. Specialized tooling will probably be necessary. Example: @@ -77,15 +61,11 @@ Example: #### Return Values -The method returns a single `Binary` consisting the return value of the executed contract -call. +The method returns a single `Binary` consisting the return value of the executed contract call. #### Simple example -With a synced Rinkeby node with RPC exposed on localhost (`geth --rinkeby --http`) we can -make a call against the [Checkpoint -Oracle](https://rinkeby.etherscan.io/address/0xebe8efa441b9302a0d7eaecc277c09d20d684540) -to retrieve the list of administrators: +With a synced Rinkeby node with RPC exposed on localhost (`geth --rinkeby --http`) we can make a call against the [CheckpointOracle](https://rinkeby.etherscan.io/address/0xebe8efa441b9302a0d7eaecc277c09d20d684540) to retrieve the list of administrators: ``` $ curl --data '{"method":"eth_call","params":[{"to":"0xebe8efa441b9302a0d7eaecc277c09d20d684540","data":"0x45848dfc"},"latest"],"id":1,"jsonrpc":"2.0"}' -H "Content-Type: application/json" -X POST localhost:8545 @@ -112,13 +92,9 @@ Just for the sake of completeness, decoded the response is: #### Override example -The above *simple example* showed how to call a method already exposed by an on-chain -smart contract. What if we want to access some data not exposed by it? +The above *simple example* showed how to call a method already exposed by an on-chain smart contract. What if we want to access some data not exposed by it? -We can gut out the -[original](https://github.com/ethereum/go-ethereum/blob/master/contracts/checkpointoracle/contract/oracle.sol) -checkpoint oracle contract with one that retains the same fields (to retain the same -storage layout), but one that includes a different method set: +We can gut out the [original](https://github.com/ethereum/go-ethereum/blob/master/contracts/checkpointoracle/contract/oracle.sol) checkpoint oracle contract with one that retains the same fields (to retain the same storage layout), but one that includes a different method set: ``` pragma solidity ^0.5.10; @@ -139,10 +115,7 @@ contract CheckpointOracle { } ``` -With a synced Rinkeby node with RPC exposed on localhost (`geth --rinkeby --http`) we can -make a call against the live [Checkpoint -Oracle](https://rinkeby.etherscan.io/address/0xebe8efa441b9302a0d7eaecc277c09d20d684540), -but override its byte code with our own version that has an accessor for the voting +With a synced Rinkeby node with RPC exposed on localhost (`geth --rinkeby --http`) we can make a call against the live [Checkpoint Oracle](https://rinkeby.etherscan.io/address/0xebe8efa441b9302a0d7eaecc277c09d20d684540), but override its byte code with our own version that has an accessor for the voting threshold field: ``` @@ -163,10 +136,7 @@ Just for the sake of completeness, decoded the response is: `2`. ### eth_createAccessList -This method creates an [EIP2930](https://eips.ethereum.org/EIPS/eip-2930) type `accessList` based on a given `Transaction`. -The `accessList` contains all storage slots and addresses read and written by the transaction, except for the sender account and the precompiles. -This method uses the same `transaction` call [object](/docs/rpc/objects#transaction-call-object) and `blockNumberOrTag` object as `eth_call`. -An `accessList` can be used to unstuck contracts that became inaccessible due to gas cost increases. +This method creates an [EIP2930](https://eips.ethereum.org/EIPS/eip-2930) type `accessList` based on a given `Transaction`. The `accessList` contains all storage slots and addresses read and written by the transaction, except for the sender account and the precompiles. This method uses the same `transaction` call [object](/docs/rpc/objects#transaction-call-object) and `blockNumberOrTag` object as `eth_call`. An `accessList` can be used to unstuck contracts that became inaccessible due to gas cost increases. #### Parameters @@ -185,8 +155,7 @@ curl --data '{"method":"eth_createAccessList","params":[{"from": "0x8cd02c6cbd83 The method `eth_createAccessList` returns list of addresses and storage keys used by the transaction, plus the gas consumed when the access list is added. -That is, it gives the list of addresses and storage keys that will be used by that transaction, plus the gas consumed if the access list is included. Like `eth_estimateGas`, this is an estimation; the list could change when the transaction is actually mined. -Adding an `accessList` to a transaction does not necessary result in lower gas usage compared to a transaction without an access list. +That is, it gives the list of addresses and storage keys that will be used by that transaction, plus the gas consumed if the access list is included. Like `eth_estimateGas`, this is an estimation; the list could change when the transaction is actually mined. Adding an `accessList` to a transaction does not necessary result in lower gas usage compared to a transaction without an access list. Example: ```json diff --git a/content/docs/interacting_with_geth/RPC/ns-les.md b/content/docs/interacting_with_geth/RPC/ns-les.md index cbc965b832..fa12d51372 100644 --- a/content/docs/interacting_with_geth/RPC/ns-les.md +++ b/content/docs/interacting_with_geth/RPC/ns-les.md @@ -1,12 +1,10 @@ --- title: les Namespace -sort_key: C +description: Documentation for the JSON-RPC API "les" namespace --- The `les` API is for managing LES server settings, including client parameters and payment settings for prioritized clients. It also provides functions to query checkpoint information in both server and client mode. -* TOC -{:toc} ### les_serverInfo diff --git a/content/docs/interacting_with_geth/RPC/ns-miner.md b/content/docs/interacting_with_geth/RPC/ns-miner.md index 8eea5e8c87..720b9fc351 100644 --- a/content/docs/interacting_with_geth/RPC/ns-miner.md +++ b/content/docs/interacting_with_geth/RPC/ns-miner.md @@ -1,6 +1,6 @@ --- title: miner Namespace -sort_key: C +description: Documentation for the JSON-RPC API "miner" namespace --- The `miner` API is **now deprecated** because mining was switched off at the transition to proof-of-stake. It existed to provide remote control the node's mining operation and set various mining specific settings. It is provided here for historical interest! @@ -16,8 +16,7 @@ Get hashrate in H/s (Hash operations per second). ### miner_setExtra -Sets the extra data a miner can include when miner blocks. This is capped at -32 bytes. +Sets the extra data a miner can include when miner blocks. This is capped at 32 bytes. | Client | Method invocation | |:--------|----------------------------------------------------| @@ -27,8 +26,7 @@ Sets the extra data a miner can include when miner blocks. This is capped at ### miner_setGasPrice -Sets the minimal accepted gas price when mining transactions. Any transactions that are -below this limit are excluded from the mining process. +Sets the minimal accepted gas price when mining transactions. Any transactions that are below this limit are excluded from the mining process. | Client | Method invocation | |:--------|-------------------------------------------------------| @@ -47,8 +45,7 @@ Updates the interval for recomitting the miner sealing work. ### miner_start -Start the CPU mining process with the given number of threads and generate a new DAG -if need be. +Start the CPU mining process with the given number of threads and generate a new DAG if need be. | Client | Method invocation | |:--------|-----------------------------------------------------| diff --git a/content/docs/interacting_with_geth/RPC/ns-net.md b/content/docs/interacting_with_geth/RPC/ns-net.md index ad4ee571a3..bacd9a8a04 100644 --- a/content/docs/interacting_with_geth/RPC/ns-net.md +++ b/content/docs/interacting_with_geth/RPC/ns-net.md @@ -1,6 +1,6 @@ --- title: net Namespace -sort_key: C +description: Documentation for the JSON-RPC API "net" namespace --- The `net` API provides insight about the networking aspect of the client. diff --git a/content/docs/interacting_with_geth/RPC/ns-personal.md b/content/docs/interacting_with_geth/RPC/ns-personal.md index 6a2d7903fc..da00e87e62 100644 --- a/content/docs/interacting_with_geth/RPC/ns-personal.md +++ b/content/docs/interacting_with_geth/RPC/ns-personal.md @@ -1,6 +1,6 @@ --- title: personal Namespace -sort_key: C +description: Documentation for the JSON-RPC API "personal" namespace --- The personal API manages private keys in the key store. @@ -16,8 +16,7 @@ Requests a HD wallet to derive a new account, optionally pinning it for later re ### personal_importRawKey -Imports the given unencrypted private key (hex string) into the key store, -encrypting it with the passphrase. +Imports the given unencrypted private key (hex string) into the key store, encrypting it with the passphrase. Returns the address of the new account. @@ -37,8 +36,7 @@ Initializes a new wallet at the provided URL by generating and returning a new p ### personal_listAccounts -Returns all the Ethereum account addresses of all keys -in the key store. +Returns all the Ethereum account addresses of all keys in the key store. | Client | Method invocation | | :--------| --------------------------------------------------- | @@ -77,8 +75,7 @@ Returns a list of wallets this node manages. ### personal_lockAccount -Removes the private key with given address from memory. -The account can no longer be used to send transactions. +Removes the private key with given address from memory. The account can no longer be used to send transactions. | Client | Method invocation | | :--------| -------------------------------------------------------- | @@ -87,12 +84,8 @@ The account can no longer be used to send transactions. ### personal_newAccount -Generates a new private key and stores it in the key store directory. -The key file is encrypted with the given passphrase. -Returns the address of the new account. - -At the geth console, `newAccount` will prompt for a passphrase when -it is not supplied as the argument. +Generates a new private key and stores it in the key store directory. The key file is encrypted with the given passphrase. +Returns the address of the new account. At the geth console, `newAccount` will prompt for a passphrase when it is not supplied as the argument. | Client | Method invocation | | :--------| --------------------------------------------------- | @@ -117,10 +110,8 @@ The passphrase can also be supplied as a string. ### personal_openWallet -Initiates a hardware wallet opening procedure by establishing a USB -connection and then attempting to authenticate via the provided passphrase. Note, -the method may return an extra challenge requiring a second open (e.g. the -Trezor PIN matrix challenge). +Initiates a hardware wallet opening procedure by establishing a USB connection and then attempting to authenticate via the provided passphrase. Note, +the method may return an extra challenge requiring a second open (e.g. the Trezor PIN matrix challenge). | Client | Method invocation | | :--------| ----------------------------------------------------------- | @@ -131,13 +122,8 @@ Trezor PIN matrix challenge). Decrypts the key with the given address from the key store. -Both passphrase and unlock duration are optional when using the JavaScript console. -If the passphrase is not supplied as an argument, the console will prompt for -the passphrase interactively. - -The unencrypted key will be held in memory until the unlock duration expires. -If the unlock duration defaults to 300 seconds. An explicit duration -of zero seconds unlocks the key until geth exits. +Both passphrase and unlock duration are optional when using the JavaScript console. If the passphrase is not supplied as an argument, the console will prompt for +the passphrase interactively. The unencrypted key will be held in memory until the unlock duration expires. If the unlock duration defaults to 300 seconds. An explicit duration of zero seconds unlocks the key until geth exits. The account can be used with `eth_sign` and `eth_sendTransaction` while it is unlocked. @@ -162,8 +148,7 @@ Supplying the passphrase and unlock duration as arguments: true ``` -To type in the passphrase and still override the default unlock duration, -pass `null` as the passphrase. +To type in the passphrase and still override the default unlock duration, pass `null` as the passphrase. ``` > personal.unlockAccount("0x5e97870f263700f46aa00d967821199b9bc5a120", null, 30) @@ -225,7 +210,7 @@ See ecRecover to verify the signature. ### personal_signTransaction -SignTransaction will create a transaction from the given arguments and tries to sign it with the key associated with `tx.from`. If the given passwd isn't able to decrypt the key it fails. The transaction is returned in RLP-form, not broadcast to other nodes. The first argument is a [transaction object](/docs/rpc/objects#transaction-call-object) and the second argument is the password, similar to `personal_sendTransaction`. +SignTransaction will create a transaction from the given arguments and tries to sign it with the key associated with `tx.from`. If the given passwd isn't able to decrypt the key it fails. The transaction is returned in RLP-form, not broadcast to other nodes. The first argument is a [transaction object](/content/docs/interacting_with_geth/RPC/objects.md) and the second argument is the password, similar to `personal_sendTransaction`. | Client | Method invocation | | :--------| -----------------------------------------------------------------| @@ -250,4 +235,3 @@ SignTransaction will create a transaction from the given arguments and tries to > personal.ecRecover("0xdeadbeaf", "0xa3f20717a250c2b0b729b7e5becbff67fdaef7e0699da4de7ca5895b02a170a12d887fd3b17bfdce3481f10bea41f45ba9f709d39ce8325427b57afcfc994cee1b") "0x9b2055d370f73ec7d8a03e965129118dc8f5bf83" ``` - diff --git a/content/docs/interacting_with_geth/RPC/ns-txpool.md b/content/docs/interacting_with_geth/RPC/ns-txpool.md index 1790ec9dcc..caeb230af8 100644 --- a/content/docs/interacting_with_geth/RPC/ns-txpool.md +++ b/content/docs/interacting_with_geth/RPC/ns-txpool.md @@ -1,25 +1,17 @@ --- title: txpool Namespace -sort_key: C +description: Documentation for the JSON-RPC API "txpool" namespace --- -The `txpool` API gives access to several non-standard RPC methods to inspect the contents of the -transaction pool containing all the currently pending transactions as well as the ones queued for -future processing. +The `txpool` API gives access to several non-standard RPC methods to inspect the contents of the transaction pool containing all the currently pending transactions as well as the ones queued for future processing. ### txpool_content -The `content` inspection property can be queried to list the exact details of all the transactions -currently pending for inclusion in the next block(s), as well as the ones that are being scheduled -for future execution only. +The `content` inspection property can be queried to list the exact details of all the transactions currently pending for inclusion in the next block(s), as well as the ones that are being scheduled for future execution only. -The result is an object with two fields `pending` and `queued`. Each of these fields are associative -arrays, in which each entry maps an origin-address to a batch of scheduled transactions. These batches -themselves are maps associating nonces with actual transactions. +The result is an object with two fields `pending` and `queued`. Each of these fields are associative arrays, in which each entry maps an origin-address to a batch of scheduled transactions. These batches themselves are maps associating nonces with actual transactions. -Please note, there may be multiple transactions associated with the same account and nonce. This can -happen if the user broadcast mutliple ones with varying gas allowances (or even completely different -transactions). +Please note, there may be multiple transactions associated with the same account and nonce. This can happen if the user broadcast mutliple ones with varying gas allowances (or even completely different transactions). | Client | Method invocation | |:-------:|-----------------------------------------------------------------------| @@ -114,8 +106,7 @@ transactions). ### txpool_contentFrom -Retrieves the transactions contained within the txpool, -returning pending as well as queued transactions of this address, grouped by nonce. +Retrieves the transactions contained within the txpool, returning pending as well as queued transactions of this address, grouped by nonce. | Client | Method invocation | |:-------:|--------------------------------------------------------| @@ -124,18 +115,11 @@ returning pending as well as queued transactions of this address, grouped by non ### txpool_inspect -The `inspect` inspection property can be queried to list a textual summary of all the transactions -currently pending for inclusion in the next block(s), as well as the ones that are being scheduled -for future execution only. This is a method specifically tailored to developers to quickly see the -transactions in the pool and find any potential issues. +The `inspect` inspection property can be queried to list a textual summary of all the transactions currently pending for inclusion in the next block(s), as well as the ones that are being scheduled for future execution only. This is a method specifically tailored to developers to quickly see the transactions in the pool and find any potential issues. -The result is an object with two fields `pending` and `queued`. Each of these fields are associative -arrays, in which each entry maps an origin-address to a batch of scheduled transactions. These batches -themselves are maps associating nonces with transactions summary strings. +The result is an object with two fields `pending` and `queued`. Each of these fields are associative arrays, in which each entry maps an origin-address to a batch of scheduled transactions. These batches themselves are maps associating nonces with transactions summary strings. -Please note, there may be multiple transactions associated with the same account and nonce. This can -happen if the user broadcast mutliple ones with varying gas allowances (or even completely different -transactions). +Please note, there may be multiple transactions associated with the same account and nonce. This can happen if the user broadcast mutliple ones with varying gas allowances (or even completely different transactions). | Client | Method invocation | |:-------:|--------------------------------------------------------------| @@ -200,11 +184,9 @@ transactions). ### txpool_status -The `status` inspection property can be queried for the number of transactions currently pending for -inclusion in the next block(s), as well as the ones that are being scheduled for future execution only. +The `status` inspection property can be queried for the number of transactions currently pending for inclusion in the next block(s), as well as the ones that are being scheduled for future execution only. -The result is an object with two fields `pending` and `queued`, each of which is a counter representing -the number of transactions in that particular state. +The result is an object with two fields `pending` and `queued`, each of which is a counter representing the number of transactions in that particular state. | Client | Method invocation | |:--------|-----------------------------------------------| diff --git a/content/docs/interacting_with_geth/RPC/objects.md b/content/docs/interacting_with_geth/RPC/objects.md index 703270687e..504cfa624c 100644 --- a/content/docs/interacting_with_geth/RPC/objects.md +++ b/content/docs/interacting_with_geth/RPC/objects.md @@ -1,6 +1,6 @@ --- title: Objects -sort_key: D +description: Data structures used for RPC methods --- The following are data structures which are used for various RPC methods. diff --git a/content/docs/interacting_with_geth/RPC/pubsub.md b/content/docs/interacting_with_geth/RPC/pubsub.md index 007ecfb06d..59e822d01c 100644 --- a/content/docs/interacting_with_geth/RPC/pubsub.md +++ b/content/docs/interacting_with_geth/RPC/pubsub.md @@ -1,6 +1,6 @@ --- title: Real-time Events -sort_key: B +description: How to subscribe to events using JSON-RPC notifications. --- Geth v1.4 and later support publish / subscribe using JSON-RPC notifications. This allows clients to wait for events instead of polling for them. @@ -54,9 +54,7 @@ Subscriptions are created with a regular RPC call with `eth_subscribe` as method ## Cancel subscription -Subscriptions are cancelled with a regular RPC call with `eth_unsubscribe` as method and -the subscription id as first parameter. It returns a bool indicating if the subscription -was cancelled successful. +Subscriptions are cancelled with a regular RPC call with `eth_unsubscribe` as method and the subscription id as first parameter. It returns a bool indicating if the subscription was cancelled successful. ### Parameters 1. subscription id @@ -74,8 +72,7 @@ was cancelled successful. Fires a notification each time a new header is appended to the chain, including chain reorganizations. Users can use the bloom filter to determine if the block contains logs that are interested to them. Note that if geth receives multiple blocks simultaneously, e.g. catching up after being out of sync, only the last block is emitted. -In case of a chain reorganization the subscription will emit the last header in the new -chain. Therefore the subscription can emit multiple headers on the same height. +In case of a chain reorganization the subscription will emit the last header in the new chain. Therefore the subscription can emit multiple headers on the same height. #### Example @@ -169,9 +166,7 @@ returns ### syncing -Indicates when the node starts or stops synchronizing. The result can either be a boolean -indicating that the synchronization has started (true), finished (false) or an object with -various progress indicators. +Indicates when the node starts or stops synchronizing. The result can either be a boolean indicating that the synchronization has started (true), finished (false) or an object with various progress indicators. #### Parameters diff --git a/content/docs/interacting_with_geth/RPC/server.md b/content/docs/interacting_with_geth/RPC/server.md index 5021a7b8d7..a45f6311c1 100644 --- a/content/docs/interacting_with_geth/RPC/server.md +++ b/content/docs/interacting_with_geth/RPC/server.md @@ -1,31 +1,21 @@ --- title: JSON-RPC Server -sort_key: A +sort_key: Introduction to the JSON-RPC server --- -Interacting with Geth requires sending requests to specific JSON-RPC API -methods. Geth supports all standard [JSON-RPC API][web3-rpc] endpoints. -The RPC requests must be sent to the node and the response returned to the client -using some transport protocol. This page outlines the available transport protocols -in Geth, providing the information users require to choose a transport protocol for -a specific user scenario. +Interacting with Geth requires sending requests to specific JSON-RPC API methods. Geth supports all standard [JSON-RPC API](https://github.com/ethereum/execution-apis) endpoints. +The RPC requests must be sent to the node and the response returned to the client using some transport protocol. This page outlines the available transport protocols in Geth, providing the information users require to choose a transport protocol for a specific user scenario. -{:toc} -- this will be removed by the toc ## Introduction -JSON-RPC is provided on multiple transports. Geth supports JSON-RPC over HTTP, -WebSocket and Unix Domain Sockets. Transports must be enabled through -command-line flags. +JSON-RPC is provided on multiple transports. Geth supports JSON-RPC over HTTP, WebSocket and Unix Domain Sockets. Transports must be enabled through +command-line flags. -Ethereum JSON-RPC APIs use a name-space system. RPC methods are grouped into -several categories depending on their purpose. All method names are composed of -the namespace, an underscore, and the actual method name within the namespace. -For example, the `eth_call` method resides in the `eth` namespace. +Ethereum JSON-RPC APIs use a name-space system. RPC methods are grouped into several categories depending on their purpose. All method names are composed of +the namespace, an underscore, and the actual method name within the namespace. For example, the `eth_call` method resides in the `eth` namespace. -Access to RPC methods can be enabled on a per-namespace basis. Find -documentation for individual namespaces in the sidebar. +Access to RPC methods can be enabled on a per-namespace basis. Find documentation for individual namespaces in the sidebar. ## Transports @@ -33,50 +23,35 @@ There are three transport protocols available in Geth: IPC, HTTP and Websockets. ### HTTP Server -[HTTP](https://developer.mozilla.org/en-US/docs/Web/HTTP) is a unidirectional transport protocol -that connects a client and server. The client sends a request to the server, and the server -returns a response back to the client. An HTTP connection is closed after the response for a given -request is sent. +[HTTP](https://developer.mozilla.org/en-US/docs/Web/HTTP) is a unidirectional transport protocol that connects a client and server. The client sends a request to the server, and the server returns a response back to the client. An HTTP connection is closed after the response for a given request is sent. -HTTP is supported in every browser as well as almost all programming toolchains. Due to its ubiquity -it has become the most widely used transport for interacting with Geth. To start a HTTP server in Geth, include the `--http` flag: +HTTP is supported in every browser as well as almost all programming toolchains. Due to its ubiquity it has become the most widely used transport for interacting with Geth. To start a HTTP server in Geth, include the `--http` flag: ```sh geth --http ``` -If no other commands are provided, Geth falls back to its default behaviour of accepting connections -from the local loopback interface (127.0.0.1). The default listening port is 8545. The ip address and -listening port can be customized using the `--http.addr` and `--http.port` flags: +If no other commands are provided, Geth falls back to its default behaviour of accepting connections from the local loopback interface (127.0.0.1). The default listening port is 8545. The ip address and listening port can be customized using the `--http.addr` and `--http.port` flags: ```sh geth --http --http.port 3334 ``` -Not all of the JSON-RPC method namespaces are enabled for HTTP requests by default. -Instead, they have to be whitelisted explicitly when Geth is started. Calling non-whitelisted -RPC namespaces returns an RPC error with code `-32602`. +Not all of the JSON-RPC method namespaces are enabled for HTTP requests by default. Instead, they have to be whitelisted explicitly when Geth is started. Calling non-whitelisted RPC namespaces returns an RPC error with code `-32602`. -The default whitelist allows access to the `eth`, `net` and `web3` namespaces. To enable access -to other APIs like account management (`personal`) and debugging (`debug`), they must be configured -using the `--http.api` flag. Enabling these APIs over HTTP is **not recommended** because access -to these methods increases the attack surface. +The default whitelist allows access to the `eth`, `net` and `web3` namespaces. To enable access to other APIs like account management (`personal`) and debugging (`debug`), they must be configured using the `--http.api` flag. Enabling these APIs over HTTP is **not recommended** because access to these methods increases the attack surface. ```sh geth --http --http.api personal,eth,net,web3 ``` -Since the HTTP server is reachable from any local application, additional protection is built into -the server to prevent misuse of the API from web pages. To enable access to the API from a web page -(for example to use the online IDE, [Remix](https://remix.ethereum.org)), the server needs to be -configured to accept Cross-Origin requests. This is achieved using the `--http.corsdomain` flag. +Since the HTTP server is reachable from any local application, additional protection is built into the server to prevent misuse of the API from web pages. To enable access to the API from a web page (for example to use the online IDE, [Remix](https://remix.ethereum.org)), the server needs to be configured to accept Cross-Origin requests. This is achieved using the `--http.corsdomain` flag. ```sh geth --http --http.corsdomain https://remix.ethereum.org ``` -The `--http.corsdomain` command also acceptsd wildcards that enable access to the RPC from any -origin: +The `--http.corsdomain` command also acceptsd wildcards that enable access to the RPC from any origin: ```sh --http.corsdomain '*' @@ -84,28 +59,19 @@ origin: ### WebSocket Server -Websocket is a bidirectional transport protocol. A Websocket connection is maintained by client and server -until it is explicitly terminated by one. Most modern browsers support Websocket which means -it has good tooling. +Websocket is a bidirectional transport protocol. A Websocket connection is maintained by client and server until it is explicitly terminated by one. Most modern browsers support Websocket which means it has good tooling. -Because Websocket is bidirectional, servers can push events to clients. That makes Websocket a good -choice for use-cases involving [event subscription](https://geth.ethereum.org/docs/rpc/pubsub). Another -benefit of Websocket is that after the handshake procedure, the overhead of individual messages is low, +Because Websocket is bidirectional, servers can push events to clients. That makes Websocket a good choice for use-cases involving [event subscription](https://geth.ethereum.org/docs/rpc/pubsub). Another benefit of Websocket is that after the handshake procedure, the overhead of individual messages is low, making it good for sending high number of requests. -Configuration of the WebSocket endpoint in Geth follows the same pattern as the HTTP transport. -WebSocket access can be enabled using the `--ws` flag. If no additional information is provided, -Geth falls back to its default behaviour which is to establish the Websocket on port 8546. -The `--ws.addr`, `--ws.port` and `--ws.api` flags can be used to customize settings -for the WebSocket server. For example, to start Geth with a Websocket connection for RPC using +Configuration of the WebSocket endpoint in Geth follows the same pattern as the HTTP transport. WebSocket access can be enabled using the `--ws` flag. If no additional information is provided, Geth falls back to its default behaviour which is to establish the Websocket on port 8546. The `--ws.addr`, `--ws.port` and `--ws.api` flags can be used to customize settings for the WebSocket server. For example, to start Geth with a Websocket connection for RPC using the custom port 3334 and whitelisting the `eth`, `net` and `web3` namespaces: ```sh geth --ws --ws.port 3334 --ws.api eth,net,web3 ``` -Cross-Origin request protection also applies to the WebSocket server. The -`--ws.origins` flag can be used to allow access to the server from web pages: +Cross-Origin request protection also applies to the WebSocket server. The `--ws.origins` flag can be used to allow access to the server from web pages: ```sh geth --ws --ws.origins http://myapp.example.com @@ -113,29 +79,16 @@ geth --ws --ws.origins http://myapp.example.com As with `--http.corsdomain`, using the wildcard `--ws.origins '*'` allows access from any origin. -{% include note.html content=" By default, **account unlocking is forbidden when HTTP or -Websocket access is enabled** (i.e. by passing `--http` or `ws` flag). This is because an -attacker that manages to access the node via the externally-exposed HTTP/WS port can then -control the unlocked account. It is possible to force account unlock by including the -`--allow-insecure-unlock` flag but this is unsafe and **not recommended** except for expert -users that completely understand how it can be used safely. -This is not a hypothetical risk: **there are bots that continually scan for http-enabled -Ethereum nodes to attack**" %} +{% include note.html content=" By default, **account unlocking is forbidden when HTTP or Websocket access is enabled** (i.e. by passing `--http` or `ws` flag). This is because an attacker that manages to access the node via the externally-exposed HTTP/WS port can then control the unlocked account. It is possible to force account unlock by including the `--allow-insecure-unlock` flag but this is unsafe and **not recommended** except for expert users that completely understand how it can be used safely. This is not a hypothetical risk: **there are bots that continually scan for http-enabled Ethereum nodes to attack**" %} ### IPC Server -IPC is normally available for use in local environments where the node and the console -exist on the same machine. Geth creates a pipe in the computers local file system -(at `ipcpath`) that configures a connection between node and console. The `geth.ipc` file can -also be used by other processes on the same machine to interact with Geth. +IPC is normally available for use in local environments where the node and the console exist on the same machine. Geth creates a pipe in the computers local file system (at `ipcpath`) that configures a connection between node and console. The `geth.ipc` file can also be used by other processes on the same machine to interact with Geth. -On UNIX-based systems (Linux, OSX) the IPC is a UNIX domain socket. On Windows IPC is -provided using named pipes. The IPC server is enabled by default and has access to all -JSON-RPC namespaces. +On UNIX-based systems (Linux, OSX) the IPC is a UNIX domain socket. On Windows IPC is provided using named pipes. The IPC server is enabled by default and has access to all JSON-RPC namespaces. -The listening socket is placed into the data directory by default. On Linux and macOS, -the default location of the geth socket is +The listening socket is placed into the data directory by default. On Linux and macOS, the default location of the geth socket is ```sh ~/.ethereum/geth.ipc @@ -152,8 +105,7 @@ using the `--ipcdisable` flag. ## Choosing a transport protocol -The following table summarizes the relative strengths and weaknesses of each transport -protocol so that users can make informed decisions about which to use. +The following table summarizes the relative strengths and weaknesses of each transport protocol so that users can make informed decisions about which to use. | | HTTP | WS | IPC | | :----------------------------------:|:-----------:|:--------:|:-------:| @@ -161,22 +113,10 @@ protocol so that users can make informed decisions about which to use. | Remote connection | **Y** | **Y** | N | | Per-message metadata overhead | high | low | low | -As a general rule IPC is most secure because it is limited to interactions on the -local machine and cannot be exposed to external traffic. It can also be used -to subscribe to events. HTTP is a familiar and idempotent transport that closes -connections between requests and can therefore have lower overall overheads if the number -of requests is fairly low. Websockets provides a continuous open channel that can enable -event subscriptions and streaming and handle large volumes of requests with smaller per-message -overheads. +As a general rule IPC is most secure because it is limited to interactions on the local machine and cannot be exposed to external traffic. It can also be used +to subscribe to events. HTTP is a familiar and idempotent transport that closes connections between requests and can therefore have lower overall overheads if the number of requests is fairly low. Websockets provides a continuous open channel that can enable event subscriptions and streaming and handle large volumes of requests with smaller per-message overheads. ## Summary -RPC requests to a Geth node can be made using three different transport protocols. The -protocols are enabled at startup using their respective flags. The right choice of transport -protocol depends on the specific use case. - - -[web3-rpc]: https://github.com/ethereum/execution-apis -[remix]: https://remix.ethereum.org -[rpc]: https://www.ibm.com/docs/en/aix/7.1?topic=concepts-remote-procedure-call +RPC requests to a Geth node can be made using three different transport protocols. The protocols are enabled at startup using their respective flags. The right choice of transport protocol depends on the specific use case. From 5fc950e0051f7a8bf4fef85dd40fce77d79c07d4 Mon Sep 17 00:00:00 2001 From: Joe Date: Mon, 22 Aug 2022 09:48:25 +0100 Subject: [PATCH 040/432] delete redundant page tracker --- misc/page-tracker.xlsx | Bin 6742 -> 0 bytes 1 file changed, 0 insertions(+), 0 deletions(-) delete mode 100644 misc/page-tracker.xlsx diff --git a/misc/page-tracker.xlsx b/misc/page-tracker.xlsx deleted file mode 100644 index c248c3bcaa4ca496e2b8ba8ba1cadc5b7a6af263..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 6742 zcmaKR1ys~s*Doa@-3+BXU?wq?cY&VKtv*dLq$b})3?6XfcrzxAD)e!&23%S*&g4^jN?kLHOu5yT{lk@)GAiSYe)US2Q$~|UZDewXn{acebA~AXHn8H(@CPGQw%HX!)h!2&=qne#iX_LC$%@e#In^P_u^)4b8wQ=Uf?UgiKT z8b0*pMvo`Fjgk=m9NA)}(KyB0GdqAkaRWl9-t}7?#oJW$Z-T(!D{2hGFSMaiW7xcm z2Vxkq(Y;GrIn}oHtiiy-3Yr-HQA;CyC~!Fas#F_n9F=t9?PsMn6s~4%qmZjS#oUV-y{NF9 zfqTOFh9J+46llh_W%g5_2-5PM(=A`;S)D%2IFF9}xBoKVc!X+0uDxuoB zNE|15U{VB0-(ttX*kriQ3X_;~=2G>Yd?H?k1|{<|9GhP9mr{NnDvr}o<=7WP1o6;} z|KWPCprmGoEO;xx#Ch~iYQ(oKQ+mpbFA8}=kOH&&*q!T=gG>c^*DiH(C0>b3#V@{$ zVlU8FPG&hL+hGHK2pX*Ab@;r&J<)q;?~anYL%Vm6_%UWaedLD1;Njrx5&tb_F#i)X zF0LN7<}QyB1JymMOb{lxJ2V!*HZ%bchnghsd&BzJ`*wIaIemAss`@75CwI4u9k3xJ z2Mu@0^oR6Stm7`%>92jp-pjOXTveDZ5z~@0Um_@dMH-+J#(%ZBi2&-*7x_w8`8Ihw z8BLkUN`>rP*e8+4`ujjDCe6?k?#Eg&^87u^_GL42wbiZgBDC4B5(7_JAc^_QKjK%~ z;8nlQ{H1oPwB_jtRI?�>guTQEel2=pKk4PI@}kD~cqW zAaSgoj!G(-%Cp?Yp1k`E-gUc)w!nv_I9zolq6WmNybz205ni~7>k=%GxQKUrn@w=e z{>H{3mSadKsS4*o@rMo*?Ug)#ThAG!eMWb?1w$#hVOhm93GawuD$N*$Cvbv7CsCmb zcy88glr_y9wzjbAhhrh)3N)dRc}w0wTuWXK+SRQH9=V|1CvM{Oc=auRB^gvnT+~@c zQ^XA-Fus~drjI0$$EJJV9MFo#TZJnhE-y;KDb_1>NOgWpYH~nXHi!MD--K)@t99+} z>AIby15)Shu@x;PSyRQl?~7-$`pA99IZ!SR2$$YzM7o#6RMJ8)-YK^Eqg|AlG#6b; z+=%QJ9#`#gsxOmeLa8ZtD>L7ejVb;;fXny(0@5}DTUvKu^NCs}gr&f)e$iZn{!|u? zwfpH+a|;5BT20$aPqV3(H%b+*<<>47_YJNE$BehXmvs+_ zhHL88&a)FZ(`XzOQ)^)g#66)rdzsVCY^LFh`L5CH3%s|%`W$C<`vG^y{)ChPu7 zTdE=^A$km&Qa1Yv!h@f^)x(JOR+STs&PDiL{a>kPnP1)Vn)b|*0<(t^ODCXCoN!od zDsy+rSC%)8ev7lWQ^x7LA0AU()Mt#f>LJY;DE}?hNq+x5xLBE+ySlLd^TGL;^&tIa zhXnyV-;NH6@t!rTrh3-9_zbtU0X-*Yu>}GpFZ9JU(}`+TxgYYbljoJ9@$u$qiFRwT z0IK-p9Lx5UxGnt9^!X#vh()h#w}k3bFt!X}Id?N6U-!xz>UY!f%WcgIQ)P%}P*<+< zmLGiC@%^69%lranA;|;-`qwo7Yq(S5K{6?4ZY_Osj1bOhhvGqzG=ADM6Ccispx(^;SZk3{GNFH zy}ohGS$RK(mC#9-!9(&}J+ntaOrl@u54XF|K17JE!(HA)uEt-#PbxO4hCoVpufZK? zm4|fC3yVna$98O7jyq;;=l0d$7PsVT6AF=!_E>LYKWjvudM;r4npC2HSw>e0)89Yt z_A7Fnx6c~;%8#&y(y|4T{VFUnnO-5FgxvwF+H6)mz0?w}ZX=GJbgLO{20r^y?a6;f zi(`C~e{RVpRU==bGcHW*F0tmt^6JW10$#iwmQcOs^m(IOY4xM`@m0cg`)g*(YZ?!L z{$|o)i8sYpk{hy>Xv~=gzzuJ9J`&ux$KdPa}usv!hfuOj}Oy zvl-);3C7g6j-euTQp{4Mm0L|^!Osas=1tnKD8)DDvV64kO5{FrWlkSVmrgHgIo;@7 zwER>lL(a+Y*}~Ntz&Ha=t3jf?EAnQt$eSRTA0_nY3P2U`C!44%op*^elQ&vk?CBXEESF z9lzCmcu|>sNke@hjhRA-PlfphbP9E?Aq{|=KF<3FNG}6qm}3D}7@{l9(n9LT!S&H{ zhx9z8%)Ja%&C2K5DfvC>Dv9gDAk30D$ zX@HNxkpiFov=v|-79fWywto1cNfEO%l`QLFU=@zn>bxDeU6fs4m1YXa2K;;&@=|m| zXRk%6v%uaFyp`Z~=srQSjmEdc80|%KI}AxG1&p@{BU8@yn_3YKWQ{?N4Z_Q6arE_f zl0^>R4O3Y=Y?6fUrxHhw2pRfK>}+9VxsBS68wiT$<$~H=17{Q%c06~Hlzf4nyW~b2 z{jK&-_dW<7X7d7QXFoBSanV0d9UbuG45nb`y%Vzt#*luns_(G0#h1_o{5gX{51!bq z3ugG1^sP9zRGH{0@5m7-UY<7E_$DU483+(aF(nf@qDC?4f-9&UvCqn*yOS6k&BP!r zG&C`Y-CTfdX5p9zBKl_KiSW`LgwbuGCUgDiNqZYc_ssCK15Z+552#Yes~ewPevXsj z8%cT#wgG#7Rdb>Qm_(0dhkcxH zMA5x{dHP^}u3kj5BI=mVnH#mai`T+bD@nT?d~2TJVv1y)3{Sawd9iV7DMBtjJacZQ zkS-fG>E%tsap8Wl|Af@po;$yG+<-BoW}H*uTkoPn*Y(2F=C);tGMIjtjRhT|%pMPw z5#Ga7MM_liNXSJCYPBfecItfCpsfyrh3TkmFK;bw!hDtTNbkeoehm%hzK;&wRx(EV z&^U}P{DM?)&C^L%@w87J(i;FE4GG`2{?uQ{ZPi{-hCnBdvgiXcYIOytDjW|oAO>y zPgW!xVNpyIHtKj|B*n6cJU$?D(b9dIQ&HxBj-*A z=|0>E7n;pNK7G_cTxAhS?TvN)v(0W(Q|`@v{{e$$;it5qyIMCbegpRuA25;1>3;Td z!zmQp(h}oCopdBuja@&PQ8RnGAMype8*z=kjC&Psn#u#JUAE;G?_?tJwXA(PaW^w9 z5(Wt{(qll0`pA;HjjlEDdRY4BDWhSY;X(XS+2ZfTUSGQKtA)L&S#_wQw<=;I|Vh3j+Z}Vfa&0qP!KjMt) z4FzvnR5&;vp?|{}WdFe#|7p?xY)1dnuE#0a^l)H=9NiL1!@kL(03roIk>ZuNm+*aW z*T#GK;%Dmbec8zMpPCa-Ym;YYBH=QS3@2F6`#TYvMuMiS z)h{tH_gU^EknZ=f%rxvftU-rJxuRm{O97K~ZIsCAtF=+q zKC`Ev*W32g_P*~4g0Vz;>2~9WMfK6B)UL?f-3|~X$c1`03~%o)FY|ti8IZE1OtlH# z>ZFXECp%sJ>KP2R=KNHbtdy4ijmmbuwG59FL+9lo;tQV08{G_|T2HAvL{I_c)E8Dq zu4V_C?1-PAlZBgz`xx>g=lu zwNUt4?YLAdW3=4#gP`b;mHll&$nIVTfpP%fE5h5o%#MMDGPCj*k)P7s0%NN*ox=3J zCwFDa4#g{7s`F%&S6qP?H1y~6D}VxjI`v|!`C5D{o3%-SZC7wZLTwaE2&69MFw)A! zsX;kxnFIPl*oqwVx{B9GFF!76?UwNqd#{zffXN&YFv9aS16WPWpXgaG2pUd%v#+I{`;R-_6z%BKFQ;(0XJr19Eh z9YJ|Qa!~wS5#~}DgN}?u(gX^Q`V^@pIm!))h#U zuXiGOd2n&%3tBgx8{%>UAsR|gb4;z~qx!RTQ%NB+!gICf#p)-M;bSLJd7`bFNweYK zR33vnj{2=x+CyMRV*Fd$<30qpnFB!8*}>6;9pK<>{ty48W~dUxLEr<^j%}9=7;NC_ zjDNrNNkOsK%DZ$kS~Hu+j=#arA)u?^u&dGQ@RbOx^khx-^B7g)R=uq1%GCgT*IxQ3 zT5k!H2NynD3^ivURfjSul#GI@e0pe%sml95FOI);8@jd3dr!0&|4un)$26}itF-Lh z_l1rmWWx#E2E%90#Oo-pVyxP1vCRC#TID+4tjL=gG(CF1%Q~f*H%NWu1_ns ztxH{jfS4k<^($*>D#1#gHW=!8$|sz}qV}9X8Eu{Nd;=-m_7c-8>a~~@X7K=0l4p$! zhK+o}Vh~~RP{Z)pMlNBp`QlqqCB5#1q}nH;b;bM9-MC#$s^$WSgVatwo%a%-lSJ?H zVXFjOF}3iv90&p2o}?%--56j5769Jptp^yn1lH8=FOa4bo^@MgB9z58=`@vfOolV7mn4vG} zVDD;f?`o{!;b`t+_)n*-A*AwPtfd^Q%Wnep7X|`RSZj66GXzkgj^Hcm1)P(71#-h|y}VzRi{2P@?d{2ml_ax%{Xl2* z(p3_SU`ln|l0gtV(u@u>FhTT+mLs7QP)V9BFmdR6X&k9Ld1rH^%5Bbsj#Hq+1XOjP zbX>LZ&msd?XgC$C?A%n@bz+w<#os;iKtC=sq(@AfJIg$-CWoz3+`T_<-@@tzI9|4+ zWOmYg$i(jbo>5KZhm6v}f081Uqy9;1CGddy)(E%wKAmh$pZHn3bqv>xZ{pNHL`KZd zO+MWRuV_Dc^b9-#0o?B^fIm6#$18yUSN^yV_*?N$BJ`0W|1G2sTm40t|E>HdwerZ7 z{uZSN!sS8vH*@;8>Yr%ok$d?q0x17?-~YwL{JqMb$l?)M{g$kU!#wJ><&&D*b<}|Cx1O{r From 1f7c9ea2d6553388c9619b4321b6d123fcec69c1 Mon Sep 17 00:00:00 2001 From: Joe Date: Mon, 22 Aug 2022 10:41:27 +0100 Subject: [PATCH 041/432] faqs --- content/docs/faq.md | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/content/docs/faq.md b/content/docs/faq.md index 8b04b29e3d..0da9781ef9 100644 --- a/content/docs/faq.md +++ b/content/docs/faq.md @@ -1,11 +1,12 @@ --- title: FAQ -permalink: docs/faq -sort_key: C +description: Frequently asked questions related to Geth --- -* TOC -{:toc} +This page contains answers to common questions about Geth. The Geth team have also started to run AMA's on Reddit: + +[Aug 2022 AMA](https://www.reddit.com/r/ethereum/comments/wpqmo1/ama_we_are_the_go_ethereum_geth_team_18_august/) + #### I noticed my peercount slowly decreasing, and now it is at 0. Restarting doesn't get any peers. @@ -15,9 +16,9 @@ Check and sync your clock with ntp. For example, you can [force a clock update u sudo ntpdate -s time.nist.gov ``` -#### I would like to run multiple geth instances but got the error "Fatal: blockchain db err: resource temporarily unavailable". +#### I would like to run multiple Geth instances but got the error "Fatal: blockchain db err: resource temporarily unavailable". -Geth uses a datadir to store the blockchain, accounts and some additional information. This directory cannot be shared between running instances. If you would like to run multiple instances follow [these](getting-started/private-net) instructions. +Geth uses a datadir to store the blockchain, accounts and some additional information. This directory cannot be shared between running instances. If you would like to run multiple instances follow [these](/content/docs/developers/geth-developer/Private-Network.md) instructions. #### When I try to use the --password command line flag, I get the error "Could not decrypt key with given passphrase" but the password is correct. Why does this error appear? @@ -35,7 +36,7 @@ The current default syncing mode used by Geth is called [snap sync](https://gith Many people falsely assume that because they have the blocks, they are in sync. Unfortunately this is not the case. Since no transaction was executed, so we do not have any account state available (ie. balances, nonces, smart contract code and data). These need to be downloaded separately and cross-checked with the latest blocks. This phase is called the state trie download phase. Snap sync tries to hasten this process by downloading contiguous chunks of useful state data, instead of doing so one-by-one, as in previous synchronization methods. -#### So, what's the state trie? +#### What's the state trie? In the Ethereum mainnet, there are a ton of accounts already, which track the balance, nonce, etc of each user/contract. The accounts themselves are however insufficient to run a node, they need to be cryptographically linked to each block so that nodes can actually verify that the accounts are not tampered with. @@ -72,3 +73,7 @@ The state trie in Ethereum contains hundreds of millions of nodes, most of which #### Wait, so I can't use fast sync on an HDD? Doing a "fast" sync on an HDD will take more time than you're willing to wait, because the data structures used are not optimized for HDDs. Even if you do wait it out, an HDD will not be able to keep up with the read/write requirements of transaction processing on mainnet. You however should be able to run a light client on an HDD with minimal impact on system resources. + +#### What is wrong with my light client? + +Light sync relies on full nodes that serve data to light clients. Historically, this has been hampered by the fact that serving light clients was turned off by default in geth full nodes and few nodes chose to turn it on. Therefore, light nodes often struggled to find peers. Since Ethereum switched to proof-of-stake, Geth light clients have stopped working altogether. Light clients for proof-of-stake Ethereum are expected to be implemented soon! From 6f6d57cbbdebf7045a723204c3bb746ec6ba8364 Mon Sep 17 00:00:00 2001 From: Joe Date: Mon, 22 Aug 2022 10:57:16 +0100 Subject: [PATCH 042/432] add note on light clients after merge --- content/docs/fundamentals/les.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/content/docs/fundamentals/les.md b/content/docs/fundamentals/les.md index de9df11bdb..b64171c06e 100644 --- a/content/docs/fundamentals/les.md +++ b/content/docs/fundamentals/les.md @@ -7,6 +7,9 @@ Running a full node is the most trustless, private, decentralized and censorship Read more about the reasons to run nodes on [ethereum.org](https://ethereum.org/en/run-a-node/). +{% include note.html content=" Geth light clients **do not currently work** on proof-of-stake Ethereum. New light clients that work with the proof-of-stake consensus engine are expected to ship soon!" %} + + ## Light node vs full node Running Geth in light mode has the following advantages for users: From e2192a477da1ae8c3563f1ef3ca8509ae16f76ea Mon Sep 17 00:00:00 2001 From: Joe Date: Mon, 22 Aug 2022 11:49:36 +0100 Subject: [PATCH 043/432] add resources page --- content/docs/fundamentals/les.md | 2 +- content/resources.md | 34 ++++++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+), 1 deletion(-) create mode 100644 content/resources.md diff --git a/content/docs/fundamentals/les.md b/content/docs/fundamentals/les.md index b64171c06e..5203cab902 100644 --- a/content/docs/fundamentals/les.md +++ b/content/docs/fundamentals/les.md @@ -1,6 +1,6 @@ --- title: Light client -description: Intriduction to Geth's light sync mode +description: Introduction to Geth's light sync mode --- Running a full node is the most trustless, private, decentralized and censorship resistant way to interact with Ethereum. It is also the best choice for the health of the network, because a decentralized network relies on having many individual nodes that independently verify the head of the chain. In a full node a copy of the blockchain is stored locally enabling users to verify incoming data against a local source of truth. However, running a full node requires a lot of disk space and non-negligible CPU allocation and takes hours (for snap sync) or days (for full sync) to sync the blockchain from genesis. Geth also offers a light mode that overcomes these issues and provides some of the benefits of running a node but requires only a fraction of the resources. diff --git a/content/resources.md b/content/resources.md new file mode 100644 index 0000000000..773f68b5eb --- /dev/null +++ b/content/resources.md @@ -0,0 +1,34 @@ +--- +title: resources +description: read, watch and listen more about Geth and Ethereum +--- + + +## Read + +[Geth team AMA: August 2022](https://www.reddit.com/r/cryptoall/comments/wpr6dk/ama_we_are_the_go_ethereum_geth_team_18_august/) +[Ethereum stack exchange](https://ethereum.stackexchange.com/) + + +## Watch + +[Péter at ETH Prage 2022: Ethereum in numbers: where TPS meets physics](https://www.youtube.com/watch?v=TdsaVoJiy3g) +[Marius at ETH Amsterdam 2022: Deep dive into Geth](https://www.youtube.com/watch?v=c4N79UXZqSc) +[Péter interview at ETH Prage 2022:](https://www.youtube.com/watch?v=cfxGzZZ_uOI) +[Guillame at Devconnect 2022: Stateless Ethereum](https://www.youtube.com/watch?v=XkzJncPYj0M&list=PLJijNYoOwnsuqDH9ITSvbqDOaUdA1vp2O&index=9) +[lightclients at Devconnect 2022: Future of Ethereum accounts](https://www.youtube.com/watch?v=pS5asEp6ry8&list=PLJijNYoOwnsuqDH9ITSvbqDOaUdA1vp2O&index=7) +[Zsolt at Devconnect 2022: Geth in the pos light client ecosystem](https://www.youtube.com/watch?v=EPZeFXau-RE&list=PLJijNYoOwnst-feT7PsCLaSdiFYzWtf7j&index=2) +[Jared at Devconnect 2022: Removing SELFDESTRUCT](https://www.youtube.com/watch?v=pDr-h334-Cs&list=PLJijNYoOwnsuqDH9ITSvbqDOaUdA1vp2O&index=5) +[Marius interview at ETH Prague 2022](https://www.youtube.com/watch?v=QKr3KHTjbjQ) +[Marius at ETHOnline 2021: The Megre from the perspective of the execution layer](https://www.youtube.com/watch?v=3DDjfUvQ2TE) +[Péter's 2020 online Geth AMA](https://www.youtube.com/watch?v=gVMDw66atr4) +[Martin at Devcon 5: Protecting the base layer](https://www.youtube.com/watch?v=wLcyIgblIxE) +[Péter at DevCon 5: Monitoring Ethereum infrastructure](https://www.youtube.com/watch?v=2I_Cfr-OUp4) +[Péter at DevCon 4: Plugging metadata leaks in Ethereum](https://www.youtube.com/watch?v=J1JenTo7oLE) +[Péter at DevCon 2: Import Geth in Go](https://www.youtube.com/watch?v=R0Ia1U9Gxjg) +[Péter at dotGo 2016: Immutability in Go](https://www.youtube.com/watch?v=fNUx4jHTaIc) + + +## Listen + +Podcasts relating to Geth will be posted here! \ No newline at end of file From 1cf24dc6387fb54fd95f934da56d28693c297b05 Mon Sep 17 00:00:00 2001 From: Joe Date: Mon, 22 Aug 2022 13:11:34 +0100 Subject: [PATCH 044/432] update homepage --- content/homepage.md | 22 +++++++++------------- 1 file changed, 9 insertions(+), 13 deletions(-) diff --git a/content/homepage.md b/content/homepage.md index 02ed13f4e8..93e7beefe6 100644 --- a/content/homepage.md +++ b/content/homepage.md @@ -5,33 +5,25 @@ description: Geth homepage ## What is Geth? -Geth (go-ethereum) is a [Go](https://go.dev/) implementation of [Ethereum](http://ethereum.org) - a -gateway into the decentralized web. +Geth (go-ethereum) is a [Go](https://go.dev/) implementation of [Ethereum](http://ethereum.org) - a gateway into the decentralized web. -Geth has been a core part of Etheruem since the very beginning. Geth was one of the original -Ethereum implementations making it the most battle-hardened and tested client. +Geth has been a core part of Etheruem since the very beginning. Geth was one of the original Ethereum implementations making it the most battle-hardened and tested client. -Geth is an Ethereum *execution client* meaning it handles transactions, deployment and execution -of smart contracts and contains an embedded computer known as the *Ethereum Virtual Machine*. +Geth is an Ethereum *execution client* meaning it handles transactions, deployment and execution of smart contracts and contains an embedded computer known as the *Ethereum Virtual Machine*. Running Geth alongside a consensus client turns a computer into an Ethereum node. - ## What is Ethereum? -Ethereum is a technology for building apps and organizations, holding assets, transacting and -communicating without being controlled by a central authority. It is the base of a new, decentralized -internet. +Ethereum is a technology for building apps and organizations, holding assets, transacting and communicating without being controlled by a central authority. It is the base of a new, decentralized internet. Read more on our [Ethereum page](/ethereum) or on [ethereum.org](http://ethereum.org). ## Why run a node? -Running your own node enables you to use Ethereum in a truly private, self-sufficient and trustless -manner. You don't need to trust information you receive because you can verify the data yourself -using your Geth instance. +Running your own node enables you to use Ethereum in a truly private, self-sufficient and trustless manner. You don't need to trust information you receive because you can verify the data yourself using your Geth instance. **"Don't trust, verify"** @@ -39,4 +31,8 @@ using your Geth instance. +## Contribute to Geth + +We welcome contributions from anyone on the internet, and are grateful for even the smallest of fixes! If you'd like to contribute to the Geth source code, please fork the [Github repository](https://github.com/ethereum/go-ethereum), fix, commit and send a pull request for the maintainers to review and merge into the main code base. See our [contribution guidelines](/content/docs/developers/contributing.md) for more information. + From a2873d7225f00c27c51edf7f8d2178094c922cf0 Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 24 Aug 2022 09:17:53 +0100 Subject: [PATCH 045/432] add pruning page --- content/docs/fundamentals/pruning.md | 60 ++++++++++++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 content/docs/fundamentals/pruning.md diff --git a/content/docs/fundamentals/pruning.md b/content/docs/fundamentals/pruning.md new file mode 100644 index 0000000000..13ddf40d1d --- /dev/null +++ b/content/docs/fundamentals/pruning.md @@ -0,0 +1,60 @@ +--- +title: Pruning +description: Instructions for pruning a Geth node +--- + +A snap-sync'd Geth node currently requires more than 650 GB of disk space to store the historic blockchain data. With default cache size the database grows by about 14 GB/week. This means that Geth users will rapidly run out of space on 1TB hard drives. To solve this problem without needing to purchase additional hardware, Geth can be pruned. Pruning is the process of erasing older data to save disk space. Since Geth `v1.10`, users have been able to trigger a snapshot offline prune to bring the total storage back down to the original ~650 GB in about 4-5 hours. This has to be done periodically to keep the total disk storage within the bounds of the local hardware (e.g. every month or so for a 1TB disk). + +To prune a Geth node at least 40 GB of free disk space is recommended. This means pruning cannot be used to save a hard drive that has been completely filled. A good rule of thumb is to prune before the node fills ~80% of the available disk space. + +## Pruning rules + +1) Do not try to prune an archive node. Archive nodes need to maintain ALL historic data by definition. +2) Ensure there is at least 40 GB of storage space still available on the disk that will be pruned. Failures have been reported with ~25GB of free space. +3) Geth is at least `v1.10` ideally > `v1.10.3` +4) Geth is fully sync'd +5) Geth has finished creating a snapshot that is at least 128 blocks old. This is true when "state snapshot generation" is no longer reported in the logs. + +With these rules satisfied, Geth's database can be pruned. + +## How pruning works + +Pruning uses snapshots of the state database as an acceleration structure to determine which nodes in the state trie can be kept and which ones are stale and can be discarded. Geth rebuilds the state trie from a stored snapshot that is older than 128 blocks, discarding any data that isn't part of the snapshot window (the sequence of blocks between the snapshot and head). + +Geth prunes the database in three stages: + +1) Iterating state snapshot: Geth iterates through states, starting at the most recent snapshot, to identify stale trie nodes. +2) Pruning state data: Geth deletes stale trie nodes from the database. +3) Compacting database: Geth tidies up the new database to reclaim free space. + +There may be a period of >1 hour during the Compacting Database stage with no log messages at all. This is normal, and the pruning should be left to run until finally a log message containing the phrase `State pruning successful` appears (i.e. do not restart Geth yet!). That message indicates that the pruning is complete and Geth can be started. + +## Pruning command + +For a normal Geth node, Geth should be stopped and the following command executed to start a offline state prune: + +```sh +geth snapshot prune-state +``` + +For a Geth node run using `systemd`: + +```sh +sudo systemctl stop geth # stop geth, wait >3mins to ensure clean shutdown +tmux # tmux enables pruning to keep running even if you disconnect +sudo -u geth --datadir snapshot prune-state # wait for pruning to finish +sudo systemctl start geth # restart geth +``` + +The pruning could take 4-5 hours to complete. Once finished, restart Geth. + + +## Troubleshooting + +Messages about "state snapshot generation" indicate that a snapshot does not actually exist. This suggests either the `--datadir` is not correct or Geth ran out of time to complete the snapshot generation and the pruning began before the snapshot was completed. In either case, the best course of action is to stop Geth, run it normally again (no pruning) until the snapshot is definitely complete and at least 128 blocks exist on top of it, then try pruning again. + +## Further Reading + +[Ethereum Foundation blog post for Geth v1.10.0](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) +[Pruning Geth guide (@yorickdowne)](https://gist.github.com/yorickdowne/3323759b4cbf2022e191ab058a4276b2) +[Pruning Geth in a RocketPool node](https://docs.rocketpool.net/guides/node/geth-pruning.html) \ No newline at end of file From 4fbe1322f1f7acc018c8791abca3871eb176726e Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 25 Aug 2022 10:10:32 +0100 Subject: [PATCH 046/432] add mining page and updated rules page --- content/docs/fundamentals/mining.md | 178 ++++++++++++++++++++++++++++ content/docs/tools/Clef/Rules.md | 27 ++--- 2 files changed, 188 insertions(+), 17 deletions(-) create mode 100644 content/docs/fundamentals/mining.md diff --git a/content/docs/fundamentals/mining.md b/content/docs/fundamentals/mining.md new file mode 100644 index 0000000000..5d99bea4d0 --- /dev/null +++ b/content/docs/fundamentals/mining.md @@ -0,0 +1,178 @@ +--- +title: Proof-of-work mining with Ethash +description: Introduction to proof-of-work mining with Geth +--- + +{% include note.html content=" Proof-of-work mining is **no longer used to secure Ethereum Mainnet**. The information below is included because the Ethash code is still part of Geth and it could be used to create a private proof-of-work network or testnet. %} + +Blockchains grow when nodes add blocks and distribute them to their peers. Nodes that add blocks are rewarded with ether payouts. On Ethereum Mainnet, the proof-of-stake consensus engine randomyl selects a node to produce each block. Under proof-of-work, however, block producers are selected by competition. The node that computes a certain value that can only be found using repeated random guesses wins the right to propose the next block. Only if a node can demonstrate that they have calculated this value, and therefore expended energy, will their block be accepted by other nodes. This secures the network. This process of creating blocks and securing them using proof-of-work is known as "mining". + +Much more information about mining, including details about the specific algorithm ("Ethash") used by Ethereum nodes is available on [ethereum.org](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/mining). + + +## CPU vs GPU + +Participating in Ethereum's PoW mining requires running an algorithm called ["Ethash"](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash). Geth includes a CPU miner which runs Ethash within the Geth process. This might be useful for mining on testnets or private networks where competition for producing new blocks is small. When minign was used to secure Ethereum Mainnet, CPU mining was not viable because CPU miners were easily outcompeted by more efficient GPU miners. To mine using GPUs an additional piece of third-party software is required. The recommended GPU mining software is [Ethminer](https://github.com/ethereum-mining/ethminer). + +Regardless of the mining method, the blockchain must be fully synced before mining is started, otherwise the miner will build on an outdated side chain, meaning block rewards will not be recognized by the main network. + + +## GPU Mining + +### Installing Ethminer + +The Ethminer software can be installed from a downloaded binary or built from source. The relevant downloads and installation instructions are available from the [Ethminer Github](https://github.com/ethereum-mining/ethminer/#build). Standalone executables are available for Linux, macOS and Windows. + +### Using Ethminer with Geth + +An account to receive block rewards must first be defined. The address of the account is all that is required to start mining - the mining rewards will be credited to that address. This can be an existing address or one that is newly created by Geth. More detailed instructions on creating and importing accounts are available on the [Account Management](/content/docs/fundamentals/account-management.md) page. + +The account address can be provided to `--mining.etherbase` when Geth is started. This instructs Geth to direct any block rewards to this address. Once started, Geth will sync the blockchain. If Geth has not connected to this network before, or if the data directory has been deleted, this can take several days. Also, enable HTTP traffic with the `--http` command. To reiterate, mining does **not work on Ethereum, Mainnet** since the transition to proof-of-stake. + +```shell +geth --http --miner.etherbase 0xC95767AC46EA2A9162F0734651d6cF17e5BfcF10 +``` + +The progress of the blockchain syncing can be monitored by attaching a JavaScript console in another terminal. More detailed information about the console can be found on the [Javascript Console](/content/docs/interacting_with_geth/JavaScript-Console.md) page. To attach and open a console: + +```shell +geth attach http://127.0.0.1:8545 +``` + +Then in the console, to check the sync progress: + +```shell +eth.syncing +``` + +If the sync is progressing correctly the output will look similar to the following: + +```terminal +{ + currentBlock: 13891665, + healedBytecodeBytes: 0, + healedBytecodes: 0, + healedTrienodeBytes: 0, + healedTrienodes: 0, + healingBytecode: 0, + healingTrienodes: 0, + highestBlock: 14640000, + startingBlock: 13891665, + syncedAccountBytes: 0, + syncedAccounts: 0, + syncedBytecodeBytes: 0, + syncedBytecodes: 0, + syncedStorage: 0, + syncedStorageBytes: 0 +} +``` + +Once the blockchain is sync'd, mining can begin. In order to begin mining, Ethminer must be run and connected to Geth in a new terminal. OpenCL can be used for a wide range of GPUs, CUDA can be used specifically for Nvidia GPUs: + +```shell +#OpenCL +ethminer -v 9 -G -P http://127.0.0.1:8545 +``` + +```shell +#CUDA +ethminer -v -U -P http://127.0.0.1:8545 +``` + +Ethminer communicates with Geth on port 8545 (Geth's default RPC port) but this can be changed by providing a custom port to the `http.port` command. The corresponding port must also be configured in Ethminer by providing `-P http://127.0.0.1:`. This is necessary when multiple instances of Geth/Ethminer will coexist on the same machine. + +If using OpenCL and the default for `ethminer` does not work, specifying the device using the `--opencl--device X` command is a common fix. `X` is an integer `1`, `2`, `3` etc. The Ethminer `-M` (benchmark) command should display something that looks like: + +```terminal +Benchmarking on platform: { "platform": "NVIDIA CUDA", "device": "GeForce GTX 750 Ti", "version": "OpenCL 1.1 CUDA" } + +Benchmarking on platform: { "platform": "Apple", "device": "Intel(R) Xeon(R) CPU E5-1620 v2 @ 3.70GHz", "version": "OpenCL 1.2 " } +``` + +Note that the Geth command `miner.hashrate` only works for CPU mining - it always reports zero for GPU mining. To check the GPU mining hashrate, check the logs `ethminer` displays to its terminal. More verbose logs can be configured using `-v` and a value between 0-9. + +The Ethash algorithm is [memory-hard](https://crypto.stackexchange.com/questions/84002/memory-hard-vs-memory-bound-functions) and requires a large dataset to be loaded into memory. Each GPU requires 4-5 GB of RAM. The error message `Error GPU mining. GPU memory fragmentation?` indicates that there is insufficient memory available. + + +## CPU Mining with Geth + +When Geth is started it is not mining by default. Unless it is specifically instructed to mine, it acts only as a node, not a miner. Geth starts as a (CPU) miner if the `--mine` flag is provided. The `--miner.threads` parameter can be used to set the number parallel mining threads (defaulting to the total number of processor cores). + +```shell +geth --mine --miner.threads=4 +``` + +CPU mining can also be started and stopped at runtime using the [console](/docs/interface/javascript-console). The command `miner.start` takes an optional parameter for the number of miner threads. + +```js +miner.start(8) + true +miner.stop() + true +``` + +Note that mining for real ether only makes sense if you are in sync with the network (since you mine on top of the consensus block). Therefore the Ethereum blockchain downloader/synchroniser will delay mining until syncing is complete, and after that mining automatically starts unless you cancel your intention with `miner.stop()`. + +Like with GPU mining, an etherbase account must be set. This defaults to the primary account in the keystore but can be set to an alternative address using the `--miner.etherbase` command: + +```shell +geth --miner.etherbase '0xC95767AC46EA2A9162F0734651d6cF17e5BfcF10' --mine +``` +If there is no account available an account wil be created and automatically configured to be the coinbase. The Javascript console can be used to reset the etherbase account at runtime: + +```shell +miner.setEtherbase(eth.accounts[2]) +``` + +Note that your etherbase does not need to be an address of a local account, it just has to be set to an existing one. + +There is an option to add extra data (32 bytes only) to the mined blocks. By convention this is interpreted as a unicode string, so it can be used to add a short vanity tag using `miner.setExtra` in the Javascript console. + +```shell +miner.setExtra("ΞTHΞЯSPHΞЯΞ") +``` + +The console can also be used to check the current hashrate in units H/s (Hash operations per second): + +```shell +eth.hashrate + 712000 +``` + +After some blocks have been mined, the etherbase account balance with be >0. Assuming the etherbase is a local account: + +```shell +eth.getBalance(eth.coinbase).toNumber(); + '34698870000000' +``` + +It is also possible to check which blocks were mined by a particular miner (address) using the following code snippet in the Javascript console: + +```js +function minedBlocks(lastn, addr) { + addrs = []; + if (!addr) { + addr = eth.coinbase + } + limit = eth.blockNumber - lastn + for (i = eth.blockNumber; i >= limit; i--) { + if (eth.getBlock(i).miner == addr) { + addrs.push(i) + } + } + return addrs +} + +// scans the last 1000 blocks and returns the blocknumbers of blocks mined by your coinbase +// (more precisely blocks the mining reward for which is sent to your coinbase). +minedBlocks(1000, eth.coinbase) +[352708, 352655, 352559] +``` + +The etherbase balance will fluctuate because quite often a mined block may be re-org'd out of the canonical chain. This means that when the local Geth node includes the mined block in its own local blockchain the account balance appears higher because the block rewards are applied. When the node switches to another version of the chain due to information received from peers, that block may not be included and the block rewards are not applied. + +The logs show locally mined blocks confirmed after 5 blocks. + +## Summary + +The page describes how to start Geth as a mining node. Mining can be done on CPUs - in which case Geth's built-in miner can be used - or on GPUs which requires third party software. Mining is no longer used on Ethereum Mainnet so this information is only applicable to private proof-of-work networks or testnets. \ No newline at end of file diff --git a/content/docs/tools/Clef/Rules.md b/content/docs/tools/Clef/Rules.md index 95fc34cf5e..3b9b47c552 100644 --- a/content/docs/tools/Clef/Rules.md +++ b/content/docs/tools/Clef/Rules.md @@ -3,10 +3,6 @@ title: Rules description: Introduction to automated rulesets in Clef --- -This page provides a fairly low-level explanation for how rules are implemented in Clef. It is a good idea to read the [Introduction to Clef](/content/docs/tools/Clef/introduction) and the [Clef tutorial](/content/docs/tools/Clef/tutorial) before diving in to this page. - -## Introduction - Rules in Clef are sets of conditions that determine whether a given action can be approved automatically without requiring manual intervention from the user. This can be useful for automatically approving transactions between a user's own accounts, or approving patterns that are commonly used by applications. Automatic signing also requires Clef to have access to account passwords which is configured independently of the ruleset. Rules can define arbitrary conditions such as: @@ -29,7 +25,7 @@ The ruleset engine acts as a gatekeeper to the command line interface - it auto- ![Clef ruleset logic](/static/images/clef_ruleset.png) -When Clef receives a request, the ruleset engine evaluates a Javascript file for each method defined in the internal [UI API docs](/content/docs/tools/Clef/apis). For example the code snippet below is an example ruleset that calls the function `ApproveTx`. The call to `ApproveTx` is invoking the `ui_approveTx` [JSON_RPC API endpoint](/content/docs/tools/Clef/apis/#ui-api). Every time an RPC method is invoked the Javascript code is executed in a freshly instantiated virtual machine. +When Clef receives a request, the ruleset engine evaluates a Javascript file for each method defined in the internal [UI API docs](/content/docs/tools/Clef/apis.md). For example the code snippet below is an example ruleset that calls the function `ApproveTx`. The call to `ApproveTx` is invoking the `ui_approveTx` [JSON_RPC API endpoint](/content/docs/tools/Clef/apis.md). Every time an RPC method is invoked the Javascript code is executed in a freshly instantiated virtual machine. ```js function asBig(str) { @@ -69,14 +65,13 @@ When a request is made via the external API, the logic flow is as follows: * Assuming the call returns "Approve", request is signed. -There are five possible outcomes from the ruleset engine that are -handled in different ways: +There are three possible outcomes from the ruleset engine that are handled in different ways: | Return value | Action | | ------------------| ----------------------------------------- | -| "Approve" | Auto-approve request | -| "Reject" | Auto-reject request | -| Anything else | Pass decision to UI for manual approval | +| "Approve" | Auto-approve request | +| "Reject" | Auto-reject request | +| Anything else | Pass decision to UI for manual approval | There are some additional noteworthy implementation details that are important for defining rules correctly in `ruleset.js`: @@ -97,13 +92,12 @@ There are some additional noteworthy implementation details that are important f * The regular expression engine (re2/regexp) in Otto VM is not fully compatible with the [ECMA5 specification](https://tc39.es/ecma262/#sec-intro). -* [Strict mode](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Strict_mode) is not supported. "Use strict" will parse but it does nothing. +* [Strict mode](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Strict_mode) is not supported. "use strict" will parse but it does nothing. ## Credential management -The ability to auto-approve transaction requires that the signer has the necessary credentials, i.e. account passwords, to decrypt keyfiles. -These are stored encrypted as follows: +The ability to auto-approve transaction requires that the signer has the necessary credentials, i.e. account passwords, to decrypt keyfiles. These are stored encrypted as follows: When the `signer` is started it generates a seed that is locked with a user specified password. The seed is saved to a location that defaults to `$HOME/.clef/masterseed.json`. The `seed` itself is a blob of bytes. @@ -119,13 +113,11 @@ The `signer` uses the `seed` to: ## Security ### The Javascript VM -The downside of the very flexible rule implementation included in Clef is that the `signer` binary needs to contain a Javascript engine. This is an additional attack surface. The only viable attack is for an adversary to somehow extract cryptographic keys from memory during the Javascript VM execution. The hash-based rule attestation condition means the actual Javascript code executed by the Javascript engine is not a viable attack surface -- since if the attacker can control the ruleset, a much simpler attack would be to surreptitiously insert an attested "always-approve" rule instead of attempting to exploit the Javascript virtual machine. The Javascript engine is quite simple to implement and there are currently no known security vulnerabilities, not have there been any security problems identified for the -similar Javascript VM implemented in Geth. +The downside of the very flexible rule implementation included in Clef is that the `signer` binary needs to contain a Javascript engine. This is an additional attack surface. The only viable attack is for an adversary to somehow extract cryptographic keys from memory during the Javascript VM execution. The hash-based rule attestation condition means the actual Javascript code executed by the Javascript engine is not a viable attack surface -- since if the attacker can control the ruleset, a much simpler attack would be to surreptitiously insert an attested "always-approve" rule instead of attempting to exploit the Javascript virtual machine. The Javascript engine is quite simple to implement and there are currently no known security vulnerabilities, not have there been any security problems identified for the similar Javascript VM implemented in Geth. ### Writing rules -Since the user has complete freedom to write custom rules, it is plausible that those rules could create unintended security vulnerabilities. This can only really be protected by coding very carefully and trying to test rulesets (e.g. on a private testnet) before -implementing them on a public network. +Since the user has complete freedom to write custom rules, it is plausible that those rules could create unintended security vulnerabilities. This can only really be protected by coding very carefully and trying to test rulesets (e.g. on a private testnet) before implementing them on a public network. Javascript is very flexible but also easy to write incorrectly. For example, users might assume that javascript can handle large integers natively rather than explicitly using `bigInt`. This is an error commonly encountered in the Ethereum context when users attempt to multiply `gas` by `gasCost`. @@ -256,3 +248,4 @@ function OnApprovedTx(resp) { ## Summary Rules are sets of conditions encoded in Javascript files that enable certain actions to be auto-approved by Clef. This page outlined the implementation details and security considerations that will help to build suitrable ruleset files. See the [Clef Github](https://github.com/ethereum/go-ethereum/tree/master/cmd/clef) for further reading. + From 1c6658af3c735d2eca701d9e03315cadc462175a Mon Sep 17 00:00:00 2001 From: Joe Date: Fri, 26 Aug 2022 16:51:27 +0100 Subject: [PATCH 047/432] update p2p page w config.toml --- content/docs/fundamentals/peer-to-peer.md | 39 +++++++++++++++-------- 1 file changed, 26 insertions(+), 13 deletions(-) diff --git a/content/docs/fundamentals/peer-to-peer.md b/content/docs/fundamentals/peer-to-peer.md index 52b6da5840..b6b62e29b1 100644 --- a/content/docs/fundamentals/peer-to-peer.md +++ b/content/docs/fundamentals/peer-to-peer.md @@ -2,8 +2,7 @@ title: Connecting To The Network description: Guide to connecting Geth to a peer-to-peer network --- - -The default behaviour for Geth is to connect to Ethereum Mainnet. However, Geth can also connect to public testnets, [private networks](/content/docs/developers/geth-developer/Private-Network.md) and [local testnets](/docs/getting-started/dev-mode). Command line flags are provided for connecting to the popular public testnets: +The default behaviour for Geth is to connect to Ethereum Mainnet. However, Geth can also connect to public testnets, [private networks](/docs/getting-started/private-net) and [local testnets](/docs/getting-started/dev-mode). Command line flags are provided for connecting to the popular public testnets: - `--ropsten`, Ropsten proof-of-work test network - `--rinkeby`, Rinkeby proof-of-authority test network @@ -15,11 +14,13 @@ Providing these flags at startup instructs Geth to connect to the specific publi **Note:** network selection is not persisted in the config file. To connect to a pre-defined network you must always enable it explicitly, even when using the `--config` flag to load other configuration values. For example: ```shell + # Generate desired config file. You must specify testnet here. geth --goerli --syncmode "full" ... dumpconfig > goerli.toml # Start geth with given config file. Here too the testnet must be specified. geth --goerli --config goerli.toml + ``` ## Finding peers @@ -29,7 +30,9 @@ Geth continuously attempts to connect to other nodes on the network until it has A new node entering the network for the first time gets introduced to a set of peers by a bootstrap node ("bootnode") whose sole purpose is to connect new nodes to peers. The endpoints for these bootnodes are hardcoded into Geth, but they can also be specified by providing the `--bootnode` flag along with comma-separated bootnode addresses in the form of [enodes](https://ethereum.org/en/developers/docs/networking-layer/network-addresses/#enode) on startup. For example: ```shell + geth --bootnodes enode://pubkey1@ip1:port1,enode://pubkey2@ip2:port2,enode://pubkey3@ip3:port3 + ``` There are scenarios where disabling the discovery process is useful, for example for running a local test node or an experimental test network with known, fixed nodes. This can be achieved by passing the `--nodiscover` flag to Geth at startup. @@ -43,22 +46,24 @@ There are occasions when Geth simply fails to connect to peers. The common reaso - Some firewall configurations can prohibit UDP traffic. The static nodes feature or `admin.addPeer()` on the console can be used to configure connections manually. -- Running Geth in [light mode](/content/docs/fundamentals/les.md) often leads to connectivity issues because there are few nodes running light servers. There is no easy fix for this except to switch Geth out of light mode. +- Running Geth in [light mode](/docs/interface/les) often leads to connectivity issues because there are few nodes running light servers. There is no easy fix for this except to switch Geth out of light mode. - The public test network Geth is connecting to might be deprecated or have a low number of active nodes that are hard to find. In this case, the best action is to switch to an alternative test network. ## Checking Connectivity -The `net` module has two attributes that enable checking node connectivity from the [interactive Javascript console](/content/docs/interacting_with_geth/JavaScript-Console.md). These are `net.listening` which reports whether the Geth node is listening for inbound requests, and `peerCount` which returns the number of active peers the node is connected to. +The `net` module has two attributes that enable checking node connectivity from the [interactive Javascript console](/docs/interface/javascript-console). These are `net.listening` which reports whether the Geth node is listening for inbound requests, and `peerCount` which returns the number of active peers the node is connected to. ```javascript + > net.listening true > net.peerCount 4 + ``` Functions in the `admin` module provide more information about the connected peers, including their IP address, port number, supported protocols etc. Calling `admin.peers` returns this information for all connected peers. @@ -111,19 +116,26 @@ The `admin` module also includes functions for gathering information about the l ## Custom Networks -It is often useful for developers to connect to private test networks rather than public testnets or Etheruem mainnet. These sandbox environments allow block creation without competing against other miners, easy minting of test ether and give freedom to break things without real-world consequences. A private network is started by providing a value to `--networkid` that is not used by any other existing public network ([Chainlist](https://chainlist.org)) and creating a custom `genesis.json` file. Detailed instructions for this are available on the [Private Networks page](content/docs/developers/geth-developer/Private-Network.md). +It is often useful for developers to connect to private test networks rather than public testnets or Etheruem mainnet. These sandbox environments allow block creation without competing against other miners, easy minting of test ether and give freedom to break things without real-world consequences. A private network is started by providing a value to `--networkid` that is not used by any other existing public network ([Chainlist](https://chainlist.org)) and creating a custom `genesis.json` file. Detailed instructions for this are available on the [Private Networks page](/docs/interface/private-network). ## Static nodes -Geth also supports static nodes. Static nodes are specific peers that are always connected to. Geth reconnects to these peers automatically when it is restarted. Specific nodes are defined to be static nodes by saving their enode addresses to a json file which must be stored in `datadir/geth/static-nodes.json`. The content of `static-nodes.json` should be formatted as follows: +Geth also supports static nodes. Static nodes are specific peers that are always connected to. Geth reconnects to these peers automatically when it is restarted. Specific nodes are defined to be static nodes by adding their enode addresses to a config file. The easiest way to create this config file is to run: -```javascript -[ - "enode://f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0@33.4.2.1:30303", - "enode://pubkey@ip:port" -] ``` +geth --datadir dumpconfig > datadir/config.toml +``` + +Remember also that for public testnets (`goerli`, `sepolia` etc) the network name must be passed explicitly as a command line flag. + +This will create `config.toml` in the `datadir`. The enode addresses for static nodes can then be added in square brackets to the `StaticNodes` field in the `Node.P2P` section in `config.toml`. When Geth is started, pass `--config datadir/config.toml`. The relevant line in `config.toml` looks as follows: + +```toml +StaticNodes = ["enode://f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0@33.4.2.1:30303"] +``` + +Ensure the other lines in `config.toml` are also set correctly before starting Geth, as passing `--config` instructs Geth to get its configuration values from this file. An example of a complete `config.toml` file can be found [here](https://gist.github.com/jmcook1186/16db2f0feddb4bd0581ebb9ba867a47a). Static nodes can also be added at runtime in the Javascript console by passing an enode address to `admin.addPeer()`: @@ -143,7 +155,7 @@ geth --maxpeers 15 ## Trusted nodes -Geth supports trusted nodes that are always allowed to reconnect, even if the peer limit is reached. They can be added persistently via a config file `/geth/trusted-nodes.json` or temporarily using the Javascript console. The format for the config file is identical to the one used for static nodes. +Trusted nodes can be added to `config.toml` in the same way as for static nodes. Add the trusted node's enode address to the `TrustedNodes` field in `config.toml` before starting Geth with `--config datadir/config.toml`. Nodes can be added using the `admin.addTrustedPeer()` call in the Javascript console and removed using `admin.removeTrustedPeer()` call. @@ -151,6 +163,7 @@ Nodes can be added using the `admin.addTrustedPeer()` call in the Javascript con admin.addTrustedPeer("enode://f4642fa65af50cfdea8fa7414a5def7bb7991478b768e296f5e4a54e8b995de102e0ceae2e826f293c481b5325f89be6d207b003382e18a8ecba66fbaf6416c0@33.4.2.1:30303") ``` + ## Summary -Geth connects to Ethereum Mainnet by default. However, this behaviour can be changed using combinations of command line flags and files. This page has described the various options available for connecting a Geth node to Ethereum, public testnets and private networks. +Geth connects to Ethereum Mainnet by default. However, this behaviour can be changed using combinations of command line flags and files. This page has described the various options available for connecting a Geth node to Ethereum, public testnets and private networks. \ No newline at end of file From 768d609e8f9e8bf86ca7fb44ad0becfc3d9e0714 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 30 Aug 2022 15:09:54 +0100 Subject: [PATCH 048/432] add sync mode page and add warning to les page --- content/docs/fundamentals/les.md | 2 ++ content/docs/fundamentals/sync-modes.md | 34 +++++++++++++++++++++++++ 2 files changed, 36 insertions(+) create mode 100644 content/docs/fundamentals/sync-modes.md diff --git a/content/docs/fundamentals/les.md b/content/docs/fundamentals/les.md index 5203cab902..039a4b8bfd 100644 --- a/content/docs/fundamentals/les.md +++ b/content/docs/fundamentals/les.md @@ -3,6 +3,8 @@ title: Light client description: Introduction to Geth's light sync mode --- +{% include note.html content="Light nodes do not currently work on proof-of-stake Ethereum, but new proof-of-stake light clients are expected to ship soon!" %} + Running a full node is the most trustless, private, decentralized and censorship resistant way to interact with Ethereum. It is also the best choice for the health of the network, because a decentralized network relies on having many individual nodes that independently verify the head of the chain. In a full node a copy of the blockchain is stored locally enabling users to verify incoming data against a local source of truth. However, running a full node requires a lot of disk space and non-negligible CPU allocation and takes hours (for snap sync) or days (for full sync) to sync the blockchain from genesis. Geth also offers a light mode that overcomes these issues and provides some of the benefits of running a node but requires only a fraction of the resources. Read more about the reasons to run nodes on [ethereum.org](https://ethereum.org/en/run-a-node/). diff --git a/content/docs/fundamentals/sync-modes.md b/content/docs/fundamentals/sync-modes.md new file mode 100644 index 0000000000..d462500102 --- /dev/null +++ b/content/docs/fundamentals/sync-modes.md @@ -0,0 +1,34 @@ +--- +title: Sync modes +description: Introduction to the three ways to sync Geth +--- + +Syncing is the process by which Geth catches up to the latest Ethereum block and current global state. There are several ways to sync a Geth node that differ in their speed, storage requirements and trust assumptions. This page outlines three sync configurations for full nodes and one for light nodes. + +## Full nodes + +There are three types of full node with different sync modes: + +### Full + +A full sync generates the current state by executing every block starting from the genesis block. A full sync is the trust-minimized option since there it does not rely upon any information from any trusted source apart from the genesis configuration. All other information is indendently verified as the node re-executes the entire historical sequence of blocks. Only the most recent 128 blocks are stored in a full node - older blocks are pruned periodically and represented as a series of checkpoints from which any previous state can be regenerated on request. 128 blocks is about 25.6 minutes of history with a block time of 12 seconds. To create a full node pass `--syncmode full` at startup. + +### Archive + +An archive node is a full-sync'd node that retains all historical data right back to genesis. There is no need to regenerate any data from checkpoints because all data is directly available in the node's own storage. Archive nodes are therefore ideal for making fast queries about historical states. At the time of writing (August 2022) an archive node occupies nearly 12 TB of disk space (keep up with the current size on [Etherscan](https://etherscan.io/chartsync/chainarchive)). Archive nodes are created by configuring Geth's garbage collection so that old data is never deleted: `geth --syncmode full --gcmode archive`. + +### Snap + +A snap sync'd node holds the most recent 128 blocks in memory, so transactions in that range are always accessible. However, snap-sync only starts processing from a relatively recent block (as opposed to genesis for a full node). Between the initial sync block and the 128 most recent blocks, the node stores occasional checkpoints that can be used to rebuild the state on-the-fly. This means transactions can be traced back as far as the block that was used for the initial sync. Tracing a single transaction requires reexecuting all preceding transactions in the same block **and** all preceding blocks until the previous stored snapshot. Snap-sync'd nodes are therefore functionally equal to full nodes, but the initial synchronization required some trusted information (a checkpoint block) to sync from instead of independently verifying the chain all the way from genesis. Snap sync is much faster than full sync. To start a node with snap sync pass `--syncmode snap` at startup. + +## Light nodes + +A light node syncs very quickly and stores the bare minimum of blockchain data. Light nodes only process block headers, not entire blocks. This greatly reduces the computation time, storage and bandwidth required relative to a full node. This means light nodes are suitable for resource-constrained devices and can catch up to the head of the chain much faster when they are new or have been offline for a while. The trade-off is that light nodes rely heavily on data served by altruistic full nodes. A light client can be used to query data from Ethereum and submit transactions, acting as a locally-hosted Ethereum wallet. However, because they don't keep local copies of the Ethereum state, light nodes can't validate blocks in the same way as full nodes - they have to trust that the data they receive is honest. To start a node in light mode, pass `--syncmode light`. Be aware that full nodes serving light data are relative scarce so light nodes can struggle to find peers. + +Read more about light nodes on our [LES page](/content/docs/fundamentals/les.md). + +{% include note.html content="Light nodes do not currently work on proof-of-stake Ethereum, but they are expected to ship soon!" %} + +## Summary + +There are several ways to sync a Geth node. The default is to use snap sync to create a full node. This verifies all blocks starting at a recent checkpoint. A trust-minimized alternative is full-sync, which verifies every block since genesis. These modes prune the blockchain data older than 128 blocks, keeping only checkpoints that enable on-request regeneration of historical states. For rapid queries of historical data an archive node is required. Archive nodes keep local copies of all historical data right back to genesis - currently about 12 TB and growing. The opposite extreme is a light node that doesn't store any blockchain data - it requests everything from full nodes. These configurations are controlled by passing `full`, `snap` or `light` to `--syncmode` at startup. For an archive node, `--syncmode` should be `full` and `--gcmode` should be set to `archive`. \ No newline at end of file From f0ccab25c46fbe6b0e1be57b42c0d150a8cabc8b Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 31 Aug 2022 14:34:26 +0100 Subject: [PATCH 049/432] update pruning page, ad wireframes to /assets --- assets/wireframe1.png | Bin 0 -> 282929 bytes assets/wireframe2.png | Bin 0 -> 427126 bytes assets/wireframe3.png | Bin 0 -> 258956 bytes assets/wireframe4.png | Bin 0 -> 209298 bytes assets/wireframe5.png | Bin 0 -> 250513 bytes content/docs/faq.md | 13 ++++++++++++- content/docs/fundamentals/pruning.md | 15 ++++++++++----- 7 files changed, 22 insertions(+), 6 deletions(-) create mode 100644 assets/wireframe1.png create mode 100644 assets/wireframe2.png create mode 100644 assets/wireframe3.png create mode 100644 assets/wireframe4.png create mode 100644 assets/wireframe5.png diff --git a/assets/wireframe1.png b/assets/wireframe1.png new file mode 100644 index 0000000000000000000000000000000000000000..036339b0eef95736e9801f178e34faa4e736e567 GIT binary patch literal 282929 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%0DVHx(^79QNsN5V4BKtL#&X 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 He$mI8r3z0`i_miVv3F;f}csJV#Nb@ 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 literal 0 HcmV?d00001 diff --git a/assets/wireframe2.png b/assets/wireframe2.png new file mode 100644 index 0000000000000000000000000000000000000000..435f8f7f1f785d663d5b81f6e8dc23d987238208 GIT binary patch literal 427126 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�-217{+F{n@56${EH(OSxWOvTquw%s8&1x;F7Pefs*JL$e?PeSht>%QyoN zEsUIKX&ZgwCIeM#!RdLQ|JmCO+rm)GNKdK`VpmqltDW|GRRNc(6KAel1F(|tl=ui8 zqund`aQN#uKP2~9)Ss#4MfQAlZ0d@EFI=6JCw)V0;Cp!^_0yyGka|-WtFE{ey(2b*wukx)*)Y^crNM5>0IsU?ss{QSa5gU}F_~>)t zDDI%n6bwbb36A|A7~&ApM+*gI-Yhq7)cbYGaw_V{3&IjdQwLP77D#g-UXa)14Ow!b zfsKywG=tI7T#z$0o8Xc)?GgVFPW?Udr3u#a(LNap^H~Aez^OBZgs>bJCbIyUwV+3^ z+mnLMZ5ccV;h1PVa=5!W&hM})aRM!$s6M(mlQ@hwBAcAJHp8E4I_LNyWW{#e*t3Di`49H_G~L*r9l zk@%&68UJ8i$ryx-_=$k3Jl593`w}O=EnDq7{~)byzWyrN*4k9(%TbxGCtX%czhmq&I*XBgPwt@Mlp6GaE4tgiAZPA2w>8|t-5;?3gufYLpO z3RJO-$b#?uX;O(9vq&{U3uKSch74&`5j|$6%F@ZDW-ZEgRgTxGO&;w^5u>Bw1TEF6 z3wEGs7Gejy!-A#d@YNEta=nP!i54SGZ)ll>waj%@Ls!yJ<8!{g1N+%c9sFw24Tj!8 z_$$=oly|Q*dhGL|0eI5S))*xxoUQdA7Ww|Az0u?sU)Y;qjtP!~v(WfbV`9U1hD$=t zTYb#?-NY8(x7SYdnUF?Qc<~&V8`y|`L%vY>@D+;z~1iUBc%hZ8f#6k~gcc8K5lmNz8#Tix%Txj1QbgR*b_=1Px7<)w5r3)(^g zd%(^tlj^cs7Ol&LNyhg&GBiO8^Q-#~pRrQn#8x%*Hqw+CIBez*M*^d+a+w1R(2%o! zNH+Wk(d8kzMtyXw^TP_0zi~BPbV8-Gc-k?VMwCVC&)7=YC z_K^-1AWxWan~hu*h4gkA*&n8zo+zz+M9cw{WH3JTwk8HJ{%khyQ68}&4zTIdeGvMI z_|a%&4XwDKGh(gKxZhKxc* zK;$e-B)VYG-YzT0Uto(~;Ke1*u6br5_vDEbpCU&z z`P>oD6b3ure^S7GG=i(nbZgNiLczq{*jD$0?bVTDGY`$3y~B|UsG{bMr~9wZ(6=X_ zZufhZ@2hp{3aQR+P>pFop_@=jgucm+b}I!bPYrRKO1WxMR`|K7aqF^IDwxhhUUl`DkoJqw&Nnye}k3qe3xc$z5VIF;M^E(yGKqah@YM|!G>#h6C z#k&*-qui8*9%ym#=+Akj=5l$NNXPQw)$lJw3;|aZumZ}Di?cWH+yA1yQVl3dxe37S z+~R$)9H>%`qtG&bJdnZFvZ&hfYgWH{gEyv|a4RlS*3qtwNcs}U#Gdk>gosH8u6IE- z3}neckwv^G`SZi=C7rpYh}&Isf^&9?)GW!EDe&&0TR1$yfk!d}Hz+r`N2gCT&u%D* z{;3o9IX14i_Z>ghkgR(`xzr}9!hTR^-k6W11y9j`0Kq?C--ypswe`6H;6#Is%9T!YK*BvR8 zD|-xntzkSmm7SwV5SGf#s(W4pIV~6vzn`)d_}o;=w>Nn8hT6K2X#E=={mQTOoEoH! zs}K)fKE&k{D-H918Qop<68uxwLE1}~-{js0lS;7ux|QiOf5hBAmspJV>Ao29fOSvB zlW93dNqGQVEFJ&NVH87JcH$-R09gn9Mi|YdUemh$A%m(k}GHK1J&-%Jg|v{qYDo z&E(gK=!TR0vne3I0wYbXr}{O^FJHegwR9+R3DjXb@Hh);=f(!xywkjI1P1IF4bRcalQNDx+Ie2YkYV=&Mt- zgD5Y^6qpjI>ChnR3s|=3%?4h6dS?Rqx~QN#&K(vwG1j(qwnC?Izo{ZQGh`yU9A)p2<4dlWn`+=KK4+f5SO@KlfhuTG#5C;ut#@ z&qRCP>07N&ojt;G4);{43q;bc;Vt)y_SH{|RWp^SK)EDvk*fZHKo(zx0y* zgHd)E!KzMDEs7Zh=uAjh-e4UXsTs91a7wytNHUHtIMk{h^)PBOB=Cd(<1lp?t&yMK z4MjJ;TA>bo<_xQXaqq;EJbG3({;B-!LR~@y@e?Pt7^`Fb=Ehky5>nZ~n-|wyR}yR^ z|5*Tpi9K@ygZrOK%L{&LYFbOaP#8fgQ|5K%%z#FHyb}1?B8EvGSU|JftnM8bsGTRr zS~V1wsPzjBfT-Nc0U$e@OS6ODq^8k8Lu3w&HzB3P?uIwFw^9}Ufk7qV?d57)1 z%O6G8gBOh0ogs5N42bsgzA3;@d7e0uWT%6D`l@k@8}sK(833pe0~bj zJ>ZQjWO0T;5AX`VA_eCU`_Uxj5hn%rVq4(fdc5qGPAUZ?cgL=68J*c#9;crTs>tB*o}yXmkx)CJ>&=cDb-QOzJ}g~&p56} z7fX1hwY_6=a`xB!qQZA=Cq)q)aGA;U)N$6_>0|}ys`J^nx!~B6`}|RxRJo*c;*pIMf3)a!qv*9&SyS&JnVoEy*d-xP zDk#(rb0Zlw;qOALmX(g|k<%#&CHC)(!MT#yUD0nw(QBQ(dB18ddV zL8J2}!V{zS%n!eO9A)F*vv{)~>kl;@*4Fl&zhd@r_5(}9y(mTRyVFHX<{rw_%JdIc zXWjxX*7dTUZcWQ0JHK$oNc?vlYe2oWeUQW~!-tqyIHT>v*FX;vo%(f(TfpVF9(8Bv z-Mm65oPG5b39v22=*fdNmuhDaRNq!Ddj^3M>V?cy8&DAb{rQHRj4eL2y4lqk9NT!Z zsMJqwbwP_gww3$-hU%v&^dLTrpzOiw2rT`h*jV?=Q%M6#JM!nR!mY8dtpR?9%lrsq zKb(~XBIGuFAECP++^ZMPBNMwvwOJ1gk5_>FUq4sUMQN%%b=|)#Zk^?&R*%-}3Uvte zp|s*IW2elTSp(r5;@_#z#_!T&k;%P^FVqy0!ql1u4S<1aJ?WgM+|PGVKV^9_T&74! zJ-gI|e8nLA#xq42Kt(d1c&*E6mf1vU{it}dWz^x&iz$>VaBl>!zJU8g01|+&Jqai& zf>c7cmH-N$UhDZG*@DsQ4e*^AdYgruSsyT<~*ug+Q;iY>^Jd)8Mh=t%6)FPVxu z^cGFvy~W+M4=4>eydY!tm(ivW^AB2!L(^N!E@eVP^U-x4Kz(C#hvO04LW{apuXhh0 zx&ajzW&6S6tl9@m-P=xkL*Hp0T!~06uY@8FNVzirAzZf{VEw+HxW}}Y2efR48ZE)I zy2qY%^!(9%iC24{#Ncd#Uzs60(VDf3=QdyY4$UpiaX>EBLq7x z2>bfKTYCbIvFFx((u)x2-hDo}k_lbX`VT4Ld!d%-?-y$EyIft-UaLa;8U&Ea5}_8P zc3DB3s8(W&e1q4bR7I4O^6*=)m^zx~ATv);yk_}1T9}xs#dq4+wp;cn6~>(@U906Z ze`q$o8V{f-{Zlrg!N7Hx*dw>nM(JI$e9Cne3$fvI%iZ~=arKzqBVs-Vx8;8|+$-I^}i{!`4? zm-ec1UiE*YwVDmo{*{ke(BB6>4$+}Edpia6~xxo^=-{xo*$Ce!ujWww3kdFfEI zCMhI-upGEe_Hp4sB8(}q$D+(#di^qK;O=TbDp z#cvFLlaljIZMg+~NWDJKH{)8^V7fVK{sij&Q;&=7KKK)@5bj6uy7B8xkFm=FbYV;Q zC?eo~8@(K<@1azysQG8fX2+~DcWi53RNt0_G?Iix)V zACE!~UR!nY7e^gr@=zqa@-_ScN=qGfB_h~g*YaUTjFF6P`#y2599>9{=mP?sA<~IV zhEbN1NPDvjZiv=zr`s}OQ!-ilxp3!^@)vpZ-Ic55W?E{B7=W&7I0}`@DLAUkwJ5H@ zD5Qz%DpiPC3T9a;oj`fA=NFwjHpBVKyD)i6)sceV6pYoCzgjEasp~3)BuC(OlcZI& zCQfcrW%=GtT}N|GN7V98S#vbLPjDG!=9G9elKhhKB6+Ea<79_>vHo&9R9_Km{#z(# zm)4aUe>;ob!g@~M*XKx!d}mwANga6}_C>G7HR4oaK@CS5^dUJ8XV}Ef2b8{S^ymGTHwfSib)!$kL9*JCmq7R50z?0Oz zc~e9iaa(U)w3EI=W{n`lOb@yfm6UVe!_?OG&tJ4|U6mdZDEttb+Y+rQ$BD2&d7hT4 zjVEA^Nsjwj`(y-qW9q9mK=~lrA@~33AFN^R@8Q(%g?=_CM#AiYwwmc4B3fJglhY=1 zWAV0)b6x%zCXUD~@=63e&(*f1&8vZ-Qn!-s!3$;PrO#}J!AW zaT(JX24}VPb2B!D7tC}PMF=HNSzC}tBOLq9g`MNOw zBIE1<_rb{D3$(YG+2j^FLoQr!OCp%TrmPnqF{Wo~;~)zSs0_G^oYS0S_?{KimiW(p zHYEDv1}r!iQdJI8B{PeBw`E^i_ZO`+w~X+nS_QJr7`D$Mn`5cSg4<(p#G>HPfB*R| zR351x3>eEd-24a^RHCn_E4lHn^PnE&=Dh6I0KDzU%=3sN7FX_;xUJsSggKz}iq(Q3 zAkbdLIK;s!;=Hcv{qAL@?J@sFQW^QNawp1&+<(?qXZ|A=`R`-;_^+zbIvX0N&r-KX z?V96nPVFsJr?7+dz}uarTo46Cz(Yv&8jf+R6moL7GK$_;DPhu%MVt znYc(Yf#&(%I(wN+ss7W;vZ6RtmiF=c@ zuWjGFqv{NRuFsfV?46W~tChzjPc9otGC-Pu3n}!{o7HuA0S?$`u$SSMrN!Kc%pM31 zb%hrAjMC}S+j16{cYqH-dP?pVU;f4Tvaw&+&3|m{&x_w-A*`@pz&Jz*iC;Xz9*Ewe zE^87ICrU1UA(#Qyyif4Q^MWUDg3`T^&?ED)dLU0JH}BiB9b*`*g$>*KiE< z~?O zC|wFrQPR$`i$FRTGe^{BJ+lx9RZ~Q_1uu|{YD*rdYH#J-GSir;UQgz#tF-WBB6B4K zp=>811Mpv`$$InXj7EfvlOYTx@_}7aLZIQnAAd zzpw$ARJ}tQR;OaK7-=7tYBUHxvV!&7!vHmHkWO`-dU*HcqGlG-t z6hBwD9_O9GzWb*RHfz02I#{h=PuFE>72(M|S!#C)5ngTcGwC|1_TC8`_5`dSDpyWb% zM1vhu`ftdw(tpA=n$9mItKI*JMId>4{4M!Y*5K^I^irVBp0k%&v64zV=diTHf#0-m z{Z2LW5lFJlXt}iLTQn6IcOiH|ce@(qvjve%aI5k?W}9``2S1iWn@Ptj4^_M2@}SSI zN8rsbyv@Om@7YDZo)Gj~1e+W^kX4YGn4^A~Nz?$=&E?w+xKO_2Dx(7H4_q~FZjN|yjNr62>p=iXO9ZkT4)Yl^T z&1AxJCBV9qb39zF{7KQB>FGwA(lPu@xXX0ue80YsUc_3pXgz2HUcagV?R~oO1Lv=3 zGDR>8yuPe=#aHaJmaA@Uq7^cX=jmM}1w&dX(D`LqxTp)PDkj8lh#a5l8xN9VKMwZ* z<+~M&!D`z(`TSA2S}12@ia^8bOKFN)d+d_QFYW!%bI^6PFH*}C*hWnA^8){pXuZ_2 zV9v_v6znYH#~dlYD|3L)Zqg>)qeNvTfO{Bp{#aE_u zSv}HX|P;}B(Y_=6!eciLty1YqZrTM;q>K4>fDn)A2M%|$F_NTLFsjS{R zrS-*l^|j1qgQnM*!65nvD>F;*AbfpyCWm(`(|j zdga=0cwk$^0fX6SJ;HD%316Cl%{Tf%47A(cnTZvj9|oj1>blDUsqOn<%Gs0dCI)&) z7mJO#F2c_faVj~YKTrgI4lxULNt!>;_n|h*y5&uDRgLC-C%@I4{6o8)08&r27x#O) z4S`a<(!;(O%palVDQNHI#UO#KG8dfyRHzraD`1axvs-XVV)t! zXDvxL8jDvMVd&|K#NR~T!&#{zR=3D-BW@l8JU6j>m9x|}=|40aJ1MgTv%UpNO6Mt{ zSttkYo;@fB)LKLK?;qC%jOR_r)`Q!bUb? zQ_#@u?}%E{b)4VnybQ?q5B{5LzeIyMC)yF=A=^Q?{w;HJzx;IO`AoG8KKS5nbctH> zJhK&cD`=otMew7BLrA9ol>c^|(kDftb)CpeW+}|9vfUj##wH~nFPzoLt=dt zZs{=q>tMP4pyafRzmVGY32?MH#fJGA&@;%3h!GxyM{8~VZ4n@^KBF=+%M9|Bw+%05 z4ir3m1kpLtbks8ld;!M?hF-xayjWwzPd*gf04v~t-?0Z*iPSh4b4w|VXPRESFE2uX z-nUvrD8HwsmvCv@{WX)p)bs%X;_#-(v@YJ9W<+^Erz#aL%?;*#tA}&9E1@YzQGBW- z^3`$LpF7N~InejlZR2SMP&&9%CxX|v3pUo+2fexXK)rF=i)B<6v>e5MigYcbCG*zs zjG#UZS>II6Rh6;80sgK5%L3PD@D(gfE>gXd#Pxzsq%Z(D)`FD2Rlc3_8S z{U-(%E~Ep6A9J(KWhr2(DYLFl~IXvWT@e3m*A|bt^$AD zc{)HYF<9h97^*~s!w!o1=(;2D1fuFP6~XUx8Ij)=qLqn|all4^y)@}fyvn#7Mog!v zf|}qnW+<*f>YvOc-@tQ#h1X_5n)+v*TdTZ?UvaN{!tRH+PkFOn&lJQR<49jVJ;XEg zo$f!C=dGF5Jw)|$wci7QH{TMn5prILCOT|uP}#CdNorM_N8No8c$LjXVjXG~_dC3B z@rOUOrEQ*v-z;JX3kec!EiuT>F@TmqShw84)w$C3jq~V2Z%U@c3@A)5mGjf+S_>;e#9fm+>R|4TRc~i-LJ*_IM}H5p z&nUa-0oOP2M>-vdGkq450C8?0$G&)Zga~JTnJ4UxLL-rnHPrW@w;gz1B=yqKExdBP z$Jc#`fx6scqx2)?R5tp---$x#0(8X&>A$(?ejJ;QI|aEM2YyVYMO9f%P6kcS7g%Ck z<`_(8ZMo19eI5u;np+akTVVp&s_sK#u5O`^HM}oT{l+4Dp-D|J$(i=erfEJwGswQw zW@7;&xkvnhQ2D-TGoX8gyi31fnkvX4TXBtgs)L^Z=ftL{vZ|uhf}X4E)05ji2;?lv zH#VOxtkICW(GPI6AY*UN!lrXO);uXMa?5B%P8e>3-ik*jxf zy@=9fjN!Q+;ps(ki{YY?n5-m^er%9`HF$;Pvie3@S6(_T1}+MlUc_($4v_#k=Q!e7rf);owqPIm;F#UO03g)^IPf2@L3??@aG z>UV-#3?%BZ(Jdx<2wruz1L#pNz?ys^vQenJeH3OUC;ly4G0?&H2j1<7mZUaxo1XjC z-yVGI4d-0{-g^sdRP7~~wOJ+25+{0X6_pWFkv3V-7r+m_w;Wn&3%n_c=i#|*^kYn; zX9xkl=~kdQq3MXH*{I_8wyI$+E;=0c4aM8rJP`@Y*?UyGNU&#x?JxNl%_m<|P}Vz2 z3yWX6k*P^f-AunI4{3lJj~zVh zWzE9vATA@}=KqPZeMZ^*V{!V=gQQtfLT&E}8}9LWOECp(j}5wB55U!T%52;MSKDvN zVvVND*883QnhwpsW>4ZAKVZi0C~w7r2qD`m9yO|}(7f05(R z`L^>*tCC2ALTqnjEZEQjHcY;!e@J2*Qe>n3QPA{N$Nzf)I2r)Mpo^%vgTCb-G?W9g+bvR2 z1Mw#pnYL|Pq7uIN=9hx});cU>^Yp(c>2Dl$QYF8NEvd}-(%j0u$JiE#NBC#R{4;B>6E9mw{GbpHBD!4)_D<9gpBw=p1BePYyln*usK zPK9btlD~JJfV_!tI(x|Kl}2sPH0DF;6Ug~7cw_HSe!H7dXMMi1b;av)DyvJe`43Zk z$6B&dhzxPuGr1Fye3kul(Z~Sn?e!Bze?u%UEm+mSW)-5xMTWCDQkgV$y89EOoANqe zMjdB9>33O z{X;A0lRka?S7t;Gpn@L!kowhE9 zdDc8v+y@0;0}WR&L`8z_BhgoGUVw|MJW(hQ@ge^NB--Hb zqNwB!6#}~ zBk40;NpTM;TqrLv4$T-UsGeBzoZ6J(abc*`1~J%fI=&auLRzV=P6PjHw#1!r4#jOy zeN(m@me}p~E9c#7Z+|{t3g6`7$Av;-|6v=}8@Ivt9L7&>&(`JVcYsjo0!r$g;2ZpK zPi0}V>a=q5pG9yv*jPmJxmCge$}mMhz(YjLqZe@1U_)d`Px8fFl7~Ya5Bz?JW~pba zJ4)BY7wu2Ky3nu6&&Zh3v!&`TN!c4;n0`qe9l6MzBk-M$C$P%rS_aRhzvs7c=6@0^ z2W+q?#Zf$sFt_=royX68rDOa9>E@T!cu%f$J7kH_eB-HM@Sc7jPA6@Que`)5hA)5P z;xbp`WIPpL`V{%p|9Q_!SRr0h@3i>{)}T@+K59{G7kM^@r8Yi!A>BvX$}=1=fNv>f zA!bM1sPX4KU9m>+YHF)tWHr(={X0E?C!ysZf)bpGKU9fe~v(d=TS;boVhs#NrqH#=SM)LR@id9!tutNqA< zskqu8^BorEx4JDa;;?K$kLvMiYY>q*x2_NDqpdD>$^j1{@o32tB5Cq|xQn3lNdf+| zCmMC8Uk1U^f`6GH5G6WD%ZK@{QCLW8a#R44+xw*%xhkR7n1&n2{@Z->7d*t;x-Cn+ zaGHCg4Z-*VqGe(%){I+%%x7fZvIn9)M*5anbMYV_0r-i=N%V`gWfZp-#szTv zw^);bdi8uG+`7!*5C!f9Z@LXQh`aJ*9EiE~Ko z*XZS~hk~af5>m3!z$gnggb*v$elNSgS3 z!;ox2xGEHf`jT<_4-4-7x5h!1+2o%$xf!Z9j~3GsQ`W;7#1Zf-#9!no0s~P46-%>A zu2@||8n(I?H4OJmij#VaYwp4bb@s!A+2^~L0JPOiw4g0uMDE8q4-;uQp{O=LETe!h zDHX@e0(&&__c!v(3n`a4YVfLE-7o8?y=!My!K|P85BnJQqctq)&t-(Y(FZ?_@h2-@ zv9ByQ@*UOpR%$nH;JR@vv6q7M0h{sf!Mtiuuy^mRJ4LQsd}{;08fVj=l?7BUb!MjN zM>mg8*lQ1R*Qp4intUzC%n7emtlYtv{f|}fFUcZAQ8;}+xnP2mOD#i0>d&Pn@E^M4fa-d2+Q4c2DX3%mQ`m33md=iI4+qmGuuIcwIJ zay8`YeJd@%hlF>iY9%pv$tS|6l58+DLQ=ADD$$$FC5y(Ppvi>?p?P~j?a=Fm-_ZhI z4cj}gw=;>g4S{B2$97YSb%uw>O-L<(qP9c}hLn;-8-O`L~S zwzIgQG&k0{PN8nq-N;~CtGBGgB;JQhq?g)}_T@lvRRh!Z-Y4zjm?Mu@ZGxT%+{O2+ zO6W1_qlBfODMu11G^GEjwQ>yeSHYI|a4GpJXDZ~ELfFqLl)sqV68|2|ocSO;mN#i5 zEfnjcJ$Lb2Q4gp5n@2}P0(Q>6rl!zxHUz)$?#%1RAWoCo^-EveR1M$@JntjuR71Q|u6p8Tk6Oxw_16WaIsEs=n12ja z5_iMT*;iBh!1X<(9#vJCV2q^D-Es}bO`re9jDF~a$dqV*aHe=vU?agA`C@Pnz7DBH zxC}qfSQ>WUTfDKsJ#nxiPg9-x@S;CI-|Nqke?$CTdwSM=MxFn0GNlXTG{SQUxd51W6H>gSqzD}6AAS|_zjmr?|Seq4*lZTT1G2GyZE zNgq6XMv!$Jo3PNqTgpwJURSHFXqo+nI%k)iz|^qx zyn{MaJu8}K<8~zabivwQRPK_+KgZR@93Jv*d0pyVs_Ah-omaB3G~>#xo_v4(OS{cW zzO>qjRKFFVrb&gfHAHddC8S|62?hA?rK!&}BD55zi8(_vqLLH7{*Vf~ zE-wB9sM(9XqJ;k2CDwP6NBF!~f1qj%Ef@2GduTY$B!Ab7Y&uG)$K#LS;ZZl9=>$cN z4IbOUvIIWx{^+Th4nxGbSyJaj_Wnkrl6P*I0uY=bj=5H?e)i3V z?q+4fX%hIMTiKsRlBxQ3Asz84HdO}QzCu64$d;%!wJ7b{F*vf4Ieb)x_#2?)JhCtG zxAaLrG`tmDK!5x#^n(N;l>iw-3;s&~c3*FpG9H|lmEn5z|c2niy=Q;Hj^+W zYkUjVbeRZ#e!GVx_3j|<4z*sN1AYtVjuuuTw_VTb>jtVOm;4NEssahb41Xu{ZmV?iP|A-h>yU@x?)Kc=&J^57s2v0vOu^b3L^F z2|xgR*Lngqcp9oI`0A4urnkOFw&;tO;XK5_e08^1noi{eYaYuWa)CYfulj=YvH|Q* zmoE9zErtT{udHJ3>@ig5C5XRbV#Z+FEce`Ebwyhl(#PVtjAs@V7gzsaotD~NyT z7QiEDyNKJDB?wqOhrqRof-!|5`9a%^@*AkcN9dyznr|aS?h9x%%I$}y3T*B^xPm;j zrQeKbtPbI)zAgtuhCB6Z6lyaqR^ItnM+-pTe(pH|Fx&~b7ml6I!!*n7Amg5j?Mz`L zNH+gJ3U0($CjY`EB%k3Dw4Y!%5tDQ-EW68_2!iX4po=!1M&H?%lv`W!U66sKj5L|j z!Pow-8FkD0_Vm==25wF6w^^sP{R+7q9*%gZqTag#Gj1IxWkg9hdLW%be7ri7dNShFC9yEpwGMgh`|)Cp~aZJ1bO!vG!gR;^)xSUS#a996q4Ky(v8&7}p+y64?&oBFm9gkN+f1 ziJ(Vl!20T_H<%hnshecUPo{BtR_?apRvMB1dR13ik+Qt~v6`&}9_Cxh$nK=)RN&oE z7;AL-p(&p#fwrRmaT=PrmR}}$nZoQ9k0vmW;o*pFB7}XzJr7{8n7eKX&?Wnas7b*C z_m}HQU>bMD8bamOMWAAnOw9ED#Iq=Wn0-#75d< z6zG}0UhJ&jdOJ$$zp+mmet4^+Y&-~H=1$sH2DxUHyvAXIz0o|NrAN-+B zAJm0|mL!`#x|+Hy>DCE7h$yvxhul#{U6jMD3$HGmI%|D%rRPLTrYOE=0Qk#GAEsp9 zDt}N{26h}F+?=XGg}Wh7eeCZ~bFEGUBE2eZDARN-G;uP9g>Pw3^LHS$GyX;w`P8CH z4M?MBp~(dR8o(j5Y%o8gKxFNFI&{#BB+2)(BZ-+L8c}!yd=oD&6nHVeTu1-N!BVUa z)J$%w*~d7DJjmnx5?oJFSoUGt{P)bY5b+?2;D>-u?WcII2jUzGK^=ZadfD2>Rq1l^ z@sV}ZW8Qc=DdZzihJ$h??B+1<4z|zkZ9pCk(UgKx)x|Y&dPM5WLvcuvul>x;rIAHCvu_u|PzTry>>K75Xy z`O;XgT)@w+X8-Bzg15~=(=IWQUgRg8-Ei92Q%OFmhnMpXRryV(#yj0p@t`=!#lTE& zuMA`qLagSmRRx(4IVw{sXl&&iHxFsOG0?uL`IhvL_6l`pq72)%`8yXzxW%tRj6e6B zTfRknzA>YzAp8gf2%M!J@7d)Cf$j^RjA(b75uUv7WEmC_{L5532Nv`7H@34u_tZ5FkeL}P z3h!1mj5)CGKXi z5Y%Or!0g0Xh=x##8Pax_Wql?^<}PHyJ_n0!Kw2F^!>43ONCmsdUcn3PM7uP8QSL5t;==nEKg8;|NYl> zWOGB`?R8WCVq`}ZdR0ZcO3Sx6?gwEYA~yJk&W#J#5Sw;T&N0zbhmO$_GK?yyx zS}uS`T8x!#?Z%X}cdED;m$E*ZgkSuzTj_wz#oxD6v7X}lZX5aEqMP&THop-8o!h8T z>v5-f(p-lK4@*g0dARHEn}NkAUK;=JMeZH7cCW_-2$(T@ z>9JeI&{wsoo~_RZ%)A}w50{(qN9U5(*nxg1je9Bq6>YZ#}YIH^^Hjwr+BI&yErLq%~MGbWy;AG_q+!q3^d6aD;SZf-;4z zBZzp{+Pt|%sJI;Pzv&GV`#VDB=?$M0r68hgFJ%ndPf+wB@;_!klqsQ{*M0r4<3^J7 z1w(E})a&_VM%7tuZNoq}4A){pGEy3@#CEoXs*VULjc{3iW#)51XUa|f$H&VZa4@pA z)L;x0LAx)rB3F9THJD0z2PbReZwjr2#!+kd-**L!xkT&Ul1BwFN;+C*>!zn@3i1lB z`7F(6^whj7OZh%aDi_hYdpxBP$!rsQxCG4JWck)SavXA{pq9D@TkI8{_CRUl;S`a2 z*L*)^lxqeaC4(4-C2Of1f;%Y3eHXq}mQwnCXE`E=_o;JG@=y?qKlz2kKJR+(>kIV^ z=Yk2YyEC3=kHVgZU_W~{HX(pDe)e?Gw`ShWnXWwJzK6T`RBE(Na429YXa_Da+@?;K z#OWf*C(Wkxz#Bb?8lSrMYtN1V1lFpwM(lZTSJi3<2t>Puu*nmIuTcvhJM9Jy%&4yPi=`ce-1*~GT*)CynU3Vah7NYa zabi}XM1O(91jsH(Tx(6FN2D0oLg3@+C;+_+}FL)X~_8TE|1vlGU`|dYkdWMu%xGdK?)MjH-&mV zV4B)39(XamGev`b*W7ITyBn^0j;dzOlG{xmnoD)O5PIyxEmB{Fd0Q)o0`eT-Hqa2~ zRlN)SUgPrIwgZg&pnv%&--KKoI&q!sBwb|iJa?YLm^^q!Xp|N)KVWG09u^PSWjOIY z@>&GX?P~09*VoHY)FhNKY=Ao)zbo#vT_HIIU zk6;YVLk-l8V^DfhG_<)PZ+d{s`f-lc+_wCcgS=1e2nKK~uN9UuqVczSa3FcwD-%r4 zUd|5Rv_-v;tmwI9d#df@>lXH1Hrm}aI6S*7deSR^$))Rcd+>Z!Xw)9QhiW&wRn6nq zB~k*}LX&&<;C0;fgRju!lVdFrOfA&d@lW?wfwo=`y+D4N>k;UIwadw`=-LEQo}!jt z*2c|nDXxKb@BYT-dz-;C+}B{tJ<-LkHhcYX^Gu=9ZGpK?YhS5mQBHKqE^Z1b2R>v zpoBjSyLo3|#nsw;s0p`*AXI;e#|pqz)zEVRGUyD=JGX1bR#GTk;uH|Uxq9aHVtefL zymk_*N=Ti6XHzfAR{qs5X71W#K(luAE?_vnu*`} z_N6aXLfL}UsgT~i{U_|B!E(*mT#(K(`8NbqH0Qsiwhme|!M*;?rpZjB{yfPG$W zQuEsdlR$MTve>2p;mFxTF<(IjRnj9Ctl$2j%felT!;pX2{r$^sO0aP5V|t%!_*JV~ zpG?oDj^+`~zbi-v2YkV0k`|63%CGx;T0iUl#PjEYaiR;jpFYL{N(8@a)aUMvxirAnbmW6UhoZk;6QEQ!TXq>%#f?MMSAMZ^To zd)Bc_60?f4K0y?!Y2vm>A}pI#K3-Kj{JDrusI%GD{^MfgYn_bB2RymZUqekzdy_A=-6y&IO$0C;`=kO_RZiX~2Z z+}41u+}QDVhRl%EaDtCXVT$xizID$9OMNdzn36cHa&?x25u9|qG%%#slOki|4_YivgR?fIFsZ^k%oA#s{roPNzpHI6JN{t%?X~14NyZ%W!t~ z4xf!ZNdu2E|{IjN{wOHv@ z!(#Amow=)o9A1@e9}_KK@7qeIcVJU_8NsTQOExW|`-X`24x8~`7&$l}N%L@ZINA|B z^zNGxFgu!7txrBbNCqo#k1tQ{y9_-3`r5V54_|#vY{j14BhAU9-mzCT6JPDKp!{Od zWmC{cxM$GBN%Eb8okI^Sb3OBDcexS{Ug!;u*;Jo~+IQKv7%=d(zQ3_?_s~nc0LBgo zBso!gWx;*P{DuIbR{@9A87l&uOZVb(7h8Un}_O7YX1P4%9H_s7d9cUt-Kq zCZICe#sZhEZxgZE%(&wyPBXC(XDo5jdsM%+R4kSa@e=}oM}LUJe<;A|e*vOgM4HIU z^JF#x(#S(QJX~GSX1Q|5ItALgRavk0V-07sCLD}WZ=Hgf5z@&D9Idw{IP)O6&ZhWY zq5mqiDI6~a+;TlZIqksmE5UV29K6e=tbu58O@rSO^t07FQJ?)Q*67D|fA4h4p+&Cg z1X7LfveB0(l<9g&tkDoSr1r|1c?ENgJpQJc4FdZ3y%OTL$RDN`kUqxmcUiAW}E-Cc2wkSQ( zon-nXv5I(^BIq$1hJo;d(X&>C$O;7DE3i&VgNHgao1pmk1V<-FBk-sN>m8ucm2w;+ zOa6`j)3{z!Yq(0`pOZZJi>xdvqDot64r{JG?>t0ZEFhL+a7EDEneH&oC9Wb)Y`S(VuA+4>>chI~&YnRujz7>A2y5z8aKGOPj4tjf&OOc)tZzFI>h-OZ`eWE)+ zxS5aIqp_zxD)t!{E;hsQLaXT{;!;yrE!6FB&1{&nam;R!LI@{> zIA#mo?IL?6VDiW*UNZsmp5YeFmj?qXZ!Rv=Zv23V`}s=bIr=9p7=Yq#!kr#1L0_YV zH+9)eek5#av#rESMk1jTe5qgH6wU}+TJA5$T)M}-I#YBYp16F*^l*GgQFei4m}K&E z3FkKjjx!Rr^HBVVkK=G+HGYP|5P%%@eo)pAmo&63IleK%|LYObCTlsbB!mYS`?vWv zw@Ylo)@h@Z=pCQ3OF^M$V;p1nvg6F(L9}+5^fhgJ-(lX^2z`oezTlNs!?P^voew@S zpml3<?qD7tN^8SrN<+u7jD=4UGHY{@KP^VKsZv z>BH#$WGB6;NjO6Jh8&?GC0$QlM|B;KY=){!_V*TAT9UKE#IpjF1BLd){4OO&*!uoRwl@mNUA{*Y~I5Z$7NXT?J0{obCqaO=aK`cs%X z=V_#soeqj&(eWUP1c2|3yCNNyO>N&*^@{q^%nkf^n{2B@aX3GOFVunnM5uYfCKiu> zn$RzWb9#{TE;NcTNo!Kbk4XtcTi|mq9UHIXVjd;GIt`3J8rq9j2OMP>?^HtB*0SgK z6L(i6+1mlqr}4BnecIRJplj1<{Q~D5NXs4*Li&|~{_tX7wliSG1=P`t7NYz{O56{6 z@XkDqKJ8Glz}Xm%EKwRkOWFI+x()POZ!?pg+=3=zTg)3D!A+=XE)HV@--r_@cNskO zMbCGut88l8|qzX3CtBHuf zy9;zXbnsKdV3E&5V;>J$muhDbw3CveK4#{Vz+bT&{OBC9)H`W13e}ATho2@r(?UAk zCVMszVkUcWVm;@fTcgkF2C+fUf9v*TW~7jh@O*Qx-zDvmA@W{>*ik@%v%Q`~Ncho1 zxI41i;j6VhI|jw;?+q-o6pzgZTV*(!U@E@GAwWP|MxEknmUfdmC`0 z=sF9VfRrjWIyeMNLMeU6zx5Ja2zBt4V7O1nuBH`!7ZUvx$12W!agcnzw3S}kP0>+X zp-p!fj|IsI`H;7_xR>kZD4Daed9e5Qt|Ro@!S}7jIN?&)vzz#Vmr<;eh zmUmCa(p7U*8?w{e#WUKbqU@=Lqgh<9ud0PgBFE(BUn|-^V)47civ-BD+K3tPPru#q zmi%6tk78)vNw0A3MeQzG17J&LetH3n4$O;Z2e&+HZJ&?W7H`vBem!%Xk>a*bgz8_X zBXvYnZafS$Q;CrrhRhx*55xqQ94RJxnR-;3>oj-Fb9O-vMi+_Ck0bBeJ@8&aZuf;V zhAF7s>;4~6Z^0Hrb5u3sGuC#5KL&gflJf z`g7%lF`*%LhPl9(JN08pwYA$eErB@{BOX%GH3m)W4a>nS?9Ia6hMwq!^2y>G$$R>Y z*>}h#76EO8P7Qw#u%t$P;OIV`9j+jp+wDYU}K0PnV@Oo0y^4kZs{5E=Q846 zwuGZw$t98R$6EXN6Z#YxuSY?cK;Vu3{B1-A%8mtEq?P<>B@!$A$_qb%x1U&GCD@QG zO=8rqJ8#?|Tj6Sl_mLIEf|$ej)7c@ci!+ls{JU*oa~Ytn*uPNj?Y$ZifHfK8f=W16 z-mMQFG(wZ9rqLPx$0shsg_GwS9-Gy3c$Vi2TRj!#h<;v^`c@G=`k_T=;1?4>ge(SoNi#P^;u;eIlFQ&{=}9(4BzdC;BFWWUXBRKz^Q?mhVeK{LK*xF*lm zj$RaRj-e5WPvu>vr@+4UDNY!~s=>3W@GRwwSG&J|3}b}pUjnM;4P4gbg70(H!(VBo38%Ebn*8h19d z)0=v|h34#*hT>?Ft7b$MA&@qV1gjT@7{lQYDLv3~~ZdvEqtGy+_9>)8L!TLkR4oy-$+!T5uw@G(d!hL}2~KF`?fOv$qM_ zXM~BP^4b#~{pxevDl?6P^F4|a(MiW%>!L^QWS{n9<}_@hJ@&}YFLAd}talNFuOv_Z zwLSK*niE^jq>qser9nibs|=0#$P2N*QTe%Tv|OH&%u!}X=I~Y**?p-{iEF5zq+$P1 zeMGZmf42F(_^O z>zFqR7)Jz$5la~-NYpY1=!yB6)i@LrwseGysqWNMAfIy+mr;pnU|XS985zjORaOxc z!cM7IqMZeQ8oV{j>F50Wd~KtmvkS+i0N?i>*>*mc{jkX)@sZr)yX5bwUK9;>+ufgs z59}NUm5miT??eP^iV;x=Bqx|HOWj&P@;M3OUjsaw z+@#O#>5V7^k5>B;okP(Utw`v{1;-A?S>Gb|X^oWMHKX%N=rTB7Ou3M@%z~(Xds-Tx z@R&u$t=>&&Ywq^G3uFHBJJ?pE$gXk*1=^ID=g_V)1XHi52XTSl313_jPcCeBDKERA zQKnwDaO)5(Gd9u?GqF&+7) zls#*(;NL6RkLPfL_n|Ea3@o4IgWylkMR&%dr!SE6*k&99+qLk-(+9CU6}HF1lPKqD zK%p@ezcGA-kxtdYFZ3aO+dXCPmRD>mZfNqX{8&Xz;f#-L%t+&k+W`>EY}n}6WI?Rc zLHxZ;X?G;yAB_dUAdk}mFLYe-y?~(InQxekYgF^wQe3@t`L97wzmS5r#kPkY<&s*4>dbBeVo52e=Zfr#K4#qITeyxM*Q-O!}ezxss^uksYLpI zo4o{@kvf9c-$VNa$prmC!YAS~NFOX&K*u%q(b0hq|NJ`>eTfNpt77Y0l4H}3SYigA zXX10`dsT@4q*^L1_b_0PB(XKyUT>$O;V1>~EDyT>EV&PCD^gC=IGVznOyh^H&Cl-d zQWc#&(7yjra$|abQnK>-+ac_&OE@6A*6?+2P>&_DI*%^lUg{p0z@pLJN z;2y%S+ZE(KR*SJC}HE-HQSZ63GI&@b2e4JX2oSKRCUfd7$K=gFvu=u$R~_0zudZG@-P$zOQ)nOZ-4a5m zz?Buk60uuPYr&PN599ntGP}h*6o78CiZkBB&ddK5A$9)YR#OeV$bTDoY2xamJCai6 zF9|UO@pxq8lTfT|r9}G^00r!Oey;yzI$ELj@euRHz#^3~c7sld7emw7;9dTLvS{T& zLcKC3Xt2>%c&_<5yW)La?zQgUqvlu5?*MEYCr(f4E3iaXl~Q;{Qy*lN>@f;Z^OdfOmqAm%1F>Rw&V(i^^;i-3Bj)Qxw*a-5+hzSbmrH|0d-$3G<%n&Ko90bOhB?Ycq zMh^_}q?mNm|0kQ{LkSK&unr)ui?w55UE7Bl;r`m~t3YJ_?1wf#G{m5%h~TssFMHEOJ&fg#44QYHzaM7ptp(T+Wjsx`?%Gj6VmnMweGQV=ij{{SUD9KJF>Mb= z#yKHvuj5&=+j^;z1_(hXh?8;qPZ_vQ7+*%66go`CTQkhx>YB@C#%(tQ6+ST{9m>Yr zPaDWid78RnxhzuI;{~P!1_>q5(j9Z4V#ghS&&Wfl$&_petu%)a8_Qz(DSv{DBMVTy z=EC`p7bC7>9zzU-RXtecOVd+duju6wM5VQ_>r9c-eM)SSF%Z*pOmE-ff4Y7?omDmH zOjeE>QLMOl;LG|6LAi+?(;$FrL>x#BhjM$d%i7R3p$;*`7UGwnFAU^jAKt}o91dLC z)LGqeWeboZOJAvX>fqWlS+9cYd&MIqK}cGR$j`+i6)|(V*C)+18AnWYja$F^xYfDY z58ksE01BwOzk{?(%TrGus2$!XBJxNE=@ET#e&7J6q@4u!71rvax$b0cc?jH~tc>+S z78Cxf6SUV5Gxb@uba#0vfHhNho*@2t_q15oRu<$8D*qwNUawK+BjYH`gIus4)`Sw4 zDi>Tl3En?o`=E-NfxEO&)GKWe5T)Wy6D{cJs(<~)DZ}ZSXuLhMs-^av;>B6H5wAr> zeS1Gb$_n=h{@A?bAfXs~3g96fkZ z%DEm#0etc2t1)`>vA$k3pU~F@v8Kjm%h%bdmlic?oj*M)Qf!Y5#0{y!{he1|R)iY& zmV<7K?VRlw04cpbl3`|zoMK>ScV@A7uaBR)$Ob)7(&6f|qxkcwfz!+kdW}LrMtdXI zdX}90g$Ps-{D3`-#8c-6uO)|#E&1s*_Ob#_VVr;H)4}hI3E`xvHW_l@R!GR?zWDEq zLM`gXxZ;<6nqyAN!I|Md>8FuJ>z~PT0N8$79&MLd{XAt_e+A!S6kz4F&LLfmte3P@ zE}H%hvepKiyUuKfMBKu!-&mj6yFfD7gU{42W*L9+{0y>8I(w{*e?#D-FnVFcq{`-b zfq~z8^lnXJ02*m>=^FI&G2{MtZ^4)To`vZ4B$7V3*N*+XafaV(Khu(!URcMgf5DJ#Z@q1Bto3Hx>XB=$ej6R`6`hIVPP_f~44|uo^tDu>z|N1^E(`8-olFACANUR;ghU zr1i^4N%VJz@sZtA@xH@IIl2e5urGJp_PQuWP*b6PDTglR!zN~Zv^9Z#3CQ(}Ux&>~ zF;;T<>toQ&c50^A&}C#9qHr1Gd(|sV2}*kHezgZG%5po*be+pC#sEJYY=8{dH8%B5 zo;ub^_FlmnYc^GTHk$X_l*ypwS=3!Ox9I~h-O&}hjQwcOAm$r5NsPmY<7MZ>-iX3) zG+=A(s>#4@{@0l2m>&sA&s#oY#yNI7YyLN;K~{|cw8rCjOEB)yxKHWHeVS@-0y$^U zn`2{XlE1;@!I-jJhyN+&6BNoGxJdU?h)IR!T@(mw5J-!NrE2@J^fGQ9;RV#PK)k>nD3cB zgIWnV32-WXM1|o`y*Jy+GXEG7+_v<=hWlNZmP0wGx%dLtB`);sM-8Ht@j~(<5HPV1S-uhD}WeRyi{Z(*Wv}`&f2LiJD!=<)W6Mi72{)QYHPNIk9z*I8MgHJKd06=%i(seDpK{n{(IOwwA@I!s6& zjNR-^?cWQtXnxbKKt=vz!0O_VVJ9J&srh@1Q0^x_&#Ylo6Aec4pW8*zxUSj=)JWcj zJN8Js6bG?*7otb8u&aY>KHR#kkJd_QD=wnpD>M%{ey@8Dz@P(ZgC_y8sxUGcC$taK zj{!k7Cp0pnw|vx!q;@vn@PIDo+C{2hGUv~!qUQ%f`$zd*RYh2)1ENqh@-S@<5Q-so zdyNY*ei(%E9G2sktV{c2f4PtnB)XJO-Anj=8Nl0zjsFcX@d9QZpSh?BgkP0pZ6?w* zAKY87O_2;2O+>LK)~aVcslfdeNuICFNS(jya*{IxbAjK>Q0^;1A6jl{_ou@m8>-Ww zc9rSRssq(ir~QFK*y^*It_gS>keP;2VTyh$nB*J~aEOb@o^wB>|c{GF*IhO+R>V8r&C0zDyRwZ;`-%xrjoEaBU(n=9%=bNicpy zG-kl{s9=NE@`aI3ha z;q2@*%D&OrleU~M;a>wYvlNmOeJV>G7Pu`20mD>1n9pr&LE!!pnH`hd=)Sq&wn9LW z`s;{OWqL1xS*qgPvh@Ae(#f`A-Gk18%BK!SS?0&FyBihqU2Eh>&=Mz!>8hAJCK+97 zVC?6YC3!0YXh`S|f?DeRi_+c9fhBuzpsJ{W9{BRlQy&qdMVPk)j9Tp$RCM_4g#JTG zfBQ)wXExr)$WLju<>ay8sPoFX?t=3!cWSX@@L?7DV!5g9k3Mmm%a&eCa!Q7orn$L$ zR$e#YjB-2Yd};I2U~q?!Ls2M}7AoH80sES1$O@%`kVrvWt%qxMt5Bb*i;cs}l?l5f zXcGs8##PAUE%fEZANxsNVP%63?wv`6y@acSR7v5GQeiZk8k$?twKjJWt%;Ba%;@x) zxg3LvhS!*p^oyTV9q7T>8UYeU?^8Nh%j8fxc|3K9JZ*eA8dNfNz(ioNi`9D+rT!Gv zLQ2bbk=>ZV^-a6u6Z=CCLL5Bs!#lCo269o|!R_Su-rx6@{t$)LcI9 ztE0M*eeI*{AvB71D>!b8FW_OvUm+N?k8n?wBea%ZoF~u!O?OZc(^=T))5!Ssa5$Bp z7f)%sDmqmcgN>EHM-a~E@-JIuM}XVo-sA&AQ=YAbe6en9i*v+T!3NbAVC*-$c(*yr z^Um%Ee9$_l;Qyc2B*7OMuA{!^Cs;-*+183ha$i)jCH$plucYDN9Fe$FJc0)1qNbWO zT>CXudXh%GF5Rrt(Cp@v$CjgPyF9+{sYC>k!kTy5RN!Z!=dpd$DXsU~sAGE$GWiMg zptjsLFU@b4b=1vy(0FMHHTSq2aG4fC?+Kcw=QERzPZ~Zovxy(^CSW0@t%;((jB`wJ zXwY5}5rABr4a8LEE_slr7vAwQU5XT;+L=HO4sY8U{vdNK)tgryCp%*Bnc!-#Gk8m~ zwI^tC-gg|k-S6~FA^;4U4RT(%g{ib>{wOB02{{e>D(85e8rNPNrtfyK^dJY&^#SJ^ z2VD_uyk*tQh75v!z6?ja;=JNsa>Iw-cKilP)>s`<)`nneTie(zH2h1oN=QCtxSuG$ zTIBC`5jIk>QlDuUSu1Qm!&A^9HPc!rCgF&#m5V`R!?P3F!mOWkjdzT=bm+JF4KBw( zQu)e5b zwI;m*bhBjOFcI0LOwzjCHI{+tUixocyIpABg3y91;z39BAcin_ZjzK}>c0la{vgUK zOc-H&;o=7W1f?xJI8vF*ji7s&Y6yX!SMN}}T;)qm1Oiw0yrY5j?f!6>h?D9H{`p2- z*Y?1ikvKnR{3E*Lz{CV@%=#tk)oBtMja2u>oz1FWzq%`z1aO<3(n(BKp`NVMrPd`c^AO>i^LiGO=N{$QU2Jh<+AD0iP?ZMVim^76=2 z@{}e?@b-wKu|@wPp(OhD#YlKPrO0%T=ie{}JMgQ{3$Nmc!Zb0Q!#|#O>f*;#Qo=c( zEPOvku@8b_7-KTwR{v-hRtk%#Wn@h_Z28s#bJX%W0&)_VUo7qNOO_VU_X|Hi%jk6ZI{MDpb_w*kmeD-66m}`UebrP=nNk#{d2vEC z8$zTIO-XDjex}Tq`&jTMX4vJ%=wb%nhba)+ZU0zY$iiK}k(6NVaKWEwkr$dij5H}- zQp9k*qW|fxSPHTLiR#tjOcMAwy&Q8o?{KW;vj|CIi7mhEuE9S*Zj;1BcXeyCu^r#Q zUY1G`ucnu5mCMZACyI|vsnWg~j&ZUW{}U^1U=Q?k_5NJ~@T#h^BhwjeeyHo^E`1;R zm0ZA2A=674+%u<4ePY(B6G?2I1NhcpvYhYD)*TCMpEv36a6L5k;1X2gqkYW3rPumm zH5r_Byxn;Stw>rB2e*F(pcn4gMD4c_o#ETi7KhgM45YPLq~YZQT<=*~30(1t^~DgIo&Qsh?U9)9|+#UcQz_ z#1i+vpbz7kY(&ip{}qOh@1Y9F=uL)~M+gI-T?ZhwV=D`26&~*QyVD?FRNo)fyIP8p z+Q`27U@o`a?Z-tgpwU=$NeMDK8fq648iCwe0?U_%8duKbSc6a z*-DdB`R4(b_F&Y8<)5{%Ry}3-IdTZ--DBC^VSZ$qkv)znNF!$nEEmbztx^l`3iG=C zKNi64D76G^AC>NA(B2#lB&AUWS#pvuaT&$m;sTzqx@QL_#&>J#SVr(_=@>aJ%%gDt zd@XKG5pU&@q@h;UY)AiEXa0}W#sOV%aM3p9!zQ~`g&IX?bD%3Lt~;wx^_R<>k{mA{ z;7ox)$78*vIApO?3ExA`WbRwznofM;sPIaC^z{YND>lHv|8c@Z?y@ZH3GcA48$b!z zUP~57t*Mc$nr@>|^q}wQ%xuDLhd^GzF(=@Efon)6@I(8-yZbmBU;DxarliFr+9O57KWQ?e2a#ha*7-`*WNnY7!|!}NPiLQm(2J(Rclf*&UNn6-6|fP7-A@yv_2tv-nimhj`XgBwoj**9B&#oULlJ{Y zhFn>Fm)Od%b0Ut;>{w0XyYzzEf-W0eO@wtlgiWL?l>6?3i7AJFV!Bwq?)_WVd0r?IByPr+UmVWGLkk^&rE6;{Im; zNe70wp+UW@<1xm5YbqiM8SCFwwK#+s^I&I90~&?U4vOk`+r3%o&SCgeB!9t^r;0CA zxe_xzC?m2VNK59?$23>tT4U)m20DyRG1+fo9u~u8L_=yxnOhO+i9%9~0+Rh&-GT)96Gj2wyAFX-6Hj%6Iik}Sb zB2HK})$POY!Yy3>30sktaX}WPSa6&FIy5TQ5>z^)OefQzgIPHH@sU&BLGTsD>Y$M` z$Y=gH-9>`D5asY>%|Kr+7wD?m&|Z=;RnCv|;`(AaXP!xgI=q`vjK)hYxM=02pYe9= z9(FWDN?Cr(NMwc=kte?pvT;&jh(!ET$8@DE&H43AWfxb{zd5qmiJ8yh|YBQ z^=b6c{B8LpXLrr|RkFWGi{f*i@}gbXQ|UqJ2yEC%0GCYKs?6H1OY-XnC3y5ups>{J z^!54eKVpL~>J#3b2@}UbHs|7T`#zd}rNYFQMoW=?Ff6D=7oXze<={Ex_({&Erf@NipAOw`Plc1WzZxQbXE%Fm7a(?uyUEJrZz*q056Mcldxi|;FisY`{ATuD6>MScN;QdON{}13RX-(wR6M;0FPvnvP+gZbH*i&JP&79IR)l~&Yd_E#Xz)J33`EL?Ng*koKa_sDMUTz1^u+?hl$z+hO zpG9xLu8bzP&inPg|6Fse@3`I}7Eb>dk@6hdd2wfAu)y9$^JQ7|qYXRH>rJOQv)%!6 z2Xrki**=+Z93HNHDWxHGX>}`^7*q~od143_I{MqWv}<~Sx)T}|!#+|$ zGOY4Q>kCTl(~82_{A4I4&X)0U^_~s-%H_Q>yfP{-c}Zk#Zak)x*ePoH_tvl&EI#}D zpBOIlmD^)F{U8(dG1?d{zqh#38e_u+*3gWV?M&df##>iH> zj}9wCvK)Lu$vTJVI76~J-Cu6il{^KHHZfmcH3~RCZhOlKa5K zRtaZtKft`D^O_8>!GF+L_xo00h$Ca zlXGn%KNveFL;fXP`h*6^9_+*| zST=4+_X(zu`>~Bh0Cv-9U)Tb_JSamL&zak#PP?_QRb)^DTr6zJqVY&YzBOD}*hNHV zLNXe#Awbp1w&m$WS)N0*!0nY(R|0%tojK^-1(us%2?cBN8>@kkRw1y(wOX)_nvS_& zLRqL_2?rw(I=N!AvCUo=GeZzvtAu@kQlY zRbGry$JKnAQ*z%0lT^*UyhsC%C~J?M%^iT?Lf0WI3vzp4X!O`rFl-U`PhtVx@EocV zHgdQy%g?e~>MGR7<%L-ZzXz~f!(zYPj`GQ^dh*U$-VWkfWAfmv_MNy+)6^Xym}VAl z)rUH`vxUo9D<(XIHxqWw4IRpt*oaq<|6;y6+M71LQtMwkUWV^v>~cV8vR1E}dqD6G zkR*5{5uk!%3C6*@XAlgVX8m(B!2=U>cZBg4X7f#E?dUe&7Nt`OS1eu9#h-}VmBo%v zFz{@U_;}Ee`oxuwG;@*_o}25a^urV~sfw&(cKi{YU$Y#5<=bkdUw;Y8kzMQaIfM#K zdPMM`HDL33b+)i5^j{8pu9!jnF#Aw=tixO@(@1w2uJ1GahON0JaB7f(dj9%)>s@@W z*XtROz54Nm5n00IQAa*una>+qZ!mnB(-fOrS~imy{qN=$U?>k4%yjqpMWRnyjK?%VW;2jxtG&6N2S|1V<}zFqdNRr zaK@W-^xhnQ01Nj#1d}_(m-nAJ3@}Ks4u)4(lTB|NkzNC1!T+$nECHx{$jDg{VFgsvhN7`oMjeIFB--t-Tp-OMy-l=3qE-Ae zf;P6Kr;HHar9B#BMqj+>iqA?H zyg;}?I;NA<0ZIu~;3ze!M+;Csq}PdC^kxUCBLGi*>oT{liMQt0uFgM9{^I@aA=y7o z=(B)=KK}=4vaXqSrTL|1-KS5_N4e5YLeh5<pcwmBL9RK8pPBi+yb)3$qj;$7jzFR780ySSGZ=*s#%c4~Y;0ledWD6q<#_kEBC zA@Uj3#NmbaEp=G1PgY(zYY(uIqVcq)CIh|5{fy{>AAl|8a&$KZ)Ag3NM_@dvoHM@L z)SbLn^yL>h&}P6^tH^6zf<&mCsH8xKLsnO}9z*X5z%Sgzv|0^F&?&L+C;*|3Sd9``!A?cnUvO4C>V}XrUy}yp-2FZ{Gvt zZs>h>kdS|r&>656*YLB8YXF+itX@Ee|rSKa_Wun!WFxVYYl~xQ$bA`jiv>a zv3BLHd8kzRy>jc^UcIwn5To9czNYeT%XM@GHS7?YA=8bCDk3zJ_rzFhw)3)C(IyXX zmTt6i&p*5#paniY__K3}joKOFi5C2ytr;6w^n`mSJQv693$ft(O9AYL@p3;FI>Usm z^@W@9t$&MSy6Ahse<#wIEOhJS{QrBs7j!TlqhqhBK)5F71Uh?~my}Kyxb+94=S^E! zn?@e3tO!a|m{t-uQ|bKti#?3KR&v~-05uUHN+C?)=D@1NZ`VqqppyV+ zzTgQua+|HhMw@)V`d3@Y%H%{nu{|%ChFrTG@1oh)Syjz%N-rMS>wo{glVTO0)ZrcT z85>aJJ!`_7T1LHUHwn}GXv-@d58dgFPDQwT_migE$Af>+=>0>NId%?SmJ4_^F<@iy_4RoE6x-<4a~Pxc-qfFE%TnHz z`zs@s9bp>qrN3uypIIwwYu(}+Je+1ei0v!G?=w=W8&2-Ujb?h;R%TvQMoxFi$R*TZ)0gdJ0(g8EUJdTl<{?k)lVz zQ@8S~0dKLMB^yZ<{ivxcG8jyPUTWvS_304zRW=QO9QT_a*U96q`gJ56YfcfvmTz!d z;po1$dM4Rn2fpqcHA{1qED*BQOZ>1>m@mMI;r+X{ORZb}xzkA83F>%*PG!6un>S6r z+_`52rQ8U3VS{B6Zr1cnt_aB%zpJ$r0zXiRD?;Axu?cCG(zCBq3?L1d$3PeQ6d#RA zIxDn4M8dohD#*ln>R8Kp^E>zD3In688^z58=V7?e6RIbu`3XbG)G@ zlL;GzI2|N64)~EXEED-rLe4oLj_vSk@P(OR*pUXPLi1D_6cc{9|K8wp&$-r-1+I@Y zu}My~o?lquw;sfN2_YOxw9u2iJd?C@<^#65O|y-14lX|+r_rXeESd_+TAr@@WdGGd zKB=BqD)V2Mx(~-S?x3fBEb8S@D1+p`2XeYK+g58k81IT)5ygQzesI)=qTvR7c)7wm zpH7}eGZ(wt`tT>PkyLZZ7-JQ}@0k73SBH^*lqfg;!5JS%b{DYcN3}=DO4@Zr~PDX-N~Tb4#3Q&`+(^_MCi#)8l!hPwE!BQ>%h_5m!K5qm!B(MuA)<1MP@p! zrHZx82gh96IM35{DsoXZN1j8UlNYUt)+ zMuBg%d#jdTfi!%w+MB)CMw;fxU=s)GloNX}Ouxq7=+`hrVx0$uqh z)%C-Z{{&wbTqq&AUgQJj*T2;BkX$InA0>^+zbti=Kkf*m*ftpMqKz$(JK);)-($|cy1+5If+HJ&UhcbhLJ!&mxyX5LEZYYlH1iQ9Pmm+v;t zEL4A^4({6P!vCbsWd5G3>6wO`l&WF51fg&ZTKZ80P0^U3;Sn|kO5?ZHL4-Gh<}ine zVCQYvsGXt(=SUj0OI8|{S3P(Y1Mtor*I98H(JBTCWE9Nm*!t++CrD`WywgwWpfq*| zt>$-~WAn~R6%Cmf)xikJ!O1~IlD{^-DVsTJMt*x84ka)fu6_$YcPkE^$sJixSbafZ zbEbZAtQ2s&U9@=501%uyD|n6JJYyek)=XFa8$l>2@^M&?7Q79vSB+01I#bXqP?7Uq zYsPpR5iX{FqOcM5rA_x8RPk?+E&cq1DgqY^M2U( z!Z_=RDuBs#O3;|PZm-29{r!|mpDuHb#D7}G9(d@oEc7n?zc#EBaY>dLO2FZ5q$>E@ zemwX4a%%Iq{rnH`VN^j&zO%~@jsL1b(_C_f^*k=^*}Q6v&j-lAh%sPXyWO93!5X-f ze|#(j?*%EcC^KW)cj%V{Ixdv3Eo=ObJc>MIcO4Q1V$cqbA@ome{j;l@8Qcd~yuQZ6 zlM7$XY~IFd9}1iP{`UT-&tTV;#RILkAkFe(Cf)#W8;WfA*a;%${!tVWK59yZNpveM zWgyCPS8$Z?rL5Hd$jG@$74RtX{9QrBray0%*CaS2-`&F8h*obf1PQ=M#kR$(*{d+W zvdkT8fR}6?8H!7ExF=Se%TEnx4K-Rq8W`@qrKVN#da6=473EUhmPfL51s%pnm} zlM0}YU?WVwjuCv0{Yq8YvS}zjZTgK85I& zbfLpT4_0@Q@GIC$euGSDZ5qJS&2MM&5X~*OOi`($VF1(4loRcNYi;FZS$xl5Gz_(v zs_*P3TUzYD-r2-Z3Y#DlKWZ0JK2{%XF}F#4TCIO&VAbcm{W+^dqx&xB_tyrFY7`I4 zTVsu$na=8!>M(KL3|LJq9R~$D{3T5>eOtkiE{hdAY=b247Sc{Uun6dI?&9chsG~GT zU}cvs7=;S&7rAoDF?RWSyR?Qzk|s2>4(YGRWCQsEy94IV%JO+CCXt1HfG}KEBWITw z9F~fDHZgWxT(2;sD0ue*F;u}#-W7_%>Q?{oeZ=6LI26GhkNaLxThRg3Q4-=%oy8Oo zqC=NwzYtTtz!b&dozc|5np&vAdHVAjji__mQfFZQLxGqd!nrcMgFqne;fN*@pg}?D z5{A^5SV#@)t=wm%FE9y#^j!V92jR5Kg!N%SPs;l2YhOdW`f5&dmcKNH9koG2{uJ6z zyvxmtVtDObed+%jL5h^UimNoeHyTeqsS5HODvRV(0J)_MzWEf5B2MH*en@zmT?48G z#mAgCsYA+putT$Ff9%FA{nq|wEfYX;*J)dI)OofPEqn5rB~B}*T)p2}hW2RrJQ)uEj1o*4Tz?2%rR2(zGusCH-D=-!?=xR@ z!hRxGkoN z{CYd5A3?Q0^zTHQ4B*4LDOW@#w!v3^OV%7l>80jvoNgTy8+9 z6y^7>E=6t** ziZ6Z4&Gy^H%k2y#Ti_R`ILD6sjgxxf@9mvv74W`>Nkdm|-$6W48z1hC0)(iy8F~j8 zZ}d6Wx$wyfk>zH0e_?Su$Bye`HaPjCksUCj~%f|xUCvzz~x`~@2F#h_}SaKOx4A*=Uw_4)L!rB9Yn)-F zd+$Cj*j$nh>wQ0X^v#mBh%1`f>e0sZ;Q#+0*s>yi`Bb{sqfMJj#Cs`da!p*umjPVnFAv&`j z2wD{?0Ix9PyR4*Ef#&xQ;qzJQ=R3(l*(QTci@jeSnWK8ZX2>{aLUs)Iar(agKBvM5 z333wzKutc)Oh4lJzlGe)$a_4`ZG!E)qA1G5thU%Y<3GwGj+96eoy^n#&@Is(O;*O8 zWUezqipNhr1c4@F^Wv+NDU^DYMJOXL4*;>)K=&*&IAlksS)ctu#A%T_-Rf21Pi28% zT}*G5AauG?YD-KMkhcY#bBChJEm_E`^?<}_R|WYJXPsPlgVYpT`DNi+iCHH+NJYHh z{ElFP`dGiE06|A?_%AmVT3}*$hE59A@Rw~Yzv}Z-{5WAtEf%EaJ-YiY?%`9c_+n+j z0ialeRpgFVU^6Fy^QU9K)7x2W4@O+_8N{ArjqABFLY8(J(F`b3jIWDF5uaOf183FY z{T0HOWI@4naT4y+1jmb-J$3LM*;5{gd#V12sau{6PM-hmL2km!t&nxsVI6M=Y=|VPsFO&u;?;Vf8 z7PRxLvYM#rO#N6igO4BzeQPCJBE1QDDjm0GxGc25_sm_ADeC-T*|>g@poNZpoOVlh?bo7q8Uhbp9?-t0utI9m`42os-Qv`vhVk8% zR>Umhf?IzD*iIA8Ge?fDU8}6{I(3t3=`USHnJeq^GqmHWo|XD7OqPC6T8+Nl1UF1? zHTAf|`7WfW$M=Q6+MbUQW?*kNrpf*5pL2!wsB!s2M??dS4>P6O)@HiU9)FMucg2pO z%muZ(z-!=x=7UXba5?f2+bX2=bYSOF|5)sX(Cs29CeYTjoqKQZ$Bc9qF1teh=xzHW z)iYn?TI-3&J!bTf!JhA5?R{ZWw1|hPpIaKjM z0~5plV*$Lx*^NKMMJ6gCJR;9MfLB2fDz=ARtZ+@j^t&}(m{OG+c=0F&qXor?hQw#| zhn@Fq3!{D_d+irH*C>&%&%3Vr&ZK`SMePM<-P1r%uaL_J!EBN%U#@a+d0QxvgD6B<(IlV6r%-k=ccSx} z1cW16HM!P;>3lQqwc$ZTo%8FmjHnJJJx3{8-X+Ol9=o~RGuKv1ok`2nXx4Bc(SA~i zHMl9vKVhTC;7pYH?3W^Nqqs|IoSPb&2qszr$?_v;;y1E4rM4$YpoFA$o7?Tkd2R;iOg!8bXBWn=5(N`{nMXDe~CIygKL&s4>-+M@q!aj($s)? z_HKNFIZT)40z*f6e+}2D0Z!x~BytV26APy_&w{ITgw`W+>MVZ9`|~QY+fnfuxrY-! zzbYtBaxNVGSSY#{1Pf>#1-dYT-mgx;NUaVie=ee&?lpIK&nRjzrZ{%z4VJ zy-BOX_adA(yS%EkW?RI^5Hzm+H3(yR-uJ`1nsoeC&&I$hNF!?7O7@~#(3XzC48>W2 z+N^sV0A=Q+hteSU(WwhTH-z^-U^PjV3toF>-`2P~8^X8L1gli3b*Z_zDH@-Apli9Y z26~B=C?qVI8bpswTN0p3EZ(BKX#IZKflRv3V?+XKyYJO}xItsQAxJhx$?E`_2T$yO z52g*_p9m9wiD03%4&hMx)9Ro|{3uzfnxu9>bdT~l_}T_*Y~y=y_9Od_5`^CL;{fQ? zn>p+Q<>pxx*^qJeaAE`*Y|=vjmp1$t4RMJURV`l-4(hoPOP~Q@bvnA0w7n?LqQ}OH zyOy%ybrdjVZpkVMmk4b0zfc$U-JSK#d2WRe1+2bOz0U_&eWaLz3aCjmj<=D4cwu>G z7ul?qKKx1^Q%>;dw+zfa8I~%k!+2N57#Z_~KO(eCp2A*-`d5ip%BCw|799d$cCw$`4+&^_INLDG8sB0xB98L&OkWlrN~o_Tp()b#rJ`+Q;3#kcn` zY5wC64zc8_(bNEiQxxjZ066k^JHutHpOk;+Yqye#ZR;Gce5-fblAs%xpc6Ko={V)m zL&OaeYa6~4tb&q;6ayOjC~L)8UT4kQJAWnx1s!WMf$(qJg4l`U2bq7p4APgN9ZoY{|WDqcL&SU4Kw|Lpi{zCX4s1EY9uh2txG_9)iWkI)vhn46ft zO#(eF)GN#W{OoR#>oW!R{MKTq-?{{!(X3ZY@Hm+>&!{nYjwb!Yk=PQ6GDMG*|+tfZH+Z-w1qCTuZ10jf-=4=*IdGk-ivg zn2jl?BG2>P<9A;W`c)vckgG4QMSra!#xb!zPCTcs?*&n%)C#yaJLG1h6DGpjD4iVkZm1hib_w*e6?Egp8H!x?`2HVEA zZQFJxHYT?D#@57kCbn(cwr$%J=jJ>2oL{i3p4wgAy?SBL_)Mq9`R%oy%{+O!PTF@| zn);5g;)><&D^8=X=D|bxjl(X)2mQ>cf-11jn59w3Dm@AD!{wLCZp_1NnSeHSlLG--b~?3_H~nLW%W z(yd6X@8<&x-{G~FZ0P#(???Ap^ial+VZl*AW-idUHCIIQRhoKBP0Q5;B;xo7!$>gIE&3h9l^ycYoc-J^G|T*Wh9_nvm- z1F&5*ZUuN54cK7S5|}vnXFKV>+PPM1m`QhgqZGyJEM1*zazbRzdFvM>wnoH_TvdPY zWynCE%~#1Af%Uqsos@2|rCb(NC|2rl;Xkbe7De@CZniGRukX6OMF+DB?@*IuAOqp0 zdOmNRe!uwN7rVSD7HidN0=B8Yd!K-^yIf%z(XuIYFpdrM1{)ml@#m#^?G&zNhc$j{ z9Z-`Oc)0qJz-XwbGE0F#IQ-!fRQHs}NHzjQedf4C{+u(g@eI2VUh-(wKDRm}SjaYc zDq|MsUGn0mp>YqP9j&+Sw81VoVs$A!wi#Mxdj(boLZm+SYxMv1*EoD}uKVjZV8n9& zxpVatc$$|`!^P$nzLRE9e?-?saM*$>vst`&I z#!W`fyCi?HS~>?E;uoD&HkNUh6jq(!&TKMhM35xbLNQKBzy~uS7&`nNBVwi>*Z6t-&Y!-Cu2W5=l1I z+90Ev3n?_cuBVWzGCb0YFJV4$mpYV+56!7FjTjj!x#zOoNA`7hQx}UBzx92r4e_qy z^h2^^4=^aECFZ^vzKgw3NHWXNI2Tc<-1Hz+5$W0i$0M2h0r{56Kvp;!6Da=NtSADM zo6pmFiUK_DIN!osl0BU+wZ(L%T_*nwJMDx9DWD3#E#iRpoJ>$4eNYKsmy}C)R-M)N zsE8QAT-0ql=$!}I<>1ZfSH6*jqsBZ);oPu6AC5+M^Atc8US#%7ZuuM~3rUVoN$~=b zO~kV;jr^r9czUEScvoSh46;j#fqy22FhGf+Ys!RpqzSpafjZ^8AN(5#dgYMAE3nQ1?z@qR zUBV3Adt>CaKc(OWst*;C&m#BhtL`nE{4lfRqo$vu*9GNfmoLakT7$>@!g;3RL5w-@ zF$u71;AJ`4(RTqk-m@wC^0N=v3lJoPubHzp%1gFqb9eitQdzV6o{etx9_cA$rfNO~ zN6+>s>3whh-tThOSxd9`!E&BpNtvY2nh}2b$?`jyy^!+gQ`us8J zk8jlW@1q1ROXMQGQzgfW2BsLfAP;~^Ol{Chsdfw(N|6o%@chkn>Vd_jf{ObQutWqJ z_Rr!5HPstw6<)d;H;%;J7S;-c2_x7N_|*G)GH;Q95yaz)GST$3_2K(Td=$h$4$^RdQe?z<`E`RUbfl*HMQov%1G za~Nf3T9*7$Kq4UX`Y65${_zK};+Jr7@5RHTAmNhHprO*gc#4rZguGy+4jNn&sv}AJ z=he?~QPeTmL!>!Qz~Kruk6W>OwdGyZsA=V7FqyQ}l>9h!ktemHI`sfEZ-@Np&@XlM z;~^zV?u%WrJc^;pnd%aD;PW z7Y#a6&gjyyYf`>c3as&!*+M#z1t&^spnQSiPYqN=!oAW@(Q|x78^lzAAw~uN-jR6p@|5iX>kYl(a#sx5yM%*R zej-vn-H|j&=&`K4wd(@#A;e#8rl3?0mSOi<&Sy-A+m6g|Cry(QTJGM=V7N~+&UTQT zd`z7Qa7twUQRAt;H-#+ofj{}M@i3=#*O0RE>FjPC#kuo?3mCz3H2-|q;J2z$`021e%H=L<5DZ_#>mLFFQhrEZCbYrF z89gsLe*Y1a^51N~Bud`oa0KiESr$3h?2rZ^=bl;}crz%f&Ml1CsZe^pI=~tei$=&j zviNLOt|szKtwv{&@3gjBE7ogaDCgk62CUMs|SY*4}^2c^HB2fsrV7c_(q*iP1 z3^#FBl>7XD|I-KW4j*G@*7zCu2@7IPA^IOUXPO}P7vM|D{bk04W-NzzA5*e=CYbAL z>{g*RwQlJyff(=~<}w3l)4CQ_iBR^B^L2}2D*3}W_W;2P2^v^oYoEA2zU zgoo82qd!xoRSHjK4YTAOIZhU_@m45#i`c)3)`!;p&Scmwo>;vNZG5;XKzu;lW&bR< zYh!w!ZRpGXn#o!wq)^|>fBYjyxh@Y-HBHG#*GEoR%ml+A8w6O4m*pAK)w_GI zwY56{8&kOVJY^CmuyN0tD+r#!xX-H3Osz-2=XKH4!Knij(wEG*E$Q#jYI@$ zn}goWv{=h*Trguu!|jm|1G9g#?a&EeSkhkU*2-$b&EdNH2>;cGY{l7y>?KYj<5Y7? zu?H}GLFw&02WlVbD_1vk(37Te`;6rai&E*F{*;&ySP_TOmx8ul+$Q053a>(Ma-(cy z$k^ixbMd7Cu$AVd-rD<~5Gd1fOi>m+m{i&nncPdCg|IGp%YxC1y2$m`fD3AphP@4AUnVe95a;!^eUE&@D7$W@yMm zV)vY6*Zon3W12PV|JqE5!?~G-8~Q(`tBaO%xka%a`paKUXlu|zXc+vh_DkgQ5j|4a zf*m_%9pGj3S(z`xMl^O2d-iZ8V=&lK=?|3U?w}5C$yx?fonLfOxE{gy^%92+HDXbh zhOwh5FA2K^_J&K|>rySTJrgKkkgXYXiXO+Zx2h_lqJbG?? zik3*uL=!zjb2(W%|ECx;VlU}b)JZyJR?tEm=I?T(nBfc$R#jvu*B zcXD=7#d1J9L|Fzf66foO?m(BTuG*oMXy<$6v7Y3G{K&?=2iBj_&gFyT97xBsy7=3n71VuLzZSoq8SV>6tQ^nP%5 z#{31s)fu#1h>#i7?4PO<+Cdn5N)-T-ncfr)jIox?DA@M)H1ogqZkrtHdZ~(d$WEIT(yui4l478? zU@>-!j(W9a!=28&=T?4djj%7{eZ*cK(4$b!_oipa(LM#Sy}G<0E7mV^4F8^_Uy3D8 zqLLIBvekE<)4$}~H4YL;YN>DGrf`<1`z4?d(T{Vlyjzk~NN{)^LjM_n7gLX&waY5H zIhIz6X*$t4)_v$jE7(1>TWP#i!(;h7t4Q0&KY=;26uHby`7^833&aI(;>g9=p=h1a z2gtcF69x}jX0(-+eJy)eGD5paBIzK-fPMfvtu@>AslNn~SZ+=XGzT#++9?T-&>xxRp5fyT;d%4$CysrJossRm^{ysE;cX{y z;|9N7Vpw7SaZC0{#vP=AUww~Jk-uhmp?ie5kj!8Iig>6#;|{X;2oBFZ2hCGf>291| z`PEFc9_DQYTFv10ZFIdFASVz@so7|NKs=z@m->L+-9DY z>13IDK**9E4(}TG!^BNgGyZDvqzeRLJbLhsXtRc9+-2-R!(FLWO+(1_hcL}5e7R1| zi6N7r5XI4{+ED)R1Xnc9-EZR-W1$+i-hI?F?{b0lgcZS^lX=>#H=+aW?FhS};1&GD z;!?z>A!GbyQNP;}vF@(E`psE2&58r=|K-yADXcXY1^xe|i9zID4~8wcc$HyKX}F5+ zEMzx8u4jq0HT!{9`5CP4M0qU*y6?zxHHTUjB0_VfWxYG3JiPv!L ziu9k#Fwj_75%MZ1I@EmA`DE-Hll3tEF=68H1q0Bx{+K3b?9R8J90%YX&aXQFq8r8K z9;(x=Ju*?Mzj;OXIin0cHvcqrvodM*g>Y^4%rGFLdPt0jtwgJO`YH2ymXCx8)|?{E1bR{jV2)_rfNKMu|} zJ!T4HZ*}m`Wsq*4LdwSgpMcy^C2IdoaVCRb$l-gO%izlWRc(Pd zMzvmL+?bH(Cib@U3;6{9L|=tVJnBwosI93&KJ_5qmnpcezDy{i`EsA~D<-hW0Z#7S zH1VR{nRSXiL+?aR^`sl0`#RnFy<=ML{D4^0RuU z1&ghj1Pz$5`3t?ydI&ONajr;9`;!zZ^sLq8GA##Z@!mz~-;GN5PK-mJ{>A+;v%x^Q zh7!RjU9KopN3K1T1w-dJz=|EqMqL~NE2hmnbiN?k?;M`p7J`2(zsue=G^a9}z7P&Sesgxc_3 zXBIBJo=7(lr=iw*;LZ|!OJ2bGxqm+RKEIt1E1YUqI9jyfq{$*)So)zA1w@L5D}|u= zSXd|dxmfSmZ8N3%eV5F~G)bQpy1xH#Ie3l1B)>Rbm2ZH@c0IPc3woP1dCN~`v+9A9 z4K(pD&1gTfZ0@!>a5$G%$lUu&ZRFJoGlahL&1r_n@NWMNL1>aF2G#^G7}& zRWpu@&PkXI4W?WMZDS3t<}@gLdv}#U zHbCwQjmGz{a*Q1#hQR3CK|yUVw+5*%EPQ0fE_U76K4o{D*hw|AGbi=uOB`d(JL%X^ zxsz$7lCsxPjtP%5x%CRx2R)hq?>C1fr0>j$LwundosJD6i)276hTe0NK6NDCvFM_& z$mPD98T2f+DI95T3t4k0=KVuImd0A5;g~5i!qXitkJ>Ai#mx)8{zG|^5K_0{7EeKU zKmKLD4ZbEUnehJA?*$cqB!f&@I^L2-y+d($3|xqCC9uz}TI7GeQl8*t%C~~bNsH*1 zInWb9IL3B)l53eyPsz(3ZA`mKEN0*twI=0Ld&+ltV2&{VKsB;JEhpfh(_)h3%P)En z^eeNFDq7*X#q{EmU*K%BftNW7eNY{nA8eqPEp3DI09zs7mMf#YnQXY zz?Xm2kE-B5x36}nD7~E)>b!qvjH+i8GNth*qFHw_jXHmto>I=%lHp|HKd=%f=GW3GK6S0=oO^W+c0NDpd|xuF=Ed$;x2KT3d~eD>XTTq+^a|aKHUIEG-Ylht-i4B3cA79^+-HRe7P*4Amj^rja6kANz4x=?Yga=Q`> z0|dQvQVfftL(0oe;;L48wb_+0x^K;tw#MGg;qQQmW0O~r`xLIiULKNvg}?x~zp@@G zKmF#q6?qpT`{w}S!u=+FTOcBViK_=wZrfE4kcV=dq^=YVD0(Hmt(F>FPqPn=@`vsJ zfrX>>|3!(cacP2Ew~+bE+g;((gSZm*D7kVG=n7d*^L4-;b;bPL zr2rynT~FKnt5EiJESll*W0c*kQgnK370^o?TQnKGLCm)X6DCVbWJc{>-C}~vwj?aa z%|hO*#MH2o`I|MqcR>iMc! zILWMbnSNW@zUWf_edYJNs{GAQ%;%6B>iD`UBiIdkht|aJ=$a`aFj2PN8~Ee8awW@V z8itEXKJSXtXH`7CcV%G-WfU=CY^%{;CD7k5YxcWfT>-ORE(Tsp;xOQ)Pdsdc4BVtS zS{=rZ5vE5{#_L|4Wv7Z`V=7GqW<&uQLH`AVIPhEUla_T|rz0ZKr+lK@?>$UtHFO!5 zYgV9Z_puqoR;|z+6E4~d$&!O%|B7pwudv9cG(xM2s9L$FDXHYOrg60a=^Y@=x>;*bDD*oeXSh*KuFajM51 zjfuKDy)D<QYY$>R4y{aZhFRuW3POKY@ZOE_|#s4aa5+yXqV}r+m$$k7|8jzL=Rzr=%N|H0W;C;SCGJT=-D>3l2(9nKNK>oo(cC#9(8Ihz6 zLbeoAC@A_BWi~5T=3t&9JmvQleI07!p_C6(D9V(nBZ03|`UFAQkv*T3naDO>rC}PM za%;8Q`nv#6>*o;OwR&yovcO(U#60I4+#@y?FDMVD-clR!iMK80T%DJznRi1c$ofF` zL=!vbbb__!_)&ej3^jjqPVvzN>|;`+cGf2~ar0I2yZcstZ?)7Y6~wf8_HUI?t&&pC z8kc_vYrd~>EwgnXe6Q5E$71WW14VfD(`PF_mpJmGK(9?z5Ovv|eJu9gqI`Jry$4#l z(CdIGi*8))B~y8t0-#}DJtuVH&7IKHzwS-CAjH>meM)B1G~ zvCkkWQ-(IDH+I;bse?*-!+UWoUhkz$+i(VioqgkE>zuV(#UMtlySH-+S7Ux>6C%~m z)Z^FJ)Y^bXh*%@+7WNRe9~dtlBb?Y_08q1O`4rrf>It$cSkNZ4?^Jpo9Nwik zbYw1ZoB`u0gI4}9C%Prlb05b~Db}*L&2wjjLgA90JAwoC@hS=0H}uRWYgR(?tE2Ad zCne~h<{L=x#B?LHwUmJxOO&Y_!%dJj(2f+@S-t0T5%s^P2bTMV#6+~!jGFk>o!|Q; zZ%x@)ao|W~#MX>r5T=lA{nyc)!_%0UOtC=g>m-y&>O{yqtwfLi&Roy`4c}Is%=W>8 zZ4+8485#hwoT~$!is;coiK0#w-<6q$nP(8)5#lhyGsJ!~q{GTn5cqiq5!MSCKf|ph zX5=Ho{r;xGB^K&a7@;5}R3F@~p$I}?<1imWZH;_Xcr7@Wnf7_+9EQXNtoDNvY{Y!TZ(l?46NQGS)Y`xS6I`Wj&^Ieu5~oWkNW zP0k&9*Kazkw{Qd;qI~zzmv4tUT?Dj=A_y#?Kf1aMOBIk(O&YC($Sg!aaAx>mnp<^! zPXrH1C!9gBf+TZ0i{g;ni2ROLeIE*EcGjIpKczXT?iKXfxl}x(!=$!{X*{ay= z(rXv~PyEQPNUS)XTyPWV3Bhn9T4}XgRiN6AjSbsaAyCV&s+^b^H(n>_({}LmEwvnu zX{;QyxEE{yc&#*?VhOvYO9e)jgnAWNS~}Gw;||7clp!@%yHLKCj2fnIm%P7Ia(PTr zifY&`+?`Kp{9bww*l+=}PU8XsPgRe+@dfRIe6RzsP3e|IIGa6h5Yhim#l;A-`4?J% zMCO6l(wl;_N65MvnkFecArV+ZI;{P zjhT3ZQ^34gcLL*2jeg@Yo*#MkvR>j-}SDNBdLR~ z)hEPnu7I9?Z%%vZX45ECz~YN)6`TRh|1U#V86b`#*&wXQ*$B@cYfvtOq_j6%s5!(V zKw0xg0^Zk%?v3ms@|n@)Z)IHb!hl&gK&1rlD{{wj9*(ge!)HQ=oM*?wMw^bqEGVwZ z`=<)p=~PUAdBAWY3pb8T%tXD6%`zwxcR{CNI(HATq0W{kod4-6+&EcHHrByl&M1-Y z%OXRUem_B^kyB3G=uegIAUbb3hn~8Ka5J5GlWW{v_Yl3Xclyria0oklGHgfQ+`QVP#p%XtTtrY6w}_@iPxhw|XKq z+fgh=+GF1^99DYRT+%vX2e6xym!qaK?!UvOnDC&(few0;qU_sMX;M;R+X;uagE9}j z&tCP=48pV_3cY*)ZSZl8R-FWbbR}pZ@8JV#2QaC|hHks=(U%uGK4$3cWP7HqIHK&z zUgHQ&puFr6SxstK<~q6vMtSK89)P?X&|0aO*wE6PhQlg}Vn3?41Z1UsZ_i$` zc%L$%*C*<;i=rCct)}Sq;LXna{D9tNS5URua-jx8 zp4U`*&Z&R74^ST_*ox-vDk5qtHmJhl%6l!01AQZ;KJAoi{0IFlGRiTIc}g2BNO$<_ zG$VM`pjr=U8gx})O@2*p4Zv-Y>a3sW$y@sk{Z9tQWG9o|+hrMoca^t9*i5gk*6y$- zv-m{@xs^7Pysz_;Ri!iZe@3bd|Gm#^->%`;tMw(S1kE`*G^q=#tV|V+2NAr#Y_trXc}uV%hMMTx zB181zG2Mrli%I43e=?#Hxr5B?ppY{!PRa zznfC$#XATSjW+>%$|1{9O!Kbwz~FaX9B_!$b+XE**mHA_Ee)V-0TW1>4wf^DJ6L{T5t zQZrxgzoF89*?ps#sPp&GY}JqO3XY_QXpNaj?4hM+NvwZnqf)L&v(SNm_PozzjmuP; zSyQp|J%=02N`t1@DdWCP-@xZ^D4BM%p~&%3K`bxu#{xC((c(JuM+65$82v0WxSWDR zJMifT?WYZ9OxdG^riN)K^lQ8IgR(=~ra6?+R{z73Rahym={!3G(Ol~heyjR=$gnu2 z_W1i0eN(qdV9qrYT8M|Raqr6v>li%HL|E9af^f&g12H^fn46jMte0mQDbg5wyxaUIadyDo^#a3sYWqKHIVv64K*fprA zEG|Bbmu=4XeKA3`-J#^Me0(Feo7uPqEKQNB&veE^ek7eCK*)yucHu{%0$gp!kLa>d~_>Rp9-4@?Xp4{x*o!a6f++u26w3tj8D$wa+L*oK;@ zwi)56$?(s9OjG4Vq%*wcr^8%Th+V4>V($>MLWj5%<{US|Qq9K!nuxx7FQX8lcw}fT zT@bI?oenH<`U|q8yuw+KML~sI#VG{!WHduL(P<+!Lvqt4+4h)pC zk=^Ry6E42bc?`XLTsQqU())qWtGUb!QsEk!9Kg-`g)Yn~7p=@86yF^g0q1A9tf022 z$&k?TuS<(Yvbm+3x75hCL1vBN53KTg*gSq&nL*atNGbLlIrfd2~lVT6* z&?yv;Aq2q&!_H~;$C&HrjFfbnDAx+=<(56jwYkAR%YcCBXks>=w}5=BE)*V;ubR7} zdqo`OWjB!yxM|LjT0rN^ASM^2=#w#YU>~9@9#gwH^aIGPRKDQ@?vMK}YAzuomH|G# zRI9>t_#V&RNRWi{#@yGCXR53I-*9+DT6pB?3al>OuT)XxR_ZHf3;oQo&3x|Q#CHy^ z7XQ~ih_^)(TT#l<(O`Tyhli;}r~D5G)65K4Gx(w#tY`S=cnWtn)Pj=7)O(s~MR-+<);s5dlL z2jCp=SLT`X;k#D+e}rfkGo^M~jdcV4FcoNQa=ppR_d9Rw;9{aW*T1_(IthZ46I${q z@0l@TS2FW#=%7n=hv?IrND1*L&|gLTxqxsRlI0P9y~A}H^a>7mM)J#K%fg*O{J#9H zKzN|!^L}Ny8ZopYs1#w~P1cVUW#o7YPLyb<>jluANj?;>edFIj9y~a?^L+d4Tk-J> z!>EMpG5j>Stm}Ar<{DAEE<|crlxmivGAWbGpSEMz6;ZN9N4*4LDc^v@6`0LMamt+c}@Q>K2j_D zKKwFoyWl+t6Qn4b#C!=Aci#of4_qfi5hWMVyMS@b<&dYbtk#L_#jv|EvsLe#5tn$7 z5o{y60*h#gTY%&}NOYZ&*(>X5pFAR8U4#79c3Tsi>FuYd5fB<730OwefFw_yumhTy z;|4d+q5Uy8t|DySh-5vM)ATE)%>qYmMno13#noMXJ_g6T3@q4XEdb-WSBT%_dXSZ9 zcwW!ec@E|#K5Ia15d1g$vuO9)u=WNA;(R>K&^+E9X<=?V=VHLRsTm)ftq6aDQHb$? z@}@tCwx^@D^${FW84a~*#1+jRgG*_-=K@)`a}^}lmsv&cwzT6&^CG$bo_PXj)+dxtIEw>!R#$TDY$6=3o1Ny(| zMhP5deFp@bSj!D1=0G>vTy-J>#`#lApT|jCDFkg`Sa1wQ(%OOvf}tQud7CMN`t3-9@YxKA?Xuq z>!fy$Y^b@tq*Lr^y||QjT*ArkZFKt^iKR%E%Gl@%ifzeOq7M+w5?$bcvAsw%+vhmG zG&?Xb4~W(7n2fpEIt<@;p^GUtnC3}26qCaCW42Duv~JI4*yj5+C(C{H-aW5IiPJJoq7aOzpF-Wde8BX2AKrPs;dMUVn@`AS2&A6A7ZJ+`}MvGMsh7HFX5|xK5305EN1>Q3b#w*OE_6|bQFB5d3CBhhC zES>6`sp?1H1K#`jWIw$6?r&LZB5t8|a{Kl(Hm)13(a;b`Drb*03< zx7Oz)c)0J60l%ntE})I@G$ixFEWW%qYq3Jd+>Zm`1^jn)IjU+A#QH~|452`GN{Jz& z40j;@7^dGrn_?zo+#O(r(-5AAI`r{C$Ss1l>L$7xEwHSH$oR9HfGGfCO}h}{SR;PX zB}>b~8G&B?thrg%Dm97l*@?7TRukAFssq zK=3MXVdXpT3??OUqJDg*q%63D_>LCO-unQu;%3!o5)>#MTlu_KK7+S0b<~MUd)bLhdxOWJ;NvSfwb%@?Z zg2i^zGp4_>XOt=a&{OnOu)L*L+t^26;V?634&cE7XlBhs5_aAX|9N6>WMe-D%q(I1 zZ0o|@6@l0%?sNlfCZ$Cy%+$~qBIo2HXaqq14U1n^ok&~3J=GF{rn@q(SrHf>lh(_z z*WEVaQMkPb^ExVY{wzAxW`4)3l>sTJo;&17MRa53JdR@Uc|Gnh%wft=kvV@!Z5`EN zS^cG=Gq`}Za81#b-Cf5z%l4CpRQi5e4rh^X*}iamLf$CHdkss@de6@Ow+|V9O)GvX z3uPlGT#w<6a_}VgJk0-tmD-ayl@fU*t9N1bm1H-!(vOB~YW!neKjF*{Dpo-ZAz)K}g6oCX3p z(NY*B;?-ecbHMHWYl8`VH7#&>d~9}h!4qEo8aeCJnkKGC4Ev=hAf8VjJYEfD!v&$k zQDpi1vvSAn{Rc8k6#&H?|K$^Z1dNVR^PXX1w19RpBo3{mBv;6Ew=^_F1IMUbABAMn zrEsTUi@sA%DXB{tk2u8Z9MCLScjns_WMLETAvI6qy?P)xY|E1$48kE_ORFf1Cb<05 zJOj>EHsKWhrY8+q?O)R|D6wyx0^egg8-i)QS$cmEU34e3URvtDP$ODKLZh#rt_!M> zqz;`XOx`Xs)U=Cp{WZ0Lre`BZj#jHOU>p@Uhg&{;%HxWOw{aK2T@xae7sq75`W#*z za1E?7*btP%=nx$`iwms%GQr1PZGIBl)83|ENiD$tG$zmvXstEPf`lf5A;dTOytb3* z3`o5GeA`{setmO>^+zwHt%JrncA@KH5UAtfhKqIZ=H2SddGS|3l=mA(g>1>WD_tD& zL~~a5^XZuBRT~H5ba%|2Q>(+WQ2swIfY2USmNmrJp%o^6xB?gf%nAhno`h_m3^sK;muafO{*Y>SEx`z*%<%0CwmX?uG!A8!k_ug}@d z*5{~DU3t2WW}Bo+kK`|=dxOFHa8wGD1@A$TkJ^7;Q~MbOP7op@-NP!tJ{Nk5Ds51- zHhwiqh0KPQh3B5hXPnURmRLf5xh1rDsihh1$IDUVJod&iR=Y)fZSC)H(CR0y6N{gr zlwej+L6qFZSmWr>^!Ip%sne6JN?S+ow!1f+$Up#7!CCO{tQ&BzE`}Q^h z$r`#B=eDYuA{`E*b}B)AsA@uO6Cs^*!z`S6F z51|&Hc_Yd!*?&-HW<9C@j0UTk0EhOGp>R)mGr-MU=>6D$c%vKTD}#&)2t?VXd2Xy# zfWUwi-&V_YA+O?=lwusa` zo4Y4E=34`Z`ROn1RVY_k#$lykV|XrM3h&{$@XmCBczWtym}0g3exna232%O}Kb@5T_E`TVpjz_pb8#{g{^zRSwC;;&o zg8<13Rc)li$tyf?ob0hf3B1~jKq3H~lCa&n_O{8Me@#{*X05F7UK~$dp5WZe8!+}R zDk6%X5|ld3LYCyxK3>$!iu${yqDnfiXzm-sUdGW=Eyw?kb$8@N)a|#48Pyj6)f2ci zQr;}z$*rit1nsarDdv+~fq0ssmVh%_agbhDK@%;@Jq68eL8A?0;0e9Dp@?a^A}PaW z((6*rmvJ#wVK&vn-hki#sdjPB@TLEnYBSQd6s~crcU}!hzQ*tv)M|g~0^Ygpd${|# zzyrg7O#%_R2Gdb=WHeNw(Js;NJKH^BeFjb5Q_e}V{XnlHNg95#=KKoTb?x7s#9fP} zKsEeKb(2Ez3&W^Cmh16gcaH~)VvYkKJM~=>7TX{Jz3ovt_y*OdhXNZR!W{bY<(162 z*aFQz zCnymvtbaVpC1kX;$}<%j3UVD@0i}4_Eqo_(if}{=Go%P!@UNv%ahti4g?y{srQ|^Q zu+|9H!BF~7?P(oeG?hS4xrzX`gjks$jX*{7-AfpU``^Yt`J8N_<>a1J=?!`Tl@nkp z;{hgg=A#j3%4WB$Js zmvtl2okXXo&;p(Mj7u;FVXkv^y*V{<->rM^-GpCv8PQiHze}2s_o03wzA3;XYs0b6 zeyh=PQ}xMoe7XWmr*R4{qm8Xs@3rLK>32o-Ldy%QN|m18#B=-wKy_K|W5K9Tn}IR^ zF-n59pOWnxvty1V#Psvbcm}2O2GPc|S=E^*^|F1qUw3U91TudqgW4g@U{e-a1-jntoxet0;bU~MQ&94U6X^`qV9C2{OBVcNr= z!o{$r1!_5C*CidR@j>v?F3E0IKS%9hF?Rca+Z^k+`}>Ir)i$kvC78~M5kv_)gRV#S zA+?u5{*AmRI7t2}Rc*qck2lFl6Deu%8G!5|9uxkodX&>_L-xU5_T4GLT+ zS$2N`2(r!FLx=p)$bP|uJ36O8ME&9z7w0skzR$5fNp!>Ck!GR~7*Y<6QN`l@b5-@a z)XLh|JuEH*`%4n^1PHp2e+)QbF``$%{GI5X%74MLCq2R!iKdqrY z?I{;>Lg6-zxybwPNW5ldFcpmn>o+vPqY9*2HwoJ@5Zu3nB}~`+`!0+C_W#lJ4(ypQ zP1kNPv2B}IY}=kB6Wg|(iJghwez-{e?cNyQ^xQwaV$#1z*NKpX)SK z05-o*M)!j?<9rn!ufpZ<^LmWKMb79y8)m zA?Kp<=Gu}SAd6?K4gV6$OiHj9?)5at;`mQSjUC5`v&#UQ2(o~nxxjHjcsl*X;Tcn- z5$9AG9@mLkFtI_PdqQ|3{V^|uE1uccW%2Kl?*(i3B7q_s+?V6WClWlN&t_?tHsF>9 z`pe3x?T-uuf2u6EE!(r2b=VS@a_gs0`tXbi;Lq4&=36yd$`)SA5zP+R1Mv&n$a%iHDC+^f-#SaEQJ>XLaQ^n-HJA8Q8kY5S z)P4G+q2?>!Q9%rmmRU&EbQYOAoi#4iQutI+-yh-Q=eU~JHcL1bbO$ORUn!7b@`|sd zTWTOn*;RPpjhEfR2^YxK6VwI!reRR@3UiN{*H{9QFRcB*-F5okUC8?Mr{B#trv3M! zaj4Dw5e!eb2H%}pC!s45PohJ^KHd6my%f9Dz0-+zoC!V3!wX@Q zO%OYed=OCC`ak}`TI%iVz3F&447FkyzDB9~pc1>}l;vZ65GM!yss0Z+*|e2ylTnsQ zoy-^$IuV7|m}=G!o&J=MD{EwCy+@K?CnuG|q}1Zp#OQ!JQ&i+=LfC{Q^qB3jA&Hxa z^AkNVbolxCJ|0Fi7Vnklr$Qs~K>Nx(a{`OOzr}UX!5l-%`>#o3XLxbcKW=PLnhLrx z*bFtZR-(PkbnC;%g>F*NMPnEthZ&$EvOFYy7io&FyNdrP_+Ej5^Ci^}Y+4*iCBDJt zHGbrZF}z)+E3_pjFaTATZIRikO{x|>4lN7jFF<5>X#ELd#ez6%)Qw5#{+6*UnEUq1 z3k9eD+Wuh01UCm^<U)$XKSet5d`b;59h7dtJ&j3$sx+ zSD0s!Mq2nh7tHRToZ>YrlQN{hjPSVLZszD}oD${dFZNQ}iDn%^x}la*u`H69VB+eE zWP{A`(q!y}r6OJhzYLq5y-v*S`FcAmCI>@s->m~dONW~cNH4`LA7F5UI3xQB55!Z_ zfcQ7{EuoN%aNA2yrJ5u69-9VRcYKq7==ZzBd}rQJgN{kmR8jT_j6m*$g6jpO zDu+$UR{drnCnng@1btRr911?DFM(AZo7#?!z^x=sWym?!FL`t~A}ei3wy`gy+jNk0 zd{vJSp6f+&w(;PI?D}6BSsvHlip5i$MwtNeeEF-$IEp0S`9Ozd5~enNiigsmcO!@8 ziBQ13+S^29QsXn_WeFve9D3mWXWp1uQZ|F|^4AH3zTWvnQr9=~EmBj~p=x&yK+xkZ z7#q>T47Ag(?ex$1ivK8mR=S2P_u6+<$MLEi}ivdIZ_) zXKRAuK{`GsV7iCDZ7c;f(etZbc*zBYOI^%ADergui(ISaXQW$d_h*oAq77GwLh(yM2U;bh=ka6G9g}Q!55&^ z+!|fXT-r;Gpa;dWZw95D6bcIiJMy7K9wZth@M@x+cjvYblaT0*)X7lqW&`A+aNW}B zz7KgnYHiX99{CZ?amQ>$#AewRRMsy;b8ds+JBjT*RZ<^MjiDW*D0{*Q{B}US_d1^h zZSdN$o`cZF8|IF;j%|Q zn~*D6JR8J>LWIa(3NAXrjz1prb9M=Vb8YvY^SC)mJ(llBoPQM4X3T1u>sV&gLB4*A z*tVxQ8jUk$G{+$P1flf1Jg4g?unHRQkAd{tyhDX>`)hP4ABrZ}Sn%n#(SIHJG4+;l zs>w}hMiW4BlKaJAYKk`Z26jWKW2q~$6!J(i#xMSIDwhLDXt9POaz)`$rE@s0pRApj|flq{%nd{OP=IHiM3na2!n+mSN7q&3usS4ZU$`XV<~txHJ?oeT6n z+w*W$z}!keUG!^gmTjJ9K)^Lt?MvOeF7ChVF9DaVqx@}ZSpuc_U=CwGhW)ON#@8Le zEcu3o3v7({R~ptCIAm#j`ZPRXq2gUgwvd0SG|(J#{s}P`+ZQ`Yj&1JlDb!(n!bM@6 zi1_tQ@T?jfJUR;NO1cv;0jbN^%vUMhx?SE~Smxp+v280vSZ%T%RtU~$&U^M7xE#bhsuV;{#(76*TcVA&VHEv)LzRHg{l z&)7#v-4O>Y?@s2@!$SnOj?ReFNXX3(%L_}~}mulh5S#@4g8hpLmV|jZ<}P zHwW)dJW}}_>)ue{RU#qoeM~h) zT&E4JKx4bk@lQz~Lu+KOzPg=9-g|(hy>f)r9E79@gf60ICrEf*X#41`TE7*=#~+a=CU?G zH27zJ3i^o}U!j;L0TVW!pDr|Pan1wlnao6FE>~<1g|CMcAis>4_i@T#s$E+0Ciz$UjN8-il)R0#qT0NZ5t9q5xcaF7ZKF zYV=ICJPW?jy$(hjN#6z-RnKKoB^+m^Aw*Bv%5?kIN*F9rRu`^fVIG$*CR~e|V1>sF z>&P$63eDNL(7~|6)xv3it*59hdC<53i&?$!py`ukJEm|JLNc}s^=_qON)S_0>;M9r zwA_=1yM%}Qe60OCQwmA+J;Ar#;6>Xwj;Jrkvp(MXWkJai#(4TnZs<@=BQa&`*3>jy zs}i^Qr+B5Ma)uV`A9nF}sT26-tzrjQ1q|nnMVuU-%S6@ zn=f%@JO#1NYphdQu2@miy%z-19?Vy>{wiVD80*Y4=e2FI6=(RWs$+rg{~P?+R+-5(pKaS=jF+(4){jTGKl922hOj?c>iDgW`X(WVFl4NK z#BIVJyYBstW}vGskJ(O1DymPD*oG9_5kWqN9tM_dwFV(F%knfXm++p@#eP30oIde~ zx)O7z5Z9xt?34Je-|COl5ZwUJ<(lkj7v;3V34v8cTjSP^a(sf*mm{u+!tn=3$z_MQ z?pZ7IF43gfA>3Dt{#`hO;66IBcg)*w#W8u;()fp0BO{SXK$)OaBWHwrk4fu*nQEZX zQ~%N;E;v+yPOpD{eAZm4=?iCwB} zD2dU@L|@6^x-j;cQWAfue}F0YXjXq`r%aL5Wv<**TJp>F#HY$kMeKnc@^c?b`#y_s z$I1B~WxHg>C!ksOe|>F3$cJptpb36%_ObI^4Z(r)+$u3lI18Q$DLA_~$DfFNy`kai zCs7c531F&29UzGdOV{M|mhX~uDa(}xI6em3Wh}7> zbZdl#u?eqdNTI59Z>ZqE_w6B}_)Q9JJsKwkWFJGH@CMj$0wYwwO7jI|$MDJc3&ni* z!wF&2O2}8CrCa6#ixItMBQX0)62heod@j_xPB@tg5I?ZETS`oUq?e~m%r(B&HnMghS)o-~}u|O3RCvCm(l#Oe)d9lo);O9mccmGfI ztifI}C$PDF+#k;{#kEVZl`P3vkPdXYh7+Rpn{K9}&!c;oo!|)Z$+vo0KxY&jqp__z zrJ&u7Kh?TDRtK#R04qS=iQGsWiTrI|alFhvW`ai%PkfMfFQv}J|c!%q><9$Odwi!+4 z6as_GxBnnT_Fl{3WR_R0%mb*0#h5)bbpCfY@^Bu4PuwefyKdrrruG@B)3<6JsH36* z-nD9#mrf2-Fj{ub!fdeP6q%&<_%i}YnBKWXqdC+jp5&2TIoMC&c3Q1+>r_xo=LqJp z4lA!k&LP>3EADL2iaY?eG*&0e4kB}HGk=-glE(QNftEmlX|Nkl1OeHDx}~-!x+S># z=S~B6J52#@W(!{K6QtVvqDP>X*Dw~aO|0^3|8cs`3R8wl&qS4ZIf@5;tMWlIa2YnS zLRnwd+KGC%u@^RUv;74VR#%u2JRulNl4A~Wy?W&bx3eFzvy zjhlc3Uj-4Nb7jiPO>33ukXF>dArooBKPbqm8))!$0Ve#Y=*RO0d72{>oFWLbR7Xew zFSCBl#villKmya4cgwd#%#C()Qi;kkdX@e@ZSgL3({! zA;LQ0Ad4>?DUFj+|3d$pOH_AbJWAPK)p%DQpE2Rl`b~`4@4{+v6taG*;+?@tn%$pj zs;cYvPY3>0>tG3p4wZJ$T(@XYU3jUp8WIFOcuRHXC@3l5t#Le1?9-+`I3~{B*P?dI zsnvfNmrrOVbA~v&79>=8SE~6v##74)yA?k2a=`qK+!5>q_myeJbIy20MrJMX|C5Bw z#z2-OS{eJ9{n1{YKLe?61Q^;{`K@>O_UH`-(%qg0x@(++O=;*|mG)W;h)4;h`i?=f zmW?}Hws_8bY-%1_WB&{|i?y;)aXhp={j9&Wih1|9+Mq-5nvY-2@vAi0xh<&ETf(E< zOj+^kMBWfAZ`rc0>gXx)JojX|jYTw*8G%Q#nkl?#I~988zJCu4#{os^GTygcgT`Y&Lvx@lNCXaneoH>?9W^7SiiXPge@D(VDzFrcDJ|+Ig z9c;8e$e$WPR6W`aMjIZ7_>+`CpY>leqtr_&2HFv6v(zBRRIDrbenfgDF68Z6JxC~a zXifpo#{HahvA_$8sX6DLe&a);k+5_xt*-#v#v8}`=aZ9#E1Vm(ckGjTr^uOq7Y< zX%DU}7oelZC2qXk{`=08OaqeE-(I9^{PjF|mwDKm%HxN{B>#8V;)U6S zsK1oM!E9i*A9ZHn{D$GeHq1nPy?I*eBQCXajfgqw>-bU5-cox}yB?m|3VP9tQ-`b?l z{4J;~Pw(Q{Uiu?bE1%UQz+X68byh9XCzkV5)QMc}0H8 zLf>`yb^_`e$S;HZcgVu#y=+N$0?+l?fH_wFVW;`&V942JGHf+@143uKdbh~CM}X^T z$=fQZNu--)Z}f_qVH))J9AD8xeNw&YboTjsy^V32*5x{B%jqBf<>o9ws|ZMz7bDNL z_tsMrgo|IIr!fDi3~Z)5@z@4J=Mq)0nKf>T9P|_MD|Z{RW9KRSwjlF-aeY zgqD4?GguwK{3paWuqi@z7B-gwdO7(06KopGj{%KO!#A>bJ9BpA?BAEIN*;99`pDFn zNMx^|n0W;V)TD?XZ{8a}XiN+TM1yosz^lkMW2aggR)~HczTILF6GZXP{DB}`>&T{C zxbr5)h58TaTMt($MDwGN#}m3Mh~2S%=TKnRS>%Os*YEYaBfN2&+$a4;3f=o~DZrK! z@TTyIhco-c7KO%39p^l^+P5KFIC5u_uGdte>x0mTxIWW!nwXH`!qkgpVPnvb9jvi& zDfiw;l}GnaHw}=qXEu2L3fmi!Y=E168jz#&B^+~xArw*Ry`Yi&Yjea49{uw<`rO?k z!?Ply5Akz@H?8v>x$cY%`G;ud6kZ9-Kc$OGV`#RAz=d>^vt9->mxLRg(B`7i)I+Ah z-vqGNGhk{sbs8obJ^mM88&wyXio>RFed%?&kiky}PPG@gwN==3aFl1=g$!|nM)%7u znec?*%flq5=WQa5`!#6p{+)KX4!X{7t@BV7=Kc*)D|ZK??g*IOPcbBGT-iGm79LW% z54s$SM8#n?Sg(n4(k-&^j7cL$0#<%`9)kJ>xpTOFa4R_{W4{0Wf4-1QW_a63*(M&vS|gYlNUU^iPJn+fRfKdHJQ4*U9w%6}1*j zrLezP`UsJo?pR=MAbNB?%5RWDPtp1Tsshtk0y3>RilMa8>7wQFZf0lV#s>i@0JZK` z2~d`ISP@YUxQ__wNC4pOtH`2<>;n$x(|cD&XYQL|Hx348p2Kh%95!MKf(xcg#$ugu zz1D#Y-FLn(#g0+>wQ+1;oZB(>lh?$%$siZ){g)^(J1GUp!kUphRrz4p6zdxs>QrEw zO1yM@hB%OQbc)a1uKV>bf1woeDc2fS{R!QI#**J(l=pERm~Yyg!dq;c>$Q4V#B=)m zYlnN&;r|Grw9~4y!Gv>w)-+_9I#XvX!iFY7-^^tcAGG-eTFtm+SQw<46_r?GU1Ca? z0!61Bt+8kJs}dW_Z=!7|&&Vcvt4w(e^T|*--7cKgqy851xC|y9E@hxp+yI|0L!u*k zb0K;l%nQ?>IIa45vD{>qN{^Vaib;l-I)Wtqgla`xy|j$c-bpjsDY5CXu)B);K&+wJ zA}mRST}#NrwGkIn(c`Dv48oAlk|Q?Rz6*n@IPXb5-d7CJBdV4Goy{a}{sK&r=PlwC zBn1l3AR3`QtpEzecTOn*n+C7t!YGrAf61b6uOCbXINM=3<2XUgkn zJ9%F>U8k;suMy)}l0Q(VkvkIGS5H4aGpZ*jH*0Wx@WYzycvc@p06==lp^4f6_|al& z@##6j+4?aA=@pTsk7rr`3ZOX5S>gxJ5`+byT%}@;3M^uzP_&Z3^^Ae&6+VSZ3)*sY zO)~yDUC#t^@wRiV@3o~90f=5-Drjqn>95Wtp;Tc>3opjEehMt9ypBPKElnp5RJ%3* zMuY^uwlUk}r{`X{;*V(leS}@+lHev?;fO?b><3|mw8-A7khq&|k@1yv-nH+4bioJ)p;J7s=XfN8g>dp zL;3eblElg4jZL16B(%qX?xn=MI}bHXn3{!$pFSJIR{hJ-rp}`aEeV5;$Vi*(wr-((nGIG zLVu+CTS%+kQgX1(N6FgYAcK+4O}>IiV4HI`*ZeiZx+xtEZc(#h#BrI;Q?Ov`&%&_l zfKN6(ra4ZHa1t|_8PR$lQqK`uGc$~caiGkhWFvv1 z3t2PY*B2BdQuoz-f;u;LqUDtVzm4G0$d54F8Rs0prrwtO8<%X0U~E-A{Q|Q0Kcqsk z0xN4fgy|}^byxPcyrX7c&poII?cV7V;J62SIe){nkT+yCMy560ACLeXmG#=D?+pGN4o{m-NP+ z+^se9mgSbZ^RwWfHE0p1Xe4zulnnjmy&};!`9jrW?Jmzz#fBI8_Fo#6lU%i*(2EJl zX9>W$4mZ&CsVw|hvb>Y}LwMHHbuJ%U7JXd_4$+T>z8GRhgIWU#<8r89e3!mg4{JRc z>Qy@)Er+rwzC+ieIv(tLRYc)s3SGrS1aX7Dm%~G9)U7uHGjuzqlb^bi-C-S9Cf&eY z#+m?-y2@It@^NUu+e6&f%wqi#4_^-`>iu#um$9&H02DKwkq2IO|Ik;nTh%`Xod~v7 zqWx}Ld8r6Re zK~G2MM*}g9&5Q)dj--B7JQNAdgCVH)-p_(Y8ZL>3o5~g1$+N{pCiz~{6u^DTiV-{^ zf^66zk|Q=rA_6kWORMgGlQutPY+$HCvRGm!Y9oxnDf|ZTck>>&GjiIhG4_c1zN6NqXw^to=h5SIDPgB^?aiMW zq=?xF6mc&C*_~F8aFWBL_8S={8-LA$7*2YeWl0hG(~`zU-3nm_(T#RGGikxfT(6=O zq^1145_QVoxGVcKJL~!%4ge!yKL2~x;?>3_HjWhDmTk~bdjdO_O{SSRAV`O8Y46wq}}gDg=o|$Ysv0p{8*+@ z7}Z?ilJ#IJoG#F==T`K$WxmJgW6vl7bNKmToSCqJSd~P<@C<_$Y8#-V4{bL-^WlkP z!x8GYI0zj+wgf_q@JEy3qVQtE+WMYi&Wnff^KX4Ylj98@Dh7zBWS zT;uf~+?r)%LA&}}xj|BNlh%*)_a2JI5b|-rMuoOXhv6AU()cIu@O6F@F&KiS&DL5;2|=2_6~TWqe0|F=#>x$!oD$oALMZuR3Y0gkV4WKARXt&a<8zhN2`2W7;Ww` zY0V6^VtjO^$yFmai?q6gWB9|bG!CiVy4UK4)xMtReqY_Eu|j`|@V-RD5A|*{O?p}% zI=3y@)efv#{7z0i86p=DJ>Gcuj5lC;m3GEqJo8GdQ&G?j+%a`OP+ zG1aNBZLjQ=K@sPEw#4hNp79sQ(8qiKkPlPcwqWv1d|H*5fE^t|3DLL-&P?CHW(G1B zSBJ>U#ssV{tm!vmTlDfmmr^uZMjB3b>FgHeJ9=Qvgoor$js0o3ejk+EP%-ATtQ?Yy z42=j((9cU0z#mJ0us?Ps*dqp#jT>J%ofBBVbi>i=P~W=ll+x={@X-DKd6DXDD7jU~~n| zwFRT`=obj%D_Mx+^SsDPOp)X8yhRb2G3L;A3HT8|nUTdDUjEYm;DM8P(AeDH3MW_s zF2+i#ebK=g5cy3DxBaCU^FeAul2dSjfu^v5n5Lr405>K(!p3m%5|VC@mw{y^61KAt zQZ$K>S#=6YHB6-kVbJv))TL7XMR@*znCXW$LNSs>o;f7(pPZs?fCVH`ITEvf3Hiv_ zP4S5Yk1D(*LbLHyY|kXW#?s@c?G?ZJF*6vlR5n6$4`5KVi73aRNM}=ULJYp6|9O-U zUG_#W4hDbL@nz$jwD9%u@2~a$BAjLJ>4F zL#bj$&7Lk3*5RoIeclwYo-3)1iG~ufk$Vr5K>`PrB(G84V*Ab@wyUZ9r-AW)N%Q6C zzO;-JTpf*Wz?Bjt1V__k%`NYoeDaEIm1y2wlB~7jzPW%^Z@F!%f=5HNyTfd!k-nMe zXH_vV0-goJxbNpX`KSo${rf*bD}u$Lsxc!n*>0vL-($BfD)v0K;e#Uk`!jS3Tw_?- zD*n@VHWk-{#xs>ipgLK=ReOI2=G@xkBr&KCD(V^81eQ-qp1XNlCWX+x#QMkWb<*cK zd2JVQa;`p>7$vD=*LdmKLa(Q#Il;Q^`fOJ*S2Cx|hvg2xmHX=N_*;>iLo5CHdcC15 zLr5GCi{O~I-b!KO#MSGS5fy4(K$||8FDTcf%G?tEK=U{4Zie%qSY=fk{ZR?+2MczL zw{nyqT0K4J{pb{GVX18ud?i2chSvVMqOqP zTbWIB^za&tOIHXUa>Ti9+V_#MuWrcn!dQHyL9X6uf5DgX0)FXM`O)*RR&ZC9QMmq< zU-I!rc#81be<{v$1jL8^(Vav=Mk{1n>2CEyo@wl=Rph~6&cL3;Dg4LVYWIALENZ4t zwTp5wz3k`G1V~Igqi(8OH_O^g1CyHYS0GmrQ=ERk0e@NGzS$(1P|Ks{s8Ef`nbl`Z zn?DL5utpO9azO}P_h#9Sw`UIwARp!ks#uwLIng?t$1{RgFlE<`Y1<_Lrcamu^)O2Q z0dt_scUSp?%iXoHzu0gIV=NEgLss6%i6V$yZ!ofmj8I#<=oXjR;PwgHHbilMdiJU5CXuP=;AmdV68*T&#ETLcRPu<*ImeD~65((hqy2;> zw>`TlC=n#NV42l8kr`fSVw4k@O$yL%mYPT%rX_u_>OwAE9c;OndGdR}xd@p?&RM&| zA{CqdvgSR(NkV!Mv9nxOcR*Vb8g<{w;CsB75$ z<2m;qAahVt1`LB?P|cOfZiP5%&5;cTX*E9qcbcK-&XSi|iJiX!gT!*7lWBNCU6of^ zF=GI@Ta!fV{lS;U>WAOW43KY69PS3%Nlm~z^T%$SJmLMECIy;_S!@4p`!_>)xK4*qN!F39cd#zHws)p$B;zAH5 z_rk%79Aj8C5IbHGQeGKaw-=s;_flzh-YvCDD1D_4WfdWJlJh^&JjHeO%iq#!54ElC zpdf(8wIl9Z6+b%tWlcKdT!8cr$C+uKeB^@dM)zCY8i4?G+rMl-Ga$(A>!W`@hw_2y zfOU76-4dwRZ_aaQLIT+vNNo~H7JLFOhtDH(c4-HuhuqN9KR^7)UV`_Oe{?Hfl7>$U zpNB#mox?UJ4?=vmNPT;(`dj}yS?9sie0O0I*GDYjE-S(Q$nJ+TB6?#J--S30?&Xvm zbVIA%bm$iWeW}n2d$u?oGDLi$!S>F7$z6avec!Z1QppT1kd*jnOwl!n3z>=+>>lN& zHpAl)eZk(94avk%$KaBRZ6ygttD1)S7WQDn@M7N}O;!k4L2`q8#$sDKq%nB4^}4({ zT$A{fTMYgz(n=;B1rgB+Ts>GW_4@30POv(+7c>|}d)YpFDAt`qShH9R(n+6mjam); ztu@Nm|D_T{gnr9UF$`}ZuXxKM*d&~!m#Hv){@+BiC?wnQ+n65(@OLT+oBnOtPJ1GL z6_k>nRak6hP1m`almi`Z4JNlAfEaUnZ&;*+8w$3fnvKpBtc1=Eu^)!yvPo!0Eli4b zPzKNfoi&0n+4oi+iwaQxfOmUgOPUj3f*Y1#3l3D+9tON3`>RE>1YXpoQ%Hfq(KZg2 z2*KkQV*51e)jkLX{TA5QJS`Q9hP=xj)~+HtK@|d=ELG)&TmBixNrFxhw+R|co19k4 z#|8@Qv8MNX`*F;n*bemLUncCfgvZ62HiWl-n{Bk=k1)GOF$}V^tUJoF3-Tkg7;G;k zf{G~4d#H56C=4-tq0oKZeNuDo7I*D-Y4mX{LprAYFLn&C+xv7lU@72{03`AY7j`4} zN*yHp`$6Xie&?U`Mf^>fLAp2@)IuYyaIpv%Wl(~tp$A>vILWTuYjC78boGVSWY+gX`4FNCUg zRB{&7)!Zl}>e2nLRL};1E@jptdncp7G0FWsiwt7Mj%@~~dPW+*ueB+04{~Rd#B!Wj z0lWp+OHBrwAmETLS#h55dip#0LFJh}oq}v4v+8)#CriKnU zQLlHsY(IYaJIqDl&fxpcQ-t7*KyTn$B3jZRVUs)grze{rb)ld(Qztbp)oBAyJ}p5W zf8|a~#Nbn^h+ks%odsuh^i~4gRPFXd2D!Uq`_gl~f0g&u89nIwV3=$)&aB(98#>%N z@d~8%!&->9-hV=uv8lo2*jN8o+|N(|09(t^{tv)3$E}#UEEbj%u62)7qwA)$0B}e^ zzMGEC0+xgs7?jU{NvHMLXipCoN@X|s_g7s|q2-7Ox>MavxPO%5xXgeNc_Xp8V}^b7 zk8%T5^E_muvU>xX24S%zRPCn0dOzqa<~H86{QY(DolsYp3b6Au=7h$Dp40lH=#h4{ ztT=BMk2&`dG(7!FomKqV*3W231O@LiZtxtT7()&Vc=2|L5?yyqAN*CrN!mZ62bA6v zJTw$_mER!E!<9H536x52qMSzi;^xU~wXnl*TsXsNyp z)4e4VLaGTY1n^iN+?cIAs2#w1dB5@A=$@;cvf@6YS%dia2{@j7oWcqCw!VSK+OoK_+Yf+Q zMr&PK1HR*;X#U~VkE33=Ey&RbPk2lGC+q!sO`P5+a-v)X4tMBVG^qL-Gso@Li2BRz zg0yhG?O%J&UyKx{lb!}SWxoa9akeos?<}`{=NEMVY_*rOYqoJS-1B1XI(bq(tg2O85|ri^xK8Oy&ZYDnz*GeVPB>D%Jv-R$EX#b zrr`+r`kA2qUOV9U>O16p!(LO3XD<51#Ai){XXNZ{viAQ<+JbJ%+5FFGa|E8xTT0aRtBk91+9fufJrcz5eOOQN9kKde_Uabx1M zFb*g+KPe3DGoB%zbf+TZu&>IOF!Tedfwo!WEK$F_pAhHBhS*^zUyT(*$IXrzDZ>kY z5cB{S0@#_eHpF94e^X%eHRDM*Pglf$<-O2xjOP{ZHGceHe(k3^`jJnuA1!X+m`1$M zTuMT46JPGr24P}hZTYo;&c*ovHgwU35D~U)H}ZJQGx$3WJMMH}q%qVud@1V7Bis+A z9#j-|9fSTJYrojmxT)75a?dUQ^*sCM1OLX2cX#VAa3l-g&G+fx#XkTdCSowp!J~Js4D`E zpzSj1CBt%^FWo95ZTrHl`MEa3^X12a*EhODMoc&Gh`k|Qt}a4pBGqhbWhW|7utiHJ z_0Zy+I~!Lv$T=gwNMJe*lH*_Q1!{a-e3G5st+Jgz6%UHfywwjZneldTqlX8Y(&1R5vNTkGe5pv}x@)ZsDgeKiO%m7iRWio$0X|HY0>_Qcww4sAl^mT*3+bF)x&}2&| zC|I8L(dvLc@&0a-{GHPi`(M1Dr(H}Q$w0yTmq!?f?R_~LYW>)O0Xk5+|2AP%cnrBC+QemT-1Ev!Fw3?DyuA-*u3u}9w&Y?vCbGeXV{y+swr^Q#ws))z3;we_ zIHrOuj2yvNOAYum&||XVoBm@=2V$N5RlC*^8ug2b?(94HW*M$i&Sj6$FD$@T?nf=c z(n%A{bLW3WM7z1rJMjpmq5?anodBC=)3V@s{7@uE{thOrBhNw68)Z9|^CNW)KPWz; z!;2cqSQNkB;5=$#&zc7AZosG<#NBk6) z--hb*NYBUh>SDz=vLGt3#u8*JjfTG*-k1vSD)%UdOkmeeG@7(k(WWnEVAN}+m6v;M zLvuP1UIzr~GVL+wa47DS7lQ_4hfok!NG)cH4j+FSr*}5(g+UOv)w0dcmQ;y05L`ke z7z`hX6AL_FpDP~R{BYK!vn#z58fDh+V|e;{JYOG7iw4rTHcU-t8 z2$4lzYyX6UEeP&i%yO1R=g-m-HT9D4BSyp0@v-QivLc#?xkov9Dz9uDl}FcL8)pBl z8f?_r1=^KVgmg!FKxR#tSh1bcrp$;#)^U!$YQ@t2V#bJv1}&1SvGC+&zv6O{tL3ed z1lorzS|MDvHF@H_2-Esm>rnk%QqJ>vEnQUHCU;8@on+F#O>7F-SLZxiua^A=PkbaLaT^V&)JVL zf5ME~2N{jQEn*zXm(4ljpesWK93?*uQ{195@GWW`a4jM@()yg&JKr=W2Kf1-Sb0Pf zu2I7Xxk#iKUxvu#;5A0c*-3l$>ERH%GLt^*W-D3x4Dz1|J+LN@T~~jl zY*@(V+VVm?O>;=ue_1AFQp9C72I@-1gNWyF!rr@fk*-yQM!QOLAz64ux=%x!%X^V6 zc>NC`B4F(u0;vrO#SRIgFqR+t8Ah6&>Po$%42EK!`Ttmej|MUlz(RTWFwsNV zul4AmS=sxaL!&J@}_T}(YcCl(c^td&GlT`8Al@Ux|Q}P zsa9~`K4YCp4zwQH`KYbqP9n$!+k6Ji}}wV5f|`5Xt7e8}9Vfso)}~ z+HrGFp~o93*QDOrB3`{m^USCW19n_yaX|g&d%vFxdddSi5z_HqWgV)+my@yY^JwgS z7#g#kkB_g>Li1f4>Ba5Ro_&o|-!8}=I>736u0dA65XZJ2wYv2^2tK)OQ(3w!1J4U6 zuw4lt31Ba|vxvc#e>$g~Nd#`JBwSf{7-eP6J5C<2_B*!xEQbfZr`rbCCF;ah*@7oH zyhz13mJN+E9*nvGGPcYvUbFIP|A~As8f#u*m4KVz3@NwK>s;6#!2P%CnV`f+?o47Z zDCG&hy4XvP$+3p&?>G6HbcLamg;l`&xYkqX4jZdvUX^PzZHs=KM@!1>U)2_aMnbFt zawuLs_>#-fzS*$^_t+F4oVrgR_0hl@EPG4U3HhkbMsDaX!QpZZ^PkuwQ-gm(HTypC+BG|HP2&-y zyuz5A9+0rlH^!BIslNVdRKzt5xz2zK>7g@OmkNB{L-@Da(OCUl8jaI@TgTc$<=_3~ zq`tPD?e_M+yTm%(8(KdK5e(9a`P|;q)DJhL1&DQIs<%R|!xl3{((<{it1~hLZs}3k zMT^zqqmavw5y?|ND~P4-H-jRgB%3`u-MjcRuTIbY-X}x-phZqS5|mGGI6!?nAoj33 zL}vqCK@|{zuph3yj@vgnqZuEslRQKyA4TBm9HU#9*7Gm!+yaMRoF6`f1?M52^I_j3 zNbSbj_SPVi-y6rd2v<282zU;RRUD+oLco%|z{Szd$K0yRhJbe^{vG_I-tPs2dC&&Ry@qqhbJpcw=_C4P(#1Nh}yMk11Iaki_J)Vj^ z(Uf&8YhrX}IqW9mm{AvI0$%(j2G?;lU-dFaF|ZY%5~16lDvZiI;&)Zux5q2U^fDNg z3oH_`Lf=DpL->JXWUNY~Ajc9sS4W*uq-uDbGIDevlG)Y^Jw@_{u!P+yr87OU?FQN; zGn3Af2z)yszZm{d5nklwwRH6z&5PON9zzXzdkSA0&9*fIS33O@?$)ip=Qe&BikY1B=s?^%T89-li4 zeRP+-pDslE%2Ge39PIEab-womSgPHl4$8`xLpNvn2tM- z(SK}aZ0zJ0;!wkso24PPPW8E|RSi1(t>We$etX>C9K1xqz6U5;7NlSU#V!AIYrK0*jc>q(b0sIMAQ5Hah z;6sA9x_}5BYQIRz9acW1N)2*JZUA9M08Cqqu^h=uNT9#3%yi0_b?{}?IBABw7zLcy z?jH?gZ|MlI(%VYh49!x9h(pZ@wsP{}HyU%;BGj1pFGK)&6e?&=WOb*6p}ts$x=kph zXOyhMB%v`mVS3-65u@>wEGKK|f#d?67vG~igWtvUex^ilpc5$>E6@p$IX&%bHigy( z)@!g&mJ@w(2TF~<8&k^~j zea{1iJ$vg!>60uvWqj`V8MD=eY>8l5Ja|HjJkg`h1X2S(Mt8yq#NHR~+(R9%Fd_^? zZYqVL^C&;(XQ5{(b*TU;beS8{mH5^&vuxsdb! zN7Gku#nm;<1}C@-PS6nC3GPnt;O_43&fpFKf;$9vcNpB=-Q8X8Jny&eADDG!oxM+W zb#+%EzjDKo(n(j7kpY`c%)~Q&P8hi>48mn~{n!dNNq88Zv3|P;+AAaJoICD-K+$H@ zx&tq!+g`!P>+=93A-N)PAzw2p`OPMw#PQjcq@ulVt3sbrFnDs`{X{%=f^Yx8e9%dP z$ZXdh(i&AB+g1tQYyW5P046G=xBH-f`!MgYCtHYms{hP>CWu(rO8&r>lQj*%Uu7geyXWHE%?U!s5^l+~X==xdP?MU6o<% zxQNJHPK%!#ubu7Wu+EcqPAl7@Of%g`s|tA@#0}3Y>_xV zPrW2UdMpWuVn6pMcSJB@T`dMv+jaI8==Pvp%%2eO7nm5lqq}jJFiLC`Mbkz@)Ti9K zeWN!2RT^~$i4U$%1~>@tj?xM+R>HH=4xeMt?^_1qmQ%w z>y=V>*aiAU&a}vX-9jtYZZ3UZ4o%I`Z+Y#%I!vgHj*#$UzN)vWhFrM*Wb@g{~13gR!lX{WES2b}=!1CEj172o}%bSxj z>7{n{A?-K;0d62i;G5f=>|J5OT|GZkIv-S;7N`9(rSYdNq})zfF;o78?X>GpYQWLc zb-I+R6-w{H90?C?L@3#niV}gAm48OkO|R66MsFjgW7ES=yM79{xJIGbuTN9?G&Zmc z;g59tAABS4U4H~R)787`La^}G{u0PGE@%9Chy?B`=h*$v+t~${Apw{h>5Axg|21B@ zM8b^hnDe`! zJug0I3;EGHxJ`chjU6_fHkd89 zU!Q~A+>?XziWP~tV%qjzLaoPZagbiKr};eV<#axk=j&wI6vS&^_^g`idbT`qW^k+g zDE3HwM4;_;0$fN#J(yFQ&aS-5X8~uw#0&;Py4rSLx}?tK5dbr@U22LS>lXfT3Xq3luee&9QrG~DLFQ_70s`BO0ow& z6uk&EuCNecHL4B|ffIeUl~BE7Y08F3nA>obv*U&tO=UIGb-07}D;roe$g$9sj~9dZ zsh+@R&<_TM2#_9a(V)Ye$JgE3PIp8R7&)XlMiZ0-_bbE7(=>L7rP+Bpa$retfQj@e zx^KO~HOZE?g<+_=3^uIIJxTX$SteWxzmNTs*T=lR%WD2TqTS1g06U;ew(vYC&+bij zGvI#}3|fAXLDfXec`1p_H4s;3Vz(jie!E24nsjAL^G0_H`~8Zz%kPL<-}qvxEVStu ztAAD~jORY1u?B3v8Spy#nt!w;t)Y%R`U!+3~`GxSVW@ zxk0b367_*qc@Yw5fta}$$Q602JnCQ^YmG~~C>#S%)p>WkK}j7}j9}Ja^OU-T%~_Mb z61HK}9g8w40z#8i}*u|N~>IObaB+({??CQZm zIB~pjQ6`oJBqXAXv_ZR~=)o~nVtoI`4@E!$#qGY`?HU_r@|Ckk2Gvtm+_P|Zst?=|00gw|Y_T~~7aUYh86_^Kwmkyx%i>mK>95_D8D?Ns0}(Bk^1 zQP7T7Auv3)1mJrFATI9ZAzw05j=}=3jf%heZNNEy$-c=#O+5G^C zm@$c#jUhum%Rw6T#wzSTEtt?Liy;Xo3*S#t(6({ewxD}>#{HO4s^oIIQF)Ou-*K_w z^}c!f_Rnde)aTbA*`h!17JZK2>3PS-;Ux{C0L=<=|GlBPYHE$)E_NBgvZWf9Rr?jS z0RUPT{x>=cmSYsQV?7|`{LjP^PRb7XHv}LcK)Ji#A+JXBamrtfceD!h=a+15{sKZ_ zk==&!Tz~Z!d`IxI6bB4Vf)`t5>=?fer~p^GZASVP08kKJzonkg891wcpo8%^AF|E|ZXM-VTokDp6n5^$QjC>yXwV9>*g6$uv-a!Cz&VTl%N7;ck@)P^}rjGIi zB~QFB<~#0xsvy|4H?pw>Vm!O2R;Ao>Gi&1iOd{$MSw%@0ckQ(*n1ZD!rBDOb_WBSH9pZL8S zj|OEc3fIhniHdk_wDbF3wZ$tE#f-9`Mm^O9kQTjy42@q?j;gUC8ExXJenU)i02_j- z?3MpRp@{6*co8l3#q1+R`>$7S;3g&fGJhQ%{Ah-dl0j;$JlI9{TLd`q<)LFWSX)29 z4WWyQO#>v?w#*cnHX0bnfK6BOX@~zq(Pv_oq>Am2OXJCT`|;~?sD~|E7?i5Nol@tQ2*m4DYhyxCM zoI0=vWKi4#E&9v!W=_Jt)-<<}gGT-BUfdHJSMycAL=78`ct|%0$)Znu?a$6$CjdHLdRP zhfRlrB{iNSmMIf`BUZud6ss=C7cT(=5T8~{DeE5`+n19ki_sCze|Eo?m&Zog0QSGB zrNoGJt7y-EE4Q*26*8sVjqcQ7jzI!-18%GLf#RR%o7I+NAC!j7T}XRDkh!3I=Bms_ zVPe<%Rwbi|AW5cyPOQRQX6$vN`m872xES@!6S1lsDUi#N{^Y=&PkGnPA#=~5KwUqh z&u+NQ!p~-*vg%DBFIVO%>i#MLbnY zOcc|<5GhaJ`_ikbzZ+gog$gX6cHE|IY$=sN|LG-@Jdo&F9czcMwgLAmLCAl!+ zPrG+`Y%7g+r=BEgBQM3q?;0+ncB05y1@6t%-4BW6y78;fvl}=Z%jwj7=U%VIfO70$ zYJNTm+)09y2a1|vNPd2yh}^A5cqe^gqyl*FV#o0m#3g~{PPgxG2`g>EdmcH@IjqvD z1qU~3j&EHt_MKEjhZT_o#UDekvCoakHb0{r?L}P}T7pCaS6lIAD|j#M<B&H62u4ZNPcN82Hf0cpYxkDQptH37EtTOjQcM$}@Wiyl#$-t1h~N3SozdIBgq3 z72ru~bKxsNp5E_$o2k^)NkGgi_S0wi)1g+H_8bS6|M03bEjJQZ(<2ZHmKBzdIh#QL zb9owV+;$oV-(9GZo(Qhastw5*FI5B9*K`P@%FlO^XntZQLREFLNLbxt=Qq~?LMR2u zTK#9GW8m!H34}6?Fij(X6X#d)e~8k$Q%cwJfm#vssR_Spm{oDfQ8y#RehW_`m#J~) z*de9VaeT=`N4UCkR)twKs)tRzkEjFcT}>oe~<3yk>D@8r-GvsNH(IK!~A(o z%O26SQ1omLcg>V>=rpDM+gFzMGTr~90Bfnk$k{3z;c6oyRLDDwzj?1zwakB5bEdYD z@Nc1LqCy~`BU&2=L5t}e4j(A1He7+T%(TEXSh!oIMQ>xU-r*ihx;Te2xb=GpTKrmg zfMT>uD3;w?d9_;4vN9TnpuC@7v1;Gc#1(cusF@B=r)gC1C)9D4mDnAKriw*(!JRt) z+GO2<`|p$J`k>@XM=K7m$hD$%8gw(G6=Hci^kaics-SI`@g){YW}N2HCh1>J7el32;q1)+!?ZpR6h$ji; z)IK$OqiGOEoguu-1G_OXcbX8a?ZD8X6Oj_g^vd)kw!JQ_GlVzuSsG`CwK=6dO#p{V zOd0o-t?+8Poezu*S6!qFdwSpwG5^dD(2e5?Vf#W%!K*lwLNYYD3tR=tV>_bkXrRJu z#i_X+ba(b5Y*ucqk~OTjp5cu4D!#%c^OJZtT)C3I(oBAJ(tjnYdUsP{cPr`QFf017 zeIr%sJN@q_Ij1ZMr34(a<|IN=CbCMXr?!5HlFhW|rzaLDxzGw`1UAZ%Y*;csAxyV! zBI%kL^4v2(*|2m2gZIRBn(gCzA~ye&@*Q6QY*OrVN33u+Nw`6J)+j=?U2|kaJJD(v z+C{#nPC)N=sfTN?uYT+hLzB&rOkCTB>2?HAYe^2QuH-@ZTL)bz&7@z_5e8kjZ7j4) zCZMV}=X9Tn-a~wh06ASoNrHo?{{hQ8-qdxo={(9;`+;&|Ozt11~3ZZXNX^md#+ z8SF&W9A{aa+k~`^9~v(v!L@my%Fj6I%_y$0!pcpT#0x+naE{p5~yGb zV$fS(pqG?k*wU}fI?qt-?4KUfYF&psORqH>{+qWAYCJdrv{CfX|G1uAsUxST2>`%* z7?{X~K&4nR+x8nCEbnJXD2vD@#npv+GVg?@@?jkMKmZT|V~}&%LKEh#;11t>=L>}0 zbEHw|7Kl^x`xeaRqZ~0Dqp`GCp^kg5wARU19}Ftt>&>HrDFI|qZF8$y zQ71g}j7n$m>g#>ip6A2=S`-TFD0Q^cr%tIbwW;X!aC;MYFAku^pOJ;Ur1DYw|Px??jmy`d+{;Tm%jvG$YBMv@iV z?S$%}{O?dUa^e!h%54_b3a}GN>x#rvv9n)IbT;Q^rNZqXvKV>_)|eTr<`soJOjn~%^d zY)ElGudxGEt3s3C$LS!m|7l0J)f|LiuQ4D!brn7?BDd@i1iDPnkAwKqjZ9b4H- zdRRD%TpE5DbTGBLAEb79V}Jse&J*331rXR%pF_new-JG6N#TLx$Fx{_R58=Vfx1-UnDklAD z$Fk8dLEMaLLr)JHmmoCyu{lLWg)i@uYA^_W4UI;OMEb(qxHJW|RmSW)ech7oGbhIQ z_R3DBiWLgp=7v;1$rt&@n6u`q`(+Pn$(9|D5@49WlnKtcrzT1lLP#ddaH?p)-G2x0 zL3v4)-_1L1g%;*nKu^z^b{$$(xqj@?V9Gm~PgoPvPIy|gFR)8`#SeaWke*{sP()vH zuar^3{r|H7fP=rI%n?vN!m6VSlD$DLabUJk1z?4`AXHgvg(}RId3hqg?JOxX`l}&g4QT|?6 z56@nud0U*?^JTb~-aeQoeg;y#U^`Da7AfyC4Bu$Sn*fF1eq!(L{0&;~z^!NtYW_*Y z>gZkR@5D-<+y;*s9s3JXgS~$-{4(v=4mH)^8Bf}EUr}F`yI<%2Vf(i%d&Eq2#^t)E z*jH5}%rnZWJg+~&kNRK0gSkL;CDIvT{y3bAUz7~3>kG-=UenAk0~S&Sc1~tp>Ng1m z%5_?xS#e^OB)B>|Vqvm?b$+9RfBc1N-Ri!bdaydZRr&%W$r1DXV_lftWyJchrDg?dXwVHZbIa3&fe;i?#@v4M zu&y3=UGwqqZWzDb%kcJ_ceT{J^b%!hXA=47pQHNx9IyM^k~8Oa2B^C6Zafw@YlGii z9V>0yO5-@$++GfltU2JYHQ{L8-)DEig0+eYqvkV#2CnVZLrnMON3a4i;W4NofLn7J zaTBJ7B^Ixp{t<0a<}K%@=q?h#gZ9)1b}aykLed!<6DaB&o#q|lm!DSPNksXqzyUIc zEV6)+LghyvU5aec3KJzOVD7qDJ>zCR-dz;S^bZWOi7k-EUJLx(s9C-9NOevYNleVb z%CJbZjp#m@_c{sh=z%$WK=HYn*~sPVTI9Kl$i6_9)4|nyD?IYLwY;2K{b+yOnxXZA zljrH;cxq_6ho$+@EJ^0zjhA?DSY)Z=*7!G7YL_1T^_M7QqaL$~7k&MyM@)`Ix&d?! zm5kA=!I-E`IhuG8)fIVYl!au7886bTZ>FXygxa>hF5j6DH>F3D(82t`m1C#X)8^I0 z(91Rt<}WS&{5dx#Ez;>dj;Hz-q<71=mUV93Ok{J2qu}VHzCN|5iPtN~EArxkU^xYK z7;UK0pY<_wCOM;me*>gPZH*?0%+1zDYd`AOiIaCu;P=5U?&%U&h{+eM%_%%BB=x6D zmtUGNGu2OuV3D!S=;p4SKl`a|{E(~8*U}KOe3sXAjofGwb_R9V38_9*Tp0*kz(X1K^aR@^?snzOy^xBaj`YOi3@#%6=t^HLYd{n8aSmw0IORqB=sxpZ|n z2&UCU%|3H7&Gd=)Qz<8!5cH_`kexQA$~>;LFKD*;NhkBT&B3xh^tKnMQ%jQP;tef% zqf)K`Jgu<91A3yl+6RLKW~0_De`7{}>jBl!7kPMY@L^YhbvDG;vX0x9pvV}JP?4f6 zR@qKC+A6ijXwE5QLPc*voWxogPD!k`x6YNg`QHVJW63f4!JwYbpv@VQf7O;iiK4Tu zJKYUqK=4!_?ECvLY;+ZVao8RrDbpy#ur%IG_n9ltB8zXiUA?wT(a31wdnW}a%14Q~ zKcR$Tn*$M6N3rri9lmdeVaWxlu$XaCpR{pwkO{`#yqk}^$qXM&!BmYr&mjvr0qOuYxt$0|>rQzNO8{YBs?OS4_{HeKhQv)nkyHEMk{!D+>l;fW znIpirP8-Zxo<=tGKd&GeeBB;SC;cqdX&g1t@VRTP(dePbVru;U^@xthVzM;)jL3#4 zAE~@X1+1~}mhu`+;?2%3(4d)gJ+EZF$U}kT<9E;P!SoPx^Exf=tW&FSTz2 z|5$F1oVoh7f{7y)OSMD?JE(SlYO7P;$DYp~m?V!`8N+lldfe$A99E; ze$@h-kC@lh7y$RY0J||uaK!a&^_(*!(7>WQSxgJYg{)84MJX^~H-9$?Arj;-A?_fdtV7HqOD2pVzfP(%Dw zaLMAF0X%gqg zrp$o@VJtq;UiauYqUV<+oDS>>OHO1sJ4lNsWVS{-HU2`_^}3IF1Dhd*1f&@l_rI_VNwf)-foSEuaI{Iby~ z=apEZb*;vwSwUmb<=tU!^DuldKRLhWvdaKPkOc89CBrXtLwQQgpzO2oRg~zc3x~JN zB&V|(V35~v6NQCZD58~QbyQ3l09a(xR%&k`Q#~Gy%mVP-Pa^aeQa0_^nx+cenCXVi zhxIGik7rZW0*ShyMrjP8e+$j;xIAB-Gl%f)3_?~qpAPbp9mwE#a&Z`zto=xn3;yv* zEgzS74}j+XU4tS1)cc(~V3?@pYO)R>X2{WSz{oz+P7ig#34)Z*5eOPQr4JDB@U**H zWt{z`hvgHh`oeD=y-X^sd3-9isdk6L|7z0FQ}q#ml0daf&D8Ch!vyIFnd=`7MQhO_jlup6ZqFkLd_o)cS0@PqW3c-zx{VP3njJE7v`W zM9|#{l`sFeN*cIi%)oyHx@V(Z5RyV!aXhvd8OvdJy?EP1{kl~D%IlT^jsf(UxlNqW zgj!upKp4S^*swng@9SHces55w}mR!NXF8mr3qzDEG zues}4=DSsi;r@@HgFXVt0bx(yzK>cKRd-K_2QLQeXV{hEU_WZ_$Sajz3WJ8JQ5u`9 zzcrR#YpgE++~Umqo&2XPk@996xrq0EJgx13m*-SJLe@G?&SHfYY?VHraO=L!+pRPu zi&R?0o*_lGK=Id7E{b(+<8fB)1SEdgU}@^@4t^ET%dPS%Nt`QnmO|N z-bA+NLU1T4Ktyx_sHiN-OczTwWWw!&iRd5*UPoP`{rZj9nKdp3WMZN}2a+cAsuy7b z)kJ-i+G`Bn?28PTvV}$Fp7CCD|0Vh<;I5xR90q=bC9#^7C)ur(@QJ2|7K`kk)yT;M zxIQUQHV4cjGU=OyM1`CEua>~;!9UmH$P!q7eo}HR&v@~?>w$4i z5{9@NzDII<#|PJbpYCv`?)y0V^><00aq4qM(AyTK>ljDJOq)I2w=hl_6iA1NP_4)w zHN3u>C!5>CRJ4}8(*F}fhE*U{A?$oUs5>OI2lE&o6Wf83;7vwd^|Ad@wgJ-EfVgps zDJR^<9$!MuLS==U@eR!ncVsAGD!1Tg=iR2IkL zZ30dqt?U{bJ>8v(*CG1jxm&RJ@GrrNSA^N-`^^o>JeQki9m?~CY{HxEpKV4XCOQ2v zF7o&o-yh@%=8fIq8eQ*&`nQh@Hbg6n^Z7*C<`Y)c$zSY2V$HD`=Zf=MbeIGTdYI_B zw=_-3AJ1a|XU<*#B2MIl#_@pO#0E zQ4()Z4#0^C>}Dq2n{CWX(fhVJHbpTuI{Oort#S4!!gp$(&*LjaJv(g6ZKs7sq0aFX`UR~#A`0}YyXLx0nQWCz_&<2X6q{_9>@vpuTp^A72!w9~=HG=n&-l-G zGEO_NC#rP0palLP)@B;?2;^)rCvb@wnnYDZ>Qr{6Li-KhGyu#={sxW?dqhtdFK_mzV620tO;$s?m`e3A&fmho13zw~rb~`?r%XL~Q>#N9 zqP2e++>K*^N>2&64blD=x9F9!iHO?2l((}?T9Ht{xL1m1RFz+7|D&1(iOpB~PhkhZ z-`o}<@#D_jyxSzb7C_-Ww$GB=sW6y75RV6X)c3i))HLR(ASN)ZLCM2TsQfc}T z@gn5!l5wxu(|l?RVg9O_)iqYTu+Vq&CA67hV8uIKL;#QoxKfRNlN*HhP!V)v@rqk3 z_@s>Ut=pM`V3(@ASV3DdsG6Ru5xLAi*5ln{LeB4*e#=Jn3lUirUXtRF>e-=G>E0hp zp-5~LA5*mYc4D>^S_z8*VCC()+?~ZNk<=myT~79^)R}P62qGV}Bhel1;XCJrFe)C2 zamPIw6Dz8Yv2ZB=RdCbgG2a!f+2e)R9eL)KU&=h)esJX`n2-3I`M=WXG*y|`bN-+d zL9M5pA~15L^Af@+zl-qdTkP)$-T86w=~NE%gz(BNwsx@Nkj{CM4k)SoqV3j&-IZzlx^xZX)O1l)3pcTyD$rQ>)~ztuAOh`c~Ge6u!$onaQZcs5uK z`w$8|H0Sv+k_O7p4LM-m5^hKLBz7q3g{+Jd#(jORv7?M=9;l<B6E>&nezT2O?=FimInV09&Y9 zr*}sE$tdV59HZy+!*{!EA}Pv$cp3D)ediGmx@3Pog;DavMfHqIqzCCcjTwF=xR|eB z#{^v)npCZl+n*kzlJ3=+A%N^Aik=eGXsPnLIW<_Ipq3dA!UMkSfJ1^Jg`IO_jV3Er zrF-;sXnnj6vzB@4C8yPza8c8@T$A%I>D}&7&fnE1RbNh;ylwc~P5lNduXMP1Tx!~Cdn(ZxW=_T#bUL9EHX1Ta!b z>y`|Sww3D3IFhp-tAh8d@zorD{#5!_HUX~9#jZG3%_G}VX2@F@Y+*XVQQh~t%LZWj z3IY+xv8%GB;_xZ;agJ9C;y1J@1ruuN%_pTDpHT1~qe`z&uLG?Y^?@}`7VVo|Z<|R9>b(nw;9heEqQkoE*ssJ2c`G!8MM5zWZjefbbCMMPbO=L$HCi5b==_le?~M=&p-R=C?p2@l?0k$?7npZ+ zwf<++%V64soP8EOotbdNo*#LUUG{0Iwp+HDO80N)dwlR$)~lFd9IhVm8~U#iwO8bk zroB(Vx?YrpMq^h54vn#k#G_C;YPl|~26eg*K<2WDCi;}$$->4~uhYF(XUYSL@7AMd zsP4yXN6$aR-N-Ju2A_*pO*{M9L$A<{hr{(;QzK zU9A9IZZ1V_z=udw^Rj@yd3>Loe%`8gZf;QL^DhquV-OUbU*|VA$ufU~?``P*`}D`S z1bxH4QL?Zsj#A0uw>-|%#1F8K$c)Xc(q;Yu-!1scJ*O6={4($z=h?sO&@>%p#F>c- z5EIaU)9Wd_>0_{2e$*Xe$s>NtG3r8qnQV-_`@IpUYcq|i>0543x6SA+KKg*-;p~KW z6ct3gyX%g1muY3mUEZ(WEe@uut>9{mL?^ZiNy$p$!6af!CI^S6&YUZzWl>$bxMsJo z%O;aOZO+bCpAE|c-A)tYZ3tE?U3{S>@w`(F#jeU>%q(}Mlc7m zjb;}YjF7N3RCvU)zP80T!1bkvJZad8@sQznh>0jGca#6hG^i^rfpK_~~D zP|M7p+(5325TKDsY_)r#3jfb#VLuJd3AsvaAKQaN$3G?+rr)n8yS*ahw3t^5%brG1JO-c`np0<;|m1 z7UpM;2{n0ywWQxzEX7!SZ~9U_6(xV4)u?@#c1|^7#Ql{@C=w-|Ye}sOi@p#?6ad8K z>;jjL5NkxI7i>!KAf4L<@m$XiBf{k!70VH@%!wjA#gK+;&z?@pC=y%hj?p6G*NH)L z2irNSAC2boj@yho5~0Ecx@9un2YU4ov_9we6O#+S^mJUCbdJm3_3gpqVm%VJC*N8> z26QjUv(N8sXY0(<5kr(jnK?p0Bf5tkU{`i3B2}ixml3@L;_4e5c(1Xb68gb^4Oorv z7S zZ47XiCug*K1?ddK;!^Vlf25X58n2;3w}=I2ohsp2#O}aeA_#Qr(shTju2i{j)kU_# z0Yt633hAs@+Xlt8u=U*bySrgJ0d#5@A|@Y-Yyw+Bbh5RWvvsedQqF!_o}c-olZi`Q zzfEG*wi3aFWxieyhhOeVdHZ3`OlYzTJu42ajTdfP`YUhBFheIBH}93*{=;~$pP&1h zn{M&Af6TP|kA(y9eX->nWH=?Xe=dlS`p|871)hC!*=suxBKeFe_@=2ssEK*nA_Ncy?+_FmOCJimKoXU<@f^dX*``* zI+`!FzfjWV2y5ZPeA1Xs5j}JnOEJE)XjPLuj;a#)kihypQEWPag) z?kVC!`h&WMgkof6mEqHJLB~p~X)mEwrs4wV2!)ZQq zRBxWvKhPU<{&xMIeB0s7C)e%I3+PJYMz6T$(n2TboDwMxPCtl26za#=*J4~VfHrMr zwxN!YBh-JIe|x4j)xG4U@|}Gw_!`ma*-)qZ>2uUotj6PKsWOm291+HD_jaxQ*RV2; zj47Ua>87nyjQ=O5`H=<$hoQKr&(1*LxX44)4*~yYCOG`5A3A`DPFPc%v@bqT!xH5O z5P7HRj3HxiIuT88L=Nasw*dOPoWZs6qO)LP0`e25Gd;)oG&P~BkF{Gb`Ig}i~ktVg44yGG(0Q{MORr@)klts&)YN@w91 zhmEQjCtV_|rQubUkb*zdJh3e;0(ZZjbuZD&As0%|+LTkl`R0a4FGdvkF6;l{c@jhn zq7J3KHC>F<(3AsPzy@wzDDZuqVDHcC3b#7i^?&n>Odb{eT?oXw+YQe<*ZDNu&uG~d zLa&0n#a6FKI}CWm@Vri`S05~olNrm|u}Nm69%pq&c8Ta&YW2VX=$4!|75B)iQ|`)K zpk{p#iu_j@GmMs{{Wl&*pPAt{y{yEzuvVR zPmF{|=;lo-An{JNUxS0-Ud7BRV`qeSqYeHOhr&(?bxaoG^T2Dc8i{LL>2}PS^9^!Y z3vHXex3MwgZuU#t+Ew`i^I`PBv*7K4x4SC^JH5%td)U=su+0P_*1Zd=#@9DqjTRa8 zw;wG#9cs>wV=cCtOJRsTk5sr5p%B}YOL9pq9Z?T%U zTYlqTLgtu%f`q}tCdWKr^CF+Th|YZMPkjzB6xp@#y=Ps%dcMn_H!;ykeuxJA+?lmI zCKJr^p&f~#2Vy^yOd>#FDKy|O_0>zI#@xd5ID%Y}OIL7H^9GXjHEoo<#hLNA)2Z+%9k1^qV2uMz zv%TCp&&D<1V{frsftFs+%$kuRuVXpsvA0%GM=TZR{rfTS%jywy{Msw(;q9-tRXPfkNE3^Ij^HSu?Fn zaA?ck^JEjkZLAaWU@upKIv(x(SHfhZ^4&KUi*_~1T!-o2;DL`y@vPm5-O~XY`N5tN zMnx3?*0PgzcRAK6EdN92zA-Cx?qyJu_6=GY?FY)9%>DD$E*N5Ql&}P3``p57q}{C( z1rcBJj0bd`k42@fUG;jsU9KWUc|?Z#MjRZvH?!g(;n|IVS1u=hGDD!zjvE~La<(%t zfPF>nfHft#H23UB*l?)d6|W`+#c*~B@d4jrGt;{bljgR~qj zmlG5D0!7#V!1<6;c4%@5C>)CdB;N-GX!m%3B5VaI7IY>>@Uno{P&iUfmqdXLo#zp&O`Qmj4t#887?7XhlZ?--xRY)o#kiH>~hQeUvUE;yz&jx|k7d~{ULmeE+jCEfWd{t2kFSeJ?}3L&Tp zqo9j-=7bU1LTRSg^l_}pbXURF43 z4RLcA)ulgt?h|*Mfmwzu{59%|*kT@Gc}(O-{RTH@e*ZYfIfs{d6+k!;Y4R=+^Bo$5 zxuM<=Gty3O>-}L%^DL1)Ahk*jn6Zf23h>4vtpZdW3_Qgb%_+pR<=AOW-{IWD1xEq{ zV$F@o`y4odm90>e-BQA&r8beQ#_C+&muK>P3Vs&Bp#%E6D=`6*Vle?ba-zLH-6QeQ z)8-~iET*c%36f62riAHM+yBakkuQr!t&N9E>V%1Lxx40&9n7YP52c=;LXwDd@T+T0 zf3KkZ8m&4BYK{z*A)48F_pj0;_Gt|r{nAC!cP^;@4jI_i9gR}1dTMamrsHt`k$W~! zGmv3b=CwXu?{&Cl!}2Y&tzmumYpik%Ps~wa-KB8bYTm#0vZI&-11hK$5+??U&j5sjAM`>dXf|VmDc%AVvy<$Rc3H*5y=O3lvo zxwa~#9eTd!u382$Xt&)xy84BJB0fZ@QTGQzRf;a|0b9({K-cWhIqrXK*4i2NY34UX z`$x;C$Hp3E^$v1zsPfJ>lC*)0zF1~nvj}r4R<*7(E3X!n%R$?Xr_PqU54X!?3mjSQp=2^(%)lPsPjnQ{g1sIn zD=zORu!X^BDg-zyH%~WY3h7u`hPK8I*bdnKM z+pFVRT~p!(dIS8H50)fp6UXt{2)qchl%{)&u)IH+>_R!3Dv3k@54t2p2FNrk4|rGb78D5d5xU^UM+GSVV^5y0Qo{ZdZ9&o zv)1%(mv^0Et}0mb$Lp$UY(&4-=@Z^7zKRvTR={1=>fl0*@HaBAZbB93*8^dQ88an(_T0<{2Zb5! zdP4=*!P4d@R|7BVuEse3_90LY;{j+x>K8JnTAY~f09&uKjKZt7`gdh~iGlW}0e$e! zceyZx>5g7FT7Ho?cG?UuITa#Uuc((->T8N}>>Bhu_TNRDJZG6ybhsHMMG)qSrnHAL z@E)3W6!KI@=;n5~_DUd5_&o2`5b~XN`4<&K&x97b_dsFna#eF8uY`8+6^+vN>aTDP zmFLjKAlnBIDF~HkdNFefbhsU8M|Eh=^vH30=v|xt zda%r{2#7^}v14eY33Z!O{A2{A7hCuek+KQN2tOS$@O%@%Chj&q+YzVIMzaY2mIkO5>~ZWd0(@&CIRi&%wyGyV~|A6tAQEqv3<6??lWddRoz z-r(#j+e~5&^+}SOGAh9Tf15LjtZ|vUzb1*_Wu}Qs2CdRN1k({1^X_DO5v6|Q@8F8z zjdVef?i)23Mf+!-nom*V4=b*HW-4)+OGz* zMLN&0*QWB3mPfd1$w>O-+VCjPH9f(>&Ch2AnCH#1;)B$$+qdX!S8Q!{dK+celAkHX z33g~JXdcG!)?4q^;%CP~;QuvCYlCPuQk$fI#l{NZ+tE|@CL3tNIIx~m%H@)x5 zURr9yj3FqCDI%u2WXX~>3a3#FYX2MVMBijm~7ikuF0Hix3g{RI5laqZQIt)w(XjX$vFG> zKj&QExBK0`)>;ql&wb1Ov5Ipd5S+$c_e=SLs8fIPs$xt{z!u?&E41hRjty3B_P`Lf zovtxM@3Z%I#Z}{JP`2<$x{JJRf~XE!hf=ms+#cBtXfj!JuS(k-o|4?ws>)U04$}w* zOSM6zSiP9d=>dxg>O0Q^JUf0h@E=^bt4%v+;shh}k9sbNKqf^e^znK}Y_`Rh zk+3I2k`luKKR>m=qs8Um=IPTy;_6o6?%H0b62z^vzVu^>?+qJx_-TP)^`mMKroU8H zjO1E+Y#aS^lt47y$6s@6c}UL;OM(6>en6z{G?C^4GwVpejs32Qc8+bo!k`J?pSs4?-Ws55Hlre!h+bu5pK>D!|nL^QP}am#r&@e`1F(nUBG!s9 z?ym0#ncKc5;4G&?%0=?8!gU|^YQ%br2(Vjl-Iy)CIq*2@i^hr>hkG`TwRl`=clDwA zc{tR{r+mcBnez=H=9-%?dYIKTper`85&g%|t41x2l+q>V#%g_oN0Pgw0IY z_hGW#^FUwnRe}3-#{`jW(?L~Ypuz$9bM!?ROF>&y{f;8nmnXRU#Ci6TE z@CXMJ1}6#{ojj#{`dH8rU=>BVcx4yQqWkK#uoXEk4WcHx7W1n7c(@5nPF(5W-y{j<8K3- zGMo42!F@LK$t$Heg-4P|6{xcvJ@lG#lRtS*FDuNQUVkzZf+sP5 z6y#s0$2KD+zJ}Jo*aXv1M)`u3DA{|)pKDCEYt;n{%l-Whm9SfbejUUnF2w`@>(qu? zE`dy6g3CM?B~#&H=Ep<<8h%Bdv%3hn=n!=oM*D+1s#U>KFF!TEZ0+#hdskdW7tiUb zg)L%lT_AcSUvrJLP0tVZ|9U8gj0qQUHySaG9*sZ;ct3qD!OXLN3grlPw@cCk=^Jo0yD@jUn05kVej336!%v${$@bJR`g<(1l9riI{q-s6 z3PYjYLD~#%>u#eZMYrFlu(Y90kmH1-zi`(FMR=S}Hq!#ZXY;*?K z8sE<1^tG-SUvb5t;a(|!PD?YtWNcDz=z-5NZd;tKaSG9GD$d;KWC-X^iay3@>@r_G zIi%6fNIj_X?LD*^AxrPS!ki!;a>|HmU7Qq7NmCJmY)S`*9l}5Ka;$=H2tW`Ml;9~O*TpQZMc=Bk zGYnyf7~K;wB`)qiD_1R?kf9*Z1>%daTd(Q}(APb)MN3- zaiY(+s8O@wXGnQB-Srw=2=vhdkW}xxz`hDq_ZRtfJo}f4^cU3(~Q72t=tRKQR z+9M&h2uKF;EC!*rw=<^@e+m1AEfZ8=7qGD>YAp}84*r$Uc2Xk<))TfV+Cs&%5x6cY z_ORKq|B(j^k*O zcr$LVrC(RtXy46tzh!;lU#Nz|31T&i^us*;kbEzG#RdAB{Uj;PqVIGkdT}ckShopM zO~=hADcwEA!Z!gIR9aXc#!0OGPMa>18b|ZKhxYI_9zs@!;7C^G`;}p8KkQY*JI93Q zAV`UwQ2dQsrHpIyY0Y8AW4!Fp3%QHZyQ$V|=EPo!{b0%K&#>t-^f&D~PgzT>QoL)% z=OKEEp$NN$l)PlB7R-8m{%yPygxebJ(`G_$>m&qOQswNT?rp?(Wl_8gc&Lkm8b6t3z0!FnhaCT2L)4bS_Xt9;pdFsiZs)l49nb?W5Bur^ z#2}M2Wu?p0=S5zYI-1<-F-Abh=#@Nnd>EnJp!*?|Z*I{Qez8&FS> zt2Fy)#l%y@5-!C-g%Ic01h-Eknus2Q+S^R*yMbdmng>`G-UbiLx%?Up8&tL0t17=b zkCXnK`}`{!P4y8*9G!V{5aiFZ702NY;Jq^gx2d2?8Xg{e;@<#ZmW?whp7F;va$I!(5MCf<&l}xcROG< z+a}esZ7{b}6Y$}GMgDwoaL=^@>?iHljVc7>8T-~-VopAJ^5Ti<#k+P-Sx5FW_bQ>3 zgLgHriUa6%3=8iy;CeW?;2|(hP?xpNw-Ga_#fJHL*fH{S-QnqWy%QB7hwh+_W_q$3 zjhL?2Wd+4NGw__)xkOI!mGOJbUr}V{pQ-aS7Y#l3u-9Bl-N9n=q@nY-B4Rny#a*18 zdD9d4ep2ZLNUktDylc33gg@QuC;B@XNlbm2AyDC3%sCY&=lhZ zB$ht)c}_#{Zw)bnbb5$&_-uq-c1$NL@Pxbb?n2WsLIBP_zpuT(jYJjev%pvUZJJKm?uWAX% zPECF5<}T3YKJ-wt_n@_?Q17xDru)>C%`s;61JGm+hBy*`V+iDBktgDJNsc0_ujBqc z@m#_wozwZ9`-q2rxWLvRU(3(`|AU*V?6nU95@hH~c>|hZC=qN#3`aU~wult3)1ehY zDk_Sdohx6*Q%@kk17qkP%0_UL-&CkAfDE0xh$?hZz+IXf1UqA#$)TqLhjOK0E^fc& z6|>ID;a_VqMb1@*n9nDcmP&t;wV0ipIHkPQ@MdKiQ+Th>?{9Vf0EtC3$k2CPL1#&;9pq_v&<^Pv)fINM`s zgTeyc=v0M%H@cnpk|MZX8rV4dV$}|J(ta}xZ=(uhzxYPIzT}Znj{j<~RgCEDZCp9% zZ>LK!m-JWJvg^j_ahaswf!1;I-n&ygz0vJ04r1^y@y~ls?J7~o$3*F}l-;alVyAUwo%P7zDuZ$# zY})=Bn>Ep_m<${}DijSmVm7J}#QzXZ@Dt9c(T}5LDr^0v{j{a|Q6>ammA`e0zZ{o+ zc7UuRHgTk{jCXlRn<=``fIs^w0pu?^OV>QVJteJj1-A32z)Kvy!>}iQrNr0hFzJ{8 z(k9da7t)8orpMTe5b0C^EPK0(-^|_Bjfi6y@0t$4NuomZwK3+~_e?RgvZGa06 z(%xD6bVt#h{iIbqV%G*T2_I(Q-oKfYa-qfYoef&wK}jPA0H}h;sY3B4C5XHtxJUB| z2^>6ar4jW|^tcjSQvO30w|7v6RAPt!Fb9!YP|Ffk7^9wL=6JmT*h=IUVmz54K*V6G z>$3lk2vnsldy`-%T9=Z~G6-;mTFk<8wDr^W%((szLPc~yYu4FiXoKQlIqI+L$p&e! z>`S&^ivD<#G8va3U;iZln^`iY1gYg^fM(|bx6r8S%g{EYz$CM7CV@n3Kk%?s=JYQU zP_Z7=nrho4d7*avV^7sqXK(q{Vs{%sSKn6l>-Kra{!u-B+FkIczSh^2|B!M?ssHiR z^WS@)%f4XYyk5No#1vc)OG~im;;kM3N){4@UJLwJsYIWhPujSTca8+%5qN&(e8RQ4HR(;!1#esqZ`(iJL8mN2Dxmf&Bm8wgPw9WpyunBPo*70 zGbs!s)xuDY3B+RU3>&jp_bF$#ur0c3@cBh^rgCJYXWks3c7M1y_3OX6!sh}GrsQqX z|IXK7y{ylmA#2C749202p&6T^NooPep3iZ;;AWyma-N7Qjh#WAm3(2_hieGR z%>_=C>q+x;66Xo^s>$`E@M+dO6rctL2~bHKcZxE`ts(%`v?74YHg;l{$x1BTZxz4p zwxk@9KjSdAaemx{(iI*5avfcN1>RsllXzI{C^B%oEhh|yKzJn|nV-xA>P0oWE9Fc$ z+-YQWRdT)REk1nQ5OwvNsF+|Qli~vSsBhBmu>Szh^?Fm03SYyq!kMDc_0jxW9O)9) z^90+kxe&IJkv`A)2(Jk(msrb7343OBG$E=Z_docILxvhECWDtPx3!3lSvwT758B{f zC(>C&$G5TSADwPIx#ESs6XC$VMJCLIShM_mS4Mt)jnjeiTPqD;y#A1#Nd(;T$@}#W zG+y+ikWVvx$biY7^l=LC`pT{sd%F?+-1P7FSfUDkDz-~rr7rZ6Tf&%QuauHxmXbG3 zvf%~B-HZkfE)e!0;Gy68zZnG3y>>b}NZh4THNGOPy3e!{*HAj~MMXVRdrx4Tlx1b+k- zi%#Z`?mJP1VjY-o1`u;H_nYCoydSQSR=?uTOA0;d6$TEQ*^M~fz-FP2RDn8YUU8#F zzt=x)S{mkri(XkQ_Q**45ZqfmmNnKm<~6EHk7t@grqEH_rxL5=0zbIrd4x3UH@hjC zW1bN4Yv8QT4AlqrbWhx%2t>voe#zK74~Kv@9^sb%aRoam>@a-rF9_s?Ft&YqfE3}* zn)|5od-T^MFJ}Iy^$ul&KJ9dE5v3JOdEu^kXnq?xyARyP;r)0CWre|Ku`Ewbi0}^< z+EEmy?-lv3Jpl)Pqp;%4lk#;ir}O1M@=L8WkU5x;dJYnLFu24b^`Zyzpw zO!^|P|9S4X*dZhFtyCWtDS%mF>AqeU0=zRBYRR^nYv;}X?{DY_H)sR-v_7F_Q3ZJ> zGVO@*2P^rTaA7bQ0wihJAELwl9~1UE{2|##zU8n2Vm3iIW5)o^v^k$7%N{`9XOk&F zD-TQT^qLR`u#UJlVTjxz#V)HF4v zJbSRGu7i#yA>HP*?_K2ak@U5OW@SImhwhRfBM8BGDK2=xXqrAA#V_JZhokW+zIu9A z$XYtX?c!OI8Msd4_@Xw7f)&6SiZz?eL81U02eo75j!*=m(lSr=c}j5bW?6@1-b)4< zAN{iR7v1BQUgu&#x|47FSBa~T9Gc!ON$LXI1_4t1y8pfR=G!*Z#(!(_9CSYo&kV=E zqBX9FBhfcm+V2d;+4-!*Kn(8b#uJGa4nuA zPWC!WeC;KgS+ML!cop5B^M`1A{lWQFnmzUeu7lgkc;}w_uv|jWHbOZMx0}fNruTGV ziIB&r5BC3G3!tpCJJ&CpZ>*&}6Y1oLR5^piu0S7QHzW&#_m55hyGD#_-98OOt^)m9 zwRGT;YfRSH;$&}0liW{fAk5cvCQc23$BMyO> zUo(hpK-;{pVqVvaiz0@^MgFC2%qGhu$@ukYuA<~?0-suLL_$l>@3GTXPlFA|t0oA3 z#5wbsAixk=Xh>`nwobtKXlV2Fk_|XC{J4iyYnHj90rOY&1$dI1I{`86H1}h~SjO)B zBH8waO7FDVx>Ib?ap||j(MN& zX|_j{P;*yUrsDcJLtan*)C$M}Zv1h1!M_ZsU-IA)vhPe(zW5-D&RqVDU}(ak2B?5( z^Q#J(f}y+nk3-Hv;QeLX)D6?W6_RJ?mwzB=5KFN})Q<)r&^o8Y{o)6licO#entw4* zH(>oSdZ3wnPiIzVOz;%hnwO|_chXbQp;)Pc|@Wk z5=CuLbUAm#fUy|d4K=89R(@YSeN_L{4~MfL^wp?;GLpeW%jD5UNV7%sX_op|0b|dQ zf0_FC5C%*P3zN7GB;x$eDZWVvSr7JR=b7IwNoosabQB2CD|HSWac@=kY=||!5+vjP zwUIe-zaq1q`k#X8A1;p7(Y5%qzy<&+?YVFW??52W%f*(-ydD_IgHXZy1EcQpclS%% z-%6_q!T}TFOq>&C&4Za&$R1#&?CaxQ62q@gVmOU>iYj~*SiET zLLPFv^UM4FuIYhn4Tl1u>i*r@1!9&(aPi;x3@u@}uri%8B3G7LK%{Z)Y68{>gpPtL zAVlu%w?nIe9uluidKc4DI(!rp{VA5@q+q*(Z1qN-1Uw>B%=Z8Ehg>2Eb9*v=j0Oo3 zI^C)Qze@hjy=^pj{~Da926i<>bhm8G5}cbAUA@*Pbw~6^#A@HuE1=}F${^*w7c))c zV=7{DF;Sz(Gu|ZVqU#L@*PS)r?bVFtqmFBU#pE&ouEMHrhvSv(Sb?i=Ad+_akF~S( z0*4Q?P*0KhK4#zhg>=Q`rtWa6)mWBun{H*TCf;4{!ElL)sR7~bj~%gJ*J1>1D(i|h zf12O(cJfHU)2Z>2xNrK-+0a(A)5k{M`K%=i!;d?A49joW*ZMD;t5wtU4v>Ipv%jpA ziZJLlGx;It?6abX(p&SaL^OX=3n2Vf@RK>4Z#r@OWm)b;OA197I?Z}^EZ%dAevJM> zIgL;mGZczkEgXL?HZr0xuFK3&Zo%vhBKffOQLp#di10(ysyV#$L*$vZU%p~z<$~s? ztRvUMrGU?Q&FO@jczP87EMjX9jeK80b`+>Ct&9veQi`UXQc5iYL92_J0e=sj*u&P| zK5ms$G`CoS4R)G)KNi}rbves5+%P^eXhVE!cxV;Afc2I*3M^}SBdDHBL*Srkp8p7* zm=<<9uYk@bJph?!T#uId8t30s^B5T2(;AIbyv7Cvnj<>*J#y|sl7;9+Bd)Q)Ibg+` zAoM)KeI4WHBY<5MY*$q<*S`n5p|cA;EcRgfNskCXw+fs1ugviNZs4_P>(iPr-Xm}( zJa!nhT)ZrY<1ZiR=T$fkslXD$tf2$1W`)Z6kM)^5>;x?&i+(w%d?Z{ugdD_!YF5=Q zSFwSwP9j<`rqhdht1_aP#MUi~zZfadp2BI*VI zvOiBH$O!YOk0t8Z7IOLks< z4fDDV81w+2Od7XmQH6=X`eF^Cz6#bfk6T-|2qWjl>sWbTjPa*A3XKuv(m(2Lcd?Yajg|A8ejCiJtO@^C949JMD-0v~+8WerE3^So*>IcI1aS zU4k`?8ZmSim~zw!|AIrcN}};9X_V1M`aLGZFq=l@OZJy)e2Px`5B|h6#Nm-DBiT@2 zZhw^e%A3+R=V?$guqgJp&~CTE4kpIE&Gl;7D_GCjUhB$*rg@im_ps3_qg*!#ST8?p zx2}?>kJ|H&p1+OTm%(Y%gXDZ!;YYXYI{A)!7`%5a9gEZyg9Wet_z5%Xj+hcmG-33g z$ez$X(F;N5D;Mf<1x`yQ>u?_t*qgRTPr&(>KhyD7rc2PFh%teuHvySxaVssZ1s}^F zw7aY|;sHhU4EK2i(5+c6FUkTWU1dPdH~^1vGIm z&Q75MuQKa)6tnWs+2wV}#Aqrrhhlfx!3VqcdD)^kHPLw^V&?bTqN9fH0>SS;5PsSFar_gr+mFGxB02j`CU7!qT_gNZJFN=1U~o1 z6{40q{NqRv_6>oMzo#?S5M5^pL~fj>@SrXdFt<`9^aza;p&yJQdR#Id*%zvp&34FA zAgjrG!BU?0KZ5FNtTKaKEaw0Ig;zjT<0Hfa|0V*5$SG+xXGI#a)J>U**!8U@@m-+89{wMS3HMn9FIv8NZtAi?b_zLJFn59E;W5Rc< z>{LKsL5Qw2_D!`Th$Irh5_tbNup%#*iUSAO$bX7d92(KqMTuN?((TiJOC*r-6fj5h ziYUZ*3QeZ4OD~J&UiZ@hPb9D z-}@O%^c-#pX;r&%{bBX`x-*NbkVMRcW z|4(pwJCor6gfX0SvMuhrr9S(hVO>f(7phfKV(p1hQUPwqqS24_eas%uWbS2zPxbW~ zk$`>bAu=3+6k0R96v0^MsF`2js0V55RKA zsTm6^>Z#%*eYXICe$Tit74*jNNw%TH!5~6~J&&t^%wxu!Z{3$R2Tz?WkWrz!rrRWW z;_bSSO%-QX)nBCWr62RVtI|xgB^zIzS=wfM-9J5e;uM>OB(`O)jOy4DKsD!>xxSHa znKi9jdG0Nad4>v0ZK8YIDQccaGuA>WdYC~h>i&DLR|gInlkRwbr^iyyD-lZQKQv5s z-pJNe*8C;yN;IX9^y7)z{ma%W{Nln4d z#sD%B)6?}rb$J%mLe`K@nLAr@|ddY02i2LrnUdY3D&|fxziZD%6 z%Y`UZ23D678)5XPhs-CX6PJ$}_tk8y#C`T!w|>25=I!E@<;}+0%tCA2|dwU|G`YAcsyczdWgJ)YB!f+ISY%hDFk}9 z)_-I0pZi-TbvKfgO;1#;>gQ zw34f9T^{LT zynW}}tnvJp!J%E>O3C(U`F;NzU^K5rWfFXO08E8vb>1+=e<(!c z4o2uAd4Yh;m4-0l4cjkn4qH+v$F>B`76T!`%3@@l>-n>!ItyJ4f+LDS5N>ViVsYN= zianZ2G-6M4O*jr;9A@P7-C+-R<$L1xp|Xs+(*BIYd8!mBWe1W?2@do6<`titU*!GeBf0Mqs2GJW;qFxtl(lN3_G zI3Iy`(oDtn+r4dJY(>NnOSnXz$|E3zeZEUM&12TeWt?=xp75*`C#?@ zMIZJzd#zXj)-DLG$&b}l;I#F{f(Rf)HA@h@tx@BwRVq-E%J~NjUvjHkj3GV)RgTaVL`Pj0%e0)Qs19o`Rt2F0d8wDFjzxAK}6u3CUPx z$Z&IR-u6`X*bp;bj}u`%+@`Pa#Sw4Iy)`X~9gu#GT_JM%RbB@#s6gx^qUwb?Gj6hU zYCd6+Jr};~=3#xCcVEl9F)+fYMNY{`#o`+tw!>Oe=3n62>5e{@5a2e}b*yR0K9*A9 zCXEsB>B!VrFT3eXcz|w3eSMScD`J0JKp*m2>ZHrnBV5Q7qPCc>XIA?pA9#meW1^ikrcSBP8cN+XkK3#KnV95E;;^pTCwED$jUW;&m%yH z@_3yAvQv8hQOy#m=Lgw#d>Sqf+s|;s)@F&YWL95bUkd?-E zqK&iSM-7%i^1}r+?}=^yU)}&7htOxV;GUVxX?xx)eWt^spK`BXUWXSA&3fL9X0d}S zKs~Zm_ytaZp2@Y|di|&YQkT80c<;3@0&XA1)>j&@M50rxz}bL@(BOSyYP9)i?AL|? zuyF|3=!4Zf;H>f6$nnB zWV|yI($Uf)!_yjnja?Y@?=jhrk>h%{5KGkClC-j1)MVXQ#g&#N`MHcLu?>41AL34S zgi7b=G0QjUOal@vUJ*fk9Ogw1R~z5K;Pdn)k@u|({Y$gnmqJnR7`DN(#8PH42_mOlorYQPH$Ui9~dX&SR0H#UTmm2-0cz*BjUTbd>W(NbO@ZJ9?jr0Y(V*dXTJYI*_SuFewEf>r0@x10Hys-%TCnjW1_kp++81K2qjVDqz z?pP@}p8DTCPv(yuycR4!Br87PYnnYGw5`<+?fm85=uxY3LnH(a?{R&`x5MUrhXgTS zjHapf9i}9v-@R?yN4t;qyP&~?qF^hWU~tI`0()1u;+2{TFMm|D16Ijyx4>`h$c?E4 z?>(B*E9x8=BL={epxB`Vv?NX9OJad(lqqJE(6QnCmrRclO`>bUJoxfyqKpITq8jO4 zLb7S*!8KUTqk#j~WZ6<$P6CG|qgz3YZ!%R$P2$;h0a8?j zZ+8NY6xq5%E@KR){+uZF zU22a8$U(UqznDtpFJrrqV4snnB#9FWY=8vBKPSsr-YJv-DH0=d7p-&xl8Ir&wg4Xe zCmj1~;eT*}4p@F8zT43ADf{yBHH8-i z*sC>LL#tI3k37hvbv@YNhj}lD9UUQ&Mm(o{&Bhs(mukAgn(i`Ls%?bSTIp64d`i2l zC4vQyo=0Zm)Zr9$I2w_H#*zP5t|GM{_T-`PaRKA~-;`{L{G(4dNn6=+$A_dZy?--z zYsl3M+BkOSXwIHe;EXQ$Ohv#TvlkK&1-qsyR=tv%^2d=8Ew6Z#1YqQCVW?c~3j%o5 z$ic;FdP5i6DOp5h8=&B9pv=MPTpvz$&Pvh{J2asx44oBJZ^{^5YZ9_AMs4m@hx?OY zkRgRal2Se;I&8G2skF$mOG2g@g9#x(#aaKIlb8!C4_@Vq0(X!zhWNSmt+=5sJ_VcA z9~L|YLIM%;fw!sqH7+29RikfRw+GXj9QpxnN_-}L?_C!d79Z_QuH zDInTBqH7#CSqnM(_#?aw6*iUmS84{EGra4jijo-3P~%LHJ@q}!N#hm`LiDeu*!jON zC&z~D5osn-{=C64`}cg8RYKk7SdRbIx7z==zHR@STiQW>YaF7^t%v3WUQedZZBx82 zTfe=E@K0Q5a`g&58p!wZnpdO>(F2Pd)rbkMoXqx-O_s6iI)iXxh^(1>eatQ{K zs@|I+5q(HPy^eX?d#}V?;v5}A82gukJepFU%1zxHWBJR)=c1+-(=i!B_d!64smM6) zslJRCrc1|-rvFYD*!hQZS^6E-e=LGWS*gfTswf1NShzrq`otJGw%%|&4=0fvD!{B1$^}r7XW7ZR@GB(ie=peArGSkiAw~Yso)loPqTnJqbw9u$D$AEdxZB^wz|dN+l~Bpshq(@mMug2p zUK}=P8AgiXBZ;pI$pd42Yd&zmcv)*RG&rC6GVEwI^w!_Ya6sU$5O&_X$^6&9q zdP6l-Fw7%AC`HO1_A_7}DD*qI5}*HILV~swnXkR5_>3I;O=;9zdDp2BMsqGs=+JEC z*io$yQOMnvvL~&H3?TB@{6^3m#%bz|fA5@;bSJ@;(r_0E|C&>aMQN%C%+Y{E{lsQH z|4$D3e_yuAUKC}pe7b4Fh#Y1bu-rB70Hf{OJ@L|j&jNeF+6>r)*cLz}fDsV0hE7?6 zr}Jn#xrBcF5Iyo#_|__V zk$!eQP{FlPa>t1B$M`y@;*)H5!Y^9k?tFY}6!Z^j{iY-sr+Rq?&e!>+5B*I>D<@0b zGuyOjvV593r{rl0O$DMF8@~kp2SWF`%@xiTscqAA(f*NJyhBHhY$LXYgxL+mFzR%+ z*ODNDXSTQ9H(YfHbNdW<%&EQ$tda!5uMYGOLixrm1XD8qHIJFLVP1%0G!33`IiX80 zQfwq=jLo*$hywB6n3t88G;%uMc#z&@8p`Iv0g?+j%AjX&5;jbWb>>qF$7wt?& zg42PPkMLJ2C=X?aGALk+In;LkU_C~Zm1b*H9H3k@-Ne!0^u?Eg)@hY~n;ab68t4&J zm?bUsP88J(H7x%15Y44*#slgzpO6gg^CW)ghtVIPajSVj>pyfKwK-}%Uv3NO&Ixbm z*SduYWICG%#anX^Jbgw$u-P~!+k%zbdwwJKEB1T(uuK0Lwk?n>nDur%l$ys!7$>Tq z3o$6>9a5F-cBdHTkC0Pg^+u4_Ta_<})s6pTVZP{omUcOrSJGk_;~jaODJ8RJk5>_y zG?>lM82w#*nrl_pF|D!~S*qc=_isw5W|`ln=qiuqOak8ya8)UQY~R&&+;co$k@bjS z2CvM68KUHi9jA&;_XTQ5&Z{x^S*(ytm>hCnT-K#!8EM%4+a#x|J7@G_N%w8?IDZQ5 zxgoDD)jV;GaX)j2@*wYhxuvbr38KDRmGA`5ky;eVbLWV4y>hNXbFMb{nLbz?`fIVu z(c*QJ!mDZ-V%~m$;}gMlWagTaX?OM35_l7yiDwQWEo6JhR9TDXdo=#{=wLoN&2+lC zrOj;K)0N4X_G9wL(?}?)cU$$V$TrnZTi1flR;Zm3OK-CY(n7LdX6i6RQ6p2v zsJlAN!G`DygEqf^(L?K56N2Z31EfbqKxq6D@_!~g0X{676&Gl3SF9yY_tc}?EM1?8 zGPynEdLx#h1^n|+wMSl+)HfS=a+H_-zvV_h2*f?xt{sn=_V`5B|83z;=vJ(pa~?$4 zv^Y8u-Qvzk6XINdEHbWuxlcJJgJ1s^O6&8}-9q zA^8eB29CE3l#`$hi8&NNCEE#Zln?IQi5HY=Z=#S-628wgoaR z9T>!*ME$eD1)_g;;Fne?UU{h;Vw>D)$z$e{V9X+?AI>z0Cos1h{C7{w;Jk{d#NY{0jz z>2lxCo*ONjOSdIKiz}B0ULVaxLUosE-eJNT-la90s)i4n>Z(g}329O-+ifLN5t3Tc3%3?IJr6 zKmFXM9LXpX@O*GqE9|W3~gM? z%u6$EV1dwUfo@!?Rv1h|(kjlMS}Zr3{>^Irn}S(SobbXA;yawCHJ1soA*{7%YJ)FC zztMUVhp_$3=zCwUMsvZ4=Rmnvt_4ZF`o+Ue9?7k}Ud|UPg8}3DV9hC2Utu#(;&@)i zuEc^RYrt23Z~&n&>bhm}x;rH{GQ}Q=frb6T82|=Yrvd2?K@~R%%2;Zkts=?JU~@5H zzeJYt96er-6UeFZ2k1m{C5U!kbjXc$BrS~d)Z0T@cY1vhoC2cFyJ0!TMXpuirE);OWSD@RTJD;B+o~12X}gwp z#5hTBBho|FOOGYqkU3=MV8W_))~hGo{6pygk+2`PEl-tqEt{QH^A-S%@0!pgDn9(L z1nnF9y6U{N>$*)o{-;+_&LMwUDkw>Tk!y^5JjKpA!0X2s^G3?Rnr%7D-}?gt%`}q6 zhg*;rKj=4nR;ohqHeZjOe*hwS`rU2vA}+Yo*$i27uiE#A%vZxapF3_s=+~d^3oG92 zl{~E4#!v2R7+&@@#>sD!MD1JBTgGNl-7~Wa1Yh3@ANy7feD8Y&%?~GqpfR@OQ~h%} zgY>6+)rn#P#2qfKxz4s0(Rq62b1YJ5=EtB73^ulC1znf|TM7B;KcW+uBd)h$e)Rx4 zW!1w%5Gyw+nR{sisuPDRT&-wfVXi~e2OvQ3C@KHk1C7sJ*fgMeGd=y)598at)Vg}?k-o< z#@LJ7;0x5o^_~i95aTF5>McAkBW0T7waVQw)r`W*a`(tSeNCZized9~u7Z%Lci88O zorwxAf<{y~xUmh+ZY{Qeo_d(wQ#FCdT#GP}Iywi@T%Q4W-$%xT&231)!Lt9P*4)82ly#RgND2UD)|~35b7V`~2jo2P zw{kgcKzOQ@U^wuX;*n}WMM1=wL*w1E=3h{J9xQ8cazU2-SRCVzAEFyx&7OoHBLxSQ zPp=L~J>kYy>7|WVWY}TVomx)7y*Cy~{!McsFiwOd(VaUqf!dBEIWl({+qn+6p1?!J zX6U@XkmLE5&=_ju3$Qykh%#cM^FNPKG7-mqq$JEtr3J&skJXpH|q9*&jZ5iO%-21iB_s#8aY?Fnr70Y@q`8q2$<}JWkV222c$i4I=5S9LA z&Y@%INs0s8&(>V7$vU#~4i@-cLg$n0J?O%dy5wy_sXMrj@HrKtQ|9tHsZD({7go`4 zRY}5E_M1I#^}wwn=M03$-Lev$Lk2I3!Rd#UzaRJ-lI3sAN-+hWCK~}yZT>|gph}47 zfR*ECgL(%Vc^{I@i)ASa|CUF1wJjjK66DVFfp1>dP+ty)uZ%8a_$4E9={wr0!5qBb z%I^Ns9OPzugMv-=FymzAJ%0$9B`5S1Ic9Wqg*dT}3yy-a`?H-_|iu$w;S|$U=$8 zdu&A4EME`j>?;e9GSsTM7v^@TAR|{5bt^Ajv$c@{TB>rlkp%e#yE{2C5(CB^{tYF| z{HXi?ruxeat}2tdNtS+YXE+yKrDu+iPeHyyp@Bjn|G>JpOFxh8!SYaw$Bp{jPxTVZ zjjYW=Iu@n{lpN~%W(e`YFO)|SgYX*``|42%EpP?II`esiWg^uXY0jllNhaX6SFP_C znl82=(w~H>AR{jGiKn2{h;Bp#N^`{osQPLcrEIB}0oRo^*`?@dL4P{;J(@AB;Mcrm*@D(9BqY2QOS*CP0 z3t1yZC5jF0s_VSh75Z9_#E`81Que!&H$5o0KZGWp4vXbG8n(Te=`GcG*tvs+epN_? z%#nR(+Og-d0iUWnq!U50>OK9W``aUYXyNjd6Nm0sna4r8ng^Q!pPrYV3XpHmW+BCQ zcP?+_X19I+NWE66rs2M9Pf4dV)L3Ym( zSPGs;o@WRZu~%I5e)Nfrq2COa`Z=c(bWoMO8pjNheCcDQm+g;S16|9*t4^=HX1rNEBm;icq zCK~z>o^jET>#0jaZ~BDt#8x5 zObY|ft=*U*ETY%BzF;PFeaXd>`ihs(&rDk8I%z&JcodNzF}eDu^rDkmLv`-!ClemN zW~gt7R^ybe{28*WMY_AYLAo0b{+{=| z=lc8yd+m2-?wGkhvtDkz?GnMdQxJ8K!;IK7I{4HE5|opbcT*KH6F8W`oLYq&`8?ZX zY5W6i&li>I6j-z*6uc0g+ljJ<^QKLq#W4|GY%S&>iRn<01?5Y3ad~p|hLV#7!S%D^ zbq1Tni>!qO0U|?XM=SU7O{>B-eS#S?#K7yu*Xs&0F-n?(jyi-n)F4E7c)(YlqL+U%Gbrym%-tzWn9w=j8Y-7+l4Akmhv0y%w zsL9eGPR6@M@S*qf=5z8fu(GEC+_I3*FYoO@_u*hl6H6mw&%@V?5k15E{;5neXLsht zgGfntL3*vns)!$xe#J99$MVULo|e-pO2v=H4|&yo726CM2mcw^8AL0EWXft#CA zMcXlCUQ)uUaNjrAhRrvp1-60N&R4?vhmuSGG@C7eCi(w`3#<0a{!gcA=T-}g&751dv9hTX()`}FU8C$(6> zA<&7No{lx)-aj1v{ZeqB2--caWX1?+z6MA_WYB;Zy77qBTnF)CNfY_DJFyo$sr)m5 z+9O&bYI=CPVS0nBJ2qV(hWB=w)7?-cbFs3(yC2==#Q4~vA4)87KXxMt(e&%c|5!$| zrS+fTzO-T&Am)a+-1n3NOc&kfc*#HKMZMH2#EJMkGgzmHaQhzqv9m=BB7b~67;bO= zdB4}KD-IL>p)^WtuSt!_MAR0(_d`8i4#8XdyPogcEXT_{56DtfxYq)^@S{8ZdCpkB z7aD8_!-!5x%a~fvln|{Rml8~C-A=eUD1@keQRhA{{-#&!A2>@Bzb^V+y_(>R{33t1 zwSBl})m)q4k|Xr;9JSzLIACQ!!4hqiS#_fMHezA85B%OcpFy+7Dkny3fjDIF!2@PK zsrAmT=`7~D>T!*9mA~NzVO0ZTQY5!JQz|dTKgItUt*bR_b&An=J9i2RZndZ#wOtL- zFpn#;Oa|<}eg54yv3>fPwIkse+)>uUQ?w!)Lse2KO#zv`zI8N1)93r{r&?8aQqE*7 z){j3;c2ZO?0kLC^Xw>J`(x_4X?k(@A`toe+8aX12srh5n#V@AO@S6mOhbw&*{Bvw( za;*Jxtc(9};xOzK-Xc5=?(N@=c@#p+2lWwElQU$6(TQ1N>Jl8iq$#ql=$(S7ddch}i2901}gB3{N}u!urncKzD9y3Wo35fTJ3 zZI4Gm%cuajPDhW7d)(K78I#MuCl6dpsVa(Bc0qP=ZS1O1>>yOQq`J}|^y zX>RxHQiYhb_;fj>kZ_;K_|x$1W^naQEAGNljOb_jOM`A(#D9-K7(S6%%;7yh`K)Y1 z{gcLZkQtQ9zC7R}PT>?N1L#y|xRqNZkT&fOdcs3^Yg@q5w1UG>I?t?jHAE2z=Ys~3 z=)@-y^sg8r7t*~kNzoEKSQ$!Id+g7f)yEWl9KXIA@oTg!5n@Y098%+W#73ynW$j`d zn=Bv~E9y>g7Awi5qY}a3#OE`QqMoWULe}SfsBc%x5mCw6w7byXbAj{ zYTTBzr_|Tqc=P5nFJgxwn6T)7z`3YQXze4;vPW@Kmv7!qRj~MeYoqr`y^+h9+r_eJ zqStq!^5{SSeYOX?U)xOyBk}aE;v>kSMq4UYPI;CRC)(%E*78tnuV#2cL@M=Yr~&!x zonQ5M-?}>8)7WReBiV7ww{IP&JZ{Y#ph{|;o%suM(6GMf{Wnpoyu7J>O`<~R<=|!G z+e0g~U!H~U_9)8WL{69p=T64xIqYmmRHSJYj%Xa(9fgE8m))A`4)olHKek-Poiimq z9_H+?V$rH`EDRZVIe@4ZV?kzWw%aaKY`Lwx*JMh9It-$Ay9aSEU0JF7e zv(A|Xvo1AU%~`?TS&gA(ymp8LOz@AwHy`oKCFtqI)_x!Nx6tBGSq4wF6TCzgW0tV) z&S6aTnqRaLFFX|yFD!u6L`#-VIMQuN0VKk$TawL~rTf@|UfL-S#o6g}SVLP{**=Di zJ|zpKC_SSp_{YMrMq*7?#g(3BQ3L$UOL1uo=_Mbn?pn3^2!t6vm*FvbTDWD%k#FD-}_ zz{blpCM9l2CB5sx@TC*s!6e~{8C59-p1}%ZDc-{h=Io3JXi?gxPUtQC*E#8w%|7bd!RN(WTKYy_EPBp|vf)ZIBDsj1(SyuH_A%MjU434n<96)| zcM(6AF)i4&m@8@dvhc?3D7hr zx5!J`WHP$d**2{65Z@i>B9L9C7^<^qf6v!xDxv=Ear0sP^}a*K$t#vx{o9VPl!QU3 z9_b|?d092D)JNBd!R_j>0IT-%UX~tEYqmmq?m!!~`5f}3hJ9&+sRBkNG;GTb4r=kqg_`LoY` z@t#&XHTCI|pZS6wI{eef z{Ah#rt`jtOR{y0JqG+vmVk>&@Z1XY~L@-0^VJtq+toh%Rw_qXGt6omts53h@Q5A*$ z-NR273?xT%DMmP@-pKA+rxYVa;sQ#M@3m&aI2V{um8mIcHC+>>Ed^Dp8#<;oiOxi)a*xE+m`i%>c@> z?_N7uQ!G1{j@5l!myRgkZ5&xD$XMjuwWSVBdEgQxaUn-!rBG8g`ih&`)JLza z+w+smyrpnI)$CD<{XL|R0Tp=^y&_I(HdNqneAIKw%~;qg)=oYCC7#9za@<#vVRklu%J6 zh>rn6T4U+gVc6@@AuycbI@((_W8UE(`K!?@Iun#YU<1cHLF68CRc}cP7Pl*+Jie%P zrEbl`LDi2!2@^BHT6wY=Gyau70;|e)LPLFZcs-4uBi%l0dDR_XG<{7|i}+0zEhj56 zFf6HHb$|}Vq|-t$s<_tMit^T_K~>qpG%k7*+%5?w$Uan?539#5?>`167|;xpV%_e$ zd{I;+AYmR;DmlF#$zi5cZloE&p3V$CD%!FC!oTs%3OLDQE+s0+$Mj!oVVGmO+Jo-uparBM4ij6c#OnIgYI5h?MHH9hPJXRw*uNhW~5;^j$Lj>XNkVx!5@PuaFTz8#G*w@ppp_4JD3BI}r3M)4K z0RI8L0E7te8$9UkSUWly?+#|?0OY#4JKw%W-^>Esf%{txKyEi298Qh>FN$V}BBrKO zDe|Uj6zWqbvFKkF-(LPxfhQM}mnKsn8`C3q-ff*Xr7}fz<&5b`sBOTr&m+5P)pSHw z09>IUA|=#QWATlu>{&MnabEjxyh9D}f86?!!9y{tV`C5(j3VB)D`M%46coCIH`z9W z8T}#hxQW5Li*G=rJ^3UOWA5QJw&9)n*7{W>w^6?$lE@dR^%_eTG|T=-WHu-i7IhKP zeOFL-l{@_i-iXq6!RM*QE1YTO9C~cMv?95PT7B|9aY;+2(V)k0d;X z^mGwj{6v=nwfonUtX`Xv!{n-$XiC{f-5EVv7YxbX7d>Y(s|UN+{f zMmb`+L_dMcmku{q^Yj}PU{rkM?stT_30R5vy2O&jkEE#! z``4d8`;*EmW#$t%e))wZ(J${yn@j&F2g_bF(9_7(LR!syNz0Wd%Z;LmPJXz>en!e-_6Hl+-}MV- z+XQF43nNDAkD|=P6xz3Z!uNV6F%>>3$Ds>;IWE$8_uPIdioAr8eH{kObb!ZDNmLiX zGwXJ*j7y`^YN6lh&PoW1g@*qhW>O4C)BnIF=U;H+{iN3|yB9nu_X$}US(>b^*!dYd@f`cR4C5h1%~;e*pys zs)1Sih5be5skh2_ubq^HOL0kgCcS}e&2*@P>C%*)AT%Tnkcz-a(51!0+Nt{cR z2zPwv>sC2VOP`j#dyU;gLeTpxu9lte&#Q30e-Yq)L!dmnQqrQXLU!RLSo`PuG;uzk z+2WJ9^#psHq0vXG0}QK&R?l7Xe!nvFDIf4;w?ILUbHKrytC&v*JP*O&97JiZ8{Ixk z1cE+5UEhsC4F-8pn7_4tYvNsEzMIpL*{=Z&;@`t#nl@s5#&k-ffL!3{I%deTpp785_%KGgB z^iZ9eMzkz9;0k8AG=IK}RRktJWwoGq)zioChboPqgSGrFP@L{h`4-wpGLWl8oe$>@ zfpKhtlS2Gbs!c&B^=`@It9xuXUden?U#;dA2!GnKpG03VxCuFpX1LULp19xn-i(L+ zr~KjrGG2JKbKjQ#eG`W?is4<&&Ok`6?3uDx6^ux=MvYBKL)PFajx~V$3kVyj)(Uaz zXd(j_--o!yprtr-b|7?HW&2?HCe|uB1>`v4ym=#{6#PW}GPnMEi04PjbkAzm`PcDL zP}en__VAx>jH6XmG`r%5P~1i5gqA(+`t-a9jqYpleykUcVtc8fgo)ON;V+r22z-Y=OI^t&DT6wnrU<3!>{&HRW}a)%l{<4c&x>nirW(tewryw9w@ zp=@!4P_T!ua%|Vkm>$4x%z${tP&o#)S|Gv(R_3?4>UwRMpxN37nVy4&c5!3b?WpVq zxH!5uxKURlim(WM7gX%HcNTTNT{D|o?eg+^cfo9R4M$5;j_j^e?$#u7wP^J0heK{- zf7@M8w1tt*9yV}94Qs+o2ce`FpOUD(3|sAu8%<3zm?pRSo<3Z_5WZC&)y-Z?TB_A` zW5RcgS9U73AOA# zL*1$&>CeYJpBeCq>4BbpU*xUbH6_oWiet0E&4~$rK_q=!XRtw{lg+~rXt{FWtq{e{ z&bXB~E!iYUibU>sP&6zogn2~w3AWZ^Rql;{$#f@GLXTai!u@^`t>w#31E2d*yrmW` zW}o2kyRXN;jc*iGdQuY6?N#pg62L<;Ue&Fv^PS9_hf21^N)8%Bfhi1EU7ro{X7%!% z?z&{30#=!?HJ&5_4|-3PklgPezWl4Z#TWOnRgt_mC)ZMq;$L5TuGRyH87iQCMeBA& zEB@}{b>X!cH#>6j*i5r$zfaFkfRu%8h#CEFWfNeV8=*PYyDq zSz&W!6i~eZ8Owt_Xv>=h&@ejVaJDkN8G3RQr}6VTBB9h7aH=Kud%-XbZI5F|_5=KI z37?b$l!=3s97eCOxJ>>@tW7ez84u0E@lAJF1nyjO&Zs26k~6vT%g&Z0_{-HZMuj_H zKjfT0{%x?RJL64pi;@Myep1A0L2O06vET)dZcX~MBG!ZCS#Qrx=+)bVsrBE0>67c26z&W1(=#kA7lWA%8zoGF1 z{KW`hHU|QGW!y{Km4LHw4cyW4Iq1>FgD4Af8+1Ho#)M?>dT#UYmfz@-FS(M(DOGA@ zalD4VXg7ZRXDw16SiNk0wH4vMG8o$5q7=b&eQ{zW+&Jw|pbbxaM@Tz?)*}T6H>VR` zG}~ngKR`81e#LTlNOB1KVGEvk+diosRN7|OnAXaC8}uxtAj@Y8z3@f*Q2ZQvwS=a8+S7g z)abF4)7TNXFyRb;GIAs*Yj+x5i^yzN6<2I=xh4O(>o^Bq18t&6ZE4#D&B}iT=0ER~GjVm@zh= zjN9z^t-I0VuZruBA>rbK^gb1ZW3wa_$R?=__dgFTZKy z0R#b>=bwO;BddIxt`ZZtC3^Y0vT@yPe&sH|P;N+@yV@R{!S#LXKVw~LXpvY)Ogcsk z6JAM$g6c&U?`;?IZ4b}p-sG>}`Hbz|N`1Bwza1)VhLVkjH=*Wn{VXUvTR4m;@;c3m z>N$HbXK^Ite!p%IX%JD^l%j<=vuv+MRX;?PbliW_k@lGY;c-2;$n#_J3ER#<$8r4+ z5g3({L-~(h1Q*p;@S3dsm=fM^#*Dm!bJp#1iM^=jBb#?*1!+m_lDvu?s5H-z2a%(; zX`MZ%ynZ6i6*AW_ymO6O%dFS8<~9sVpur_5Op#Wh4M9f2C|J zHAj!ed&J{Lw7au}tRV!Q2M(F5anf-W1~D#7rXcR}XkOxrj;=gY5!!I)1>W65LA^{% zZ)=EISCW{8z1q~6!%_0gUdSU9X4u8RHW@zWN?GMeRHe;H=2cB(!tKWs7pfEQ^$wZW z!;?24mSn^ca#U%Bv%}((uNzRxuLRBXL_{Oy*!Z$WH~%BL=+2_2nuDAm`>OBHpU#IeddJUNZen01zeLz`m-2N3#}_ z;3zC51s+0p^Ky%Bx{-okHZZ2S!#g6%0s(qSQJ|192+{d1JSy4vI(OGS@$;WHow3Ip z&@7COCZIiZze~_Lrp#-9D5>E?DG9WaS(f~AU{AQ}U&1rz!O>E3!EL&QvNLSR(UOi2 zYiAW@SwQqFA@ZUzrK~y`!F!DKIi>FbGZPjGNo~U=v@%25AuzdDw(MHvC+e&U3+AOq z@P;7g@k8Z&;77>argeswaDG;Umf;Em!w7>-n-ydGw;yh-k?`NVoU$k2EVJNXs0}JR zcsLdIdpITJ^>QBWXlVr^NDU?-qNB%|eRr4yz=((O3;0+a4IOs#gM*qM=B&1HxQU9! zLd%yy)IBnaw!xkt2Tpi>_4rHWuRC5bYCT+E^&YU5O561FgfQeycOloEbuw>CHQ?l`VrAjQ|4U<5SZXv+Zu1e z10PQ!b)LM^a?&^LBfkc@X}OWBChEOfFCqgwjLLM#UJEch1RWL$P2YcX>n)Hpc5a}t zTL2ixknE9!5;j=|a`I@vFN{m|LahR;Hk>b31 z2+SgF7aFigk?SSQm=71?`swt(Tf>;>rdsvMs6t}yjH*BjFTl<2liNIPg=rqol~s{(e# zy9O+!gr!ji#(GqyoTS6d#SAqu zAKs{A3mWj77>z%BZAAKURih-Wdtd!s7lxyJ=Zbwl(-RU|nRqMmiO_JU@2K}te--br z^J{D7(bSc2MO|`}4c~U$iEGq&59L|oR$)tTYD_K8UepNF5wEX!|Izo?FiHU~>&2DZ z@_u=)@8eC8c~|4m3DNv-n!wKgr^^m=XSMH^kJq6f!R+`Fj}x@96Jw1hzS=6mnF}@b zE?8!DhW^;-dG(XhLS{pc>C-hL9j(5)R(NfvkhMw%j{e1;qqvBI7Wk^#xyAyf4sc+3 z{)q#^i*7F%$J_?1HHWK$BS||orB%B{k1Z&EuJRInt{i(V^NogAN{mXG8q0Z69>i*w zVNu=ET^^G}t!zil)&1@#e`8YntilQi+|Q9k%r6yx|z*zdh+$IN?QtwbVNG03?8 z>95o2VjaU**^}KiKOAm$!!^roQ1J6>GyaXTMPyW8)?UyOb zQEk@igGuLctLvZ`*oqn7GT`rLC)dNb=mwuW@$gJj?oJYwSN}IC6==WqoOpd*aH1kL zhWLE)XDd9x-?V-CZvelDW&x~qH3YK|g4PAEtknzh`V}FFr-MnLB@pjL9X}^hH{yHy z5?Kv16mFi<;gGjflSG^ZZT762-=(#GZ}3j}S9s~RB~{oHGZMIZz*zAlW-r2o@#SbW zFsMo2aQHuLshE+e=SsEn4%@H& zxi*FubQs&6r7S(I0X9le9PemN;EBF*W+=A8umGs>)DK#@?FDuefbQU%cC=?ezFH2YyF4 zI`&qjKTlfDlplTD8M9RW_KEKv+s}8^1!K5@A4kh2In{I^;>R3f7b8_hVV|hDq`|Qu zffb2LdK;y(7SLPZz-k!A%boQgt_LP}+iwKMb;-ZKWoX=0N5Mb3hAnVmLWj@Tp3s}K z$0eAjYH~G*Q~6I9kxw=Lp1cA0ly2_2{mm%rS8a0p{IJ>w*1ekV0mL3w=;vGjI!bS7 zl9#+D$bM}joZh4mdp4``W-z9Xs{CA;t-2Xbf37vy@OeU%^=s>xqk?Lb?|>uBfu0=7 z^CfVn?TjT}__7?%jud3;Am;W8u6}qfoJD?B#rfUdqnkL^OYJ^<*n-Ccfo#kd*s3ry zsfqZRG|mQ%I&dwAzOu3MzJG?!EFPi=#jRD^$hg@%woaLZe@CQYBwTVnmW zm_vh~;6Yt+9E2>qWQe^bs@B|xBlb)6y!0|Sd=igRX;XYvx=yhrQSKZIQD(`B4X3-E>q#*)wZ zlY=`6tQCv@WTubP^#lEYN~wb*P{l=`^R5J{Am9?3eX54bDljkQ@r8E^mnI!ek%qw}wL>K4JXue9#20s+GcF3@>rzqhQ7se3xys=T17BvcdZyHTx4Y z&vMaD9nbsc_4NLr?R9XUM$JpVvR1`*5aB+S)`G3iq;=1PtnFfbk0e{q7{&|6efBXo z^htTbraSM7c+-9ssa>ZX;q~6mHt*u7gzd3o^Z!g#l{$!SM%DyWPE9iJZ}osA=H6^b zKkmbAYXsr~*>8B-`dXQ$&6vbc+g4f3f}y;S)pSH(wrb9sRVcw#Ap!s0q{@uVB>Wrw zzsW~)-hUP_mfFF%bk`+>#ZPYd*UOSQ7fnE>9g8!J!c%Y(zOd%^XL+cX)20VX4x~a* zCi9n)n5A%$jpN6ytJWxGuUZu26OjZ-gW-~~85OuT)}e_wDE!~%c(q&Cf;kV2C}i`A zU29)|`ig=T8hY<3zm~@TPa3C*3sASGO%39D-Uy%SAx9>3 zlM$W61*YJhw=$!CO4D{z-leUnf4i4#+g`qxI2`zQNuO)#wHLN`mMnJ<}5Ocsy7R&o>}uuucsJQJwspO^JYZrA6_fI3er?gc^;!|0e&b0m#p~JAffK zr{7ZzWbR`)(b%U&q5wevZ#JkPMS346?tg1^VK$ogJtgTOerGEkVR~1u&e$bRBC>I? zX3gkdIY7gPIRTIjxlj%;9UvtVstLa*xhU;#L+0dCNg@^|heO{Js!P8&F-**3I$qi3 zRw1^w{I-EL)s+2?5b$l%Y@HdM-{`) zzMsNQqC}Qzz z+Y~k*9k{ai1DLozy6*8^;gS6{O+6D~oKB)(s(=y)Z zOrdDXYg}9VV#Vm0M@hqp$g?RKy~`*T3^&)ILt{a=euihFkVJk>5UZw_)y@#2bCAQ3 ziRaP5Oc`98Rtbc%R0CEj7W}9u;Y(sSGa^ER*J7bSY6Pv|p?ROK+c@Q7uxS;MXMaj& zDp?#!$CflYX0xNycc&~{U_9f%y?Jg}5~HePMaG2bw>1|VAenwb>hY}A{WWMso=*`?#6bcovFc?Mco!{U82zl^I zEE@WjM}LFjMeSI#Dw@zYw4YGjz-3m#p<4cZ;6TpO{>J=$ukHDGT%h#RZyV+8! zw6S;wK-~D{bQVB$cdh*!hA`+c;l4sY(6D<93s$RMP&07oF-;V z>Lb8V5sb%cKbtbk;GR3R5N<13Vj9`S6vg=MX`=2uhR8-dtnkXjdE7jM8Xn!GH%;2U z@0aFb3da^T^j($}Ttu<3)Qcr*7sf@f;Sk&BMNohe zrK7!e=ln=cnLbZYW_5-CC8(p{5Kv7~bANqr=`q4!2+qhbYoZS)-`8#9a_`=)xcy~+ zM`FE$G4C_|^H{0`VnAD8RC0kV$`!K@LhLN<-sLLu{X6e7q$v0uxG9}RQ{7{xeD`FDL! zmN^ZH7aY@#0@`2=ktL^a#74(%(nIa;x7NL@bbx_0n!BHoIj*-DE*08vf~|0#`e@+; zO0XLc%BhmNgPKkfej6zr+s_hG&`spjAm<47rnSuyjQuRCU#ao+KQ1D3Au91u`|SCb z?nz}#&S-C2b7zVBb;YL9F`)Y`B(A<~Ng8iBgF0K9@TiPeltFS}79UZ{@faW8)!qeX zqpRyLZYU9xw8s4&Bq?nvF}$PGdBTXrv#ybfc&#h%$hG;8mpJx>B}1KfEpL62|L@C& zPN-S+Nv_%>6`EzSiDfV~eex?S#e4T$i%~iOOMP<|k91546G@7KD zLa%Ip0T z?P#Ix*FspNlJu-;sZd6@hMQ9Madj9*lNb8t{~FALTo{Dai35iU78H)`ksH!R#X&c- zx6sERHgzug9pb6dk5Eul_#B_Te$y6qyK;}jq6@oVzeJBI?)kh* z)ULzDcP;pfq9Ci~y z9yK%uui5zYChW!>|1r{VHM}bDQpx;b_RsT$x{+`X;cESXhVO?BN*c>UEo;#`ggQg0 z|Jb|8Bdxn$(!R965{F2vtb(t;t%UlLG#*HW=@HIrM*2Pe5uu0O%erSHHmDY^p;c_P z@6Sl&)hl#e{0Cic&03;7*;FXcPCx&@!p@m1xYgX^)MAZTg=P`R&@T(n_BbN=2`FUr zrr}~&Zou~9xu;3MIJFZPqr|${F*VjX>STUEH3YG1B0gI&qzxUtJeDx8Hg}61lw{T?H5C6dTsbXRu01q!x39i<7F0DP>2L6XGrf}y zPtf*CtbUA;-FR5_%C@cOWSt4}Xu z;q)P*#s8Kk5P)848z;upmtI7JH5{)Fe@x3n@xZ3vb1Jq9;n%6fvWR{M6NG=lLo&{l zX(oS7A&ny1e1^+PNAAbC*zgDlll(K)@9K#z968@`Nqpnv^Kr}uKErFSrI z#kvlmTrmc%Cd98_E)$z^UZQ)Cig71KjufXFlrJI#EJlaf`hv-t+f22&DxIR;Po*+{ zmxc)dT%6PUD*SU}B)Ic1<4_F;crWnbQ?d9Nev)y&Y;apGB33C}){4P5;Ktu|LHKju z>2b*tdJhZjg|zH{L0l!~`%uj5D+p3Kgi8$)J53_H$&Vyl%t@bAP zHEaIpk-$mYdUA^(Rb;bG`n2@|JZ>i?g#LLp`jHpr-N{N4<2PaTjhEp{UC(Hf=2~`o z%7(U*i==aJ#jZ25_AdIVrykRrebNz|vNNY@>_U5fCNf>TAOUl}2dS71bJ_9!;zhXO zCi9}eL4wBGsk1EdU#$=0%4+wjm|cz1uWk9XU4_fIZI=-fqN&0A^q?YwbJ;3;o>(-N zi4R->)Q)U^7)>2s7eGFI1Bh5nWUMG%@c9kh)G|)nm_h=$#wOV!oHmd#g&ayFBf1*l z`=vQ$5ML?6|7l6*JmHV>7Jf)Ez2o?Cl~>F_-TxeWNG*u*23jv}>tjJ3$WV{v=S1t& z#}f3Sx{Z-Q!<-ok78{OBtSy`WnF<=T=wD);KhSsy+IiBM2G_nCLM-N&zHq+sIMfvX zfb1q~-!wHOkdF+s_<8|=d*6~{3b?$_hkDUAsCOW_BuYHy4jBR8Db@v1>ag;oUv-PMO zJ+*XqY1IAu)h4;&^&M?@miox@YA8PvJx^R9b^4ute9Aw$Q)^k7*SgQZ+8aDb2ZDiC zKEc)vfJgt0Q3v>6u}GxKJrKb-Ti8c{g8KOzUO3ro+zmq+u21==G!lsM#8kPQNTXx1 z2EcK8$7`KnCJ}(rR15R`CYl&F1Hfr$glv=6ZH<%N7BGw$Y94f_kr^cLf4uukCR4VSA@{t zTW<0ENaA0+k~cZ>^joScO%Aj6K(}lf(zYgTv&snu@q0&H2?D{n(4(;)8uz(Z{UR3G zz#D;YS^r&HW5LMkaYE@f3O{#B=3m{R^~LWrnCqCD_qGdNVWO|uctfZeZo?UKeOT}j zTfKITsdpx0JAX|x$Z*6dpR6Yn%YL_a>M0x}HRY^N^OZiZ8T)!%w-gwD{CMySGix4; z#D??0^8FEhvME~Q=~Qhfs8xiRVw;bPpYU(wmy2N}Vjt0*)q=4>w+;$Q-Vpj77b#G4 zy3HK>(bh8~=20i+-*~RAva|KyJQp_(|C6(lR1h!gj~?8FFEA~RXEn+fy6oZFL!T;9 zjLscn+SuJwNRNe*fbaWRK%6c1rv?Ab`*4)3zJto`poXJDcHnA{5 zu!v20kKrpL<^JbU3982!!Nb$tmB{c`JG?I<3Bn-x$4}12x_Qh-|4sENR#`XScg{LF z(uLT%9q%z5J!|~ifRPKxNMo`GIHcaCEnBQzVSOFAc0~+rJt_G0)&P4>v`V-&x;16C zs$26sc7Pf{q3<19;jc9lf*}T>BP=&clRSf0C#)#-Q zs^8yT@4xYjF^j-#98u8YA>w(E`%#Y!|LG$6j5^4fJD;Xr^OPr?iofe$+NDWmV3u#&#%7;#lrUg~#u22K65R{JLZPim zx!QOA0%B|Fx(GvEjRdUr^ z`Wez?7U!%KxX4=wcHsuor5m{u6oOMt*8^xV&Gm^?eimQGVjPwTz$$E=^02fuQ*nEq z1GG}ZWBecR5FcFOV4tr*KI#kOXig@26B5%pL8$3m`TlK#J|0HJ=Pfb*`vR$LO?CpV z8cqKZHnn{KzU6!du~kg4+xr%N-^rVb88STNF-yj9M1j{ZNLt@}&McJ52+k0bl<6!w z<^6VI7IOFq3+ypf_o^c?9XQqvl<2Be=AP_#P@SRd)ew0gIMB z4rE`)nPpMogaI;AL9Z-q43srx`J`nlw2;Ju&_p_x(bnwG8p) zasO<8#d9(G5!7@$s3Qe>p3+P&2~@~5F+WR%B#xWL$?eGim0a2o z5XF;6nrNAJO}(Zrx1rpQ2O_{JNy@NG6wYv^%eoK2EJ9_<9sjG90WEQJcI!4JRPkzQgj#%$EG4*c~;9rTV_|-+#3VTdS zr=2ym-HV8uw_x*JEx~_7{o;Vw5`%6`OegbHvrLJLdo+>z+OAI6#|>dj>E4 zN;}8%;#VU`0t_%xfM;VUm!iCiVhmd~@cUZgvV;%>1YfX$OGO?DUblY^)z-TbZi=Uu zxWG<>DP^56``e{$5Y_LMOWR38CwciW(f$C;p@L{X#l6H6-?FjdA zeKxO4q3IC?;K5x@^|ZmUjSyD&opTiJR2OL=gZix^v_#U6MInQib^o0}DC@?75wPfW zyw}FCR?>VW=AH48JY3W>-rPQgxVmL+QR&)z;(~?AEpEF9Uj$L-M!pKQ+8_rS_+>Ky zAwLAR93lZ-H}x)F;JAH$ZW&0x)%_N>Reszzqb2HrquTtRMulr>d=lgm_~|j9qrzh( zp$!p&yi`413E)zmx{Sya(>?{&nGSsE(|Xff4)144H|&W7lMTCyE?sw!3a&-BgH)M_5!PN=>BE7{jgI1EZ@mT|=^cv2|{wvcO+rj!_ z%CvH;phYGHC#TH8reI30nLk5dieGAx%`1HLk$tYk>?iuz!cb$p<6`Xsk?d%MXFGWa z(w$HBcGXumL0<(ap~Md~l7c_qncUoVj*|NvAJ*s>KKXbomX`gSNOfMJEX9mDlChQK z)jRyZ>C`Ya#N(A>tcgPa2Nrf%`+vpbg|4n{6}iVuU?zy z=HSDqNAU$>Lazg-7}Ny8t3Ihkc~g5?dg1Mo9$1IHpXLO!hmf@+I+2rlA z6;?xsuc(MBk>a;{0uYq|wz=m}<<6<5AU$Xmv!0(6x&0B@ZeCvHo7>BE zA7C&`q`&37TYnh2p~&7b1-}CrgOw8T2bGE*3kP!DzDBKeP#9WF|Ihn5g=WtOPm^^L zdHrpdAOgFAE-Ne!tpxW8Zt~lo@=IA=e_eEKdTgUI5+MjHylQSHfD;Vg&}Ei1`>95p z%e)NJ2x_lUG<~V6r0`ad8A?3|5Me5UYLo&%ka&O<;*?3ow0CiG*z;mYvUATiiAg1s za`FYCVHCE4+SqoPf-r|WcW89NC8}qnh2e)dFQ>j^zPDZe!*Jh#(q5DfuHUUPmsbe2 zr#$3hNF{Wi{vP4@eHl--Pnp}%+ za1ECxSS)p0tQ87}zY9!scPLfhlcwME4+p2fWr8GAi9l_(VMv}JnDeF*wSt~&^L3q> zFY0Z;iU!Q{3&|`riLQ$;>ygcH%as*mPR_#W(p{3m z&_j3k&<#Tm{c`X9{@&026Q1Ynv-Ub`uZ2T6B%w4{=ii_tjc!4mrPeQd8WH2u18q7k z>x2oKv{mfS$o#WAsmS{V(4h?Ie0^tB1X4-9S6bHBU)VwQ24CWo?&S!-Y|h#HMZw#1 z?~#d1QD4nEd1T-rzq!iEN?pzqj*Iz8-wOfzvk#UYJm)*O2Fxt0d$$ahX$l}N@GZYF zxpB84Dl5=^9BL)|-2Oo64C14b$;l{-1Cc+dl*0692o~9!irKspe;oh1W{G~602Fzp zzGSVWNi~L3)`r<00$pQIKdNe9;>}_={4|!#R|Nj~85srsSGE8Luya2rO9(g_8bpM# z0$Ks&UphZP#h5_P02#S>)Dr>=O60=n0U*n8C3og*?6vc zM2D{NMCq3^CPhsa!A)(w;Z!afK+JtZ0~%1iDwswzbXz4zNj7ES;& zJepVEOyP-g_=>O$ZpJ>)Dd3Ao*YO(y=Opd+u#X-_>H=@=y|S;HAK~;So08nrZdeY6 zpa(cE|L&l%eLGML`7SJ-rENgoPt2`LL7LYS8gv%9bkt8!BR#AGX>1o*@*bTmI;5Wa zx`iUnR*S(cvBBkYV3sYAaE+DnlazZg2dLObxH$7?ub0F*UhpWrf+E8I)#9|G?1Sfa z;89K5TF`$KiHd`BXQOO}nGX?56}jM#f_T~~U`;Ez(m zFX3B-W!yugPtv&eurlMbHD@hlmjFlC(2Vef=q6VbE^bSTBd09_`7AejsYfpQpd6KM_%M4|$M6}Rn*zIlm!2U~>e zY%5|zwvUaikJ^*a#U0L{3=)$|zy9(~8x*>Gjde8B24?&7NObnJ-PF`~h7fQMn*7_x z!pa#8W!XoD@w{&HjHD56 zHP}W?Y%gT4s?zkD#XM(oO)Tv1;2t;+kDyn!eE@$d$QVP_6Mtq&r|(=q(9!?+>Lv6uUyGDbJJljprh#wFBjp(awJ#xx0`TP~%^l zr#O4(ccdFz4oTDOd|etA^0Zf~6f?GkrQ^B=7~CW0CSLsPZlu_e=Rt~PX@H8I#)O5N zrxb<5Yts5>4$kklqqCDc{#v~t%96?jT4pGo?Wpes(E|Mp+HBTBL?n+~kr3!4hn z8H#i*K8?iO=BRn>0{auBip9{1Kl+%mQ?kPx7dF=BhXMv%KF@Uus$bY0y`7mje<=#zjMs@xUK((f~ZC!1qi8nB`F5f zpI~e3IwLaSX5)9<#Rok<9m?@VO{mttbHd+U(kvFtb7SfpA@GI>w#c?J zdV$M!Svd}z_9jBER=FPrvs6&AhmKuh>>73hslXMevjVGC+~_X)w1(!K$Zj>iFb|e$ zCrVtUy+g#|F3D>5F9T=`q9=Dl_giUaStb&Ht3a3X?(D*)#=BEm9$2SMH(0wCaqxrEs^M#cgD2hhW5prO%9Udd?GJlKAB8G`J> zO`Yh@j^xWEgzam%{^cYiEr95 z_eciSr_0iACTT!UikzaD39L^$5^vG2sqgxPb ztdZ_W`G|dwc36$@`J{EH&w_H|KIL&0qYoz^766CGT&47#00PwW=_*pZpG(& zYI;;6UVEC;Z7XVtaI35pPV&B=iA?9z=yD%YW!sSR+8#Eu_+$o}8}=Ev*t@q*BaY!_ zHfw0!OeP7F;+Z}YWHD==6KZF{)IEy(Qfbe-wT>Hc{OTYbYv-+a|J{0!Sb+ls=HNC= zscUXeRdRaaEWWt0Np1M?my-CmFKIZ(*<^G$-FC);*P7#2E9ZiR4AOLprYQG+Xb*kV z9d2S>)}1pcA`@O~mfd->=nr}=6=1bQ8FU8nL?1ObPGnWsdL&hSEy`S?gKJ%#y?JLb zJrqf@_U!|+OJXz0jNJvSm&sTNKA2j=S>NC#rTK5aHyj03`T@SK5m+R*Wlx_}s$a5K z?&Vo8#Jh)0a0L(7T~^vfXg z^(!m->d3DuO)f3MXJPCm4QUG!t>k#z1 z-}&34u=~eye^og~PTw~}3n#&XeZhwD_%Hr46#xxvbhg(i4Id53e*Xa^;KBQ&Q-gbq zOqQw$^1zam_vhi*iV%u)QeUT&A54jXrW$_R=IvDUo!sqy_-ns2W~z|hj}ZC6GFimM z;%TppS(*2>3N-JS991=#>caZcu&|zvGy+8z&12tGK*H|?aif~$+~LSs@XVB&VV%Md)$xrW-GNh5D^_?GP1qzLrvYw;eHmM$Go2H)KOBJq!W78Q27XrgT@eF& zJ(kK5vj#EZE_B#i6I~dcSLE1uB|a1bu0wWz(H(ye#BI4rRiW6Q`hvb0%7RB-uQcPm zdU8;psP}Ea{D!AHm&etM4zjZEWY+KDbE2 zt+ncu3^_(RG$Le|joEjGJo)5@80-Gc2o%DmpxSJ3^0^MTZP!;{sOl`!04}jjk4;NI zeo&<*`e5RtF}ff2br~JXdDX8qi)e15=KcrelQb4BPX`XSn*4$2m&DEV`dfvBnE-|n z!Uq;4mL(CB3yq;;1{H^UN+`Bdcjb`*U7!ul!~79aP=G2EgTIIQGQI#gP=1 z;sZTp{u8c}z3&#;l42W3>{Y3M#pvU!a?p@%GR;GBqSTl?_s@_r1b)S8sWYZ@mwCMN zN2GNJ@oh{M#VWBc3ahltLVnX@DTb%?GV#^LU|#%0qm?bUFm_I3KTD$=VAdKE^qcAw z5Fj9~9~cmDt#vjf($#lsHWj+EkVnitti|p!6TPg-yzUNJnr^xi&^D)&b&OGIXt%eE zWOi7-oC*F?(>-S)!O*A31m8=eaE>A>7D`Ii`(7>$tB#0OC>1uP5Py>@8dt{DB;0{X&cc8QbZJKz%FVLTAw zzUFsBRWrC4hFNW>q4UkH?noVSj6=7i?vfsN-FC=uiKDsNSW=DAgL3y{Qk1^1=}H!o z^H&w!>FCtQ`kOTcPz?d9{F|uY?;Fv@-}HHqFDmU<;$fHb$6GRJak-bW&x_QUJE%{J zT*>;PJgsld59WT@uXn6DFM&D*t)W#cBJXF`uud#(?EIANGoW#h%xRa_*`=`#Sy4u+ z-;b$2nt$cbZ|#L!Wh|DZSM$%x#YtF2OV9KGZNqepP0glA4Eoz zj{80bErl3F<%h(=@P;4y8-ZVmf~;$*Z2lmI%FvrFBGSmO~AH`~R(2wNhZ?}~@;QVop z|K;~Kd4Ir1vZ_;Xs{Uel7b z*DBd#eo>sT_E`J#UXpJk&P^GPga@p-ZtmSYTpYssUmwmeC-vM;@kCh8A~i$n>!<&# zi-IY2bLxq8dGTV~w+8wa%jKDP!uEicShXPOh#PWuV&~Fwuv%rFHOFgUiOrW1w0?KLF;C22GBTJ2xLHkPg_ebcVJ&nilxKH=QqY`8gP% zUQ!jVh1c-DFW<*FcTDbBPP$#dDm#z^Aa-(NWqB&he(?L?e)@qh@uYVq%~J)Vrgky3 z{r9Qh=F6toe`T2v2$%Ay=j&sI25KQBv++CBSAt?_zoU*Lc(G4#zv%%nNfH8>AxJ-X z#z*omX;mGI*X&VzyRjEh3;Qe2_#DNMBxh_T$rg9y3X$>&yS3@;0ND>f+a5D$K`$muM8Kz#JyurM#$W9wId;{t(Vm#re~8s{>xC? zJe4)Y5;<>7R6C;-B&IK2R4(Qy0F(wIn*XZ6@^ov6f@#8Al0>rTvPYQ|8>f2{(*4<`DmILZq8h6%8!${&t_dSP5si%9f73Gxu zpaw&a`qOQ*2D$x5J+~*5k8=Mw@J8V6m||r(-ptYEX&68GF0t#>32`i0W{^#YJ7?*N6I2t$ zei%#U0?n0&9(RTfWf@Igm$Z|M8CoI)#JFj2oLt&@G?4D?+}o!X9ii`wo{w$s&1ocw zVmIqpEg7$^PqlsC_DGzWx5drIl0<~& zav##k8ux0TfB;RpF%6O&o9VbV^jzss^1NIekc~;^oeoSJiihRbb6KR>-%t-QR-~cx z^VRKXo}5A@4Ect|{zq6YoP@t2U)v}TpQ_v<68Ymu$~rJ6){=Amx+hr?!wFhC(nU=!7mHAJ9sd54ire;*&qv`bUil17i#sz&;W{UqV0 zLS_}~hZ#c!0}E!_v2}#g+4``(>aGAS_QDS*?w^>B^SkBOrMEpQ(frM7n!E(t|FH;c3#1zS@^J)8vJ{+_ zvmaJ3*Q>roVMDT{u7SF ztFFT+n3N6q{aO^dbkGc$gsR7^&GEF&+z2{p7yj>4y)39zQQ(tQ1&-b)|I@&I%n7*^ zSK5&};M|GNp91h(6gL|O*4CCjI;sWVpLF{xcd981Pd50bGG1+9F(%z;HmiKo*{)y> zAp9vH2GP@n@5A80%05SQcL9~j4NdHz&&JgqI+*sSvsbJ^RZ$~|MUlO1?6 z^{KV?doASwVyUaw;~_nMCSmBiNwMBRSno!k%Qh#Z%>I;thoVqTRI|h z`I`wUW@S5h>wCzbsAlrPDJ6!h%;~|i#Z@Cz&sXL;DLS8hl5nI63T4ypfUxQwHjSp@ zgULiwSZO@CCfytES9Kk$^S|@|@3Y$Op5{U>pZUv9%m%fFaS<*6C-Xg~qJ_oVXMiF= z70;TNMy-{8%9#|6l$++OQVu~&Ei*s>V$m(h71b@s^NV4zpA=9Gv^>gQoR81Y(NZTx zz{V4xtW#oQ-vxMgn$_nc3DuUv74sueo{R56BTEl&LKgace?$%_Aarn=QcPGZGfhG) zuz$DJ7Gbjm3#)!8A$cVGOA(R$01X z*tJ|yo|+JHugmwMa_?Ur=z}fJRp_G(J0S#czgS`M4_{=$PQQ!%{+4RFo_L%fXEd1p z4pormf+e89{-7~S77N}K@H^W-HDF30ac`j^hzefbpvpw#_G!o2iCB=t7s5Ta!>Gji!)l(nr77 zt%f%g!@HJU7i8ML8Dy7wnQlD?Ypd$xA_MWiaxW-As}b&8m-ib^$w1;wf8`pVu{M>) z^TK}6^(k=NBW?yOk4VUkbNl%}gB6r$@A?oB9TQ z@8!uJubz1YUgoOSRpQM42{oEI`usyUMzP;gjC z{4>@$07US1$;q}oAiTU)&tkcEN{Kwu4M_)oQ!-ii{=Zjyek9%(lA}`E80ClwFGpDN zJt#gG*^i+TDQ6bdz81mnYXbs3u4k%bL|_D<0`X;b<_F9gb(81d(?o|OnNmd|#PY4H zvtv_)mY+IOCO9`B6;5!lZQ*yszAon`NAioUtI>HZyCtC@1==efBli^tW}GJuHiVPv zMw+4nqFVs#)4W+@(opm7i;N^}T4A)C$YO;!2zZF{>P%w?De+2-i^#DJ>Pcs?)1{A? zNV45Pvl2SF3nZLJ0)*Da*CJ!*-9l$XEj_lt@w~0Fq!ErWr0}<#L_~f&@)p91j?0Gz5e6$TVUD6AWjW2{0JvFWgMs{O#lO{9Bn?Z0$<*q9bN7oQ#&}&Z% z1=Cd^E*Z^M!y5ad--ufo z2siE#pH(7{F=yPe$1cZ<@-oJWQK-*Z8O;v|8lZTw4Ew|1mtwV{cj1$Y*=EiN(WA4o zJxM-x)t_ydHJf#QFuISW^0#oHMY%Hj4MqrYd7xRht26RIU1C zrEQE+;g>2A>3AA;MR9ih4UV&SS*IU>B*a@|;`V^jWTH0nbtf}Wg&80(N1T}X?$7DT zUPcAbLTz6F<$C*V(|wtr%|v!nNjxsvqh_KF_7la?aS8RzS~=2Lx&|Py2q7rUt7?#t z)&0X(Px0qY6NZnM*ojRSR*&HLG_2{ERP&c5xoWfh2jzf5!{b9xdx%Ei?TIt(^Pen9 z=-dmykW>60S2rwz)UueVxf% zvJNo>J|-nLIEV9?kk<99BNE8BkCb5YT7SVa++yy@U2Nkb0G42VBpfsE{&QA?@H0tL zur7!Dj~~O=;i;{MAnv?sae^kBoVSVqF)d$PZ0y=W><7TPmf()$QX-7gf!@Y-=+n>5>M&TJK$lwUFWYdY(y6dzz|}mS+I9I{N}xV6KNeM#^VjB z0mccmY0E1NnjXU@b#!+#;;e*W*o)ko6!re1i`7ci2})zP;_v8RE3ZTXWzgFz?7xrN zVDZldU8FksnX?_d1L13pX_mg|42wyHQhC2Vra*`0Bx7(%zfhCy6H*$+gLPK2HCeE$ ze@ZSrknsmd-O%_OZVxB5aaB0qn4B7nV~+&uu} z>-81p^@`IeZdtiADNQ5m@*G%~C!yjy_%nYR1N<+0#IxbgmYCU|R=sUuRPhAnZAa>Q=ptk?Lvnp{|EfKF; z%Y)Jxp)0KBduLXfS?S3|p`Xj=zxjJ}JNCR>3C$-#G@_`0LsPEKwIU_qC^m)wznIac zHMf1-it_(>ytF`4b13wAZ1peTFfH*a(`V{kjsfDJH10f~OenLKM*bk~JQ|yM&)H-` z-h>V88^-TE%jq<0F9d8Q{IKLu?p3pv`&Y-%M0ZqK{6bd0NQY8BLMs`1v);55rPuO} zmN_UWxeFK1k8>C0PJXBUYp1nNyGy&}yBSv%^;!4ct2ck!p4(QP_PYOqu$TiKVEn<2 zL@;`ULJ;LUt}YTu^|pHYMlA0;9DK0Fo_EeDF#nBY%6rL+&vUrjh!VG&@@57(OwUbk zZAS+>x1yoHE<@h~zo>QgKyxhKD#HsJ(T;eiXz0y}>Y49)D@=2Ww2tJJ!W|}DA)tW0 zH+|rUA>_waqFqk#3NEk9SDM0e?IwQ4+eOK?m{`9}$!9EP5w@k1loSQEo;bgH z1@&{6BXjGM#ROj-|1X=P~e_(CV6tOVs|#J#F$vwxIDnoay}8hMPk(+INA9Re}EN_O7yiB|qB>b^`c zub!F{?_EKi|MN6I!eu7X=37Ou?sQ460IL1HMO)C!n}Fh_CQ?%QCI1ikP1oYTb#+JI z{h{(dp1qg2>ZlTK69->t#{>5W|0$s$LMVp7CRkBjIbqmgQ#3b3Jqy>L zzML~s2-BB+POFp^vn|=#XH{JJc~%MlvD8OzN@ymh+j3Os`j7IS4E9$VFRtR5QO`LxOhW88fEZGRBZ;lKYnMs%UASHG+D>0 z7ljWfN9LF?sFR%>wAXytN#X|ZEN3O}m}>l^+=iG(=(!8>nWpTx88E&#bko16S<5E* z(I%$e_6DhNRXh}YeF`{K3MW2TPsigtd8nVSuzg1J+cO~R8QPCVMSD7sb$^Z8u6S-G zGc`-nj>~Z`$&HF?JeFR1R7HgN;5TPd0}9SmE<_Z24hhgWONf6}aFMdm%_KNTh8gTZs)zqeQSeZM|5^u z9hJ_c+hzxe8N$E@d>WktPH|s-@o%KE;+R&rvgTivTT~@yUFqhAO!6+(q=?nsp&$C+ z#_fvbXSpd*>{^jtZ+K;r<;8n%CG#AXV)svuMxPO1ueUIF1moUu>FW=;^tn}*SQo|% zU^h?%!4F1-F&2yu>`wS;6teDyY0c)Er;kE}ChMN7&BTgg47_(NVp6l54k)^>=7yin z@WJDf1JL^DSl1s#7oHo9Ac^udL`XivD3#}aD$p%X`%+=~tsO&2=I)n6KcOsCors&< zCwoV)Sx3k$^QNHUzGlF@xkIV^;-@lJt@XW*v251Z*askdtIyF7hKp0SO!6@JYht$z z@t?A)Ks3NtA656@g{v77!(9eEv<>D)A}$FIi|C(G>n+GRzg}3_8gz@s9#SF;Av-_1 z9j%yqM(w<*9E+B7rM$|hEqnwmR@kjVX=n zjC`uT4fAvZ|Te) zm^i8r>=r}Q3(7s@g6y`X?tCj^mDJ@Z0i*I6u|TkNR;;~GT9Iy`1O@V6WtHn1!K%Q; ztxKdh%u|%-ExF^7H?ZKf$#}lpijQZgU!6bRb|`;X{W?7=mn?AAbt;H*D-JW|Tx!?+ zt9^`JpWH9|q)8r-+rUclptZls`Mk_{hgx4$BCgTO7N@~fN$|94;%pc6fOHScECwC4 zaZY4o_oz?~$B4}c|D|IRENg@HkA??{yY0pdXnRbtjsIKKMkpMZGi?|t9t6yHh%^Uw zQU1Fg?)n?7e{2!nBFOa$O4c2NL0=Kl0UabAwPAexV~jviJFK^6;U59CWYOk-QO5&u zn3Fn`qu2tAL0!ItLn*ZmP9>2NOY$f*lfp~2k*R2)1NfW)`K>&r>Z?$zt2htctj?X3$?p-5dwQ2HJCIB#E^7_dm3}{51?<*_50P%lO$A&SSg&@wTn;?`wnl!{1ie)WRNL4BQRf zntoVek#Yz0A-C7%A$pH)Ij;Tf`AvC6H0HuBOA*95!@Yg$YjAn&a+!!fdfg)dcq*(s zw>|@WBc7=I@f!Jp%wriDeqV`Oq(XSgjrDxWx9L9b0cf0=&vEu$TF!~|W=;PbxNgj# zv;sDr@x28hzgnIw`V)^uQHRv@cnItm->rzV0;wkFi~7EQB5iBxre-j=-KEcuYJ+WZ z8XtMBQ#0K5uXN5StaF)gH6}iprOlpO*0WuC1U*0Ifb0Svkd|I#DuL^0VN8e1i$;zO zX)RznbC+bKfsYrP=PQb)6Z|E`*UYdn(;gR?CbcyP73};+VlC;av${&?4*NZ zx)O#q=3G37X?6}<3G!KbynW~sh1M8d+{kqNO~~f>l1PN_1=hln1&i7DpO%vXX;%4FI7)7 zW03%c{w2b(%R7GAGqtnU35%>lsZJ2Jn5m0zFP+n6N}k!{CHD{(c{V9%b-KLc9T z>y;#DORmE(BWp`-+k}UN$)er8I$$okAi`Q86@FfiPJ1eHOF|B7p4ShBk|s2V7F0atA*+5IQ%B< zwU?ez!U*z;kcagPF6V>IS;`IPTyL( zFeEt7UnApe4&NqJadVM?Zj9=QpjmZOTe-F>>VMylICXiue(``MBBN51ZD}isR2T<( zU@5}!YQ>?Hwxt(wyPY_tN{=%uJndEFYC_fe0UwM0|KF$=AJpm(}cg58}ZZE>(B?7v%Fg7`Nj6wf;4H_i^K8N zyqeIjx!x=oVVZRBheIwQ0T^XDTyBsO&6w|a!>v-lD#WAW0%k|-vVy(p6K@P}hNSYMfJ`kugJaILuGoU_qn2gB7DM{I5 zU`qxM7~u7UIaIy>o}=a9z$YLl3vN}sXBS>{vu>ipNwA*9z&dZJ`NJ+#>Aa`I=1^)F zHu6m-?W<$GVx((UgFCbTwXUGAZuVyJ&L)cbyNgk?qw&bKZ!ap^mq+k04CvK(hlBN@r_9>a>b&3umlcw?{v;R9?i}oUCd3~fOk;zar_tY z$7_9XlEmnd<);N)NChVisP)_oGWu8($nM0@imYkE>UI7`t26m@Asi760_i-B9G2V! z)0DuxD(B;{!xVn8gLVBIiTY{o&Ej_bH5_6;G<%KvYVDktf+}j5*b>891~^wxBBk1b zpW<4o)bH7L6!z5Oo=YpWeV6ds;)z_3Ek3m#Ki>X&am)G~XcgtTPIfO&_fVEpu-hy5 z54xBV=Wg2OjXJCOb-vr!+3wXv>O6mYzxetVL7=%LGalqF=YV_ssR@sxx_=<_NFoZ> z^mwr=_`nSyfi)s^D8&lc=zuAmKFf$FE0uH@Gvn$hWG^Vsk{+T&;t-uu&Wky7treHJ z>_nWwu5}cgaLWZj+JlZB)g(r6Cupy4M|Q^VGIwS4KPANe8|4pXu=8XS*pT_nu=S#h z>&%lQjHLe=eI{>eKm+96*kcH2(1(11c#ocShDcPx54z`7<{!$lIMv7gzK$O~`FGNI znKe$(VP2nrV`H~|mvjwO=eB;!^3^|p9grVho<7|3agwC0Ao?`&<(^y!C@I(*QA|46 z2*IHMDb)12max5l3p1-9=*8wr@e-3Q(7d7DCBS%H!tF=~z%pq@>>^4|xmFSr^c~)) z9(|>I!Rx8xI;rQP%_=Ms2D4j&5KA5GK~hvrP4g^;%1=IHgFdtV#Kh?v4`yM0N?C`r zQDH%BKPbkdz8+6wqO^^dro&;rs4{cKpw>Moxp5wPQ0tbavKpgfWOFs;628WbuunwV z{oV_Nz$I6Ey0}~I9jNwtn^}I2(_#ZZvJ6pCM_$AbP~cO)1fn}@Cd&`=$5N7wBCMdp z)AW58(e9M&Z8N;S;8?7LIT)h-0vMBt$_A4y6+!yXmre9o%%rIX`Z(quBHG)opeoNU z^2-vi{+KoIF}9~bI&5|}9DmP7CEyx#;@68C*gJbmN||d-yP(FM435&PnvsFc;vlox zG>t1p$Pr=qMfpzl=B$8gYBNh7bZm6W3uPCe0Dju>8k@iCuRm64&~1EvI`tj6EC1)u zJ<^6A>mfoHS-&}kO^zsR5glIaSJ`y9)%%R-Jmj>)mNo>#0zMpX5|w48B&-3b@SLP> zuu}c}|Df-Y1bi1W5Ztgh61fjuOdRNUi@|4lhS&8q3R{HtCznhd}agJ`}h~HG7^K`g`jp#n>s*Pr0CIW&736HOI*<(;Ed_OHxJ8NcEKT6VQ&!*yGL$DM+aug>V09md5JI*71mQ zx4cjg#5oQ1K@(`zsX}>bxMpjGU0B8kTywdLPu#T*tx1cD2^inYB zc{|>6m4W{7U;&l$bI}~#$k&_@H2DNO*mNxQ0U2)N@x#6gNDKDHNI7r)sHWNj`Gj7Q z8BTJTvNkk27(2v++CB{^JWsHLs==b#&F;hT+ck`@Q}l?vVC+mP6hG8PNQqi{n>F=l+9)dCUeb~6 zl`Y6pN!3g-^-%`6I+HhBY|$;jkIm&U)Nq(^oq1#iDQD4tO0g>qoh80UBV_wOEr2Sw zvoW(Tmota7QFNI3^x_zXsB}rnwiy+1H0`zA+%KOksA~rDcWt{I;T|&e9KyB0RP@FV5E#bHQ#Okg5>ON+Kx&Q)=-eR@wLkBcT$6nu8f8##34a z_TqktQ?9c603#Z6N}N1F=;{bcv}?CAS1hhkD;wD_A=Y(Rj#VP*i?sC1 z-kU64E6@WQ&wJJceDdu{zwJp+mXl)XP(;|`G4Z8G*TcU1ge=0apjh4$kg-_npTz#F z1m`FLDczIvzHij--Rga%3U-m+Q5O>929)#~+qdZ+$Jmti>fWtDv(-nXTD;z%RH;U#il`aMwjEHSxh^u4%m->-^`KC~ayZhMe3jux0ua9p?3qa{aA zq5Hg^autz=e^GO)D}_4tQgeyQ+OWQt$nQq>xdJb$yy@4*l`K3XeyeZ$Bocso;*78B zx9XHF3<2;yYTjP>ynb+iN11~hr=uYG{NUZz zbTHfSoBDW5gG(rZDRF=Fgzo;&S(3T!by6YQskr}Es;9>}V~xFKwPMe>u|>?a*g z=D^0RG~$|nSUV(@4YEs$w#-vs*9_qPzjtX959`-^^r5CVA`2?1%VG>9=T~XoRi3-k zO;io&ZJ*>l4)stywnPa(v#%OJPCDQSX9$6!lujs>@qcS5E4uBD`pDgo+V+=458h?n z4tKfjyLwknkVqIFbJV9#7h06*cg#U!oCQ@Z;CkFKoT|M+N^; zu#K?R?vmO>Tql9u7}CAZVqGy(pz}rmdb?s$ktjI6p1wC2aK*BuT&4|L>NpiV5PQyE9@eIUxSsf!f889E86v#NpX^-Q zb~_;Zj}j^}3aq)Yb4PIUTf=(d()AFD(?$Aogu%Byf|?burj6f@+euIb>OvsPOHMGs z$k9frcr&>8boQNhptsJ++{Ws;ADuKbi1=aoRNFT!)m@pRVvm9D2D!BCRXQnL0sA^I zz&^qCgv%1UsYg#veD3JAUAI7o@!W*)yjuTdBJTJ&s6bNdblNT9Z6gq8i$JL^O+A)C zw}R4imZ2TS${bef`!TYM8XlFVpx$zu6F%sOjqJfbP&Y<4k#4og<9;_h^EsQvY@)J zI7EGi=c}k-#bKbneOZ;T^!lZW|IsWO^;tE7$6*6)-v2sqJCntha2iu4fRr$M%!H75*ir?7H~H=2brMb2NM?Hj1GQ7Pa!$^TpW&;dj%ct3oSHwi9U|ztQ^7 zY{9&TGHN3@j#4;3D(V_-$W5tQw)Ev|ymQMJr1R)q*Qy@1<_&6>`}T!C^^|1YZFYhc z_C9q=Zv&}EFaILsB7O5B%8ryn8<@0mH`M(t$|&%^lG1{9-1Gkh1sbBidU3&>FUhO{ zFaTH)GuWr*+vY(UsP?2tzX8KJRj8pU6+1ee{PyeTs`isA&57R-;xT{!Cd#o4%z(uZ zp7AgRgX|H9<9LV@@Q<8}5la^uZ?|Z|Tdg*s7MRGj9-9b{{X>WDzNP~b{2wF+!2GmK z%%-{V>{S5*u^nm5bF{*9sb(Q~z5qp}bk|tAvCveG6$KR_MY6DPvy=NL(d;c*P9tHF zUaG$f&S@26V!NT4a5#DZ=^#{O6&l~}r$CKz828J(2{g|AlatyB(p|N&@qR`&^={&? z#irQ%cV@WySG>QXDZ!gMdVO+ixJUZ!kyw0!ejMYsxODbBNv@&%aevKhvfL|w!u$1v zF=(=$l3Txo9yAjJU(y{>9#)AZ`VMYsj`j3Bn|?wsbiA=Bc?%ZwOMpTJBI#Jzw#ju? zL>7hVt<85bBa@}G%yo7#KfO}@4n52x4QEAr_Z584-A^|B_7+qYyvN5XG%gJ@0iQ(v zquC6c385{CMD=_8C$eY}z^dC-(44Z9BhwHhd`wxdQstq{qJ?%>V0;<-PG5UkBAjf_ zu=z9B3In8iFVF&rfK%ju3bLa-(%ztr`)r5J+fc36vLPu zXpOR7pTAYf0c{nTR^nP8h#x^Q{aCoD@euHC0f%K*x{B?yFxh~F+oEQk@y9JM9RsLD zl+aFzue$qm>b$$|fJRR~YaM2-qfy^kQz zm9pmji3^T8b82I279jquqf?Ii57nwrh*K8lXQOmfjckqA%0s7M#Iw1YcQ*I4iw+l=oULB_qZxUrHrl13fx-JcLu8Q>V7=#+Djvs#fp zJ1M=MwH_s(!Bmx@l=ykb?LUI_k>e~B1Bx=d?>QT4T_UB3o5c#-8%L1Q|BguZ@s-aQ zf42mfJ%Rl)oTsJEGkPPV+@5d_1=P_Sdc6Obrtt5BBCx+T(e<$KZg2x zu|+yQkLeGIL!QxjF7yR??@ENjPcBc=YtH(l{&-s-Rn91fL>LOGdBO12*z~h*?S%q1 zAII#dN;^sHSTwM(3jKv};ig`+LjM5aiwys=m-zu5Re^I3zlQhY@!8MpON;lTGfP%m zao*+RZGQ&5Mp(>^l93V$>g$J)OI7UuIQBQkA-SGOdyOWi(AF8n&iQ_7#`AW?9JzYF z@}QVU@y&i&b?+W~zO+pZ3XRsaG>|1FU2z{4d+jeA5x+?wMry9*H@&+({4p=~RcGl_ znLH&Q6_o#>kb{Ngb1j)A(M7cl|LXI?96z_%QDXp=R{p=exbn|Gl<|9mvb)9##cY-v zK8dw+)XjQ#1T(g5`(JR&dQA_2f5x}xf=bcHl*M|oYyu?*@NHc@x@Y43<8bViEA}dH zm&6o%W}}!2-sQI5sdjOND`jHKSMlc64c)Q4X1k$toSY|tf1pI@?nT)0c`9h|i|oo< z*iGD4W6vQvBa?iOnrIOX-z+%Poxy;Z81A>QWnA3=me7uGpW;d54nUr=kzyN1fMSVr zk;ly%Gvnwfm^qnO_)fsb7?zy~8u_4s+9&bS{VBOT?*c&f1M=3koq65SvR9doU!aUKP;<}f+)*Hy#VYeX`N zi9TgXmd6mxRqp=gZ=Uhzqw713t{6}T1VE~s-nBZY(PWS|$2!x7-H(KC8~4ixl@|jF z`4tm4(w|`S4N>w1GIjwdnMng==gScY)6{-k$*d2?jl;@R^sSHI=t^3w z_Fl)i=_Rzj#3NIx(GbJze!z&orsBn`_?b9o%YyWJbedHnJi@mU3k6OT8y92?xO0co%l-_XL^}*#UNt;zAGr8)V-Wmyf?Yp} z18<{@yvq={yJV>XT{8UN=zUaKE$({dH^&dzQ81@IsN1;}9j(m!5gii+DR17POOo?_ z2G=sq&nw@hY^eKP9ZOXA*PBu_bMKnNIcrTESz*K4=Vhx_@6 ziluheQ91Yj5%raEQLXLQLrY6{C;|$?5YnkgH%K=KNOv=YC?MUP(#?Q$OAOuJ-7%yC z4Dil*Jm>%Z_V@ka-q*fjU2CmdsZV&=GonT#p8EA(>eF%F{H8QLTSL+V%Uta50HCl7T~GzWGG(yE_aH?5nBAUF!11 zp*`t>`wDBZn$pOtNAP0Rfi5I(wpvFzkq@;^l{#mGZjVl7KjNAt$E@G2=SZr&ud*t- z*iJN@r!=#lEi0ru|?Fh!_Aq{9o1~4wskXRc7aG_)_?rAMb=xZK@^Y(Epgy0f3^V;l!KpS zD}jfBZ|K->sMzVmv*w5S-1;lZtk@pZ+rG5R;TV4Q&_!zXB%rNUc9&DAa|!#fq)tWX zwQKZnjQ3qS)1|!_EJXesc5Z!D7SIJa{0B}xQL0;}8O8{6dvsPP3}N0G0q56U(VXN* zM;9QU(Ryy^>-=yP^$jQP@M7GVN%XADfZ0FHOdX{CZIRoM!&x|P{0!WY){Jq6jj3}o zGKlFV8BiE7-^u~LFlE}gUU+K<@Xx1`2#HUeL$pvrlG0G{*UP^0p!b&6!|u{F3VTsH zqr3Pd%h!{gzg9hIXf%mpg=w2V&3F$V} zPQsbRuUwifg`u0>?c^FW4yQzHWwXGl_Q%HZ#A^4KByP@yo)L^=%aKC^JbdQ1hEpR+pH+Q@N zUjzmVR%yS;c-?UnPIE^s=K5jme0_*kAku}HBNe>>&jvDlxlfeuW}wnXmg$O{F$EEb z=Tu$S?-vk_7w&t%o0kh3kS+@W?S8l0JzM9<}3CvLB` zxUN<}c}9K%?=z1Qa(gfSSYoQQ?eEG%KEDg{=Ou%dX7FL(5txhq5>MLjl-8C1Wvit< zXnWB!GKPx4e;6)AdmZw(-(zh--m7cPR=JP-649Y(7sjrD*<<8G#?gMIb8Tk*R2y7n z+5Qrgdevz7CxPU8PIar<=F;MmV#u68Sq?s)K_FxxjyK=ORmm~(L4k12Vy02*$fjNw z_2D!vyy+FFl8COc_i{XXv)p@VZ^_)}B?7ZxzEJt2TenvlIguTDOGvZS#<^hy4Xtoj z0)LtIBmigipph$2+`sai3x$?!I^p_9AlhWjMBI&?hGtyZq9Sl02`ulu(ir9NT&kbS z;IE{tX(e8#ax%4cj#}(SM#I+*s#NX97eD>mHH1&V7dvSFT6Txu=@wXkun;8!fr!8^ zkN%A|>uDDPq&w%O=b|bZyyWn{_og9tonp|5qDvCk)a?Oj2dFmTs_SS+?M|s~!^OVj zgz)>&MY6ZN^Wo-yopLWpBL^|!q}Ju?Q6*ETh*g0X6$x9E^9aa4<5%ZaO*(;rtohLz z5h+ab1#OTIVcv@XY`WfB3SrbjG#O&T&7}hGKg1o!zDPpFI*5{S`fTdJO zSD{aDI`IW=y2Zc!O0RFbn}4p9vz`eiTf>&~>o5S9MN>i+WiO95`=+3Mmn9L))0&zG z$ZL}A_3kLnqJ#=lFbgF~J7q_=dSENIX&zr7hE+hGF6;KtE}X`g?E?WMrA|-U<#Q9d zcbP0+LDdyDK8TS#C}|b(N(@2%);#CMB$uc_>gH-(dj<3 z2%2xW3El@p(xT|oHa@OoP|zY;2C?ekG+3SRtsBK;Q%@^&a7*}Y#$vC_opNQ{EKj1j z<+o|J*i^J4%4Dz1pZjiPQFJc2Py?!Ks4l~$xy_1ZOsme5mjBa1+Asmx?fv)1rnoCv zM4IkQL?r2OWSm<~9`P5HTWuwEa_+KRi^MC!jM{z4XIk(my`SjE~LRkMGU~KM@iY(Jp<`hiT^Qc`n*y{^6`O<|Ss zQ#w;&HUDiRFbJKioiq6enHXvhu1lTcVdm9^5*{YYq<7Z>+$fF^#)eR zhSAQ7Z;G2o`T!OV(z-7!_I|2E*=HC%f_QtRlyb;$`< zkIkRuBac($%JmwCDFZQ!j{BXEil6XC9kh=POXyw z1fWQrcOnh#w&w^V!TH%lrET-E9^_}=CM~1vY-GIez!n)6FlpZ8nvN|f3lUO;-XoO;0G5xGyOn(9?26h+F%!hKdT z7u@?w!bF^m%&*#Pq5$drX6v=IM-kzIX7`v>o`rqUd;Jp{$&fGG4FPLI4oDsAQ+naU zg*|T!-$G_Mhvy@=}e>z6_vy*PSUoUA2c0M zrT?U@dGWL{XW#auj&Cd4tXGx(@LPYj>CfLvd5K6aVwveQR_XzUKK|OPjqwx#gDh9X zZ@?y7Lt3has(YA3-ZX%$*TV$!V`nxqHaN<180 zq`}YPi@(0h4w%7cnc#wo**6YF$bSK;RW(0@{Y|a`&z)osrHc#soy1*7FwV&BS6B&y zuQmt+`q6|pFmvsK_eFA6w}qxLOiRu;T^JhaoH%{`@)xjeF&9Qv*;+>nPlaUlv zLwpRGU!99w25)_^IS|GrB&x`{yV-^ry>qQfz=Y$+`}X zZ}EbB&s%{UU^uGVTQkF1Gf_ON=OQ^eUp+=86|UI;k*&wmiH8{uKu4SOrC!q@Wm@Xw zAJ0IW<5W1G35i|Kj7iHXyO{O|Qnv`0`zRn>Hu<$&UCiGMcU8^G@Sv^gNt`@IB=M$& zO)mDE+{(|VOJ9`LS*)rJXZq~#+8dbG!QXK!#~1&Izi^5L9a`c+1u$S{NC)>RIYHFz z5`90NGvI05ftdr;BuaoI0Ii5 zzyI3g}kIuKJyL?d? z?#zAK{a@89MAqk)(7Oq(uZHL zhSC$9oe{Ww7rp|YH*>Bb9Qek}aQXo9 z(o@@q*7p?;&$&q5l!wn|Ze5igs!A(G^#ZYz`#XvF`W4p3(nA7mEl@G^e0<26Lz+Z{88^j0foPIh3P zJ_9bx`O*gAe+)M)58#_Ux_%BBr5@jMzPCx4N4a`~cNax6h;+jk(**1=uK>5`Dlzat zhF&2&4AGIgwKOtzRH7vBXEd6pr9XLS-SelIweM`(tbq@wyGS+ru#61JW`|?V^In7d ztb^Wy@{PcsdxBnjUlDGXKfbazRRI#w7iT1G;Xsh&Xd`U01kn$O+M}^Wm|hIkHE>dp z75ub(sP4e7^mfBP=q6YmhGab?RA7K;zdPL;^1xB%SdN4K{XR%q>%YGWQhTWfh&HS; zJ@J)*zP!)S%*QX%6DzfODVBTVRI&bii#d88y35%ru@$OoS)q$W!(6E@>hSRiwAp6! z&0j}nkZe5JrntSZ^z(kl2fIw0(&T*qw#CJqDqDrHj=U}!YxNep@Xc9LA-{#&mgI=| z{lqbkfwMnKFs2)-O`rX5gS*uO>L(doKiSHbDqWczu-O*44gt^_ECZ>g_Efh+5^e3k zj+lhmNz3|p9!U36M-~Yng)jfjrsNeo!BHL7Dq9Kt?LSQhmjG%tF_Oax1vX~aeM8qJ zI@_#=9@XOTU;Ct^WCo?YZ{5QSjk?;dgmy;Jle5bVR>_FF--wTeH0qhFDR1mOtlfjMxW0bY`5$5no*|9^eRTQ};6z+2f94uPjV=t&d)fQ zA+wAY^Dj|C<(uyG$%KQ3+*PH}YJVrKF)2N5;B%;)hB*x6+cxg&8mM1+^O%X)9fwk7 zg?>Zfi9ODgzl+cvMoI-7ZBzSo8~iW{0K;DUCE&MneS>T=#%Pf4jq_kQPc+LZay0FGF-8R5h%OJFO`_hiVwv^SQ6H##}xvHtVs|Zi9)d^Xy?xhU6t0 z25`yNZLcueQm@KhVYjepzXc7^W^C;aG-^#A+REHP;FR}kwJcERO6ndDN91L*D*4^p zp9IP!SAV?e+T89${ZT#R-wy&%|)=ts-x1qc#L9j3wviTj`D%{L>77- z*5&ZXCCaHLy2i36yw?{x@9+r^Fku;%z|FJz4=5}|=*?GsCk<4ij;*+ZurU;7x=oUV zIs`M*6yA%Kk&K6<0yqEQTs)O``DPyYpbuu3lg*zXIph@%Mw4}(>BdYyxlTHKz&5R7 z)7|*q(Y_8@oQrb$gfc3`Bl?kg?hL&O8{LRpr`sa}Drob7C2VJWVT5tXmg(UOc-XVf z2oKM?#T@#N3lNHL48LB9?rrjRigoVi^=^2?y7fr>FBKOD7(RK?@r!B2NQ;>sy{Pgs zM^e3EoG4PrQ9^k&j4Q>IgN<^G24xKR7{tQMB8p7RN^drS(OL>9yTT683E=27wLyZt z3YGFjia?j{1=eq)%2GX7M8&A3_#Q!B&d2Uw6OS~S6TS7`5&u900w zUNZ9QY%zS^B%hS0n~wpyh)-SRg1dCRTY5F=>9F=^;5^AjXU$S$FA+r9WQ$iS)>*0C zqMc4msb1T{b9Q`#1YU_7AG!d#=VRbENJEV!1-IL11$b?jYCth+m$Dez8hs4T_4h8K zr>1>>EFeSJR0+0FaVb=gD(DR+mm`WhsyHd{|AP>(fU{&O)~6G!M0fAmUBjN4G7*^85%hFC)p3DhDtACm)F|7 z$+!;5*}^{|r$!w#k^KmL0tuk!GZ{3-&j=!7f6YalIjX<+es%MfT{54B^vXO>>GY;8 z|2$V#0KAo~C?CyXHcSbDFC-~LEzSX;x`91@zL0sy@c zp7d=L&#VGA7l%@va*S z6A#7gj%3a4w;|0?R{H8gh|Bg8hWthq9;@u$Z5lM!dg0PaS+HsbJlN6R()e@4>i|&$ z{;FphKOoSvtdWYG1~=Ay)Eb=eQ=2ZNUx1zyvDf2a(K(w)`J@4S;a_WHxU4v!jmTl> zs<)JkB7kyKB3!5}*|;=4*+v-iu3CfP525;6lEklMB&>=I_DIwsV;IEp&fmA@=VMvl zMxu?9I5roj09D32f^2<=r=*TTb-%gGGJ%?;Uq1Y*vw}VAK&`6F2fWmp=!nPR-r)@G;s;So5FvXi?#c7jV8-00>t5X%#y03S3{z#CMT4HG$|aN;~YUHBFK zAHlm2@rhEMb9^q1{fbLA;b}NVg*WXy)Nql5$I8lN0D6@~YnS7Sn~Z;@u+(Z}ur;V% z3a#Db!yo_b_3YQ_N6FTJsR3Gd~E6jU0G24b4P-~r=s^ofx z^#Mp=0t|q+>DU#=vn;q&w#)7PKH=D0)_3f-YqAOfCK6!J^C_!{AnMEZlIX9Yh zC>>PPh@8A7l)rTFoMgR;ky}^ZCk;-FGe86fnUryG_3gH}`L0GNxMxI@Q2=uvTRP;i zrhEVP#Fll)W@ihlXz)_1Z)>(>0pARb<7lZShn=;NX3?MRuN{$eY7943T(+NJLBD3c zef4&kYc4NTdbi*Y`{3s1q!5zp=i>N&j^FH&+5nJkra&5JLVm1Jomryw)b0UN9~3XH z$>&?mKI&Y)i&YvG&u?W(^iaYM=e;nyY8h_1UuOuzLqweSs+vvAVx{nrnYi)wjz}DE zYE5~?nGfwc(nevPz0v{o`>ExhE~-VWHz1PXOByS1__R)2Fwt%TCc0>rD0I(0zEZ54 ztd}zDkX9v8GRq-*ps8yi4zDlcl}he`lhy$v-Q(}@i*XO6I3I)HY~Jcri~2VL4qryF z#cXI8tX*Vn(n}{&MoORwK3}^YJAdX}1$_Hc%GLsnZ3#L{u>aa+RCbPETIXu(f4(5t zHVF~#_|+HAaP;mq>uu@!S$01}Y#i(-zlGfaGy3RToGMsEw&14o9|3crr1QH;=`pg> z`YhMUw-x*XWQ*Qm+Hr%_NcmoTOvZ1Krr&uCl4u9fbht!-k>uV@BTr{s+Cj0zz6>IaBI1{Ds=$U5$=KO%e{xT?m48CDqZN9MQUgIH#V3xl(*VdbEIc7qenCr~`wf(gNWHhGn@o>;FTZhI~8stwqOdyM(kWmaD z-G<`u*BwN3l=59voww#Yr6Bz>LO(o}BXg#w{dl^T>n>?w+hUOpH}BUcm;a3?C?uga z7|D3gu(q_TFyGAn89Eu7>8oT@$~V3do83a}ln3)j-ylG+*@g68gy9;TlgB|TJi~iM&-{S~U|1lREGxa%{7=%Y=rocEnw_j&9H2B4 zoyIXD7InkDH`AI4_iOK;h$aBucpZgjPh)R6d~7j*162@Y;TV8FQecPQ>-j4IAl!N{ zf!XdjGKvq<@{4!z(@4Jat;{VmIh@Pm#5Hc1bd-h+QsvO6H-b%{nX|S{eT;Diw zNE!K1a`Xy)ZlX=fsd`^{G4sWTZU(t|hkdPSEvSN?J~u2&c)=g-J??(L>IcyPN95mF z#y@y*o7mC~sR7)dNgB<{cir+UK9!>w-EDLre@A*vL0-{h%z&kX$>y)CY_UNO`x<+G zex^+x-p>FE&Ml?q_3bH$iZE%c6`yLwG+iKyB0s720e@ot5+Td3*+CQ}5_$x$|zHpqkcd zssA~3eO9_4?R>p}6W$$p47v@1_BdiD9OS+J6L7#mp)qb1y=pdu|QvOU7aUF~cn* zy5{XSI`v9cZ_iYZo33=LVX59;WBc8HiKDUWF={DS1~Hp&D;d14w&m8N4REW+4NEce zqxad$Gh+UopwfoS^4R--bVz^o9KXLZF1L!;*UMy^_)AJvsobaYM0P0L=_mUPBDa(r zRV-(Mr_MhaA1Vbh*AN6A8C$dM`^>Mjdu86w+n)=+ExOoVge^_mQx2xxX7wQwZ6B;h z*6ZZ;Ga>({(~s3_L{BqCiDMt}iUutztoMi$+*7v3?Wq&OmC`>Uff$aaS*sh7y^+>s zeaFO)7J_a|)jQWVjOrCZ^g1(pxmTNtm+TZ%p67IV@}?IpxmOr6zMV$m>w5Ul8tQ4^ ztafNpi^eG4(s3@~XqJ0vEkslr_=5rM%(1+V$J!_2Cb4Bvzq6NJlk&AXXA~rxN zl!2;)62Y{wsQi{^H`%=VRI4=x`+}qv2g)V+)H!PBtc~SOX4-iAOwR2H5TP2Wk*Mm9 zKy0s{!2-z)t#VOu+a`TFx$>IxO;i8Guoe{r(z76|q}Ywo5`I2FyhJ{>6O6|j_1(X3 zQ-f|>zyEruE`}=-kG6ub@HV{@Y!THE%?zfN5Jci1iy|s{meEVM7wHm3{Vr-SS%!zK zG1g@_fJPu6kLYp}#&2Xx&nl%5urZtb`6f^|!bO^+&`|zLph)>C2!7wAU2Ok#% z!H@fIllEday^B0yZU$UZQ$lCj^3%Q(?Cbg>6WT7iNnWDCNtfT5E2u5;h59Z<2}0Gz zcmh?UNb>~JxGg?Nedf*o9dZ;)Y_S;0?!@hW^JW(QkPR{ztr1IHQnILC{Y$6Pmn9jm z3z65ww~L5!BjZ3KJ|mk!LiSI&rMzmIY}1>Q-iPeVnkk$=+J0SIu=ynJW{ENo&ZNMu z0G+cSl0NaSYx%4ogtI@yqf+^O*M6sBp%;=h1Keeat-qN$>l2v*EKB}1mjm5V&Va~ zY`bX>tSZ5Og;KYbdSSZOYIX6GSE`j@*GPiRcVa4h3uD?as(mqqos;*Xeqhk%#d&a% zyOP{HYc45EYmlz;DW2aC(%R88^ah)!C;pJ>!qIHaKczI6`cs?0DB|^2&(`2p&698h z5qV6$-{BE2TMyRz^zyLdzNJ{uVD^8THplN8;%6kjnzf{>yLsDW za3mz-QhQMZ(VvG$zE2+K8~=d|PzZ>3rx3-x*_abwlsN7{m+ySG6f7r)yNV@Sly7olqGkl0pDR<@l+4v*N7I5!%(~7<5$5 z`2OFcU)zpfTUYl=jok7z75RTw#V9{k2e|n>64NCmVI0|zAKAQm!CV;%*Js`Bsujnd zud$!w?#(sph*YYavws~?FFN&vh47k73eQ_>?8}m{TKmLz zoJ6}hpG4F3q}?9axZBh(AEZTWj~vpN7Rj2LLg72ll9{)L0mk;E#1pc@le=OjpBsg z8~M%s>2bfepw-9t)S}_C_&=DSN2m_L>djuB21PG^qWSa6=e++~8eByicJ2Qsja76Q zy^Ke~^}1U#$Cp*4+^wM{jRhJK)N2Syp9pAhEhUQuy}=dxBJ5PM!TIL3rQx<0N`^OB zI;j)5l_+Z?-(lu1H6o=t^Z4VUW(WHT9j;uwugdQ>Aa=v{8sISJS8>WA(1_(VocEenv1ZJG0kU0|HX z`U;l)udL)~8DAoR!W7d5wDJa8@qE;D6+%a3D8_57aor8tqhm5YF3v8LYNCb0z+fy` zs7(O9>u(uRR@q?e@L{cYJtaXZTgZ>2Fh=H9?WTR^ajCO%OI?7iB)2JsrP_w*VoL&a=03}(PcGE&n;Ly~jO=f4(IpS-RV`>+}>(4>Ty}#rA z1QvR0#%lL`nfMaXE{D!N6Rh!!)#v8QVMfFN*>arUGxz&0&Kg8z-_vKr|*fF9Wl(+ zEVU4>nfVos-um^`o$@DW6+7JIvjr3E~)4cWiyeNKjMJwucvDTSBdQ4 z*i#&%>UT6#VmR&QVc~GQ-@~?nrKswMhu(!0-Ve$u!`?ecOatT!v*O?E ze-ReIIwJ%7rd9FzwW*U01<`CJbj;Mx9UN6J5x2!F#)gjsoNMe*h`N- z3Vij>nR3-E{I?|4q&12?F=A)Xx+i`QsATbMh?nW_Ax<|dNYi6|)-C~c*y_dak|s|P z)Wk6vwwVzIrCk~PoimbJ!=ag#i^4>I>_&c_Jx-!-rnyhY;rWRTej#wLrCEt14-1}g z%L*Nz?DQ|e?unAVBWr(_Eqn6aeb;FH_9}n>YZ|prqTPf{M*2l5&>veNDf~+3#z^*P zX$IW^Pu}kOz5S82+sG@vEXRgkun>FH!@D)LJp+?=WTLrN6p z%6+D9KQ1M{<5I|?I)aRh?nlTOB2ou2YL=#9nd{t=x_a2o(G}6xo+r~!3T*6gGn7kf zxT4Iw5L*hc=A+=5U&Z}sZS#$JxV~g%oqAO`L$lGFRs2%WL}@0|Lr(%j69l|hTe@+Dq|zY)4;>Np7Q625r$44oc3Pu&Uxr_ zkSh8HY9nSjOM_n$qbT4D^2d0sF?oeg=a!X%?niQDAV3vr+dIA(Y5_`DMb-;Nk>H*Z zmsxtI$1n49hEqw;!}W<=p|S4B1QOIY{RIkdd8&GOP3Kn1k%ZNVd`mW#O3W3Zfi$b! zhLuM8hu~iO@g!Z@d;Sgr3yfdRy5cOu(%6^W4`WsDatS9@ri`EH+4pxxC@8X>08P4OJ1oD859h4lVTee052JAPX^6vX z;!Nyr!>qx-J^hRuWk~eo->r;xEwVRT+bg0)@-~^d*R+C6{4B~&{`#V`ZD=;ZD>DHZ zV(NBpJMcr-{HxR@`CqOGn>_VlK2q!LDg86DzkVSCv8UPOZ^$_-Ik_2m)udE(GnKYh zSRW6MeY8Js)Rguw&4;(kBXxMZ+|PnlX&83!z33>Nr&eZ5xwM`DQgH!<3ICANbVn;h^(C3n*fh|t5&2HM&@4zb)1`MY#t96U;WGT`Jz$f9OBGG zjsF5o&O4+OmQlY%A4^X%2#X?TqWQv?afRJ*@|~H!IPy4~jKZBz{VO~Q%0U~Z%-_g* z>F%qc5}W=L-*9b5^Uh|xcy7`=`itN%^ldg4ClFJ)ds7fCel%fT^uJtbye9ctIZ!4A+DpTH`_ zL|y7j{gUn(V1VQ)5R61CnWM#8nnauxFp9NazfPZ4-wW17_PV-}{Mi4S>yz(&5qbon zr&&bjZU)W2$Vm)l>x!JjW| zwk;q_Jp`?&J<5asGJ!qqONUp0)`gmViF8K;`;i`%tO+9jRR12%#V$3}M z_05agOtZ4tuk9f#C+Tyw$~0Fa*I#HdEIo=9S2P7Q7S4x8*T8$KhZ!j8f0(IZN=lP_ZJ~(>>&Us!_J=# zl(mqo3k#MldFv~Lh{m^F^{2;AVux2oIrL}bm>+SG0v#x0Gcl89lk2id86hva#xuFW z#X+*XTDPUpM9T9PN@2djVuSnXTYhsNrsm*EtN*wFx99M5-6L$Wx7NxvbQ8B%!JL_l zepB0)o4&(dXaAi`!yK?Tq4<2t+dbz^r_O zDKnS(yT6=S5)xSz1jBtkwmZsjjG63(Iv(DP^L!XyaCYU8`O`8-aEoLM@I#iI?r<_n zI7g5ff24#NQ1;LnAPw9CcnopQEc@CdVB9;nJ6KlM)G}{BKa$XFtfh9YpoZi+TzoBR z-8)pMGz|ZoG*tCCXE0@m{r;BW8$aH@#){0K8+rf4o5K1AT$fGr$P}TR=3-?Ld;)X7 zZ%$dSv}Ob6-TL7N24wPsjk}$9R*kWSvnXB}z&PSHuC>R;5K?9simf!=Qzep8PtoYO zzW#ZvByCf<4Q@M&DOu-MW&iVJnoqr~?kxsKAdFCo8v@8%fD9qgF( zMDnoE;qRAhh{5oEN2e-gh2OTpmiKQ={)3w1u=Xjt5s1BVu@eS=rN@avfApYVB6aI+ zu@d^t8R8ZS^#fNJmcq*8{YmLbpv^ZyG3SOe11woYDPKaY`Co}8NB&~+GfJc0FACkm z>$o2JhpVEY7FDIv>Hm}W2L39WkELqJN$60$qPw)~Qj#Qae)-4F!|m=g@Z~?lRct63OI^$MH{P2~c6X%UYvi%?>5|w@B*dh@CPcpQ&d)Saa`kAfU@X-%N@j2X^W=}c5t3WlQ zgA5;BDY5|7@(|;-X!&Vm&%lki80z-8^*;a@p~LXyoxmC!tGJkmp7-vzf!(uhFfY;^ z>JfAEzN<9|APG=@-~+y=29WWf{6Y#n8B)?0fx5}nVtpDQG*%QI>IJ$7r1199U=AiG#o5dmwM(unn&T}6`bK3-|=-Ndt79hLruhTTxWS;-gHdj#>^KPWYasfM{ zd$PVlotOg*{Cv{fV`1n4=Yp6_V{muM>}BP=;_}reGE$_mCnY1gcVtE+gRUy{atWIr z%axUpyW{N819=8m&(HTY6}$sMMi471UVLjv>CQBZ@3@fRvS2!RtD5%nAkevw$>G4@ zbMY%6+&DeK{iUDiv!5B?e^UEB^M0syz zs)hj%QgDYW_8NE0%JuiE`zYU>yng0oKC(`7bJ+Er5a}_pR32Oaz|f~ooT~gIQLVga zrr%eO)_Y)#_I8?_f;X|yS;6m$Cu%f3#Hi)EGoDsUq{sMb^HQbcU%|LHnr2misFqQ;ng@~(1v=>sAleFK&z z)1GuA@lE#L6*yHY5?;Ws7BL^?uDdcU3*PX-5G}oqZPKx@aQ3Dq0}EdZtnm6 zpy;2(&)AX^&@0qdu_#s0^$P(RfFy;R@GPP2TMbzplPI z)@?n|yj{RzvGD7FN@U*vH`5PR!4VeOvC-e|`$?)EZ{E7lJwyI790VF?^|<7CA?0+s z^%cKLS(uLb_T~(OjOIS36)>?Wi5t4kle^vsi=;$(Y1!`5ZXPcn$h<&b^!_xp+cHY| zI@V#=(qyp!S5OBs4Jj(lU>?Nv+YNPi{h*zM5VlkfkNq%KwJir`ZFMU&je2zI-G_w8 zfcgqC8tdAddD|gi_w8xGL%v|2k+~FJ*E$U58@qhBX^Eq-t{SA`!F)T}uj7r^1MtfhTo4-Y0G{@UU~mb&5Il53!qny+zYg6IDAN zE~{UHR{u8g!X%B=og-17;S*1G*3zr%lYJ9=3-~sVGuBVw9Xb>ED#N_{R0Uh-8rWt- zAOD)iAQJ`i&iUc2x&?Gec_S6jPVHF{estDgjez@{N0le+2>*d9vjyKk_E`3hrVE|n zNISE9F~fAJ;n;`QV#8%oqX-S*M2#&vcl(LG6qiVNWL2j>#pnKPDmqyFR^aG-0zTD! zWWZUSvh6M_{`Jpx)}4Qf_P4id?4LY-fR)`ui=qsDz6t4M3VY8x$?x)F z>%t#_^SBugjhf7<+H`x_(A_Q)s9nT2Q?-|ecR(?fyGz%7aVL@r^uD3Qg3A7+{m}Dl zqH4JlH-6gZV8ZYgiv1LHwc`tA$b9t~7F zyoY@e{HW*}W_)$8-4Ow3v-+wOv)^z*kkmxl+?)1wk`lUefw;@R#OS5w0|#|;PmlA7 z|KBjyB0FUsf#iKxUkiv`-ss3*%@VTSpm4#s>NeaK>fqll9O(Lrm!|)z&9`-eryjE5 z?%Lyjyca|f(BVpZ^1D^?Fqb}niQQZ8E%8=>3Y>N5)uq8j(n%hikM{j?ZGQG=uKfM^>a+s>e4a5r zb&)wmM*qk~9}l3*iRxq$85OUaCSXNcob0Z)=rtca%SIQs0xlsf636GW$(r91U< zaZ8-Z<3 z+W*deoV8jC?W*YltkxlWf`UE#&*FDNh*#}cEV=ecDf034)seok#*#=_eAxuAHLpg4 ze^HvkK;Pi?oT+nLH5!P|qQN1(dKQ$o8_*H{SiM0LXH>5z%6gM@v8?(h9g(oETudLU zv*dluewW3P@wD)R-49(2PiT2Y=OhsWi{wnxa1D&qEwy%kV@wWhzG=uPv+gSOGc5= zBe%X;Q3!$ED-zxVw2|CrmWY}6gK2XpK4o&-2Lk1{UI^zMtrcq&@{rX8uX~|U=2h)_ z5gdSfJ|wK0S{$!EO1?iLm6*cgG&K}+J z5Ji)P=wLUG*AUt@l|_?ycWS!1kAgg!`#za9wfem1M(HUt!1kF7;U0vifnT2lCRLS& zU&gQ9{#=3f-3kNM7^U*IJ|+&)epXw3;O57Xe(a`et|aaD5s&%#?8n!eWKR#XL1H5Q zb7t;H{`RV4Ukq95%s3h93boXZF+-myW*7O z-ucPjsH}IeKNZ>IAuE;4)lgw(^v$32 z>AuG>sML8hA}TMuO7nSk!FhBHQ8s>n6$z;;6BFvD( z%j{m?Tx%}>0{fh%uSQv0dl(j=|NK-Ua1b1+mJsM1-l2y~M=x%t zjWdeO{+`bU653Zq09Y(@n%LJSDYVDe~eQO59g^hJ@v6Cf~>Uju%DMbcx+zSW^lg#iP`} zw2rJaLnWe9+19nO&YBkJ2+3c*G4h85>b*Y$jbQ&jroO^2%C1{`009*QmF`lImKeH} z5|EH?5ReXGXc$7JySqDvPHE|ohM{xFp@yOJo9BJcbI$kM|G_9&;NkdDA82YC7Y`KLMI7V*f45+o-*|i+amZ z-o=~J^%@~zs+_Yo#|CCqKa57HT(6ZgB*T{6{+G};qvMa${mqNyJ30rz@LGvxjes`V z|8r+OfbPW<+CJrX&4aL(Xzs40d(5>rRl}-Cn3NEf_PRMoEY+_f7>-LPw=G(+uEZoD zL!(D4%X892gxaoXr4b%r^rr7OtPDn{cg9W930z#K0N00?r6w%bc^60(rdKhLcs3GR zWeT0`N?i3#bJZ&A*-o>mg%hju;Wxkgm=r=C0;i<74G(ha8xrZ2H}1HK&OrM+@X9xx zX0I_K!XG+F^CVlDo8DdJvuHz>O+IwjJ^lAa?N2=sn>X65Evh>xGNsSewtyFvqakdr z;beRY1G1ejGB{KHg|=OHrBCpDxe@rZlUO`?Ugq>{F&#A1X!ms&rg+O`^vH9gm2Xgbc1v|5Wt$>N8Eu7{##pw~;r94ntUcvB(= z^{6+~EskBHq##yu<{8HM%WSQ(_;>e3_yX;~)y1Iy6DSF!Jm2-~LD3dCj(4Unh^6LZ zaHG%Xj*g0&9%aNr3|2)`uUZGMG#mHFO4x@KO{OZSgoI5O(LGj_e{$kBQONo5bfaeFG{vO%yc=qLrH>+7Fm1Hu8;Pe^ex5$u5NRBB|0`f* z@eQTe@DRpC5#*2Ra){OzRZ**U7nTzvtRd*0G)A_y!OfI^mm2W#Dv_y!{bV>OhHK+5 z^7GP>2irBBvcsn^)P)%{iL%2Qzy%3JG|%pB7HXfF)-jm-T$!~#)6tTheN=dr0YZ9=Eje&TIBzor_0e1^QK2_ z4R^#R3I%lr99d-L>+l%k+$ZILNj3*Rjx&JebV6oZ9cB&YZ-`%1Pp{*bdJb3KpPJHI zwYlaUpLsFEF-RrHJi0V+F(h#rlz!yG&;>aet#kCGJbSQw&|P+IAd8Ebb0F#}m0^LA z=7vwAY){2UHC#$PyEyyaCVmr8_!#84PWFA4{Dpn40(!GyAG%~)*@A~DV@tS2r=j4N zJpCl9Pxw^s^J_(RD8AOFo_W%EO;6L@qE=6>T?{!XqwmJ=w^@eX!+&JAQ**T&k&=av zZ#lht=XL`6QfL}NYn3z4)5j6=VE7)TBO4d!?V2BMWnAZoDP$tRPUDIDrS1~V_%-4g?wxD9ZthX1)nH4 z{y=?#``jS4 zKOHi$+rbsl$1edspBH*4Mh#M@u1>g6WZ)5l4y|dNW<%bjdm=jEd>vJdX}=|16u)sj zNHy0{q~B6)wv<&B+h=SIVfw6cSnb7Zo2au7X-9bnLHQ1Izxn>PAY1oX7-E?cnPV(q z)Wz9(J$=pX4E>)FlYbr(J4}u`0#vKBqA89+cbW3+=Oi@$iJ6LDMBy#>XFzc%=Hz=m zw7GFWEvyJoK-!&W%Jw|l!?jEgrkWjtfl^j#9|A_wnT(CEK4J=Y3S2{M=*{;(8M?*| zHM(O}Tq19Us<$uA|Ulslye#YN5 z$TP(#Kv|#Nt}!$U;@1VI2%UJB!GZ(CK9q{|W$O9$wWjOW;GH%5*cL;OJ;d~xeLZLD zp!-Ug?x#pde=O}7}E^HbSp&XCz36UjI~mczA}v7xNw3tQ@&CYUM3w zN3@WjYUs6~)4L`=J#k*r?bpE(VC_@rL!e=^wd9>fzH@>SXnvn}xc=-kl!QDLo^Fr1 zej3Ay;z^oGxoXrV>bqqud`CWVyjut&9{6qfkBN0GO5ZVCiozBb4j$Uy^cRcgxM=gvt7WW4?BHhPK$_v}`UBBbh4@xBWSj_VDTKtJcMaF1ka8z}PI%CXrQC{EGW#-@PL)2M;}`bB-5Zo4VAdDa~9C$ajx zg!x(y`+hcQ(?oAT*o6$ew6A(tUEV(DQ?STriE#(rSj9F|AZ!I_M_WJAHp*x)2CfKB z@hPz>BLIGHJ2@69RxD?@hfz?D}OW650d|*MtG|;W; zBh#Nkk9GT+^aDcp?zwI!gawvEpY6<`9QHc;!`7B5;jdEpf|o=|;~T2^GifICn{4KP zbzS|Jt8_mVGJ9O*vOW1_Gx~VBy6R@qKM0~{KyEW|A3q!|S6@D?+zK->DD{Y6gs2P% z^wi^uIWf3Mczj^+BB)-^`UPfMH@os>s8UM-4W$BUCx1$_l z4yE_yR!#@}+0!_>&gH3xWOo|jQN4%)9|h&1bC$QyPyy;9GU-#YKEpdK%|(`XBi4ra z{6Mq;Sfek621?o^F?AlQfxlzdbX`T*XuV~<1XwF29To_8(-=sfrmoV96ksCJXN!PbNWlv!t&#{ z4TgqBOKHc8@w&wsv62g__e$UO*-rQcF5FnY$ck4^C(*}pdaK|?JavA>sJ?paN>eZx0~oO~;zyh;KjgI^oH@NI~j z!@v>!TK!&;wRsV^eGy?qjyRDt$mTUYe0IteI1=~KuV|T)VdoFm9oywJK6B@h$ z?2NMv)0U62@nQ{B!_i&J9ZK@9R~op!>zzsm#aB)oBU)G}PrtiGYSL@Dw%SAgs?iPt z&+)z33%^!Nudm-MGpa&4H1%P5QIkWS-_j4f_?qrv7)Q&SH(=i50*d zyO%$`N?Ab#Mb>eNL6L|Rwm^(U=~;OQBxnWB5A+q>@rd$WQ5IZbL3be& znw>s8OQ#1*)j(cd7s*~lw7nr3a7$N+RZ`d_RbO+6XMhymLgO&|TTq76ndweYPUTNK zRJ}ORRAMFen;rsw5+Z0BLh+BOg0962cYH`feKVde>;2bByEbFD{lAxBa+2++SW|m` zMR8366Sb(;rdIv)`M;~A7h#jX2?cjtbG1ILTL=^iGt)BG`!HTQSN1a%2HJ@hUyQm}`sCY~X9t~>uvuA= zbJOoYv&nbdD{4GkCqFr8Nw=l*ibFU(PIudeXaBfYMFAKQ-v~q{oUee{BtDJ3Q%4rp ze@Wl0dw)BiDt3kSd>ZXsBKEUD4~?X83{IeBG&P~4(T-czg6RHq3`E!JP2HV2_)qx{sBPU4W=4^^GAJ?tqV zWc~dLZp^NKUo-9=v(DqcH=tapUuN93RbyFwp_+9XXtsex$0xGeT{&Mn zD`EYzxXq%c3mWoxal<1ye?a`yFfM8&0TIG5gDr9PO?OUVrZ2LeMxhT9v|~3L-IP~Q zo;K@I!tEWjpkYwBh@IY|Jk{)!u+WNhZ`nd~jK9PmJjai0V(Qmog+e0+#@sG`KY#CP zczl)uUmZ^5ld{7;QPD^YCOJM!e3zFvq^c#MoO`fzZ_GK^b^vJC8tWf-mK=HFLzV^Y z34<&!6RoqFNRjA)`BIrl&=3-}cjDqd)*nW|ecekG$K<_$T0hiF>)r^J3&8w_f z@0C>yk|YPU#mhxW_|hMKJ8H+)%u0Qdo4-bsgPi@K48&7Mu@OCFu#Rct|NL+3p5tn+ zrHUmPbYiN+{aPgizON;+-bb@|-81#F**A;W=ZERDHDfr}1;C&QA-PlJt|VGV3Ww-i z6&_d7VP(?ReVkCV4AEOH^gnAg6#%^u?gv$nqm{d4vo(i|D|9M)*yf~(@iu_>1(mm+ zKMnaCuyCHreN(eGS)|Mg%Z0sIWs_DHLQL9|L*Bh-5+5#5q-pt3OR34rsfdaYtFYeG zmU=}9_a;?PGEElztywjtX=>skL{2-b|Aw`*=`4FXg6kFS&$DIr%5Fv*8(%aZ6ToUs z@D`;Y=MV{AIv+mKxc=*Sb`Nv=Z`=lHQU%nirwATNQwlETh6dKDqX{@Ywv(z)%9J{t zjG;t7d;6DutXL77d`fTqy8^VqbuTuc>JM!kSUo|JmkNb zBhfsvo`#MU_^5}GE$R#jy+|%Ke2gMb<0YOi_otGA;N5~gV;_lILbO8qbpigU`Q-;| z-Dm-tTEb;q{FJY{9+ljU%g|*#Lk%(&vf%g-ao@&qngUNen8y_Pw=j#`R3mgTT@Cy% zFW8PCOtArO6n$}{wVq=8%$(dWt{|+c5$7hZKMPljT|vF0bet=Govq0$ z>o#xfwsz7E(|-J{qFXGx6_)Y;IaSc-J?FhLc4HiCL@1jKE7mt>g0thD`_H*W0ZUKZ zYw5p_(PkyEG6Vt)u&QhY0ut-Gr(3LWD2nKfmzcYc(8hjiJ3S@+W%S8Mfrc+8%I!#( zQQC8HO%Ei&_p>8)k(1gaT*P}0%XnIXfn{KKdW!aP1jvX9mlElJ$>T52nu85sp}N_q znhO|4@19SIr}O^wX+@>4FUw#0PL2uwiv|f{M^;Jpd%k+wF>=_UW%`+2jfQJz;pG4| z&!=YR^D0*F*PN!sQTpDC8w0(3y&rysh^%>Jr0#e^ih@$Kcf+{*!*_1Nj&-$jrfEdm z^8u?uBMgn@{!op`u=_u5c#{gtBE&jsAJ;0wvLxsGeuwEJ!{c^-g49K}uex8Dn!Fy% zUvV|~wN^Il(&_lzCz>5T?U;hp>l~7a7xai_eHWJ_TS?%*0TZ~jyLtOj?(-k*pEFfo z6e3c%o@a2tpY6N%?$1_sD9hLE;4Jt?$IbqGA+Tv-IxjctfCFmumeMwy1twMPC2>;5RyW4Z(3Lk)|M`QvBO4hw)UUrzM$p zoepTrVf;K>4pN8l$#og_qLSdz^FQ7OV%zu2PIR5ews++>0U%u|6+vku*SgIK2A zA?W`-JG%Z;PMz@2vLqshEljLYV9OMY>1o<@G)O}9vtsn8lhf&dmO}UFCak7if&*q+ z)-@VH@rTWDTR&`r2LN=U{xxQvJ8bOLW|HQ-E7S z?zPJRhQe>Vxxo&I5*;+d>Vg=MfW#P3J&FT_%un|I89DS!OdY=VGOKWi5!}gS6#v>R zz=Ebq$9JI3K7y*~OpLyQL@32(`*riSE}OC!Hgh|}>fT{9gP70!-y>kOEDU`-loRbv zZ)sl$S*w6}F)4$$EQDbAnB?OABK7u4)gcC&^I&vB)++KaC$WrYd&jIf`Pr_=O{v)O zAW*bgGO!uhBg;E%k}*lOgoz4}m7zeIByH|34BNM( zLFGa<_~vShqf9l6Mgq;}M~f@29SYD@zfROG_1}}&gzg=fcQ!k{yEBpS`sn(|C$t;S z*cJVfpDXyA=Wl9Rf9_Lt;kQ%^O3m`UHbT&`v=h)9!mPA*jjj$CCG^U~1I*Il?c~uK zDEsWQ;QQ%n;1e3!^o))?o8>N_)!w0d_?EMQolDO(XYgYfLrq_%QA>vXy*~7~a$gQ; z5BRPT{*AIvxc1v;$W~nsk-HHmzbpAlOFz62AYyINlkHetOCZW@nCv|-4L~fGs`K8I%*7-A%1tA0br-G<8Vx9)$aA)5s{@IT z=6LM9>fh`g3c%?NV15{d?vNgAe>96sW3(o+{GXEy@iVM-KNJ$}ZbMQr8J%n@bFuns zGGa<#RxPn;fBvCofhi9m)GvDarqYih#8yv2_Uy^!j6`e~wG~-3gKBkOnByDgiC311 z=7}kgxl~fW`e@7OQtx`@win^cv3pDHF&~b$x?8w@?&QA-YmFwN=oFNR zakx4;M(1&Ddjs+=A$y{p^-%RWo7)2&PXS`qe~bhDrR=TJ=y{06=qN*-;1BYv1o9MC zyOM`q#NE6d)Aya|*YrNK?&SF}j2rl@#Okjc}mQdna3SUg0XW?eUW9YcC=|k=n45NvU9S@X@&~ z*4N+unNq|cFiMWC78Zv8YDaVS51j2lwVTx9g}$DkGj)xrq7d=2pndZ`AYgP>VWsX6 z6>mK1faW^|?v8wtkV{jB)+~HYNUH!bF_i-JL~G8r}dCfwaOEbIrb@`pZ74aXxtWy=21 zycg)`d!W9iFoIG3U0TihX}AhlGyITfM}8ce$PP&yi`82DIaK+`zFB#=GZGiRK!&g~ zRpxtbm#5)4+vrGPT7`}0#kVM+xH3+0ar+sK}bwlL?VO zEna+HMFy67cBh2)USDpTlsvCr+gN{}FvVTq-Lo9+PF_zZ>0N59Q0KWPG>J27I=a*V zGf0q_B0iSF%qAy=w}isqmedkztW<-fajobhev{rBHCy?OUYcy9?H>^TZ(O)|r5~{p zfRzUbbteX+mFIeM{v!|4 z=KYj5aitnqBkII+{!&DF&>&tYd_KVT53Tc|p4j-NxBp1(RB(bpLKrBT15Wtj5dERa z6)j00!VUhkcu@4ZgcYlKE0rB5voGA-dvtfcrZ$3Tz<3}_WS$J~XCYSH*veyOTy1qj z^h51UL9?i7;nK~&ILS3p@R)K_+3H^q@4WMgjF?u$*thLsdlKe8;a+g8?zud7-eugW zS1+!G@oVU?&1*Z{;2`bYZ40OHq}V!F38R1X-gFCuAWm^dbE9d+!+6FzX=_;s@lCpt zCr;e#V56Rcx?YB9kH^*F(B+MwP!LBb^5K%uo$b;n=HTs6n(0ijmVfc8XHd#lv8hm&cuv?>uq5^jS~%<Leo7rw2;+~3SCW+~Z zcc8bzcF{x{fz~%FKd^$$P< z`QE7dol*vUS}6Nz=Ro$CFN0$%2mKYir&6AgZ?n*^lU<$!KdB0$`I#b(zF3I+1WS<7 zv}FEgf3@j+<7Pr9_dJtI%JqEX%InGD3Rq=zhy>bQGl{sHU9A7ZBHj*6PG47XR2ui7 z@zrl@bYg{`aMlK-nqkA(UDGmXcN*TwX?R#y5tUY(aN{DYLq`9ZbI3$v(F|Ji{V zo5WTD6P4M$r9V-2K&6h0pfUF}#bf>TuWIl>@lypIapjQK%=hOWNjtw>UVVD|;e-2? z)2NeeG)chsHEAK^!QsAGx>3_#kcCi(wg~*$AIhTv!;y8Io|pQic_6Ya`++RT#Vq~C<33cO3#>LRwL>@jkpggfj1 z%aIP_lsu4kK8HWU75-Eck@fIn&*eSGOorAb`Sw&x0^sNh zz@KtJ9%8=6P{q1*GQ;ydjqrRtcZEVqC9gnk{pc z$H_sU08f1$c&3}u#bMy~n43V z?5IP-wIOh{6EN^8xzGOpT7WA)yV7nM0~}QT_4;POzAYwk-213H6yEic#{L6ql^i9< z(*^()K|EZ7x$f;@c(SHLm(V!2SSL4^nvrPaxeB*&u1t8Hngg`>gB3osf)K}WUr%m@ z5@R@;4*R`=!B3kSX=OMIAg@p91Aa37?cL5nwMahaQm%wDI6sLtYbUYE@Y#|sh3`vI z;mi!23;I4R?Cwee=3FHXDk$^)oYIA0e`d8FCB{ediYw>O2wMVBA6ZA477R0bPfvaG z-N7d=yHoFX*plea5YnQ!g%;E`K|8?QKmuLYb(%z*5L%BJK|fJJI(qEBXe4yW=kGX% zypv^S-&|@>nMPY6pX|WWxxexmKU)V711ThdYWh}Y zN2TS-M9JpIe4rsquUoMJu;0(cY1o2%vmj@mN7CokE%=J^)GLwwI7ccfw20iPJv@V_ z=u*37Cg%L?__c8E?3}EIzju z?!;As=cFg9FYcydk+3VNo~}@Bv6Hx$M_jSL;&`g`r1!eJx!;3VYTz{2>HyPbpkkZ- zoIM*Zb!)nxckvEEf?_rCf4Xe5_FcXt0<~N9kFNfGb**&Z!W>Q&)MglbKv+Ad_dk8Q zE@mIgcSR!=SF}n(btbelT{-%D5-#ILh!BPVT7_<4@xkYFNWhnmMr&lh=btNo#Q3<6 zb_f_ifB7adr!d|qdsUmgD=gwZq0!|nw#6oH70;M4S*P(tng2Ei{#`AWD}}|1q0xMX zZIH;DV4U~KJ{f5T)-S^xdyt2jz;jA!Q|i~{Jz}#v-UP5WZ_^T5tDSIpfGGKmBHH?J z*HiH9#1^wfc$xNWFVmA%L1_PY2(j4Ea-{CHta#+a$T6V>_`UQha7!e3>14BBh{b<+ zNhE?Hzd%R%^7Z(layr8tBj<}0JsSL2Nsn|@k_PB-b+F%jQt09c{yE}L7E}t{?N&tQ z<78(r<`MMT!)1tkIOu~RQ=Xs`;dE}`7T=1AOHQ=S#%B8Gb23)9Auqf2W9Xxq(?ycG zFJsaw`a`%6j(g(Wxxeu%rcdo6!{5z=95&1jrrl`xVAdWNugx=RD-W^2L}_CpFrT3hq19C?)1Z8ec#T&rNYdBMX(s{_BY*CufSioU5k>3PZjNh9C$8y`4lef*8M&LidYaP)Ek?MYjDJqt1rZbBC zKZj=SUylh$(Diu@mq{q0&9iBpm&}l_2O^v3CY7rqcT$ynjZ@wQ{d)T))^%yCi= zD?e53I4ta?Z<2-^3>@x#G-I3SbNJuOQac|V!RWrdK!-w^FR-i|c*_khFb!R9A8`kI zKeJep!zTQw{v=aC5fa9vKD;uO$QZs23SO)=?txyrD2TQ+7)R-r$6t*CtM_{g+5^twzQLzbP^enW6*kK zb9}Jg7Tiw$LgKy>5gIda7fe(x5G~yiYJlrb7vr%9wWeH@M3u@k2*!nvM#sZFOy|Gj?dJ za3iT~1h5Vg1qvU;UWPHxjzhA=@0x;?Mt!yn=$X762M=o8|E}Y9m~zwd@5oYFv-qxF zq{4??rmgQ0lo`qooR@nxwTl}DVDq$pp(V<(=jvHj1_eY*d=^A44|QPnb~0P#>rNgD4fC13HD5?L(Q;QT=2;G;B2yOT6@A*!(k1)7wGL{bxJ3 zh2?y@`RJw0|47)*F>Xl0`j5fi5x}!Q?~QBj%2%WbIqktF5U=L7yOwr_zm4D*z7iJ9 zI&DIT#@|n?dECc3s$cEQ-+ZEtoY{Nz|0C~|&X^T@*zZuUPMRN4HVSD*hj`nVNl@H# z=6^s}#wr2)=)q8_`{;3CU!NWr!2V)yheP8GZJbii^lpE4080(6K0OGRhx!J6BAzJE z1l~m)mrQa$9u0Y$NO97WG&^$!8iXB@6SVsgTcQ(yDC z;Qp{Q&Pr!Uy}9Z(S3Un$D7!%*>7+i6L>v)@;!RD%i7`0uhh&p*+7CvKxY(t9UX7K= z_tTbm+Qy}KF!sb{IVo9Y@-_F3klhP0-Q|m)W@C~r9gZr2(-Jog@Z4|yF!t}aQD3`o zri4k;zH?>>GL-7A|Kwgx zAA>D&$zrW{T;w2T4>{A9Jn{W!YR@9(&cxM8aiGV(?$tZ1UU`v}}PA*xUeMb6{l5*h3U?(e<2 zO~HP6K;Jp})Y@kl`}`!b>`PgvAG-g8~m(y-c?&Vmn_}GwX*_!KWi?*hZDzrXfIa>z?7JzUf=ThxYZAdf#)T$7 zjQ1+BHeR91esOb(2U4q=kx5LuAZ(B^ALsxg;% zW!UW3@TlE&9dT#gxE~tBk_$3R({7MIykNENC*2k%L|Ipdo#xuR3t4^nAE=wLprY>1 zD*Fr!iJQbUiyyuV)2csh4N*F$Pam_2( z1g#m*dF%K<%X<%|hKg&R;5nO3(MkK?eQ@&g-QT?YApOSf+}SrqS4ffTHpQEyGDMt_ zN1|UDQ)#S9~Z1^EHEhCgTMW%1YlH%MzsqCXzaEWJBndTmv;8L#)>1{FW?(wwB^yp2;OM*$gn8f$) zj{;gOujjGq%mel2b0jf-{mO{2@O5hBt+{HsHxavZ*4oZQ!SJPnknoT~pC z5)^Sg&+zjP3HR~cEZy!Qx(wVjYOVH&*@X_?QCZ^d`pbbvxV&`9qCOPYU?=2#-mhHm z5hoMko2<4+Q6>vyG7-T_*rSzpV}(Zcf6m$yO^K|Is+3JR-38|Qzk&+-3AXEFNEp%~ z|M7U|>P~a8NpI~yAuc&A)`U{GZ`%+~Z#^z?N@!bQMA#bHm$+rUV-(B1%v3ZFr~ljrV@=A76sU z!C`O12pHI~rpzsDXX|D$cMO8g8GY^F`f2~!uSK1EzXgXg)jN~FMnz0H#|MZ-XaDCX zJ>{p#atF;BwOv|hX=-2RbJewrqSiv zAHc+m!lX?G$1KAI#3T_Yq04_iL$=1+ILpgQ+13jem_a9J>mQJ-Wa1(R&oYb9vv{&A zmevG%<~72#m)UHe(HsJUCxGrHWZZpNF`-`@6|`+(8RDG^8|bZAF2;HO@BBJifxOQr zHCS5&wlD!9b7)dT9lO!gJX;p#>s=7!DdpBkJqE_lq_v!T*2u$zIAj9nEwM1NQ~73q zs{S395*eS;(9aFEs0N-n$Ox-P<17buJSyg{iUY`OgQA!lL5FrjR3jmq!4_c3kNcvW zJg4Y|{98iFDsE70@zkKu>k2dv6`ofQYZIW6sSeOP7FXkT=if^(1|)mr&=Oj&gpBb9 zv{eKvQg3ix(JrmTGbs-l<_$gwwGl}=Uzc@qIoRfVn$E=&Bx1zPxi<>4^qKzQxc$)( zX1zmdmEOz)#LTL;(@;K_?7&=F#Z2d@;e6N@5h8(c9F&`E>kkXv%WJeAwU*2^Z!3$f ztpJk{tu2n{E{m=IRvf98vHw`DlZy>G+nGnEx4k^cOVao5!A)1->u6(s5hpF-w-gJ3 z3raoYr?rB8Ui4tB-b2y341rtr$`bzBM}nclbTN49@5RS2m99JFYf&0;i)G;TW}yWK zudOEyCp6QV*xsOYLx^rwSj)uS^Ku0db;)wqwmq5ttrjzEfQS@jk}SMwoL>lwDA>)e zpLQy7V^V|mVO$yi&4rWbmvGTN++zG%*dxtbkI)5&3*Lu>ZNE-@II8Hno)OF~B3t*44O;XJ(Ju7LM8YQlL-R+4bS#dEZ) z<#W3wt_rzofuLC%L*UBvl{3(x`~NPzJQS38|D+YC2_5A?*{UkR@ZK6Vo;2@Cak?E^@g;`16*7_GKHV~^wD zo2S$RK|gY73&(Tm|6J&RrLaC&dZbSkx+jCB65F}?$jN!wr3|P2Nxz%LOW0b*d6YE5iPI@1+qzR@6F$A>d|fDY)6@Ee+YKi;Cf##e1`! zOuE;O(Is}fY&AIU`=vYl-fLjGp;k3Pa*7wX7DA;?zELAz>=y@2OjVL5ip}M9ZyA@t{a4;=xLwH)HMD$jCVxH%c=z!nb08 zslLkk4FR&2BnhIFZD+2_d60^k{VUi~!FTqfPge&CY~H7NDWST5 zKkEhI-g|`14*o4~CO&W}Z?Z5GCIk_*@5`bziT_@K##Suv&lX%RitLj=U%mM9tvOfb z7-iJ`0e(eqKaR&(eZ`5R!qc1#QS`xDJw3UO#W>-I=#BXVdz5lk5 z&Y`4Zg(|Z%@K8#mKz>w3zl2ZO`QPd1j0OPuUrDTjW@=6?UV+|0O+CsX)Fcr1aMBFU zZIvw?iN&3+A=r=06@jmAzKWN=o5D;a_k-BaZ5W}taQ*(6ok;s)37d}g{ok(S}a_{RP#`~6M~b={-9s7y=p6fYBw#f;04oZ4z*kQ`k!yw zKe>i2C|Y+^_9-hYBlWMOBxSHOljhz z2&N0zo)AYzXZ8f5q;m)%SO4vIIZ-mwEDmM-zcWp=$>DSgx5kGHVm$H5&-8xCK_M;% z>JsN|>iZpqGU8JF!PniTNIS_tn?qqBH-qc3mhamEXLSqRGd^;VLQXA3F-@MtujMX| z>kn_OlZsKLd|C2WkAVcUsGfNCw?n>2u!niiy5KPfHDYn@U!)X*zN7BnB(?^0tOq&6 zix@3@)s22V{B@qhBj5U{Rs)i3%IP?j8 z!KAen`SwY+Fo!2$SE`+Eqf^R1Y@dz(;r}FSUmT|#Vx^KH@I|)8WM!*QD&K=E;{0ot z+44Y=;|psUrC#DRtAp1J_W`0`xP5P)#1quLF&`=#B<`rlA)+*2B%e&AriVVsYonwd zAl#2y*Wj)+Lh1`wzhV*xjckslZ_drgfZzjoH5u+#h`AAN&gY)xn+h-R5U5PzO49P- zYWl)WS++AOJ#b&QqNBFi?wc+0azJfpiihk-0*R=PQx~Y>v%;lY%a#LEl1Nmeq;NE- z)Vs*@Z)HF8SUV?t+fZ9jB;iQb=%je?@owLXF(@-jenX-7?0-oTqf;ow*ttAA*p^3D zGhpl_vjiFrkL8*khEDZ9>eTy_G!0txcIb<(2%5EM8G0K!Lk^&>>!y;wytc{34wuxAG8ts5qK-((h!nnSr4DAUG5!xLi?VT4n1}@E0+VcA2Cl9CBk5MnE zED$JKxC;B2rO+9F&vm=rNm2*Ze>Q}k5s`yYxX;KPnpvxAmiFooA{8*tes#z71nNEp zxUNc2_g*nxKPp=T^nmvbj9UA0yR)hDeJy2v`(D*-O=~UIJ*Vafx4VnA;6v5gdRIfX zN{u|4TtzM;6lx>7uC?2G`zfmNSZ%BEwbF5Z=BAVpzYj%P;K7QuUwcw9qLKTIU8!1l zVchZr{rA*dw}fDnDAQWRVv~p+zI~e9|2!uWWt};qanTGHs}?|IQAJKqDwtC%I2yiC!e7_j7=0lNCH-+T`&50j*( zlcn+6Hb>A3vVcEIDU~F_YYb8DDfz2safrVp1TT{uf4J_tG@NQd*}BA?6`NgO7la6j zr+OKjNp~DPPsA&&mQs#ZgO0on$W&+^CNuh)CCGDGVZo7OPMJhIFzD6CUwXwdidz%* z%}YPuVW&sQ3ar!V^D?xmRyo=F>c=ip-w_-WmIMrOFHj$hLNZ!U&#*yFR&(@z>~h`x z=C6gtdpxn}O9BlKf4-i2JXN{Zb4d*%^{afA``n&y2&TAm+*hj6 z2w0HPX+|wY!06aNHK_{mUNMhk8wtb$iC@N4?tI!IvKoh9x1Oh+-yk!oAJdB* z|AHZu5cXYLHP7+@U<&;u&9oU%`yMZi!VJ05zE-t8^y)iFG)WZ+3K+c1cDrWj$=s6w ze4Y8qbaEM$fY1=qq^$kV?I>&^qwX5eKS1Iu%wOv0gE!$2a(&>cA1GgY*P5`UT>Z^m zpXL2&PdC9uMY|)nLtAK5DKl?b|woB-H0ul)?dLsCNd04*aq_ns>&(UmsNYcc!vzxmd#7!ehgBrh-$tjhmw5(`Q@$8B`nSS6!ZpM=QyWtl z%IZqGaKESiIM{-JBNrFnX?w^^6<4qPK(mXu{8l<=zo)OGD-c(|HLv&JE5H5Z z`e3bi+cwPqLB}3?*JACP@2c(gc4W@Gu(3!_ri@zHzr&Yqb!jWkbkaVCcV)nn1S^KZ0+~QIVb~II2sIrtyS( z^<39DjA4qd+AaJaYqpYz)Ke76u~zBj?dPQTHWN@@v#AEs#_|KmVH`*+2=!&*Ze#jc zi(y$$8hqtAWzT&PPDg;5J?*cTk^7T~3ZA3q%Ac6glZsK{lKCYzqN@PVk8ZgyA;6?_ zy0`Ha%f(}WDW_TE`?k(-x$qi|!P)O*fmdA0el~jT(gn$?W7_z9;f-ij>o(hoQ>QW4 zGk`{DXgI0Jz-;!{gO5tILhd=iHG$Q5B!6&ISUR5YE$h{a4Ae``CG|B&stjhVW(eb_ zYftQM1Y~*kyH>EgQszzp*gb zeI;hPV{Z+YdOw^W=dx=yllqoJY$LhI)V4TpBeDKO8qNLd@Lc~!c~poC0&}ooF@ycK z%b?R?9F;Qdm6T-%1-^^yU9i^@T3ojAq&z|CvdeaiZn>0tE7j&J4-jw85WlQ)bNu1)> zC)n1u-ss+k_QRBj2gBB!jGoJvS&MFudce_V9Pg;hUEP4EB3c`%Fk+z70wQr@=zMST z7T?-*hpE35Y*W&x=UbUrX%W!_?zmcYdM*A)qjMZ$R+&DaQ7=uU zgL#(k81n=9g3VCfdSRwf*}6NYdP79>4nAXk6jX4XHd8T6K)~q~FuJJ$EM5#zEUKaKWS-U7NDODgb`C=RPWLxPR%Ws*Sydih!9qgOW{@F|vn zrdl6P2SAO{E8g@R>-a}jHcHS#MDt3BQPKMQ3oz`6b)4N}Idb`lpCr@P)n{MBcj!+$ z$TySbuDH6iUOYJ~G+(#DV(5~v1u(_|0zrq74E~^s)+XYoR`eJ_J(5hf+y}Gzw*y?; ze9y#F;^qp|y}%pl%mPgDY;kQiYJUa$nr%p_ysKw#(&ajuBS)}1o@-)cn*SA9;~_0C zQf}_6>7@UAuAR7(W!vI$^)(Yd=#8A)tQ7X0;v@J%+V97yVgTUw#ZijiT)5t43Ikv3 zt$Xi9cFcs9<8G$MA19C)a_uzwbu&gOitCTM#p3U2^s{Lu>P{I7HMU;;KdRm`AjM3}xP!$8SSH0xZspkkMn(i5naEy=6;$LQlQBG>ckbbj8ctW(Jj z@QD6-A570!g3)SVyL!fNcNTEY{9KexD%EXM)^=0b|ETyP#J1d4wt@Y{->CAX&tbSb zLfP@dbE|!hPIvexcz+2LioaM*exL<)a}~NwzE04QQhn<;vNJxjV|R@zUp2Dcriv~g z)tD;HjrE^J9?IDjdO78&Nkubm38X_xbE=jight${~E{5 z&qoiL1@1pE_AsrQ&25uGF|g|);y7aBnxYbY%A~oI4=gcZNnkEVk`nTu$%^{l3ftZ@ z*KPzK^O|(JelLO#;5~CbTeXOMJZ|Wd+V@=3?+O}vm}}eoeyubO@(G$n5dev^-(GYx zZqw_4;$;ucE@Et7bk|4s`e2>rhJlmzX2)376R(iLmFatk~D~H4bQ{=xV?z zMRh9>wSi&{*`V@yh)1&TtGY+n7-UwWZIrrXYt(#Us ze`2iqJ%z4AU#=`Dav|n2o=9jqaD|JEcgKAYX4&yg+Ds|sk)%Lp^G~4;;_h;49?{)s z{b}^qSn8%>gFnQ6e_Sed&nrS$erXI5dxQ5GaYz;p4&z;9**>sEWcj&_SUcWzh^)nK z{1$-YlWq&u>BLz6=7eok2W7vduXy!Pzi?P?-}-vZ(4r&t5RV;VBYgd_aq*n?7lt$B z5JTK0^!NCsy%2k^iP*p%8>vp>#VV;W6mes{mPRWcDOvV#_-%B6cMO3E+^=} zjC`@hI#XwT>os|AA|9xO8g^)M9ieRhor1D0CyR~!F)Exoc8t!A5|7f*?u?DU;?D`{ z{C6dY*OsbwvL?-hw#3X~cAO`e&T!OrQ3Vwe8le-ubgDhoflN^`yU+C1U{sksPJN$2 zRRb~8p?+73VTFNwQtpNWNHP0~z*Qq8+s2~9tNuwG5dTr-xBjFbxpNXN+0c`&rr<*> zMN`t@)XYSMgOYd6Ce@D<^+H@PxJ)s=)QuV0kA#Fo<^-50rLHhVXR@E3MN?UcpZhOf zlh5wxSNV}H4Lm!HlWxouQG;zl`NxIkQ+j`domoRDSTYgQEHCV=33v8{S~18aQUccZ z11JAf#<&+kgVQg96Q2#AT)>3X-EMGLkUE*3*-*IJIs94JiV))1Z_sCTmgl=oif`5G zy`th*dYDk%PoT1J_E4xd+dk74uW&?8fI71l?L*Rlgu82ZdA4}k(p8M&hllHAaMlvS zhd1Ms1|N8Q?sIhXfY{G~vxl?r8`YIdl=0(5!P))A^X0q}Fi7AZVa8lB?#}hOM(cWC zQ~{ z`LF5~;qLG|Dqm%my6t(QMGA*Hj2v1M$at(hZF$=M8SUXwCfbn|Lr`wF4l(Oy zGNh7jkc~bl_YNxvyXza#M>Au`Bo4Jm;(F5d=%;4ynLzDcAwlGj=%=o=Ftb{mHN?7!-_p_8Po%+OQ{^hOwi~Oc@tu?F7cdh<8y9? z#u-W~%Lvp(xn#A4`#btpgK0P9nxD8h+P?H3+!PKer7oh0cP*dGQ(TCYTfA=@7BEGMW6v*=VtWXeF##vM7*G@Sc5g51=i{B^ zEYP4Vw=_QuPOpVy(CZ-1(uHbnH@nqGX>HvqCps<}61zjOpj)qOU8BcPz-;Uh)uZ87J)NZl7J94d~Mu-0$Xn{F0;PsB-O zy*veZB&?3nzh=kk&)tv@AfXUzfIHw<`hg+7>-(;@WZo)|S3L?yhB|m#K9*kbq`=MTR1E-NFmIAcq)USj+%G1AVtTeGH>%25W*oR z+i$CUMWS^r@K(8OZatH}&5yJO(&|RN-`aEd;`kwLD$(%RJxnFPd-2?);Ng!Wr_;ti z_j;Y+ZWKH0sr<#GaYj0n9f3t)E#NVD5xjnvN8KDspAXwV-`$e^60+HsUZssc+oW42 zJujJ%NK|f|f1$`Pp|DhK407xK)F;fU!C4g-B1jD6X42Ub&__&ldzM){Pp>2x5YjHT*&l9r)RhKu|pU6UWq?N30Z%_)&h9XPj|^AEKP z4~6}lsSgI6?{X4UKyU4=Diu^*#2{x+^pVeUt((ht747|KagiP6RvE7UHBfrg^ua)I z8M8y%=h0V8uP1|KqU3hObKirc9z&?Qey!*n;c-1@)R4F}EPf3*IiYGE?PDz=t19{# zakb-?mY>~fFiAer#YFC$+b}s%2gpT*D)ffx#d`d1su6|7aAqf13_3N5bXSCKeNT}X z%%Wr;H^@zC&zizA{9es`P{58bfOTe>OL ztk{{U_!knCo4x7J1fl3^`T=XjIX^ZqvZvg&+%m&FQopZ8r+v%GTiQ2d)rCc7C5Q%K zxe+f)d9w_ZK&E!%%hO|N+U_!ib$i{ioEe8(Y*O|c)g(Sa%Fj#>H6TC{C#sKn40bcW z?#U=RqgYsiZj`X~c z0qx<_MO8*5@31t9tigL#iD2(;FIC9)YA%^y##kPaS7d{D)4zM&qoqMrA9YzwbPY2K zzU_Q!OjD+-L&a4hAAgCQzV3}&e0n}V7vCY@$A5jv5!Tc4(IxQk&gV{l-H>Ie*%)*u zb#BDplCu3^96c^;CsM;5%l;|gVpu*Sto*R>KBLYqLw=80;I&TW)#9>R!SU2DetbWB z(7``i07*ZlAWMO_sE|QJ$&LES$7Nl^j}4RzhZA(nAWvsNA+q1k-z5FH>eO)NIejG_ zTr1l$DWSs{bJ%8772UFox)%@9&P9f~4n`7k3AF62g&rK)-r+IS%9nx^Z~SeRe|koq zesj{u9I!dD<0-r`Z1jBx8$??ZBAjjmQRZ%A2QcwJG0bBPLzj43@;`OnTuZ9j$C}i7 zJAD9E=Z0a%9PwYcL@_4z90%+H+OB9S%ZJ&bx$niIF?Hux7(eZ7xI|(HRdtBh`lT$V z0~|>3ltM~0nrOt`%?#(B#&(F{(!oeRbQL|acKI6XXw1W>1j>B6&-9c2cQYFIZ9JYI zL2Vkm(x<E*MU2q#BFq{L|Q$&99EiRhrd=St0L9=r11s)XjG^ z-cDMogw6n7zd6`PMiFGX9>h(te{)pi{cav8Ig!J@)t;tf zMv^2l`2j=nsr5d{;D7m@5*vyJNdyj^Cho> zwwl7`iz{NUHf2qu+4o&Tz{W>OUm?XHL}144RssDF`W+wDI@qGnY|KK-KT?3(s-P-s zs8%ql@Chfaxm8*3A*%K@6g+i5-!viD8KdhsI(1wTi{P_1=7Z^te201v&?-y|{z0k^!3dvu>IjCfD{}_47G|XuW=mb;T z;jeM5;Ikj0{J&($5Dzm*8h4di{!PVqty${mcag#V4`2Ewo+(%y->hD!9rWA%D?1h% zMZq|y#q$c3=gRU%ac&BL*3kt&6{Sddj#I*1Gy0m_GDMSnM>?fyyA=D!?+2NkZakmi zC%0d6+Qn;|nXaFO7-_Cmw{N*(2ZW}#p|{B6XCUID6x7yOq>7P=#1GV0NN`<_dzZ>n z7vn*{jEjRluRlcefE>2mYo$b58tns(dwcrj`B<0`YBW6Z)#z|Kab&mS`hvhY4@}G=nzxp@ zS#01S5sX?e+MT`n_~G<}-0|}1Z=HJi)%ICv#Qw*!ZMS?dbIC!^(m=j zhXc(efNHo99Q-N%v!J5Q_QggdWtKbLOage4mwDd^i8^OKjecTwz2i5156QQp43jno zmPTkRmMG9J^aFQiXq$p;$EMTF=XPC##CS-?JwI3Q_Y` z|B|3R&=lt8Xy`^h)7GUTU^O6MIK=6V>tt%faWjwVK>KbIbfT{-_zJ^)W!q?!$| z*0fiHJ-=#lWS>)lp2qP33{$gos#-?`BcH5gIk|Bj5-OGtkTLF@53?{K41)R^xo5^5xVwG^tpk?&ft(nIK9 z(!MOc@sFOf0r!<2nlaRbeI`e<-8*Ke$ZENWa6b3pjN~r%`-58Nr`=hq5!qqkZZl7; zdRgR=t>0`58{HMxYSxn(YVH&W@r18gb1?nLyVe6tK>u>nVr*=m5CgJoqinV{PkyyH zRPr*3A;=W4#a_3w&Ptu+Zu6+QoA^0ze`?c=(I}wqzpw~# zag&Ce3f3mUOQb`aDw*10^^fveyumcQfxNgn*t4j}+OQIFBL{8@>xWmOK|_+-G#!QY zNW4VX_105x>2md(bx$FM07I88PkG@=Z6BV^Cc5*(GT-$#(H=alS=44+6n71@)(?H% z?J3u&!PwhFrRh%+X}@U=kTjp=I{ycG(B|OoG`ii;zzrq&g>MR~GwtvC+l!HjfLy{y zd^;=?_+N)MIJxJV!?7~oOGw2B7fi@^el<^>UV$B{#Q?9Qg}UesuJw_O z4(t;v&JYpq9qp|BY)0#pHU8o|5|fpxIS(t&c!jEwPH%nYTNv<7SOd>0?&+9MP}Z3_ z{B;2~2SnXMYOWxbejr+62o6V+C9+8jaP!X$JkhgT@FkdIGubv1#pdvk%E=T>7`>XV zbyg;vla3ecSVAM<*lMh@sJ=x$MHxOz#x}?Psc&L>`9a1 zBx5gWGVge0mvv(MA0Y*6J$hSHrxwQsg8AB~fr+U(_G9t!ahY+Ez}p~jP*+g5l7fL# z!1kbZv_0*@MgF4FwR!qO>ue8fNJ+_ng7K1d`dTz==tj*EBdbrH3or@z?Vq0vEw8-5 zoXK2_m6Sb~Kki_eiKB)K3Tl-r!zmU%uu9&Jfm~y9IJEXNo;$gJ;UGRXQ#rw1{GD8e z4qR^ydvfi@f1RFP#F`16iE^XkAm;`Kb?Kh@-4$%FR(pddH=1`Pw51wXchM6lYOe*} z&~k9mUtT+iy^*YO+O!b|i`R?v$MEq)($ml^th=E(+_DxWaFnFRWySb!YH5AV1O(cO`{B|sZ8Fd#nx&7zNM zm{2jR_MLCXAoc?WX$E>DGT8(>ndf6n1iiB~Dim^Ky;s;%G}@dMfO+yM=)*TM9Ko^b zS(X^T0iX*nhS9nvpQT+)S|1qpJdzvD*IaY%1W&&JrM~EWZ0yRTEw*3y0C-amfn?Pj zwCUV3)*IKeqxQf12bUXqA#LW|?XEPot|g~Z-{^nT(&EsO_`EnVM8GFo)hqToYC#CK zY>43OvE_i!Ig6LS+g%Lh$3((f-hjg}G1sG7i2ikjpumU3aCNBMZQ4d`fCBa9c%zCA z*4D*%ckgtqc&hEMk#o-@yDZxSzx}Tq^V07R{~rjJ4PDhW3r8yl4hwzeR57EV!iqLi-4pL*+hE-N|YX^ zi-rQ+Zzt)?FVak=p?eV#PNs)6?Bq_#fl`N1Ulp`olWOnSU6fWc=Vk7K+hUB9R=Z;_ z3%3Q02o|@-26|{D2C(bew-g@Tkri$XV$f(;KUBB%D~OJyc8tGZ;@`ZH1C)7HWjff5 zMsBH3H8MZ;```!az7lIJE*FgJa&@^)$^JI&R5@Y?@} z<6fXRqyBFig&qwk@?BNOq+}%ZQR_~t!CH5hw)*mEWjepgi7q&)t*^Z1U5EJm-?IJloYA^XFGUqxadM z*gM0(Qb46z>D(@q>@W)o8LX!bK{UKiwP#;(0psrM4t&nSWma8-6rq^G>33l&@ASmp za=grN{G8y*<8o|Jw$B!nwc5Z*It;=g(G8Vk;5h z{PM`_IUoD;;ctM}A_(iKqWDHF;mujd&+pjd`xex0erlFh+u96XE#%%WoZ@5UsIDiQ z`X0a?p)@#SzX!mF!Jm-FOme+*C=IvT@EJ!2)#3lyym*!Vqz5UD3wKmIO#eICc4kDO zn^6Z_)da*}AGa?R?>*%Y`)pUMF1&1Idn31J$HtucpeHnFHnU z407zN?!it{J2_4pB@EE0vsFV6X16))4k?IRxy zHUuG*5Ktda|HEblH$8JuIJiM8B9m^lG;ctPz}Vu`8!86k$pG(iDjAOzs{KaZ2mn&1 zFE{H_OB!h{b(LBql| zg(B5wY7IF~l?5GM64{ZjaP z^Y;gNf6qRpC5^<{&ZjsXRUQ>w=g;1|9%~4m&7%gKf$`(UmzEKdZ`L}9^kFO@&InhJuM7&)cp}17Gbtm0 zm^#1|Q_pac_O;S;;?gz6&!z9I;`FYAjOa1!rICuSM{-ecltdUOW@!SGw5NC-kFh@8 zO^N}e*vg{p7WCBhD*OOr6d%NgD`dQtlv|ES$ac%Rerd+;W|7>Ib?j)o?qxSYX%^dv zu_JsL$E*5`{<&y%Fe%C{{cUoqUQoV)r*Mo1fGvN!1^pFM=BGQlpjNBLUku23YI^8h z8T=L_VALdJs?4fqgUe#OKaICPtj@f5e8YeghM25ZeWD-0I6aHEGo!c46$qY5 z2=^=J+Llu(Rn304`vv&=1>pu>e$3qSSdiWC;JW_aQ63Q?1dk2_ELC~ZT&e=ksW^v};YlhFzF7~bJ?=ZjsddBd4zCZG-BZY6sq!*$$D9mkB$Tl$JCJKqks>^-^A z#RM_A!&o5XDE}(*{LxhnJyWR~}LsR3xr{YcE3UX43r+JNqir8_WW_*78 zqZP)P?T6<0_yc+nmh(D!$EGEWWD$rYcaE@u5Qy-yP~bf$Mb6G|s6K2~66b0M)nV2U zP7v9AG2WDY#pbT`f%5ctX__^W9(*?VJJzG`c)Ox>x;XWH&S-e|>-x7lt@N)n?~O-C zIe^F=t0>wO088;`^r1iYOmg zUqrG+_L*eSxY1=DyA^ix4fkw1TCkwJSoL?X#52Pe7X-{hM*P24RWD@P1NVcFq|$yDfSRU^zv6JUp^23hv>~71DXJ4=svPK0jjCqc~0PT3}R}& zr#P?F$eJFn;agG*G(0lav^I1q)}$HAB5HbZo+ZfxIDMsgocYJbI7WB9et){Tr>T?P zo;xkfpd5iuv(!Qvub{qO8)xTGXhUyO>%H5Ih33G2&fiY{wY6%H!LVK_pwFY%@{8F1 zm=jg~>}WF{vp<8iRrhH6ypP0JN!ug|O|YhP*gNE=Pop_ilm zOrn;_wcVA54eUq!4`K@{7M|v}{ z@qk?`(M+$5_uk6;g$yiL-i=?!snxwvVz#=(SdztliEXly)nz(FVZ&LhCFXhr>`dwi z`}79)JNCqlMWe(7-s@3LmZJ*LB zt#UXkg8?g;_GYEY&caOZbIU&5e)bId`mwpveP8#8+Db-MqRmi*Ch94v(Ot4r#B=Oc z**AyFBmCk3gVEx5gLN4Fd;&YH#@Bq6Up1>+FhG1b8#oQ~ZB)CMCFN zX&N0!_q(!@X}rLTA;3f3R;q!Dgb>BhXfG`t5Ju(-nG%CBuU4jjY`iI6gE8?7okYh0 zkacXA#YZdN_c{WcZ%9r!Arg&Q5k}{j3TXz>x z1hnjRu5_nU1jVzaapj~g$)w9_7D2)Z=JxCeaYrdd0tz+3g7pjtitp6MCIEPiCt zGR2t(cPpd@6LdUPi#l@2^I&NciF*b6gGw9jI;KQM#vX^e`7*w>%sRu>I)s9&6ty)ppZaVs;?E+kYvGH_H$j{B_`hKdn4(Y3Gvi~0~ z0oljJHy-dry`YI6?Y9a%?*PNDD=}yyxN%?b*~}>bWkH;)^5j8y=()Hj!>`V+0=q-| z!h&CW;*4iOT_!hRAO*{Ehba*iY zVvSWX+jAz`Tmd!RrVy&xu6(++x9HFy%PfI2+VXIgci69a`%_S=OUlI<`X?bmCv*%Z z*JO!t5&}qTeA%y6(2`c4v(pU`#q4J1BiFiGpJZ`Tp^gb&P+|BGeA?AKt>KmNG(Au}}2VhZwW9n@(A) z5-k+m<)ztFX5e}PpRbi6_nGTHn#cMFAG8y_?lxY%_hF-$379mL!9WFkneuPKgy8ZL z`(rEz-j{Oofhj*=!C>8zssn(dd$vw4u-FIn$?2>AvI~!cyM~``F0w2e8DJQU#4>#F zB#9+CCIFsx$Yv?haGRjb#8CY4LLC_#x2S5JyLsvB9KIE`avM$)r0t4&ELiLDgzYuM z`6lrI^uj`Yyf*T8_TGusxnp}kn9@|sKfGQgdgR~rcnefQ=5wQWOhIwM6~A7CF>215 zqFlZx{N@0>>_k3RqdIu$^hd#xKmxLMej@rbj+Z0et!9+n5xUkR?`g3Wd{d#1gr zvG*5ic8WmzF{)O1Fv`)qwMlE*YSt^cLfYa{GDB+8eX~xV6_QB5on@Kv4!uZ35~2U{ zAcg6&Fv}HYXSz^T%or*c_?B~xOM&Kx(6(Ga_fd=zq%fsA>Ml*w z|2e_`O~mMu){@HEa5zORB~J;=cq-Yq__RxeUAHY$(>H-o+gOZop<^~}{aLxl;72qO&ikI|1jhp1@{9|z%l#&eEswrp#7 zol53322dj~`{szQtASvNa7V)w4`r6ZH@!$*;}Ad!?oiy*nOg2YA`%_w7ZYDd+D4x| zC}y3S?n*p10BXEx(&h?`(D-&l0IM6Q^H<qNca92vFAr5b{w1O=CJ=?cr*e{Afx;sVZPmT4&`{z<)Tq1k00?8QY5!3KgZ$2amjV9Yw@0lSYzK6m6|{$tiQXZpmo zyBE*r8|9n2o93J!5MBudtVf_K?)|aq>D#&GCnEP)NE+&EL)2HirD2(0RsAJcPB3qI zNj-DYOvxt#=I9b_L@}gF>S*HZ(c-OtE0M*08#xiq?Ys#INEHFy9Xj(wjjsu{f+#ro zP2y~1xy7K7M97gyF9qfS+8d14J1+`vuMnl5AdNJ8o7;HXfHm2@a>o5mDbawZ6~(K{ z8{SzYA>WQA;LURZ`^~0F|LQV7lTlWqj4(;sg9t{iU*;RVf8MmMgomc|(aTBCfK5Dz z9m9IAWL}F1iy~gTE9V*IBR+3|zN(H9-L>S8$k5+J_lFena0P2(R4Y^{+FsoH1`^Wz zf}O{jpiC7i2@vvQS$hY`OS#5$e<}zy-0$g8;Hi7ZL%}R92at5U9L-#tn`89Ojtn&& zbaRzawF+4HN*J@|`;tna;Vd{8iyEF7Kvi!t2Dg*xRlX~A-u{1jZ1QMe32uzpkEm7ypY~R}B7`}}-weXVPuvZrPA~+a zA7V^YFA~fjl6e#B!F;}geTLkio=xV}Kz;ap;DN;~Iys~1i}O~`F-f-vUlqtFklde~ znLC^RA9=7<4#*iFG++ZXhEIlUwbHh_<$75?0<=y8dc-sr>1vB^X_@a0wd|}59 zL^V3RYUkF_+Ys)GQuV9Q3?F!O9uS_%Y4cn)jcU$FKqGw(5T+A}WfC5r`E<}`!YJmw zN?azPtXv5#TfEV5f$x?Om+A;hkO^;$vtN$M0T`O;nfjLVntKm=z=B3s%|Ea1bj?)v zDrO|E<6qY4FZ%=}qioAgJ3>!(4H7p*KNRWml=BObz;9aW=$YxF)PyftR6wL?{T1p6 z=#HPAQ<^D*tL>ce8OSE&=^u+lREsyttz1np2D6>t6PO(ry=CxdZyTI75*PTyc4 zu8QoVjZ?X3HL3lX`v4S8hYyOEVv(4$vcZ;ynB7sb{D2m#u)Ji~SaW^#knf|GCL^}1 z!vu5~lf99trN@**cs|>IGOa{WBDy$tO-KXbIIT>K611DPw%4pGpzSFoi~4LaWzs5~ zMS$~AEXIuqF%0s4Z2Uw6;X>pavb{+<#>3o1VfJn8#X-fll(rVj?AFw3v9tCW7OYc7 z2<9doD#@<~qJW%cgsy|h#uC>QqKAdU(-#x|o1xp=vcid*L595mY0Cw$J!_jtj^hW^UAeMbUF2M!v1HRnQoE`W z+n6yD=MC0*FAiU;^TnF@omwi}LLxopREUHjjUUGv>(m(GRpoe#*ev_zgs3eVy z9d&v+*M|Imtuq#XsLKoP-m$lPp-{;`dWKghbduf&3yfSUYX&D{N5IMbbs9-&oCakN zN2Wn0hwQdangM{Wz-iTvbnX%Blm|&)CkzLDotew*#TlY-MznYx>1&Jf6Rk~I7O}ny zfe0beF#x)RTG!sMIf7oI6Xr=)H373XU!HVv=Moret2Eq-(0GrMB^o*rae zeejEJYNN5L^vj{1)BIKbqGXQoYiN@#s2%;I-SyTuu$IF3QiQo5v)PZHV@pgTwMb%(@bF@l$~WR3p&;VL zwhH&P`stcGW%!~aD|=13Ze1@cC9bJR;Driq-ATIy`D_O<+augynOxK(S=MaN@0)Q~ zJ;S{YMV#N_3LBrpOqkBWQr{}up85~|6d42ZiMo=a6%Aayo+G)#sJAN>TGi`(a?vZ6 zZ%^lBN>{IOcf=~H^7Tm9)s}h#_k4piG&r;bp-2L`fzNKMkLF*bTN74{TR#3(=Et$m=k;MoNTSE( zN1!KxENLX2q1dK`&iY60Bu`(DzHWu}2u`Ly=RY1GK(T1v_rUSma(%df>FKxmZMwh} zLx{vl(9M_x&jGqTY3rCxV-3<)GF!3YQ$4u#o~a((3H&i`e-X)yNGC@Rm10uEAw^f9 zM$5wH_AOt5i-6RlB0+F@=&*$Hp#gstzoc$-yZU|80)yQ6ZG`OzsZ#8(My0|wIT89u z$L@}u9NM9`qT3y+uIW}lFIj8Dr>y92lx{2-BpI-R!JRv z_pPban!SgA8O-mu02v-G1|4Tsigm)&I&IT!mK2DnUGc9u+A( zYoJSdyr4cRNi{~~P=?G@oCF#GFP-K>cIOnX>tEHVnw3-7rJ}N#hsb)`l_NsAZX0R|9Sv0sB9wb=gheU5EA%UymFb7m>X*X; z-9;aCXlB#ioO9h5;@Ok2-pwm=Z+qDHk!U`MGA0Uqa!lLySxSHHI&N9Ko?ENl@st$) zjNxWK_VIny@BS$rMf<8}Qn8qGZ8%g{u(m^P*IFLeUvl_2J6mk;&_2|J{??7@?Eeul z6gS89VMH=2(~uxLT`nst@D;I}O$~(8gWWpwRqrz`u7L3yfBS;U+YX&Af?(Yp(ZE@} zc#3^^Tj3hzdTUL2>*l@s*KcmAi5(74Dae`M#7z1IN5QM<@r}J-#3#{tqA7)b9m4)K zAmy+Ges;Z6P({OMQL}?8Kh@j+yxy*OSw=`G^vB#aSAu9mv|t<8?D1ZwJ|ah5w0i0O zHT6c0diy(+AmLK8eJw?Q-9e%J34I?7Ek{4@tQ7Nhxeja-+#S4f@ALB8igoM0-z4?a zfjoh?z-wq7w=g@=y~9M&=f(Zbx~-T}(xBqcvZH})Mmv$X!NQNuI7>^2h0<|$VrNB@ zr~;ROZS60dW*IuMFGl~Cv5~Fg99874df(mA#_oJlQNdA?4qJej;*n>v#)o|ZKRl;*%y@SmE2A@zj&V_5dmh zvVZa_{CgJ#L=CPQ73dw{*`GT+fq{pN=j_M?4Wux?n?(5jHL?d|I zI*@`qqx@0~X*6FL*UgW`)>D~>8=qM}{yvj!sZ1Z23gN%$=V$Pzu_3xz!M1Z4#(Sz^ZgL#5)*N4u5Igfk$*5zIQet!G!T{|XkG;R-9m}%Z0piVQEjhb{eo;9&}X@4BRf6S-c?2;U6F_mGX5=Cv%7 zb;S3RiEPQfKNR3Rj-qDJv-|=+5cawq2h%S>tO>gvt`zXyY?O#RFMteXE|8K8|zQj$2$d`s|zaqUAyQ_CeNX&q(-b zydg{*Os?_V!0p{07f}$DqCIUA{#|CZ`69IMB@^&;a-rTiA6s&XycPUHe{)t zuV0C<$)MXI=>r3fw2Y%-?h&GGtcK0qYCY0c&r9B2d+1NH{9ZK z$0SBVqf2$!|3C$Vg7U+xAIvjEW>W%Z*;h8}gK|#DE~aPazagqQ`{VL&m(E)+v-}UT zZ$UmWdl%zw&eK2t4~ML|%1Oa`t&?t4n)eP)T?|T*BHEmFJPjyHfss_l@M?dnPV+0Q)(@_RMlUWSiXF<P@D%Hue-9gDWmtaRtO-MCwPcnv^a1RzoUh(#L-k2X2Qj_w%SvR*7c_^*lA@ z^a{yO!JLE?ksTUTDKm&4Oiy)e$H8c`{eRNEi};B$kbV-mB0x&Y`L-Nhf5Hml`Erb2 zY=51Km1q=K!1uzn`-SCCG1s5rJBAF+78X?$72h`Eca+8+eFHB7Ma>6POC0(z39qw-BSm-%1 zr*OSiTH5T5Q`z}sJ{PL!K1kq;Ym&x_pln||u%N%6ZqrL$bkdo9wZUgw*77od98;4U z*2*}bO$?--hV_c^G&<~r3zF(g5q6@jQd;J0>X8z6%a5)w)HNuqN)&GXDmzPj0yPRe zt!*T@`a}EONSvI=v%g#QNz~m7WKNlEscPL#DK)8v@}S=pdcV! zN{6(xFh~w9-5}B+EdoPHcMjd%Jv0nC^gH{!XYaHBpMZ;Np5I#QuC-3GEeDlv$Ei!= zxTYH)q$+KExSQ#=%HOZPd$=E0Np59`qvTWtX!qNW26z2Rx!dC;n?3!&ABX62FD;` zrENmxX*oj5@UC1XTIS;-%R9Vp|NFn6KL6rDbNaggWr0?C()G$p^^;Ti=e%=H$xurr z?KaE9Y%@P1aiyE#6X<;r(;_^^x;6N;Z-7V2*e{KV=H+RDUw*W7gwx z!`Ui5`f!O23h(Q+0&_B~@`JUtH#`u6{nD#5b#*{9g24sSG=xsyJd*P^uEt=r^D~%v z=XNkA%40r|tFlA(h$ypzFHkB92$x>f6FZv}>sI+@{yAbHII>*k#TFSvsbaYHtW9cA zV+|?v{*$5_G1svm({@riOh5jQ)zhZzoFJl`P%-`5N&e~8>e*ktM0?L{`M*SQ$5CH& zDzih<{3U!z@Y~>J6bN3Re#MUg4rD6VRo#vynolHjbkn2U;7w|#_vI{3DXkG-dXonH z_T#OAuTJ@YI|Zi$=34z!ie|a@V=c)SiAuCB1>HeF=+)BC3+dOJJ^X)svbznKeN+yl ztifGIJA<9`s;+Se%#tuydw-u%oxXU<{ds0|u)z(2^wwNwzt6(*GU@)cNz@g<4vK7S zaq-BEy|Jr@dhpmk9`y9P>`ZbaQo2|5-D`?d3)lW|d&k&oSg82{cR%FOa%&i#Uq8AZ z661bOt>X5rezZgc{b-xwdca=Y$;DPIOlA7^YuMcc$wNhkwK&l@y7$L}iB3u67msRg z;k<6-2+M6I4c3ZVCN+W(?6KG*T$4FVgCO+q=>OI+ZkiD_p5nG={nsq^CHLR6Sa`%6 z2==fSA-vM}W4oO+l$aiZ<7`a($fdssd|o8P(W=3RS2YSthF190w{} z$ty};CJ?ODeP%Uav9D9~NL{*;bBrjB8XH%BZ&H(<_&KCF1TRp3Cl7_|(yQje*J}(0 z1e}dkLTW!z23G5rPIFccP_;~TIKCDc?F;Q0u4&Vh+}JoX`IMLBgKu#E%FFqpRN{O!BIth^((RV};Lsh6fwqF~||_ z4&{$-`kG?PG7{ee?w~NON)xnvqG6j(-{cJ4vJ&bXHfcFIua60@@J$7k_nM~f)nr3n z3l1*vFdonGWoi>$hd%Krp0B3Sdru0Vv>0leS(V*zq#hd7VD`lKq;_J62>~G#m&!8! zs2Q%=-LS8m1xBB(cM0|FJ2YSa#Z6rMH)u|s`cR9V>!NrG6o~v1__DPMR7L%#QNwz_ zT}&|>=^i{+KW8&xuep9PN|dKXH>~Cv`7D+5P<4J1`f-0FSU_5K$Gz1u|0&r~D&RQL zSmR9|u2{YVB_C&(KFnhFayGK>sHL;&7(<00x(Ma?BIaHoGg~bGKyDpv@ad8h(UQr} z83Sk_PLg`wA~(omqmD~sj9FXNCMtV{2u3V~xc=0*Q@gVf-gxI{G;?<5%AbXM8||^R zDKaIZ%<3A}LgoiMqvM%5Z`kfME^axhGjV(=y|-hM@y^Q|HT)~%3d*8rUQQvNm3Pjq zk7%n-@#NQ=B$%9SrjIBSQUHJB$3$$u@%6HO^rhbzCGQ6c1Lss3+9e_6GeLR+mZRgl zWL=V(?PO0p0fq=hJnzF@+FR4$>)KXxQgR29m(gp6bET>wl~0_!0&`+o&_QE+f-E`Ef2NqPa&sk+7;492*BMy82KeB-8Op+RNj@fPs(qnwv)p=$YVY4_T23PzLYX=2_D-NYPZ)ws@k)Bmf-) z9Wu`P3X_u>^9(0Sj~6^|?qYJ`ye<8<>z)lO7x$LU>r@2V-WrK*V9eM$ySOzA4VzwyS6&Gk>ag&>8WbjyWx{rvRN3q~_iGrWFTY zh)Pf8Z}rQvapF*Ca`I+>OTRW2f2Ki`7Eay#(d>*P!|}l6MLzOp=++4V$UQ|8=GduF zjicxReAe)YQvf7tTMVPAGc|qX6^$V6Qi44JnYw5aVaXKQF^&Xn@FU-H_L<5OHVX0< zysu*2;XmaLpm}FCZgKGSI6B}9dh~6`ks%n?rm{OA9IJo(g2{CD;=4_7FuuODZprW^ zKi(%cp4gco^+|l|mcdg3oUw1(q2XR3i5F5Y#0VHN z7qD)h7>$x)EAqZka5|;a8U|ha4l7z*I7}~x7lxyPOU-|esI}R|BXGJdqp()Xi`ufU zv$WgLrNyl*e%l@kCDZ^_WJ0rRzy?Dr*mCsd`AWTw^FFg0aLrCtMVjiqM>L?qb!Xdq zDRS`v{ckS-m1s&G$0u=eH$Vh2?mbWHou=%A-`TKI0)^`${%bnp>-X!&frJv}Y+w!{~J41@Uk$ zfB0Ie^XH9&#xk{WAqSwiR#FFDg?Rn5nJD9kSjIN6ACW~*TOj4SLHY%$$B;xC!HgU> zD8J0o)-}a6zRPSXzTqPkv-Gw_=Q}e|$JQ>GiWppy-2_{CJEfg7nnVotqdA9Pn11s*J-STw3JVp(uOkdVv0_c2eN#J% zKmsv7!2#zq0V9zneB}BxjPuiNo(d!s^k1UE)giuQx>B#>**{Dn3O1d_2 zYJUoriPGZ{yXZLci`P^QtZU2Ne18c4LsT_L{`8`sOORs)peNFy-L-iZR3J0dm~M^5 zLnOxNYfd$~wmSA@C%jD!c^l}OK@5j{Yrxq;r_F%qH7@BDo|5pkj_n;T{z#y$3gQwG zoHpULnTfJCA2H+bN0Ejjda-I-WGha0tu&Yksn_6gT|kOmI8vCKj$fcv6(P zpf!XfHW&*A`%kKp<+Dh)S+R&&u~%uTn$QSHy%?3eaZHzgwf)DSF6+qu1Dl!qC41QG z)4U@$wGTm-@^$+xKN&^CV{}yMi2!4{%dfs<0kNIOdKX(zla;JOCS8x{JrP$fYyQ<*5&{-Dg0r6xP@5g2Fp9ZomCSfPzTObIW@i4TlD@*xu|_eXaR$&B$Y~#U6e-e2IR}xyo!uPL)f%Sl!O@o+*_WFe zC7B&Tm!NXkpBLSitgcbUYA?!cFt?h&?$6Z|;Q1+p_}(8c{yyfS$&2yHB|2w#Q@)&4 zE0KK>s|E>cUEp0?qQ8$#dDU`Ye>H&9Us)xC7akFf?pPFu;22e=bu!t%H`p<;wT8$F zO7yI9kPdmjYjiE*5VLxdZ~6z?{4Wk5N&vk8w&M;cQ{g{xmg?&GppG_##fqm&w%$np zVV(V%dagRPi$FcHt1v9&WrA58ubKiVn_WLNy}^k8T}z>$p7xfpd@LKJz9)!tLD=aU|D)Ly3g3=3Cv;^C{n=q!2_XGediT}QAshI?^hNKKbk)Q}2I zzla3qv9MphJq`c6W$jAPS=%Ft-GgwU7kv3CI9IhM#)-BlVN4nJvC|$l zaE(M4gW*L^2vBqipEYQ5hNSLa+PtA2H#{m6 zs=`RB%qNP%psA``GCfjL?qBe@mDxeqt`sV1#P_dxG+@G+0uP$nJUbZ{RWv-a=iGTd z&nS-;eLv;;4++2?@CL%CD^ul+=a&=gd;jSE7m5(@lXF($P(eqUdaTsoYogfpVa=Og zx+*GD8|Ptldq$7Xl?iQ%8<8s}(?^A&ln~sL;$=S43WaWU5Sb5bxM*fiuCD^MQZ|e& z{UpEpXm1OLcLK4}Bu_o=^VIa~z(iVn@7%d4nqv8X)nwG44)Yx{pGu&%`?;#q%4ueI zU2HlY$RDX!#fhhWm7oL(Gkf*C&Mi=rqHUjFS&utdayp75`w<0*WkGEsTS$P+zw!}> zA;pL~kq@$`9cYSYeukWQ(0hlV0%}@2O`HwPYpztqZfMD|LB1jK?Z&9Q5jpxL;ZMcB zPMM-+FE}yE+kW;gxuEPI8AE2~mGYXL3XS1$D1kxcgk?r@ut_z#$u=b=tEr{zD$w&O zJ#3g)NnEnw@DB#IJ|Az>=u`_>%|J*u4U4 zT=bx!c1B%Zl4}lLP>AxrKBhD$xi-WXCon|1<^gRR_mwIKMek|0-T>WN?<_h>eg-tS zA9)Ud+zzl(Ew+ka0m0Ay1JV9ckYPkrm(L%=;y{7NBQ36w8Z4s^MjkVb(^UG|CROS*X=*>30 zm1>l&B`m(6*imCIFw)R_hq7o*zBESQ`HfLixG zbQ>n*H(DD<^OM~`3KjArBetbw;U2e}^E?Rh)6K`KLL;tplFYRu&kJgJ%zkfaK~qNV z8K|1tNbsq*HhAvsI7h>mTF%9}^9KA@`KrIiJ|Rimv=5xrULfX-)4|Gwf|5dLZmIbz z?JJ#fmRe+icf8|kz@JaQ8lQFbRI_QiEcHISrZirEneGu!Sv{>R3z#^jmlwxrci69f zH!b#6Dwf!bsunlju}4oWQkX#$Hp(6D)7hFn^_r}B)Q`yh;MHwgI1u?AaFz%KIqJUlip#GN?fp9g> zTH)o8F(gP)N+oH&6z4^v(UKHPCEX2yu*JxV#QkC)tiXG9Sy1Ql+K(9`EtooZzf}a} zy_qlC1cy@?#4L{eQu~hq;V+<1Kr(XP+f3Y8j)7Se2bcL-Me9tYq&VcHochv9Opvkm zeWSF5kZ4sfk|?Rn_;d()7)fd^8=SZPRdaUVS>dyQTluKXyq=`&pmD?Hl93#|5i*+b zt9sm`>d8*p2ewz37lFRbvnYZ)Q3CxsK#2s|HDCNq;`goNV7wp3JbCd<3q#9;_JPBM zherw%ncvY8A6J*QFgqBvll5jGxL++V+>3g97>L$(h`Q?QU^LFCOgJV1%X7J7dWM2} z|1GbHFVGz`_#YVWmoC!`&eu{u_+Nrlnn+ik2fd{0|DU^Dx4KQVK;#_(zAY6D|6lB$b| zSuibhgjs86^YEmb2-uAy&aYU)m3e%ZF_A>6bF0Lj5}$v>bCImVo#g42&c6I$wGKM# zuA^7TJe1=$;dX|O78tn+|9CGy7z|UKub(R!;8!v5;9kL^?Jk}-y%UA>QZu=t`K;MA z6Vs2&-Y-cxC5hLV=92$27YDXtqKgC@0z6U3idmAY^o|!Lp{c(Wq`yr89wfHn;@9@OYJ~;3}v^P=wqH%im(VuOvKT^M* z0?_qvx98Pl+(DN%?$x9C5?vKDI>8T4g3JIv`eb9}}{DJ$|2b5bk{e$wRgh zdFo>G{{fZ(R$C;7pMAQl&Vh|#Hv#%Ft^y_=KYl}Pyok)xjJ zuXV0eZ6%7Z3mXfKizxLgd2eVDmbJI)@HzK@>HfLZp}!AY0(@fs*$MR!#k^~RKHM2O%EO2@1F?BNimTeNgzC=ciJf(uM?mH&)GBRaOv~_z^_ics~EjYZ` zNj1K^^feQxa2lkAl5~Ra{aLc8OEJfCM>2t!x7knqxgpQBpX{EH*p`BU(i9XP2Q2?I zXg#TPzbq=Sf4Eh?GpOC?{824EZSzmLa3mhF+%!Lhd~zaxWrN~oo#irciW_U8*VUol zTs(uN)6WK=$;YQ}yN-3nzU{xS{O-E+^ctJ7e!I3D8(I!l*w#=K5h*}e3oh?{F$k(c z`&_!6u*iUp7_?K@9FSb8kb2`&Hv70yktC@Kh4Mdj-3y+$SI#Z3HRi-Wd-wyQ**ZL* z>?N}Ml_c0F++_s%+3l;OzV+HZ z0<2bW{jKIlF`;H%D}(d1Qh*H~o;=x_^DD_VTxs%ztqiWz8nNmR9%Na$dnP>VS-yb^ zVhk!ZJ~D^dDdIKdc%Pah!9bV`?_m2Y0ZtcV0BF%hv3w|(rvW^w(9VgUv9bE~#lG{g zlvs-GeAHT-ANJaMhdVP6u%m)iTXtUZ#~8NYNF&d+-S8=ds2dqs+R@=w45;sxQC>$Slt%_22ST%I?WVuX5Z*U5B7&jQI4$w9u3KUFN5@gOK}kMpCuSIl(-|~4zp3Z z#IE0Evfa|rcz2BtQ)~7-&r4Kg|7Xx6L^JR_aKLX`3Z-~5%}~2NjH8)B9p>ruR=p^e z^sXzv5+B|B6#bs;hR$TkM)KJ2@sfGh+FjnayNp>T$0_erC~f8V?T$5BNBJxfi6DMU ze`Dz-X_0L-6>96dZBx~PslV?%^1kfHb%i*)plfnQ?7{qbaOM^CeR+!%cBxu_k+Ic- z#xqC_#GYxr%wx0c)pEh4vQp;^@e##l+cPeU z*ZXD-NALR7BX^bu8(vULD;f-*Yf{4X7Y+S?1Y^!Gh6*c?Pd`x-=~P#a<`*Yn*I!m@ zExNJ!^_p(k+xe1-;dx~F4DWE(+*=QRjF_nVI>&0XFYt#sQB1M?cxyF~^oH|WFNN?u zt1Z8un*ldOBZja^le=34uMQd3NQ0qAIR%qw4oUn@diIWr4ZmjQMW5S-UE+*i=z{wo z*`tI+2O?TfYFSr*dnx`O5@tm2Z7Xg&jtBUizJKTra+eQq7Qu`j8@~OFdCMxmmQo=~ z0uH5XW<^y~2qqoOv7g@$=k<1#Rey*77AYV!{bLa3>way=g_^ilmXn-TV0jGllupEX zed=|Z5`{w~>MrSU*L$n`)@< zOqtFDUz->@q>8|gP6kX|U?K}yC&~3t`H}fax>vR?jclP1efmWSjsAGaCrS=6cfD!) zhfPygEmlu#UyCZ%Zy)t`=qp}SI*WWeJt1Mw>0nN#XcL^Xy9U55qC6g`kk<}e9#C96WWUmCtM~=d> zq>Mk@vO8zvJF(}8 z{G4@||3xK71+>i-0mz3COH3yT{akO%#qdUW2QS)AxQp-hio#F_AM5C`$?lFbY!|AV zDaVbahO!&UFSh!Z+}bLAOTMi3XLx^sWTmeC54@22)p}RwPnL4|J@NqDT(vTjgH7Ms z1Mb{g@u5X=OBmT4@4rSVq1C3}4wN^=T4aE!hQCcpXkFWKixRBe>56(2Va%SmqoH3N z9HPJFK`D{6Xm?qlBK~7y*RTxFEOu;oZyV{y#()}n)(aK69UNw|hh)g@2OO`t~UIbgAD}GD*DY36jL2WgMsPtq*Ty;nl&-*Jl^-iP9*D-RBJ8Z3N2U z_>aDiC-Vj#wx>&H_gn%W88}QCCRdU~E^1Y|%}it7N&w-I(JAndoN3Iy;F!wvby zvsiHpD$(gpNT;hKuRYl}0?C@1$SUO2!c?f(=;(t|BHCU&7qYs%Y!JSmyX)`X-3x*c z17RCm{->`Z=d6K;r-p(KmEe#=$N4 zV;k)vJw{#%iUwOD_*dpbo-e`5O^%tumfqD}r7Yw4#d9TPU5U#ockL}TeS};se*zji z|2L+UVW5kYf+~h_m<03wI`b!;h^n3~0ukMEULHpOR=rsyy%n$AaQGO>pP{BlD?B%HJKG2U{%pNJeF=(noHaXM=xLZkx4w>#a{W#y@=M11 ztXtm&`EsaiJt_BRj5!1#+vP%YzLmq=_tm`^(9oJu4)NqzxTgyId1fi0{%-n2wcQek z!3TS6V1{%tHuTzxK{(MJR(p$$T)~*Vc{PE8__ns7*ODK)W=|$KG$hY^H?+=BSrdM{L9=s3&%nhL!DQBxta5sa|Q6hk4%%id$(y zGVs&gAQ+YkZjL|Z2ev{7*9>)q@-Xv| z`CTfCD2FTWx-A`bXV4}Z|2+|_;_Cmv-9F9adH@3+q0$ouqoI~__T+xE%MFG8-`QC~ z$wF1O#hUwLY5wH<`)Xynj`}t$(+d?Uv z)T~F-&W#kQziRi<)0oD-s%c$aQ#B9rD5sEs^o1e|8)7!ylH{lNlp#HGm_$Cw(bJ>a zAxfG`UXJ<%5&XHdVWC*2rlVJkg!RW7hY;Sjkw|VO=3_w>CtD4Bqd3y|wAGGvD%jZ$ z^{fGz)nqC|{{prpQfA5Ij~)g7)c`+_Nd}fh|3ttpSziSluzN8# zE@3yZO6ixb_qF6_;QA|Lq9aw`Xhlr-KPMw{vr*22=ua~6A+zz^wW)IflNnhT6dc+JTFQGIry%$6D@pQvZKzGZ}x?jfMksLy}aP zf^7CKl`wT;O9o+!!}26f`%w+wKfZ|^{%~{(@7Ip9Y9!>;uj|51Oxj&XmBmeAqtC-X zIVx;w?n-8MPxtSKX1P;5?QrmP;Xzc)6qlQw2HLr)JF-97aAKkJ@Y>+8h$^vVMD6UR zAVZ*edj#!&G7UyXLijB8-wb_hGT801sm$exlpZ+1Z~-g__2^(;gvGj6MqYf^M{4TZIh|wjV|JluMJoU@*Eh^XMTUv0$%&J z9Nzx)A~V1H>z&}M6`-`~?K^&`@KKOki}|W+^5v2}B+>pa{RP>LG6&P33NOo+OEv+L&>Tr|m1RIC{9wP)(5jYQuY zjL4f~Nk&DpKf1u;0^E=Enq-~D@WBWx>|iyIXd&4@c_Pv4Z1`C0xiHvB)m zg@yoKAMml^?b7G}Pl;C$H`d3W*l%pS^tv67-Z?aB)R`v3zvBJd3qS-EqM$j`ci+YY zU+9r~AJH#Wk>2uzTRw`GV}4gj6p<|J&RJZ!y|;JOmyn^PPo&w9I%glU*mMqAUVN@u z4|w925Kd8uPL3{%i*^?a4>+H+UZC($+$Z)<0TIK)I@LNoo6U?0WJX;q@^k#j^c&^irY2!Xp zoKY`;ormkOiTJJ?Z}wgE;1<*HZC@prKp*3s8RyVPQaIgxkGpob;)ho7^^|n5*yMS$ z(;|yV&GBQ-d`_+{E73EH>ROkjo##&bBUu5BF1G~^mWA#@&t2%G@Pf%mDv^<1dI_?F zOu=@MJT?X^w&G6RT%9vy!jy3P!Knmx^|@E?b4q1!42O!`E1X&c_P(hgU4GQ#N*9{C zn?89foKd_?*{5<%=|ps=4{&mMl;e;+{Ixwq*rUUf5lMxS&i)LaRPU_br2qi?V1LH) zHW_d)9yLQ2*LF!VJ*1g&{%!UnYJ-mLriej9Q_5l=erS5j?Y5iIvL1y8*W3T~cEy*( z@Wq<pguoIW>J0E8BLe>V$$re z`HfAAkJRuu@(r{%3POkcPzN4N+`AV1EpBL+ymzCX$}n{+P*rK|PY@iy$5s2>n0 zkJkceb<*4BaTMK7j7nawb5;&@rE$0t3-Z63pS%udx_SZ1YoK1Tluw=-2cE?nL=DUN zd^OV;zN1A`AO8o-)V^#L&YuFg8i%6Np8$~5*Zc(N@jFI&4wn#UZAhUz#oePXEXr2< zYaeHRJrdX-i||j(tlRUabQ$Z=#NwA;2%BYkD$Nt&PSH}~7VOZNY#&hDshUt&vKiCNo4Ljp}Rc1B(eeS}KfXrDb8aIUlU<7mg$$A<~c= zbEqS9P}o)M%ns0P7=9)UlJom0s>z*~>K(GG_pE@oXqHmaLHBolXs&BK?MPrt3r2+>0p-`_qVZ`;Yh6L7ayp2wn36v7k!{UO1Ia z*7nUwss;1X-SzAw+#x-^_NuTlA-MSP!);f;?D`B&7dq7N1gg8(7Biq zbn<9(YKUR@idxhwGq;;5m$}FhFe*|?`dnI;6wM2avbseHqF-~bbes=b6Q#XbD|TDX zlh}a7pl;`EVy<9W_upH8HmJ9p9Qvg+szAQiW$L%~Wz13cU_v`zn3=t%$3AxWaXec9 zqdrUVX;%98n!}+h=#5Z5TvQ6w+43H_G>Z7~Oc~i81$??t_B}xTU&NoO-@Ae*NX;lXDFiDzqeU*gs@R*0yBlzpTlBcR0}ch?pzdw6k5z+;E}is5QPhIwx#0IhtqH zEiA}~sN&L-Eo`oq{=;>0Y6oCl?%zlGN#n=iPcO?*-6S zvG`XY_KOv9$mtO{thw3@8{(Y_3K@3n+8X-a0`2DCVfFA^YqXaCLM+zRl6rewJdYE7 zy9m9KBKQ0)Bo@CIwy~{WG&Sz|+P!ukA~1>1d7&*_@it`dY`GY_nMl>N$umzZSd<>8 zYTUJy<;NnUl&{Ypl)J55_6?Ab%!d_S#q0RwMfHJQLIY8v#+X4hCHth@wV~IiW?se< zgBpl3w@g!677AVqg%WLgEn@3}GTDF<@r0AhSu$vp%L?(g#q#b3ksvFnfckTAwwl-f z3Mc{Y_JXle{3(VMhCPRrY$%FJ8{C{tR*IXea`Q~#l(`;IVOLH`r2M!}z&Vx&`w zzqyMOhjD`|%cXoZ^t`gI)1<`xQvTv{jq5G@6Ez+1^;RS^Q5VN9A@+HPZ;A^X&>b~T*3 z%l&8$`%>1+u%YTyOI+RZJX2h+t^mrK(dy0m8$U>)?SuS3m^cp=+HG@C!?sbdDCcbQ zTAo#LtfRQ|DI7)3A}=Zn_H;M6BC&AzwIKFrcM-7?cr9eU4nTx>!jr%~35|xM_xF1h zS92ss*-8mo6kaN<+uo)9@vi9|27hw2{0OPhyt+`e0uPNigowx6fZufw{wA2VbvcKq za^9r5Y!Bo-L)Ez7+cC3@-?hT9^47XwQggD~S%$#n-aY~gW=^N=qq?^l0NRmj|2FTq zAG#4gU$(G7bz}vD-lio+BM>cb>m0MS|22mMwqoHbrb{fGpHx=PD)>MXiYjWE6kO6I zJNR4#joZ03xL*3qpW=s=yun@;Wyp#75y*`!L8riy6XmUG>QSK}cN8Xj#P8_%B;U5; zGo^HG7BZ9|F%Dkhn%-a+8gsEBjmE2ON5T^FNk)+D@>x-rbdWNotRV-^m7>w&&`9;E z(0Z(t`e}KB1O%ZkW;Sz058$qHKa%q3af&>n1MgGPJ9JzO7(m_&%zP{Ppg2SwuyRw^ z{fv~lMW^uqzpuM+ac;g#X{)wpJ+WN(kV{8sjvapw&-H|OQ~St02c zewn8Mfbukz;$RwV_uZd!JMGHU-T9oC_A@`2^akQR9zs_;fUotgsvXh{zIJF0xYYFn zO7*!RsdGA2bBr&EQ6Y-|w&H#?wDjOo)?vMgZP)B4tg4uX%W{sQbtV-gI}*PaO(mnj zVWk=ouF5?ZgX;UK8)m!iEyL;qg>Ve;L0UT()+f9+@g_Ba;a#d=aZOHr{Cklq>Pf=v zZ8pKBo{s!tkzkC-Y&LYXX2So-y}@rFkD7Ih3yGHXx(bLJC%{iO!sD^=+HlU_GH5k# zo;IuSesN}u;kLlx7WIq2fKY$FTBG~YQgZRjIscwtWNCPBOO$ZEHWSEtSQsOAqV~@` z@sqgLpCm~nn9>E!a@3l|Wv3_&#`=h|yLY-I`Xli|?g-#@!I0qFBAAvWV6vUgFU;k~ zw)rXaI6+#1VV#GE?0F+ACpEzTIz5@eFK#^$II)sS)-Y@{k}$%<8pA7-EY>k}zY@B_ zQ=mp5-Gw#B-dJt<(m`F7ABdHbZa>?5@4r_5NB7X!zsd9y*Gr4;VPR1j(vD6>{9eO= zjTxS9pr|f5ipW{KMyiO%scjk|MW=0ReRk*}Q z*!_eQ#}(8!&L9rR?|s|YlNHK9y{`lO*4({Y%%&ftT`m(9?z$3HE_WlQJaCF6nKs=t z7R8zA3l+NsF;ts{jQ^ORtDAGV1|5!8ic@$kb8=Zu?D}WDVfm+(a%!P0g|}%ZMg}HN z_Qr%u_JYnlUv}wz2KwDXBBv#r|_Mlf=K35>;IG zcW>ZN;f!gbMrJ756qW7NRWSMlZi^U~B$0k^-#~!iKvCUuEFpGEaJ+EbVp9wY-tkkX zF0eyX_q9X(`0&uOs#u4NsG7m&?m=xFpx4lV(uwQ~p73~vbPr@1&`sS15#^V1)m91G zlbt%J3k#<4>YsS4gQ@gzM#kA>Q$4MeS>ZPr{#9u3$3T}_B%e&TaYo|+;B;fu@`V#; za73gyHtlS6s%MBdkZogz(3?uO8TpD)Iadn7K~V`VMi(BuJ!sV_jA7TkTf-SGL2_ z)>T4Z`Z|iv(2vC}){iavElrM&X!)rIteOKV^&)(2{%3rb7+Ys}_>WGt)Nn3M3i?%8 zO0^=rAZ0*w%+vY6rekW`)1Y$f3pR6D9z@Acx8N)1y$QZuuO5#mUSJ&sY>O=QXT{^p zk~dLJJ$tH0FN=g}xz;h4>r`nXO-=N;ev#`6yNDC<*}jBg50cnyhi`4YG!;Kd2hl{Y zPa*V2B9jiCXsYWpFNFwOkj|V)ytMtqG&On^bzGlrwtYC>UR=)8BSC;e(+%a#Qq9&5 z{(TIfLpy$XFNGR-UbtT8AEN@A7o7H+qlYf;DK9s^M~0uYyS85LiJ~vJ{IC8?uHZ>O zAL@4)J(>EUy%ywr;S7`M8kJky2TZUyDUUXEZn%s9Q=c9N0(k1M`>IAVYNH0gzB};u z0?W_4O9y%8zkO{n_HVKIVe%zC(PnG8xSQV{ua(T7C~RtTJHh%Kqd7qG&n=A==Gow{ zzc32Li=RZa8CJ)ys^E&-5XnaP9!8X9_hCvs(d)3b{weQ-o2smw32@btJ8uG8c_iP!$>3EBb*EA&erq;Wx2+$G!>X1tf1I;<+fUi7cOZ(J1^eIj~tIfP&zc>1cGL2aD`lx)LM@~BwvV`@yGAynKEFY@iM z4H3I%%UbDn5>f{i5P5s(Rp3D3HQZxhz(B)Y@(=6qrI9#f&#UJ1q>Vx`#6YCrtKD~R zD|G_AOjKliF63LLk)|nMobn1`5Lvv<-1@xux{niI#950{1(H;KzZCXW(rtO0zYaDm_E01rIZ^7sY z^r{YIOe&tcwwQr&G6J&E{ColMeKtW6ExDcNz~|jEAZ-*L;J&li(|)uw_TXNX;nK9H z>D|o?+P_V2Jdgv1l-p`eIy%W_{>f@fQTG39Da_wA!%t#uJU<~pv1K-*24CTMUMp_0 z`x6^l$w=03a@CLZx>~Dk5?EdvH`5}kcOR$P9w$`a~z<%RF%cG{~F4KB{!aGw}#bL4+7VpvRVro2m5r`;J zu}_FbaIG>e_S`pO+R(2;!$;_E{?9ip{b_e0`vBdWo}Y8Nap4kamNgJqrrcTsIu+ZF z;8&s8tz-L+zR;@0Jqz7-sXq{I!S&}QWCv`ODM+37SaFW=5Q-Lcb_R+f_*_4f@ko4) zV}2le+(gaqv8O@yo&BKVy%5smjcROos>p#<4RdE5_RT0wg0VQyr7k7?hsvlRBuucu ze^zJjHb3)(If*j-5@Q(W)s1OH>;xBN zSRSO$pAx+N(&|xgOF_fym40$GCS<4EjgRc@pY5Djre$H+quH zKF~xC?aWM5Yr!&G2TFwXf0MxfA=XhjIK_0MKL)L+6=q~DEI-tU^Ll<@spdlZ<7-I* zN=m(;Fg2Eqt6y>_n^BL7XRbkQG@!l1*W%i?zHb&0}26$pqkAGn(5_ zr;PH!P9|qPr!`(UQrcdJ?3_o5&gGfL@e-aqu_wRED<)Xi;qM>lBAxr8!muRMqs#C! zrR{D?(xWX4V#f-WBAUhq0lS@eCoh4=4Ry#J6>*m_?-kklDUn%f0znfw*Ikb`&z|_%F)#;~6>bzqF__F?2_$cR2ghkFvQKLg|%r zM(4Wz6)m~wQ!?mXlpM2cCF)!{3bi++vkgsDsV>}R%wf5{`+l#3Q28CX!}om{Wz*f+ z+pxX(YArUO6#0?NmlYHEdeVLIExqnNloIpo0JTqx1=A(K7t}ao*T+?o!Dn1k3P)E# z&hsg_@4o8UA7-K{4!f+e&it^BN3)Joh{$?Kwx0f__TB==i6UW#RlxGbIr54aE_K85 zK_D~Py4&H&mWBbmQu*jJyE@y3T|FI zMU4uxq7Xd!Wf1y8{s(7ynb?RQqN-F4Wd$JoaI($U)wp~;(i`k)fn3Oof~7#QE8hy_ z79E|Ez)t^tSHD4u)K@NYhP|(2BhoVHZ(=c^rysyQYP?hFdy-gA(A5S?0cw$O0o`G5M%5Nh9PCkmMnw8*tapZ zF@s_FzMRuJhxg|n`2KJn4?oNU^SbYAdtS?Z-Pg zxLYaQYzd~Bd;CF2OMo?Iykq)C6;2=xS*s5?D!)<9LXUgc$q|I3Evu1A6;GKJS^fg5Yx0M?b zjA~e7<6rj9U3jBL&?#6V_ILVBOpIarI)CE)X$S|7a4*u5UWIg`(T@V6c_{j25)oM- zrpt8(ZzQ}wP9=ueP4La&JS7O7#kO)DjrDR$AyvXdJyF+uzwGp|o~H!oFr>ydtq=a9 zFeUvO_me_+s&c3hzGW&FDjmPyHp>wef(qPE&FifJ|2(8u;$O~#bZhp6ac}!ctPG5U zW`8V4KPGGoA&(3uh+=o}nVW4<@{MES$7f@w#Lqa4Cxy8$WMbu3l=ADeb+JbkV;$-+ ziScPn`jGFuH)LTc`LOPd`-q^W?k{ftR_GQPsG&}-XXgXJi&pil{xi;x_{Wd#yEJ87D z^@-8NDIYSlT{hbT`J^S2ZeB7}6YhQf0xLdh57Jtzg?bjR4snMY3P^ih@X-GSypXaq z{R(oyEiN6u*5A1^Mx;1e@=>(QMac(7mjHJseP}0YC~3-t661kZib|Ye(**y|h&f1? z!0San4r?s(dQF7r%T;rR=D51aM_XZfQokttt91blgXI%}Fb<4sP3&8MucCHI@J>wF@GY^rKwEOXnljOB4!0F>X4? z?mb%G=_~rXHR&R4tQ3vmEHB=y9_&62?`xU3f060q3ohrr?zfgZGD36?hgvL1Pt^UI4w?OV&Qo5TYm@@6-A7~h_(Ov+V_&T27@iyo5CDmHx+J-iTAbFJdy z)Ta9?*W_GiqF6Kiq@zFuKftCcFLN;{S_k)x`deac)*UmSB(t$A*%nfmSQ5R?nm zfVET|XFU;+J?0#|5T8+TlJ#BCuh@wisdwF@(WolkXJL{N*bQ96#RKDZ_UD(fa8N@L zg`)Ke<>eQSz;)v+w7}xO61##g3^H-HT>3NHtr2+}To6IxefX=ZW6j@5|8ov|*&yB# zExde=G`4=LoGgXarmfYqI!(XAirB|pQfP=OmB2-heJ|a-t}2zD&3aox)$;y5>tXWd z3#*@5(I224Z+M#+js+t<1=MUF0!_525vg0`n+bvI z8q%Zv``^cs(|Wo%mKX0xrUgAdjvq*nOh1O}k>Xk_($eVA)@Od6sAxu2#_Rd5-%Uoq zxhO8+Di;@BW7kJq8hn!!!@OFi8h_;JDHMGo1IyM?&T!RRZ&IU^k}}yNddhSu?QvDj zzZ$h|)b+N%%GzCD{CaHbmc855YgPUXK{iFlm4?q8pIc9aT{>3~y_$ZFcTyzCzyrl+ zdCyOA;N`jxptz(7raZ$x}PTpT1=xbE7c+uj)8duXlDQPdCjK^pMJKw5gH`o=p zzz;goQQni^VAitT?f*c zhksxVN5}{6a{?86S3%%pBRpDX*56^2Zs%==6J6y8`kX@Vz;2c!Tr0AlgmY9|Wfe|u z%mMXrYnQLK_urK(6ldNIJ=r!+>h)3Yh`7T?$1Hov#NY%lPco^)>$0nbNkLz2ndSZ4 z0#FXw_ZK8h-fz9OZEmx~o9q_FdHI}LtH5xdXl$2|z}YshSQb2cP0WNPbw&?J=?hdz z+`QfXp-fMqHo9g!T;|d3@YoZlMY1wR^+D57VY}+zTOaz*MCJkm{PZH_O_>{-1YROn z&K@@u@u|tk)KT#%M0j^XQ4UjCFHuKJt^ZBg#x9;^n_WR%%qhRHW}etN-V3WwYo zaB(D@C!fwADoJp-R{#@u4sL@HM%(4EZ zIJqz^z4>!rAYJ=eI+d0PmBnk#61kG}S0i6LbhA;`yD`4vryErn6GrDRA$wh7cSP-H z!LZC*oT=X~Cn5((ZxnvK_xjofMUIzyot2|^ZHV2eIWzN1<1*Ohm1Lo$OL6$aGr|y= zej*?Cm)FuM6PY+4iAvdT&qFOHw3j~?G~EnW>zBMRl?+}ut`hV-hEaaT^f=~goK%%Y zzO>!7&i5<<@qW109IxV=dvo%>jn6xT!qr;Eg;|-OZ?$x#!UHhr>GKv`bdyi+oBSJ& zC9={e#@QHF%=Q{5w)j~oa-9mBp5$2tMvA?rQ?-UWb#~bZTC}{k(H|Y4ZU@Xm^>eG% zbbNZp6?7ibDkdHk{#mh3>BhA-le1Se$1?Z6#tx&)*yMwNuKCpm=EN>ociga2 z<$2baci#%4Go#+OYeVwOm#a4~r>4HM->ZqPicbq-_%;0*AJEm~qXh?1lxecE|31J1 ztilyY6vE3aG}H_=*2^WBl27g27Oj{Mu6r~t5$*XtDu(#2$*S4=tG>1>2TNevY}H4h zPAxQDTM`CwL{7mYcbvyt;zqVW(xeqq!t^8e?v)hLg^xN?ZWn(=N^&VMe2Ikn!>QLw zgBuO_AGSXTf9q3X@kSrnC{uId=Hrl)d#Br0e_oJn?7r9wx&&U8E?j>MT}dUie!GBr z+G$0x9F=D%i7l8sAt39PIhP{9J+BoQw_L=z#wrvrAvn7(;mm&Q^yl=|B72{KXzvk< zLuqqBtMfGZcaBGL^`Awwb)PODnm<^()f`*XQlDLe{UE0e4ZR&K{L}G#Mg`pYvuf+} z(pr#WqQ_7%*(!;?UL`x!Gd#mRA5itIu19Rq&Qcp27-9nSt%BIbc%S}hCxSG0hbgzJ zYFrvFYme`JWbJS;XkmGF0Xxh&wJPM$JpYh^>$&`!x%vBQ$=n_%dwTd&0zNxj;jHj2 zk>%`wzK)5I`RAU~eo|ORKgSmztzH&tTtHbI{J~^IWnA2aSjoDQvsc=J(0ss}&g4OV z{nVU$;>-)!gCxA>NOoj6Xkc~6cHWtVuJKASR@}WI9y|3^(Yx(2o@z9Y{f979`1iK3 z2QxSMOeE$%tNYDqyf6RIOp$i!eypu3gR9i(FIB*6_H zyD$%~6Xh11Z<3E+RBS@G2Xw*)KAq41Chf^9kn!C~DJE6yQAg>KtDdUg`T4H0y%=wF zoI4YtFBx6@;TD>)J9(B@je%~$m2W09V9MAa^Q5WnkDo+1vi!`1{axP{E%%FdZwNxh z4q|E$!s2%%IMu3lx3rX9PUSJAFEQw=GXxwst#HCr4wh@uIgZVHuZkjd}ED21kj(4;Wq0sZV#SoZ(S*_=f_3~~k zpPG!f%br1dE06qojJ`kXjf~6(25p3E+ctwA9OEsh;h&Ep7$4{Zw@2YvEc zJZf*UqVX&DO=)h}+>Pm%sp+TTPaI7=^M-Z8ojgubg84fJDQz#_8&oI`MmD8+9=J^l zK;j&|>(?6^GZLrDf%-|3UQy#KrFKs>D0-dMERf!FgdhP^NTl+1GSfg?9pEu ze=JYG7Et&$>z7FWnh~j&JI~r^wE6Ri)e(tJ`UV6chf9*F{5Bt#z{DpzIA&7-}% zcruAE2F{TJ_jt9@lo$jOBkwLH|I-K6wzM{VZW8YZzTfr{j9=&AK2RueoffM1tsP=E zzvQCjqGTTLdXctmDN$w*MR(K^Xr1=tkH=_B>MkdqbGaRtkb$K07^GRLoU@qqw!80S zO>cRfc9Ro0#5zS2^(sVFT;K~E*f^C;*AJZtj#I4xW57HwzeVjF>m!d8?6{{#i#A6> z!oxiUF4zWH#K0nN%F&k+({4Bz+0Cr0bj%aOfbp0Id=@wTT+Mf`5I<}X=St#=_}GcN zn}kk14%R3d5k)b0L7QuQV*2-b(8a5eNpW{`{%q(8kf0GvuO=K zg_Q-8%Ae1c|B_}+6A}P@t(~7``NrB1<9(d{HhTbDPor&d`yVf)zCIk5ztT76MKWv8 zx`PY5yj#68&3TtXm7vRsF|$mv8(C6_}nk z$@2K_JES!|326;$hQ!l$)c}_v2Op@!@{WZ(`6lI(-0Qh&k2ZIyyJZ{}gdzVc;9yZTKr`f~`u_D=6#orjZ>Z`3+uy?tOiJ7>+4~g7!zGB)XyHK^o0g(iy3TJ6SW=;`QIj=YAx9Z|!JJ zzdLydP|pGPqlOpbtn0F1z!?Qe$;FzTVk&I_0z|*-4Ogx@*>AE0n)e2*&LX2*4I~x1sDq_ zn5)kA@bO;sZuASiavmXZiw8NbYlkrXWEVB8ZRM;T3ygI(s+hTH!tJK(+M32aMWe^Vc-=N?-JC>)U#t-p6CdlNWh^XBS6YsYP=1dopV)4+(d0x&h+PG+JWAe*|}2V^naV zSwv~iaYGyL?h8lrvblY%?tL#L7{!4eCazt(&RWGKp;OtKW{UhS9Alz?G5zt%){hvg zb%iFbs;0~P7r(vvy3O+=8Hz82XROZpt%tXJyFX+*5>yKAf*7Ci4M_9e{N6ZgBW^I-Xey-EhfzJ(rxH6Pk|Bg4v8|TU+d4L zw1*Kf{W9LXa~D&BM{ne)xhaSYF5Iw21f4n1@C-C4od<5>=ny4r8DDFiU}MH#=1-r` zyQHLE>XXEBQR3c3&rri!re_Z`XV0Cr;Z25xiv)6s%XqnQ@CSUhS_SY>WPe-S z>bUcj^e@oWCdY`j(P>=B9u1v(EB~5d-`v`_)dmJg4Z{i}{rmw)KV@i=BH{7! zODh89v&pj~rNdwQv*Y1srZ`TJ_SM2@j>dZqLMAADFJo6Hb-A2 zI|D_5XqlR6)D2yBf(oMye7;ZU&O59ev!I@=0&Fom>E zTM5<;X!e1ba|UMQZ#?7(L`392JBTBT%+yc^JZY;wnubzY;8nuw^Y&Df&Dq`lXDg}` zDmP+Ee@IcXxXbo!K>j2B;wFCS`Ha<54jPl=G~^H!SmPq@{me z_0h6)eXsbgo}`bi1_-7uBdJbeJ2x7hA)_OEJY%DRD78 zsJoz^X&f4WUncLU$NHF>C0KkB1cbuQ|0^I+JgP8>NU2ij1@qd zAt0kfLV(&OZv?FN=H+Nqd5?+hflHx4uw2YG#*;I|{8Gol1aoDn;UHje*Pcuj{lo`ocsXekMGUy?*n|$IT_VX6&7kJF3??;)3Kq2Ixkq?Zadl|L< zp%se-IND&)g`?*gTP)7xhA@xl{R(*%!Zy!q75Ov^9cFz?jQQ+mi?3NKYoyUmdZ^x*7NBleE(xr>Pt7hpaFf(4D=LyR}Oi*|taL)^@4P z_6DYTEYH?$q6cT|_O^i^4+*i2Uc|1yK$?0`hQgcD45EMAya4Kf`^>SoXfH9f)DS5f zO0{}XGAJVQDGdCq!@l&4oYjI}pQyt!mc=O5wuEId!O!BsBX;$EH~j8Wnw5`PR4>Z0 zaLChXyWbbrJA&DNGvI$CnY~|!fHbf^ff>Nz;A1m6i%_F^craD>6 z-%@(E`Z1~an#10FmkTt97be^v)3*+$A?apQ|XOO%fZ4c#cjMxm_mJw)05ED(NyW#6_H0&O( z-^)N3DzR}>i*mA0lE~C6Lph28_9X~xFqGrO7wldA?0%cwYtvz1-_EIZB~WVGRv)>1 z?KaIfMs9XKNT@@3AEZ|H!PFn6wdKip*-YoKpY{n(_yVe{&CbAp;wbQlqx|GG4F~?z zj+?y3va?@;Y6UBpbYPPT51uf`OQpP)_88?6FT~rkyZ5_o@nG6>W}v?!zRI8#D>`k^ zcV@ww^9#M!Cj4(ziSF49))>{kteH{EhfpOI$6>s}Odz_BY&`G0@Xo>UyXZ*yY@o-8 zj4iVz;VGt~b95afo2r1`U3ib?`4~JpGXO~&$_VV3FR7C0g4obC#~~k;tcE>9nFI|! zdhv4uetIRcS14HI1NX(h8IZuyf@RKVpUPu-ze8DdDw%wIL`mRX1-4}uxWssTDG{?a zW0y;8$NK)T>Fl|=FBAPt)I(8P`ursIU7-Nq>~*nRqN0`P#h{zJLKLQQp+LzWZ90a? zkkS;Kf~8lq>;)RByuR+Pg$MUHw+#%j>3&Za^rwH2xL{E7puuky8SoC>DJV^jPoK-! zY=dRq?j_uM;?7IAR+=9&mSLtR&jRd}dj;yfBA#6gn zP3=6nLP;@o!2;n6iY-)FSB+XQ&oIF+*C5?eg64yF#R3bv%$}j}%@YxSX}@6663tf7 zYnwA7bt#IZVeDQy&@hJe4k|(RlakD-EyY4-FG;qn)?G8u38ZI}=MK#UXC9MgaJZm8 zW*NGpgD|G*s=lz^x)|)T5PXxO?pQ}J?$1-4zk&#kUNk?klho^-WgMakt0WS{`L};7 zbpl(YzZz`f}M{wFx*Q06`5@1Iz;=i{F8z$ zOqV?++eYT`UVmlZ1!le1gXwm#jlp2!3`P~04SPTZGS$whU=SONA^b<;sD#d3$(g2{0!!OtXa=>l=!r%OJGaRX|hu=YTnz>*;K#r&2p0a{s=T%c3+qgBcoInw0A3Xpot$(eK z66k&Sq550ffJgA2At_Kxb9l$S*2ulR>oKlzWSif*PO-Tkt1AX*51Y}h~ou6ix@P;Eb=!lF{q`Amzot1MSkyl?Ftd&gJ+h9H8Uz9Xj)1$ zPFNxxKlAnE|AYr&a-M3o*SOsBuw>7xxUAQ_=r~l-+3lH6aPE>$m4QSw_SIE5*?1JR zBUHS4`WFjNGHI!GhU6u&jw|R{E1}PR~epBU^-Lb!9 zR^&*t6*zl+rfe_+O%ff;mI^j73^wX<*=Xp8vz1^n&>$?t)$AB)2pO6(Rto9ct+_Vt z7S`!lI9741Cr72i!X?1?PHLc602-`xP0!TaWdzY*V8Bjq;?GrJ{ACE_eHIM$RhBsALbN6k|3?B2w?G6JVARo6TKO z#24oyt=TqcRsJ+tm~+o3r{#uD#VU*%6m$zH5(X%C8c)iC~cV)X7#6Wq!(@Y*LjaAFro-jrPr=ytHxtntrU2(Hg{P^Ec z09dGZI(zc4eQ+2C7LuwiYeS96ECF8XX7<1y|D^65C@NRxUU~U;id4008OiABQRgGQ zq)ku)NG?bQ9F;@CgBA6Oc>uJvF$^&3#ALOtl#RK{_?$go_ky@r*-o*=IUaCSfAm^p(otoH}joO+n@RtZ)Z zNK4NLpj_a-Urklt4OfBaK0%15uRdsUNyn&X{9tRqo{oi_*biB#X<%ZnvEH)MNOsC; zNEZz#tOKN@)&jp$!h9LWG?DCQ^YsaPWIr{-C4Wi189$Su6t+@Q-(BLp$zCkA%qM4l zV>{2#Cu&7_nqK=?eD`Kyln!oRe7dgXGSUtCx8>1~)2;m}JXrcfQExwro?+}a{o)^2*BnzVq8Y^-V}^k3-b%j?yh?MbhDy1e_P zqS@x^U?tf}q#3n#GyVcl%4|CBt-FBVibgPo{f)T*J<@b*R^u1uSJ;K1qfkci<|Mrs-lhAFiHFWtF}+ktl$3=P%d_vTc^ z3x7QS%v1T|?_L1)_8H)E16$yC1L@zObcSXNI(yx|dN2duFFJ-E;SZ=_nET_`kJ8=# z?5)UwAiey|wfwgmef`f$I2Mhcq`s|)p{?+Wo)q2zB0iof6)W~U;Q)Ntpm09EsQ?Wp zxTr`Xn&vczd1|1#a&5x21$Nbw7|KX%ih_d;5l1t~lYI;C6gIk$rYN=uuQIO3z#lC& zEfn}}2SUZ{`aG)@u5EWZKIufRKGQ8Nn5faj;ygHE0pXc{!u0;0#YJ8(GpeNv*~q%D z3*=CYa>1tuu`+v!J1XlY-r$;(f<-AbL=Gb$(yo8Q)*>mdG;(yvBRKB6L0I(pKQ$%F zLa>hDJi}aEL5L7PrpfSUoG{MWvaBrP9+66cIU7^gEhJWG_A)+71&0%L8ro`dT`O-r9D!$p zBAj`j$aWo9rBu;EiQa!)>Z?Wex%IqO%L98yPwzSo+H1S`TcW*{=s{iRh;n>Dg)z=p zKFzh_79MNOZ;8Q+PU6`rn4de1_GFQJpCLVZlk{vc5a*eZquqKL5d9I$>eYo5!_M#E z$uK5F0YYsiQQ7CJ?;1A4S()-8-p-&ZpkxXUE$q7V3>8zR_74Lf761br-?Up87Mi** z3g}Yp@avwzT>)J1%}ffp+Q7ksXP@{Y^`Nh(k<4WlY62?`lk2~6aft!I#g12yk7^I$ zG$>rjELb~*;WEO6#zYsv2od9066lYtc99=iyt$Wc!=G6AjtD`Pfv;Kz4l4K17GjiO z7rexr&!`2Hr-FGIo}^BudQ8do$jtKO@s_$2W`l+q} zD#XSLLMj!^%F(;PTWC7GBHA!e1dHF!YHJfyy27B(!lX!ZtlFciRr0|Z5DnxlA6Rp~ znpy&sm327lv+A}2bk*R3ZJ%2?=KwYT z%22k~fd7>IRlC-#lIX$uP53X{c9o}H^Y40L*=oP%SdmV*LxyLT*4c@<>FG9fg33W$ zWyTh}Xxbbib4f6A67-5TyZl@QgBJqheh0x*sfiZl$d`TK!EAb=kcb*=M@jG%c$mPA zs_|P+&t|?XSvV826!&u3r$bFwA&`^yttWU!Fk%4^k5g ztFw1s6w4@^6UFj;(8Q+RD=b9sOq8`yV)7<0XcE^5EL!_ zVx9U%pYLAR;wwO?@`9l|?t~9%WNQ4p!E_%ygLSUd)%-8NV!KScrqs3iD(GstHR6Ye zs)7P#O#sMR%gO%f&pvKpjdNp2xCgcOlg#xvf@CrHmjg=*hz^aBuk#ko_pexHFpJQcF3SIR6}F^jOw zGIExoQd9r7AJQwJ^lBx8RZk9s6~+xIgmdv|n}IZfV-oFPTemyQIfN0DB2Pf0=z$I? zy`1%Bet*)lp0imrlLZDF=6IQmYP<)cZWR3j7uRg_HUVX$WcDx%jQD||!7>JcyOz^9 zX#b9^0aY}5 zTyr_{i}9Z19Q+;J6;U{b`|x*S1rqLFIaY3E4WskRi~* zP4b`p-~b=Wj7>G$t7nle97E8I{TX@~n`Ul9Y8ni$$^2zezqL$WAoPP#eNHLkW;-nS z(zkweLp9u8vtRKh*H2ju=e=dGUtpzEplzd!rT*5D;toa(ANpu@-|#!d3Q&1~BI03z zsvfN2Tz02sZbiQQ^n2T=KU4x<&yZ%l(tTiKX*@-fT4J=Vf-%_cc+*a&HRkjH#dq1{IH zh2+L(xn_6$_1T6aVbk}iok~mO3Of)jJKfI;2EF^Y8Nsk?F&2`2g$!U=t<_WIKxg)& zvq_5ikx$6p&C}%;DwdRLTSO%8R`6qYZ+@Ak$uq@7Wo(XW&{c)q*R4&B8$aN=IP+Q2 z^m!$&c>RBrAxcjW%a4*oujhs0$bGc+Soxm?FMuK-d(w7>QsF?2UesT-{1s=@aB83 z@9O77$AGHcbr)kA^iP*fb1ZkNs|>FdJ!ZXadso^A_j;zP#>-MkzqHP!kkU6A(b$3U z!;a=vDO51KB3CiHn6vJ|JBl47#GteC?py1*?Umsng)W}-!r^2P0PAVw?E46BmN3oV z5*Jj@q+O$o`xDlBjVJqSc5gI{8{+)|(*yLBWHQ5%{^@`8RDym=(p6Tv{l)Gb2ax~X z)cUjuLIX^?rm<|s;KV*G8@f!#1#xmmkkN8K?6qB8?!zbZJZ)rvoc%o#b4^Yx0+UtO zC%v5dDJ8Q?r3_Q>!7(5I0pr`p?d3l^ZA^y10IF*#ZzZ5m091KKGUoXqtd#M2&IbZ zsrNk{jAM>C&2hXDs_z3o%n3%d#gLc|p7RepTJZznb0Db!BqCo%QwyGsBJo&p|Aq9w zO{Huf9R;>);DQzNXeM_|4T8ZRmyEQMxBTG3emp04KHiS}VHL81Nv~vnomw#Brblmy z2r5wRNQa{(*a|92LCZTu!=qabpn9k^G6AKDg??TX`P&ZnsSDM*@H3!8^}fl}!++xr zAVjv!uHO_LQ)U7}9^qklkz5wj)6_l`9-fNCD42Y)FmpqktlW+?qXzS%>k>TJ7mW9M z6}3qjxeinrMvgi>XS`ddOhL;vs|f}v&dRsu{5jvq9a2Gc+hd_ixGk2EMd3r+`F8F# z)uvCu^drYw*(_hqmB(FO5W2Fhyre`pf4QdIGSWgy4ttKE6M=AP!6-K)G{>zW1g9Pqsj`hEeWctkL0!(;EL0M&AbFazU2;g`hxyWAN9bv>WK8Jb2 z0-TU$^A>n7OGh{(h+J;x1(ZLA*oAqU1+FGr1{AhVh1q#cDL3Mwvv+?ThK|_JfQ?da zSR zs{#l|>Kru5VhYApidZTRw!oormxG*Ud2Y^GFajCTLEaB&s8iJ(c|CIQck=l(T0oJ+ zLc=D=3+x3hK$&$|z&ylu@K1X$Ly-wzJJ!aA5?MG{OjaxqenAbZkF~H$(gXNhxg6A` zK0Ne5c>ZTf8VaSQtyg0Br)vL~rir_DijG<0Nbt<0e7&PI2mz)Zi9n6G zWC(0L|1%v>fJ`S|-d4sk1^^~X>9jM*KX6F&+a_mDu~Bs~Wbq!PjpbAQfan-f!hd%p zI#6st1>!8mQeafaLF-NJItqS-O>XYHg)KCjA$5ZA0o=hwmh1<=P0yDULbX{x2TeK% z?Xa^~{5f1Zq`HV5h~^)m2wj=pTiEIJd9n48$TE$8@a@kJ5EFp2$n-yi4ybhf5W_1t zjp~RBQ{~Oz(uIw?tbjpG7st2$c9w}%wFJGdRjPf20Q6GM_h*0Rr+;t2)(YSwZtZ5W z$ia=0?%29=ta#MTMfjPw2RKZI!kgz>&?I*5n$XW6*T>6Duvk0h)9 zhJ3MudD>r!5Pp)4O5j}$;pBm@+BVX1n$iu!*8=S%#^3j1mX%5050!cT)XcFEI@KaJGMs9S>~nFxiI?@xMR)Dba(%_>VvTapM5g{f%1xS;~Kwawy{X4`2_* zTK{q5KW_X7mH%16e^&6H75rxf{~uU^*Gl`Rzk31xi(UUeja|3T78MJKxUn1#EQ>N| zxJHN~%^oQ5ty%{Q$sf4ctWlxziX5A5mk|iDN|0#k7#OS??`N_w-`iD2?5r_{Z}ea& z6(DR*&oXuHUJtZ6eN)a?1y)7~(&niXB<|unS!anOF142nmx1~)F)&vqNBT7EpU%JE znDsLtwDEsZAC?$(-jC_+bo@5s(d3?Xd=&!-SAHpZV|s8iVZWs*<)<9~LOC$^Fwpm z;&^qgQzlfF8m@E=%Pu&ZX(E3vBD)`DP}%2s>YwJMKOa>IJgQMmu;*ZPiz;-BwtuR> zi(u96NX&b^$)3wWgH0iK_R0w#S4}qgyR-E#LX2+%RiuXk&*u-RSiL(9aD<;Ilz|xT zjy2cJq#1KMNtOZItykhGMsr9B5UmgS09HI=X^u`_stFbqdRIIcKunuTrlhM9qg;{?k6XFWY{r zu?DX?s>2MUra9sB#3Jg7_1o8Lm$j5QowqUTh1K_O-mvN#4D2|0%;d?=U@s$F4GmH| zSGZvisJ;+>Z#j|tx>xs}lZ|hHnTvarZZ-L<4SEa)Vzkx~ zYw5QqZadPI_Dp~4VXoaU=pcDg4PydH_CRa@-SS(|(glJ3)PhB}lWK|-3EjX)j_@le zlZAYD?Iz^KSvbd!!zE|FBA~DuqDGZ-SPL8JPRbi!+79h!}m4^MZHQ83U+9`P<3`c#l%e;YU%p*r=B4s-zE=8AIyd z(%>DjiPI~vdt#ZxxiwBXEZdcPfeI#wtKMXwDN=5IH25yqA1jMV=<&iV?Rw$Od}s4(On3Jxw#q=8pc~t?0jfH{{fpF*)LOMdLu@1?6#Y1iUmInL4s< z?x@N^!{ERXjd*E=9u_g63$ME{+|TBcf9UtReEB;m)v-d#(w!tr_#tP_`FDnUCC{93bGJY)Kpt&`UNgC< za{tV=-hqk{|0Y!U0I}&!y!D%|m5*-%Qx02B22eHMro~@7B)%&WcVI!K-lG^5lR7c> zCF4M?ieu}ao%rR`j-=-NIFhaqQ9t)msrsDSFqdwJ2EC0?R~q}CITT~_V6S}zIDxa z;Nojb>K{k)$cp+iZa(=sK`ITlVe`ZNee;v2KLI<9m~7_U%&?ZV4P0Tvd(>CAWGycdC{IQYs)!SpGxfzJD>r17!d$mhJ z{`z-_zjE38q(fk%ihWC$53-hiF+POj|Hx5(fyQNXd&F(v(vC{9suG-xmv?%+7><;y zMKcBi&{e+HdV5Y<_qJme%@{4AoV+m;iu-~w@@HA0dL?|28;gm6_SJoc9y*QFG0kKS zwmBWf)nzN65I9mAeXUci1aZ!)YOjk_CiXdzNo$H~0wxtMC&trpJ(lBXxQ4&S|$%I8|%~ z$k=xt0ghwJCezY&Xm#YFjk66L+s6w*CAx#$ip^8!-L;0|g8QCpz}G41w4ch?yhn}d zC?C#@1ovR9Td69cSpHhyPGpt4SO~$_2xu!?@yuP>INcL7%6>2pso$jsJZsP&8NpgV&o{Lff-XQI4N`Y+}m_H3>R@2(OmBAvsz%a@5Nd%JmBzna(=m za!6}{{=9v&3|TyNP$lIZX*?q92w}8+wp3xi72_c7BvZhDHrGcU^a=HM*`IvFI=PRO8t?8tY`~hN<#g0~ z?EEaX7o!SV_KmGgjEWnf@tgCl9#LMxy5tYw@W}>!AKXXod^!YDYy%bmw@1l5(1T0r z+yeBZPKir}bGOeWLu`k#``GsCZtcB{1iy35aq!QSCnO`QzO}D!UNA=tTA>sCkGkrK zXV}4a;YRgZjiO^`Ib05MVZaVp^h0ZC18d+EDkRTT%`gTBKTTedvolHBoZ++i z0IuzpBt)!CCZ{g!bMG|U|I<>eOM>>7l z4Oq{N8rZJs_}ZHbGmvGU{3*4G&RKH+EFCQ4Ei}67iw|uWc^QC87hvZ00filV&T!u} zRky$>T?;t>o(-A-H^J&R9xd#9xLt2gUNN#FglW#K2i{k{k<>RHvQhgqieQ8I7KA+P zH4*{!MAAOxJ_r(g4?_1*<&0=y2V-|t1D5eEu8)(_ck6iUmJ->8V<$WPhD9F_*jOPMx_6FP(yQ~zbLaYy+LaQpQHmIFamA;* zq=ecvY}cIPPhjDC#IeGn4mpSowsQMC`taoV!R7h%03J1KVw_Gg8q+JAiYn_#HgWNGNXQYAD5|c*?<;8MYaNu9>wP-MX;49+cqQCI4edDc6@X>PPQU_!86uA?ZW`p{ zUS1y@slbk;pd2c&@TDexA;VNJ-f2l51$(0uZ$B2-4nkhQE^J49(x~_v>p^nF0Tr`O z=?pz6Ir(2S=orgDcz><^BkcKcEVd1W)vI;PH^5j=dcpuFQEho;b4_QrOeOt8-* z%~G1N?Kr+t(GHmnGeV)S@#glcp?`a|_N~Jf46xFF(((SmwfW3}&bYnUQL;j_(VPW> zVHc@1me#)OVN99XWV%Lq<#%>M$>q{n}?J`^a_a&-EE;JQU=GUpj|Qm=VO-@hTUIiz|VTcsdPE+9$1fJ zx_~r{`hkq(F)6}_3wiJ`Rlv6M3aJVdP{q3gAApGNfAnK4fL1~|Bb;CNz+%)iI=X@y z&La)pi=>Xir2a1}vMwe$C_g`&<-n1NEuE6E^&Ec}N(V2&z7%_DIbEEB-(r`)!P}_P6t(|ew69{rqZb; zXerq{bY&wo=Np#K|L%f{p+Fj;gMGI@!GvmObjUQ^y}5H_Z#etG>HwE?;kM|X0- z3$X-M?JrB#kkZWatdrAvL@k3UeRPLIk67Yl+LBncZ;7bpUw# z^)GvFT6|b;?R^YzQnBhX!8DP|$C=L6s@b$^V<48psZNEEs|efgSpT1%I;1#&+mG*j zJA~V8Ov(;ZLn#)!B)~n#t;70Ih59$PC6Nhr3NzNZlKTDtZ3*9$5_s$uw~CjC=EpdO zY!Hau#V|sZcfRqizV()~6A=ujNjCzff*7RteLaMVY^M4^RFIbX>5!s)rah_Lj}M44 zo+W)lnQtkH?bMzfAKT!vY=SvZPztF6x8M%Doq%#Mj_;i%s^)42`z-) zLc-ggd(Sx&Ne~p^dEJQ?g zGz4ZfBx25i+;Ax1!$bV_j+h_Tu|Na)zo%G)P$4Znq)sg{EDK-R9-lD(=0DxuEb1}~ zxji-wPAmIR4fCaM#LQG1kXk3Vzf_QdCy8!=CNqU#@&oPd%L&|1O6JTJ8zg39wJVK7 zS&Ml}T=K5e-JVi4xs55KPGY=gFr`tT%}k)AXmq`7)mSsa3UtF_q$t=Y@46VQB9r!4 z3h;(N)cIz>IC+7NJf28xUVoOAV%ZgKFVoCx2-@mY4+Z0)iy*gDRz+{YCs>UJ&sJ#N zzdQWx9vA_x!1frp*7EN$H=R6n+JZ(wO|KB9I|NSq@i29D$8X_qw5-`5ABhL=NMlD} z6(VE&mXA{J6sE{ORJay*o8_-`BmL&U}azpBRw*5|MvSkaF zcyzIqxAc<0xVEW`)P-)-9nB!`eJG~g7k2e~V`mTHY=UJ?c#Pzkv9b)jyyDT_LKDx) z94c_E;sA0@cy*^=6lZs0*d#>t$do^Pi9eSw?P}Lyd{EW;&VXs!%f>bXY%+;ole9HZ zwx-s0`fLFGD1mDl|( z76bGlxRj5wS)*4Xtdi{M$%$%BM8o;MX_fD_t z0=Gtipdqw1Z!ql%N}|d-CWRhag_%7&h8NlF@oq3?2n?|NolvhnV7)Bdi-S7NxqHk# zeX?lkw>->(rxND>XLBn-d|VT+P*`O}wcE|pPYQ7;|G$>6_x>VCyK4+yVudV4C;9js zKKmfJ2J5<>3fnR49r3q^@~y;_?i%2h`zb6GI8SB(h`D}!r-BJ}{i#6ODZtxslF6pm zQEo^3nLd^QXN>Or(Fm+YF~)56^>Uy?3-(NI zr-Owg*^(y2@AfZ;95XbHQcZVA1ogV>0GRQy7^Y5cJq(dNPes5?orge;5T-#2EkeE9TLOI&416{&O} zG)qZl>({_ayepq?ep)ztO~gL849;o3$;pWtZP)>$NDO?CL&e*VobsKa#ldl8<6xu} z+kC@yNI@?XOxj~SAOE6va`&LV*y$@vjHK=~l&2rR(FwSsw6~smlt`yyt6^)G zr$^Op&2ZvE$jhf*TGPs!r0@QyJNY0V`O2;`4q@w*{YBmgV$O2O)Ot|9PZrr|(Mi8< zOc=8S&cBmQixUg=E^@ILhbnr&wv#uo(MxEaMFMlJTti~@ZQQ==j-2phv`f+tBWX&J z6cq!=1Xh+~rvmv&W?_bUSnoP8G+-j%a-^6H{+;w`@{;GRWF{ifb~elpAv=}(py_4PR;}@QjG3U%t0v_Hb7TzPrO?F+-dYtZKp(yzVpk^{Uq*G7 zQ+8@)jtS_T6r0#c=JqIYEu{JA}}tHy5Zc*E(HZwVg(ksEMxY=f|HZ`)<{<^#g* zEkB(Ayh4gG@P$ic3)V$#&c~=u-`5^VT@;xING0(Mg3?4)Y|W<{e;hX;EFr!e)`08W zoUs`Y<)kBIk*y>71Pu})AC=%Aw8)yPge>OZWQjS;eu|HOv@8c4Rzzz}{NSlJ-+&NH z#%$txD=B`~)FXr$6G+baPg&;?vODjeUVwjO79h4tFMkYX@VribY!F#R>zk@iv!a_l z**_FnS;CKA5(UNzTopUUcUcy5n93_^ko#rQA7-~0lOLKs{wXXkxPi7WMU(5}5dIUU z#&BM7(_=GwZ(Mok_1C4qpgEm?`5h=kk!yH(LrR8*QY9IRidAkSnFLY(t@H}=L^mDM z^uU6O_i`yj>%)$eojmRdoTr*KQ0r-x$LUgtuqmw(z)u>kQ- zzFoQx{UJm<$Z4@Szsmf8y=Fzq&*+~W{%rsPv~D!`Hj3o{t8io-4`}T*Pcf%igK4Hn z9~A%88RW+qj0PiHn$p+H(_3$VEoN@^xg7G$1j4tZwuZRVjEY&{gVU&_eO&%l#U_q1 z0w%qctIxG3+nr8Ds9Dm0qTp&!4*bo(RzX8sckzlC2)??LF~Bs-l2QL?Cd=heVSJ_5 zo1wPOjfDAf0*dWJedZoJJK~cz(3Yhnv^A!$D?+D~m)4eSO^M!3&42>2lBKR3p)hZT zqH-1bdb?TC^65jqG1<%@6XPen4C-~bpS|%d=6G`;H?v~i2Kb{JiT3qKTz41v2S zrIjbVaJjL1O*swcVckYqtDI{3ec6G0lIrRSow4~;uVVa!n^K|oWuA#1k7b(XgF6x@ z-&o5Z&Wnw0>|4c~y+SEhGf$tUBJnQgfecn*WS2dKmJ5^;Xw!x>r6#M-7E1XrsI&gK zG$k#uD$BDyrUCS;BQs|sD(@VxOaQZk$v28T2- z1-p37h1XplDFY?|zZR$zsy%;J{#A+<_6zjvJW+TTCC5d~8vvByV88%~rPH4j6;LKN zrrH6{5!tPd|Ib*4|0)7-J<&$eYhdUWM`w`DqNxm04EaRowC^=s9xy$OA*j`JI92wQY0w10fQkn>(#A8XnvXg9Yod7UMYg|1vGBRVmQ;7 zU??9t9DjJF3)Qu)bl_SNe`n;NDwPAl&?zBiG(_1uQ;O`yo~|TDJ@ae_r(*TA%!QAeI>_)QWV7j077z z7+iT0#hwXL8k|7s5-nr*B0mf4N|o`bg!!eSK-;tCZv07CUA9)<;$M46JJSO$mt$`5 zUGJeJUcE`an%aH&`G}UqHG%-!x*@>zZpv1l9g8!tMx;`~K5k!LJ6PgPE z7Qc4sDf|RMHNWH@5YZn>Z{5l7dWn*CbqAB4F?5R8yq4#xj!2IwXXb%USwYapfb^J0 z>a*mu;{CQGFqw(6oyp?Q0jF>(_I{9+yVW=y+#l;+V<7N9W)I*A4Y0AfWbZ&V`q%}f{y<) z`e0p*x)eGxaD>n?f#*-4!^;P+EGzP~uU^3eY&fkH$Ar4fLPybcDsslrd9 z*wZDyRCo*GXtomaI8@iZzGs8SW8@2K7x;48xGUc6Gd?%uxvv+X_7c#*WC38)=!KEGy=?cx!A z{_l;@d)8^m{`VGx3?wyxunhdUL{st2VB1FTvo+=x{$cf_5CCQUNsqO;~nE`~oH!Zb>(t2!RbeFDAl(>7{ z?i9<_@m?Ar-fKZK1u3Jzhb{F(U>HsulQV68v5K7E8j#pMV zo~EOiVy=8vI=9y#(c%`)X=O$sWs8bi$T3vYZ^{K~&S_A3k{2A+o~;YI4%nUSp(VFZ zHK{#`O)H*@*vhRS*|l>tlMic-dvd+$U1}UchV-iT`XdN+6)58{SXNN+&ITv)d8&z~ zGKFpr-3GSC$sc`>iYTbirz%b_V}xIlLY7gEYH6xI;_U4Wk3yn73mNqwt+7>7~m_lLzk5w|$_DG*nB~6cq(7l%I z)xN3j=y5IGvSJ+(WM$8>(*EK8MoY*z8xG|?L^t#h%N8`l&Z?bfrLjQ=rBoy9F1G51ixmh%#!& z^vcf{Y+JMh7Mm#H{Fh{#q|s}B$@kJw_lwgyB6Av%@ORDbPPQ@0TB^asSGTiC%>&N|4a*|d~ zK62V+XbUQ*e1yL^?Zp7m6B;BnT5qQTUEd_HlhcuF}9KCM=CM8swm@4Sz`%TE` zw!OF7NOplQAh#ddz8obloFpi`4|#KTw0Ll{50s{1+z~rt5srL&;ek)7}DWV3{uL?3W_TAUI9?*Zix)e z{>$;u^UFzFmg5UzC4(qCv~TK4T>+sDzVqY=yV8w5ghBL}3PIRjnc^K{Kpw(+B(nAE zziR;ogzNy#N)}=;VEpNWy^ZTokLRNfw=2`vUXQ}>P1jGOfyrz1FJ`@9B5n!2{t_!6 z_Atk8!1cz4w^$}7_tCM{@cp*Gunm7t<@y&On?im^WCuc5DBcdZ+q@>9x#g{8Y`T8> zvhv9Es?YZb8$lq)VSEt_2y-)G$E@j2`p@KC(*(DQ)G+z$9bTxpvL)Wy2CprvoCDk2 zQxKaumA3y068K|E;CC>UPZ+0=?+F=|ke5L70d%Y#Xw@i=K>=Yry6d@^H?D!hbE4LN zb?Aoy*Y#6pbiB;)$hA5tsUoAYjo7NjIc|&vP;-2D@#T(AL)s2rO^$3zhOKA#vG!3V zPYVSAF}~7m=AjZJnwGJO?4TpdNgi^A3JY4$=Ml{~ff1Bm^7k)ql&tO)%Wrj&nT}&f z3DsT+VL*)aGZ9uI;s03yT!1I}!5j;~lSrIiBL_IB)3J=Erz|P>>vkf z?HU3Phon4euuMYMidCn}R0)ocH5k*gZE*}J0ZIhO7-It;n>*!vy z??uVB@#ysQJ55UHcKS)S?}GPGfp;6)7d(tNTHX z?irh;LuFEQddeu3x-kJ6oCc<}=dzU6V9QEB#{k17{D1|WtzY@6J;yKSVFs|?4OWH8 zic}$D*1(}leV6(2UPZUNM{mN=4P{xcl#)HX5N3b4GHn?j0D;t@_7)C`ynYhA1IWr7 z9rb&x`9IKHaHSos;+Q6WblG9m8S1M7AA!cr!p$e~RJ{$}X21K{5NIzVE?pmK4xPL7 z3e|AWIvP)^=h$TT$5~@~m^MN?cUW)a6hHs&CBe^=a3HN+g>qU9+SwMIP&>SF2+PCS z!aNpJNZXU%6OZ;|_6{*7TcfU&1j+V1;JU=tuEtZ9qrGi_cf&3TDTD1dnM_<}38s%_ z+=t26k?EVL$+U_aPG&n-DkXj)PL`MegBG2$f~*p;(%1TX4i0vJO0aluXlG{VnL=@8 z7zQ^xI-rXohOBQ^GKL(ry-pG5KP?61A5=>2rOxS{1o{x;99Cfp?$4QEKqrM=^Kkpa z0Bmv%2JEAZQvA^&+v}?kq$F)b=p;(zpUvNjOj{yCP(xd~aq4s9JMZo(YWY}c6?@|0 z0jVz4!kGFf7r5O}S)f2PU)|(c4=_jI;jP8D1L^L8d1WqPU6M}k_eb_$4TRNgPr7i? zn%FLT_bHyHq%l0nfVZ1kPN51C0xqs*93y{>VmI8~YhWyb`q&>f-Y}U;j2^^$@+X)B zA;it@t;>^I`h+C8&0|B?A#u?)5n~8!Pg#`5q}0UXP$SoUuM$5)tH<^ES6TM)_=F}? z0lDkQ(Co6?>t4r$mpJ?EFcv>o4nN8j)?ZgI`JXqx=i9lk+(`3c0cM1@hrO(^`9wBSPOgoZg)|uTZ`iMBZLDbD%dp)o(n<{a8>d8sUa7*S20CXY!@>eN=&f7$Q zX3$Zs9;j5db)vN5x9-@<`xGjALxgLOo-(G=$XbH@BUSG1iUn0Nb|JV%~}`)HySxa%URh&;9d>eRYqZ%$3tvVqXP$<-oE^!QGD12kPq2ko~mf%eP7_#z}hiyyTv)47i9Fp zMkZq^fc`#k30YWiV*RBp+5Dp%yT-mX+J0m0w<7tT*o4gmHae}>)Qd(JkGY~P8to?| z3WrJ>CRy#R;|RaT$!4u*js-9A$l@U1cG>ZJFPp?)Qud1&s{>(_T-vLIe+2=wSGa}H zJ>b|k{@nzvGaL8)=TUEf!oO<7IClT;0GJG0&p+m`zG#z8He2M+woa3?iakzt9+zv| zJdo_U;bvGW6O?hoAN9B$<@%=alCW3TQu_Lv>rhn-v0>Ept>*k4oe2$IG2Kpd6a5~y zjN*_W5vm+yJ+i_@8+q#q1<{^T0nqAb%SsmIIhpDRr2lY?_^m>?i?DbdtdG)9NUxdT zf|R~ZeC=2|!LyH;E88{(+-hkM+JKXyyVH%iS!3E*ZuIsW|8yT*Sgl}YP*!R?T{t>B zA;ccwHVSjFwNX6co6<#87dc!wIH(sS77U>uylULhF2)38K_4#W4=m^_v!|t*qdED+ znO`=+J~r~71a` zoL9M2UTOGLc}n+jB^G{X0Kk50@|y)j5#1QL6=Xy#+z1%*@0}zzpin`wg^h>M$>TH( zDj?c00f9AVBRsq-lnKSxO6WR__?oLR;|_HWpLZ$S$qMAlD9OAi{(M5j=Q;rvOE~Et z6FZ`Kua$$ZaIRYXl&HhDa9#bPnLV7|Rz1|5&f1Y?7z^UF>yiLDVOkxY+eX30JbRIq z8=^hwXq1iXo8|foS2Yci?wkw3W;Lc}mgCF&^$fCZfoM+zgXjc6e=q4o{8<{hshadG z!QTs{_>V9_fwlIGl5g0-lZvLBLA7^t^?pHqV6+Ti4&Tgq8?FXzTu?$>16lhTw&X#r zP^VNE{L9h8mdvj+P^-em2>JUC<|lV03vGq@U=`m{pSN`iT%8P`IjP&Y!>3!Fhm!%&NDQ6D%1#SbFzT1JTCQ-Oz&?D5Me;JZBA zDqEAV3Y3lFw%AMsLsNuG#Ijh-Ztn%Vd*ADY*JA@6rhIwVmdoK4@3-^q``SKk-jrnz zP9el`@thBgMo70qzE>ryB}kuJ^)OmdtI2G4AsU~rJoohME6cc_rzz!lBDl$t!5*f9 z&VF_#eF7mP3>v=WC+Z|@ct=`tIs-;0gA-`3FyhFe?mndjQCaAs=5Cn~jXIVCY?zbmUfCKwg4rSucxiV*Ls~_jd!x1h_Wr~2*&$+(M z(gjI$sXbcts>R&wye$W{@ZcqqeN7WE%ZFBA<&tY?lM(dMJ>fr&d{`RL-XNhY>g9rH zHw60_DwdqVUavW&jc_;EV%)kHZ{pMR$>zo)_iWzG7p|EOR8AZz! z9|XJ`^)H=MQtR^=i}*y!Io}FNJeoTi+v&;23kov9A3(H zC>Q!`Nv;eOm=cI{V6X~B%`fRafqYbtS`z&PMRgvKxZ!3--~KVR|4P%7T?Mo(%y^|3T zdL8?&b?4Yc%THyyF6ot=!Mw+p2-VQrjh;D6wpv9b-l>w)S9jaOFUVJAr0M)M<4{}& z3=gk%{jn33thqY9P3DqIL(NgB=Btc1+ps*(NYc?! zwc$UkKmI6i=6(;dj{l*%QYSvh%)G(6%oIu)LJAM6U*=#ck4_d?A(0YDkix(m8@{kn z{H4`-SWckz$;Kd$(&{sunGy}|I8Z)Nt)>#b~x;%G(M!m3dr14cg*<|r+ zX2UAU@4#pe*%hQntmSiVBBY?HV!=1Z?l6Fz=Eb;fsh6bK8b$#CcgT_j3I{Di zlYuPz`y*6HCL_e4F<*9ti0VQi?OITo^^o~?pCL#WOeLc~hjjq{Eyute5*n|1QPN-u zf5C;WEI0onJ@!8!U|mTP_gaN#vBQq~auOftKQX=~`(&jlTKQ&qn*(Ps0b?mXGlY7! zDNaLD9eg&S0Ww}ck`wT?D+Bdq(vrv-k|wmHX#1=h9jNO)5w~*4HLxACxWu}DMu?wk ziNPxTA^VY;jq5Xas9i>I(|bDM)uMt$ty#(C$G@QsRG zK;{K1aRa>+bbOVfuju|z=o9hsG>r0v&YLmo5^FoforhQV3TG3*m!=_F!sWXz{TkPbfY!BIZd?$(e!-Lz}q7c5R-)B&*N8n z0%EtH=dhe#$n2;uZ?-IWpPgI+cTztz2f>RCKyFMHponGf6d0^+$Jx)fp%4o+4+$#6 z|5|=Q5Q_=#*27u5?=N47zW&Er?=T90SkJ4<{_$9f?ZaogHB82ehg_m>$~rmW;JABS zq^rT(!@>h8=Z#9lc2Q9|q9qfh^9p?4OqpEzF zm1cC>NRBF}Tbup2l)FA|UOj%D4N}&x;1*uWpo6(cMD%{ zwKCl&ObhA0$KdTra`~d8@sb+Bu6zK|uBtpZ_2Q4m%rtM+I3L6Al6mh1h1E(%AHF;& z1{U2ttJ8^&L#d~})9b9LIk5d{GF>@OJhq3J%C4Q<-bz2`Q9)RIoSzbgGN?Q6GvEdm z(=26B7%Jbs47e9-&a=oFY-*+B!;Q9C$fv`^KqJ0{F4B>` z8|y#Ti;~L`;5&zK*-K@zI?`wCYQAoiRk)CkksWZF=}4g zP~39?AvU^mtuM1Ex4|y+Op@`#Fw~u|J>COzK4t->FUQbycHWziG|)l*XKR!1iPwVC z#G9h9f=c-y41K|zE6KdlgG>E@T%eE?t%^43#EQTg>LtIUPqvs@bdDm9ljLO8soskr82$N|ZZ82i$OlovuqeO?wxy;7diaf-{J;$Xg=COqOZ-w63! znA2^yG?2ngTA9QziEPL?9ZUni8okNw(vlrP$2H8k)jOf5a*q9>Ah96Yr&`a&sh&O+ zpgWVkBR@D&I0LI#BMf<4HE!nY?O7nma|GvW++oT~Y%kpgwrAHNQG~W}Ysf%J>n!9z zPIIlYbF5P@#|+uQ<<0kw+)plo|c(W7p6qV`f~C zo$2519eNj?r92X?EK(Q2WL+p`!C;*Dqk;DkRCZ=xkpAKy>hSq|FlhXvEi;wwTuu)D zs?O|*6-4e@B%xI6)UV_--`_KxJ`6a6t#U_8T??yH7CkwCCWh2D3VUYw`0gkoe&CJf z!y8gD5OvXlVC2znyZYf>EtR;y+(0e9gbmkTpHr(Rh^0)b_?}C{<_{u9>nxXzUmts% z;b8tOXns|K+x+SCS;uft@5^bD&a?Z+E4%Ilz}f5uZG4=vFi6reb>%y{`!l z?<8(C;4Ansq(CDZ!F9p^#)JPQsqsy5Av9EG5Zsi(s8MZd#BaU5XQ*od%bHWu4@8G zZxyM0Ewb$wL2RJaqw0{fUgT@@bC^m5eq*KVOLY)6shfUok$wFOGJdmLDBD*NKg@5wnSj zo6C+&K}i~%b;H;p^PGQf=dYK1P}W>QWuJR!*iq+dpk5MX3OIA_(L+5y#YroUk1vjA z%l{f0vzn{v)D`P*O!LD$|4wp-Xz`itfk%qQBS7QVZ8@XNY{7VhckbvA*v~TJ0vxQ$ z=n&uq^&MwO)x!dN{nq6?*5wj;y1oSOq4p_FzaK69!q4;Lq=?g2qbhx)rcxJa6fse? z)!-~Ryh5t*e*bx!mfTPK2OTIqK^tCrRb<`AdRnF` z?e%rHFeU7HEP7bn*IHB$x8+P&7=;xF7RArpw9dMD&|pI##J62gE~X~C`4g{Yr!v-dgrHoMQl5fhcIC(B$XrkXAPj^vJf zKkSuIe63;xRnHck!qfAGM5@W@9quW<_sZ&*hrVM$2d64;y5c~u-Ys<+$xMf+`k;+H z*J~rj3~3mtiwlmTBRlJe6Gg>@y+(~G!jR%xOUmdnbyDiY1qJ~S*Og)FSaj}=O3T** z^U)6hXA@8k#MoBxM+&NBTvBl)PLQcYdisIKm-}AUpT85|9)RTokfZx*ya$yE(|xhU zNNKTVEv0}uJLeM16+ew6rK1si2*}3J8sDv&g(lj-Cl+$;cgF;05AcKQ#6o0T%sWyW z2hqnFOB$NXvkt4vo-pP+MXX?IG7GpP!!@DnjQQm#@>K1}jp?w=_vbab=%&=S-z!f4 z7+PWrMxk=?X5|>e1x0r(G3Z>W&6OJWSe-m-@5ciMA}@8~!8LhGvcba{;^mdh=yaA% zNL+g*J_02G99zJ;bi0M#Zah4bE3IJPl>g#YUptL?22HNnc+SpA8y^Xsc zkz!^o8LB^Z$6}(YkcB!=OU1JuYg?NS67z5DL5xFs-Jcu@kkYxhP`D$Kd(m;4KpJg; z#kS3qxnPuDHoxw4XelX2h_iP}xH6v_)3&b?urN1tQ>B*>W7<3W#p2tuIt!@S@Sfg4 z*;oNF8ELx&&0JIM(nZ>(Z5m^uaMJ`(WSIj;Fe&*>5r=!GLau}4U4^3jzOCc7JKR=M z_XmR@Ljx_!A7MV~TE8i)a%JW*Gs>+5H*u?hXm*du|J3H9bSGiLeQ)xX?(rvS?v%Gq zvLJGL__-|wB_0c&5C6+;KR$PNNiWb&;nS5tZSNq0iQOn)#rFoh6o$YK9lKe69wO-s z?B+r_X2ik1B(g%|XIIKd{41PBptpsX#1Dp8y|mtv%qE=paD*9j^otc|Aqq1ty%I)b z(!Q=-i%=L)qLC?-o;lkT!9uogu`^m|`&fUq!wn}IaLJc@ekq{y!+%oL|7;}r7LdF^ ze~#`kq$CDUL3Bfdq4Z(x2NT$y3z?$Dh4+y@n$VboEQK&y!=deJ9>xQ?Jz1R#%h{vI zH}0qBAVDjE1WZfGLFM;lZY>A=@at_$?3iGzs=`nPe5~{9ms(e2`1{cb{eTEscn_`B z#qSRNU$f(vZ_bGi`v=~MOY=VLdNfkg(Fzk$1F7pZ7K3-BlCk2Fq$$LuK&6tqO!cVLiq4(v+{}HjMMqR zMt!oy`dP07lNmyc&&bY&jUML!i+SgL--jlz=;s=&!4Me1WO^9wj!w96>bPPUs8Qeo z4`YUeao9_)ArX)X?)Fu zf-B;b`9?gRE9D+&Xt6?_`Vfg{!8Jsi5(iYK z-U|eS0@acoMHngQamY8e$9F@wvbe%HL_gMF_ftt)V&kyUyZPBJ48<9OHOx6m#1>S- zij~M85hK+voISLzMH7DbB2hbq&x#g&@2r5+YR3C!Q!^3QXm-axKi!^~G#BpfjA?-< zp<{g{P#ip}pgK2kSMWu!+jFqc19dI4lDstky(f`QX3OxXBMp!3_wrAnY>t%8n_F;O zS>yJ0H^MP~tS)S|cP+76{6%6n+k#FuN$M_oohS17MjpuC6T}7N6Zfs}y^E%f5qXS$ z5Gq2qrwfV8_wO$k% zQ9$fmk8f1B+teR$7=U19EFsD*5c$XI;%c0#nsWZ0VizpcK~A%a?IU9^5XqJ77mI?z zzUrmboeTbkcDQ!S&$#&}TbjuLdUoBRDnN}z;T;|S$k+5!NRVrZcrCo^S^{XCsV#z~ z_pU8gt6z)34NLpflUE)cI}zHu#1?82b2ujPDSiVJt?-f3azG(cFM)Iew|ho{2&Im4 zs(yZJZKXAu_GH1S%7Ny~Z8dv050e>)p@zfFPb<&-l18NMxtTSwhINNYt=lfgk>2lv zCctqna|0#_N#!sQ)bK%n*CP4J2WVL zPQL?vsVQM8RZ8W%9N$!yMUplTzQ5jL&v=9LF6K-3QM&P}GH|W<;7DI<#(Lgb^-A(G zW}x@kUR)PeXveg+d)oDtO=M82W0@G6sSwTZ>^Z&7pPEQyY|O@b9V;04J`rORj>};@ zR&{E$K6z6!CSDvx#1**TVa%UE7%6`$t_{|*0+iK2c zd;~fC+{=jwp$Mt6?c1|nj7?@qZa%1!O>TBZjVru=9MlFtn9}@k$=s9&HT9Wc_iUYA z&+}KW!rIkfTGg&uCnFAx61-K2hqp<|pKK(R#nE%QMc}bM6lZON)k`zWcQ5l5X-ive zuWn~H3tY~_U*?|B>-`1UJ3bTuSdk&rXDCRmW#!#>aoV_>Gf6EDdyPTpK@!IMSxV{M zww)(M{d>JRwrf7KRIjU!0{AUVcfE**Y z8z9dZh8;2F%AJ9HNQ+JTg2QL64e3`x&E7-jlX&qwRVKaZ%P{V3UXCRXrGd+VE6I`RF(UdB z??BsqJ0EYd$+5*+VKAD87(ZM`-S4Q&djhV2i@XZ#=uTKU)!NVf-ckEo z`!iHe@6sLux8I)6<_k`rDc#(7D~PvuNZiI29SjzAC;#Y~cA7ui$lM-C0;p!Xixv1j(c5DmjogRRw~f7%!^6jF>lGg(%)YKT$l)ZEhb{}K zbrGx;>;mkFHh2BP-rCWB3*)@{;mBhtc4r_^%u9ty`k6}2X`61}h-GYQ%mKDBFXvLr zT+)0KvOI*Y-ztl_z)InRXc#X4F2&6%!QS&x+El2H%E_dpGj~P$Si)%$Dp7AMi01oy zAHLd15)Vvfr9Hc~%*I;wZrvr-mJIQb&Z@q2JZDx(S2(tv954@V7=VWQBt~c z8cny3u#P3nW>+XkS-u1XYU81(KrN+#*Gi$G2zBagwe2t9EJUHtPxDa%bZkiQ-Kpc@ zKlsdWY*}oNF@_y{BaLxT<4nmI8}1v8pDULJR(9GeWUD3;F}GAnh#-F#y-V+ux`AUK zE*1(_HuBbAwy|8cI0&a3Q|EH14>0i>=Tpj=c!J<;J{L0DVkI_dWF*Hrks22Q$N$tU zl}uTf+}zvt32rm>>unv7UoP*jn!W0P@s^*|{t5=@gLlJSPfnU;ms%}Q@BU_d2Jy!N zLUJ*g>;XP(-tJ$8=^U5Tq)t`ZjsR#aN#wRapj5JWmJpYZ=|z`<6gyoqJiaKzU_Yh3 zSv-E>5h?Bq+z42~Nt_lWLs;=&d6(fx1& z5^IZ9888tL@%)Q<>uYD!t9%%n^n~k|M#^udASZI*gK6K%%3duhLQH>F`ll|O09YN9 zQ%T=)~0z)o7mz5Bncfot8HQMbJ6ySiJL$08P4!#-!Nr5?8<6 zN{r@<%i1}we)1dKK+t^TszuZ1wS;7l%&_bs%guf}=xhTeuBe+!CO ztnrVNsb6Y5eUX;vS3UVY@;Id_2t0iWC=&nA=&k|ElIGJsI$<@_1I4J#I(GVThRTE! z{ex=XH{(8vULgA`S+DHbf5BFk>8;T~mVSI|=p-rw0 z!Eh8(i2bN1F^C=l@#H=W({U~RGFz~CgsRr}p>q#K zKxtO@71&LAuZ|?PafPobFdl4S%gh4es=~v^C*wY$gzwqBo+;B(iNihOp2I|3t^13= zpHlbq3ap3^lU^-z-TU-xrer7AG3dF8tTnSy z6v#NNEMeDJ9R$m8tsjwyR#FZO_K!v(UcE&pEk4URnle)3(G9W={ZOF^2 z_-CYb zixwij4!1`pn(dvh4xKX@BBRozC(yU0{!K5Q-{Zfzd$iE{;y=9r|5YQFx50Pcz%NYs8%n7k>S!EzeJv4! z@zN-Gb-gUt1~p2@_eoquoNUR^=MnuHmX`||eb^l)|KMcevDo9pOM2R;;P$Ayrz^f0_^ zMVh^Saefq$n(6A&^>w(`vVqPMu?#+Ybz~@#&K5TqRh_DJJ2ML+!elRh#zFFCOLpo;F7@B>+ez6dZK|dS1K~b~jG$jDXPr27&aW0fnUqxcT4S-AvcCfr zQW*J&u%oj@T7;EF^_eoiO%N~+vmQCUq{K@)yS4OqPHunLZbd3AMDOl1vH7jRv`5gd zxh}~{PC*$@Oh{ikiJsq|agI!KqR&0E_=_90ZQi{|l#W~Ww|PugDw=~UKw(Mvb>-D( zk8(eH{t;`Q7Xh5hSJB9HD(Aw@pz(6JPX?c$sC#?GId&u(8vpBCc_2ah_G#74T1ycS z?40x6CtQXLQ4frnn-WZi-hsiN*~KIWqQ{ z$-3EHnj~7vdP9iN@0{72lm|JK3DJk%NOV_JYxT(uxG z?UhKA*+;F#A>XpToQ6y|3CGuVOFXN}`}Ee-YwvOXxOsQyXaOqV%v)zZ{Y@}7lEV({ z({Qj+gKzFDrUMK??e?#0Od0sf|HIZ>hei2DU84hnfGAReD512Zf|QgD*OZH`hneR5vty`!cKrn_SW|Th@ZG}>(gj5HLs6@R+(zjy8X^$L6839R}ig| ziNQ6u)c92GhIZ5nt{=!H0ZABByX4^68?8WP1cG^i^br0A+W3~cKF3iru@h)stYUn7 zSot#OfCv&U^d6KMPd{BwIfbyXIsa~TF%GRz@_p~GxnRmt%~<{N^)6;xzjYDxQOt!*-~CVy5ae3oBmVHWnC8sU@UmU|jhx{FdO*v#tjCVOCpo7j z_vp&h+W>qlW69^W?qyOV>Po;WVYmTEXF4vZZeZDoGP>8@e)kRhkWpwy_1eA46+1xe z;GCGg)uy^xsygM#+YKI!s%4fH`A?i!0M{D@Rd8cJFcileW8;Kg=&AeTmq41-R`$)R=m5mtgoY)_@ zsAb$RR2H{^E>-8L1rgN=hl7_)jH@NedPlV4wd8W-E6`2|o|L*M-@dlWhP2KYc@To@ zjnzA}0BP$GdfF;+qGSVlNX8`z!lkO>xMpN(5 zN%!UzHll*5p27tpZL1>#1W5WDbeU2W@U@QPy1YV3lz8V4qb_ski_{EICQUkSY7h)d zJ(sarN2@877Wetu|6KH2ERQeueCpbaE?cJxNk@D4 z`@KaxEk4rGKY6CcGHdN+MiZvbZM#e9lb%S@T2n~V-y7s*BNVWvMOz^qX#G$*dr&G{YgtA~(q`)Y$yUf*Q-`ehfY3aS3YNc)bs2s3DEdQ^%dL()-se&VvutOMT<3cCdc!{xGes8Kg$P6KdgK7* z+7X>fqv2NR$HebTO1~}8kY3GVGrzI&FE^n|H;uK_6?u_Bro}@SUD=Qw#e0^(&(v5d zP1-Z66}?9u47p=37~?y3_->WaTbpJy?bchqn0)X&saiC%&x{H6gee(I!>s>iEx*{? zH=FfbdszGa3Mq;m9j;#ikT+*3W)>}uxkLC`hOgu ze=jfWoEq~3nSToXnDQ=EW3UhWxr6U2g!F!l1J^D@=#v4kODBt1XWncp#1-uSuTIe4 z&roC4q&C0r^u|w`Qf5E3uSsEs2b6&_{IY}29flEQZ^QY~^D5PF*$iH@;*vq5hjprtZ*X%BW$V4w zB5T)7v_H*n-B?@ukNal<6y-?C{FC^zLt#wu z1x}z(kkVChOG-w(7J+0YJe+&-spw-?y58(9lgJYG4&Q_JH#js{!MP^8h z&!d%5&i7YU80HNC_!sy&-le-7tPB9s6nUT`QU;QHvrzIXBUZP1$0g?&_mfpxRVv<+ z^YjUWj~{fzt65^-@X1l8N-iBYKB^h=;5O?k`rO-hf_Xp5kMZS9Ey=%`m`IVWZz?66 zD?}+JRXa1v8x3%QAlW7;fnS>^`E`*=UXfLrk2in#CHW)|&fKV<7|&+QGO3kZ#<1Vv z*KL?kI6cP3o2b$R3l4$7MWYyPBWLSR8Pb8*jR>Op{%!ll$=tjA#~(a40RZ%mq)5bn zlGp1cPDYOjNG}ve@fOFcVP_sXn)m*g8tcznCw>n6G|bcH+c>m@vG4o>5CZ?eK~2`S zhVie&=845QG%Qbs9pX3Z5lSPG%)usnUotZEK)`K~(=vLXZ75t|zXJqakZfC&fA)H( z{Uj|J6xYr#Y2Piq^eZ0hK4AI==;@jW&=aa!uV_j1v>foAOMIy-;x|@7ydZN7v2dX;>T?`-rMzRF6iafEz@*fv(F}fA6=X!Nd<|k zv9OSvMJKCp_M1dUd>bB=6|OD8NqeAi7hW^)CmL6nXN=I`p??PmZetX z2D9bl@|$}QZ0Vd@mJRM67e3^jeszS~KCdapfV5T1B(Ye&SPA4=&k#~WF`DhVydn{& zD&LsFOSv;WtC2dD_v!Q-@02m=#BZZig(7>6iIu|xeA%%Tyj+N?7$yK-&+jVg_xe}N zajiJh_{K33-#Hb|ElWg`&`Zm>cCt~|k_dIp`Qw4WPQ0NI6_DN=%ei@l8-YSrfx2(T ztk`S0t2lm*K!cb31L5eCf7>Y?(1#e$P_RVf8>OF5EO`iu{lyc?e#pwrX%>bkQAfy4 zf2U{#k681jDf}v1)(NkPNrDWO&}5j1PzD>sWyrHNYFJUwCZ@|*^d5_@>;tJD$TB*s zQ?eGmV%+4Iqd7RRcAx+fxptx?FxVUGZk8IYhHi+ZWd}9>S)!X?R(orDY7QI+qMK=3mkA#zBoLpHmdBOsjxp~3w8vU6&^=t;D1nBcPq|4YhGE}Vql?e+Yi`HYxU_qH`nm2+ng#aYKM(*8Z1~np-LL-6L zR7?}Ejs`k&1~sfL@en@yygCU}s<%&&M<0fjf}8b42TYUdvhd zJ;{-Cnu!ehIIoo>DQqd)YyF;2P3?bL2%Z3Apb~$0lj!o$AkXl^%idJ9JRqY{L-J%F z)|9(QfGq<}0-@#hvFGEg0es!+xu%(49VoncR|o$&vHHrZE?VI`^B!5L$|Lc20-1wn zATt>S)**aQpBt@OaIH)owcdf(!usL6y+^4shpsZ*3s!smEet@7c7l{@Q+wNs?bf+r z?AAi9qhgFCSf}oKz-?2`^Lsw1aCSfT=lEA}sKOh+_o#FFU(w*TE8m@y2zbt-B5Qd& zr)sMA!b1L)%bQ)4)*&^|Qar{yhkYZ7n__6ZAI$5d}3b?x9;U4z`Q$N@tG>7o(?stVvzX= z(@)M5wWf!^+Ugt3{7v5CS4NP&dsVj>Lb>%Gv1OZ12FXFxDsV zq?~VAN&rvvi?t_~Py7qMvnQD#8I91U#k%DtgRZY<|Gqp3g1_TQP+^ud7_hM3XgWNB zUs=8#?V+}lqiky6?ySug5s2vdw3_mHduneXIx#5yPk`|)ag1`p#6h1X8V%cju z*_5w@g$}8HxHRO9HT1}-nxXEGRD#}W6`$lg(%`*PY_sZJ8OzqLC2(iJOAB-L5YuE? zzmGTW-a%SVLlQ6xb(<3|uucZin+Pr*Rr%BcRd@USUmv#JQ2am|KDNBe&aIgTG4%7i zscg{Y70Qi4-UHt&yjfH0Z+X1m|HLq-l%Hd*gyrUvhqNdzACojYuf_>fUaJL@np{T^K`m2ESM$Wq@4H zwG;RBLHb11P!v^MUd z+e75%Qcu*lhX13^BTE9IKvL#&?w2o3JmOq}GmVr#nL}T0C4+p`$K)QKwQzCg?5o$e z$2}S29*MBAe?H+Jr9M-9?{%R)7gaE?b^IYAgMX!(_2GJ#DXB@!C=Zmg-^jVIM}8;` zcy36Qpkn#{gaBMFowt#p|Bnp~H_HGRTa*g{WQO?8`r8!kZOnM%6SUm{rB=vdv$tId zoJ`yxBql8-u=RxJn;(f43K>YZM2IerG2=uz<(9W^8ZS!o2kFlT@+o+7sj&VBqeU+; zx-%u?Dn>iv7tc)Cl*xxW#Y9J)F>sza7CP{!8ii-8tW_KJZSXXq`q=*sSoD`f-r(62 z)cTQ8OgN-OT}n8_gI~v&7*WoT$}G70!-#{+A87Y%}8!Yj~7m^nNZGV@`@_Y z;GME=+b?u6t2=$7IC}ej&I<;cnxqLWcSrEwSK(utG`QJ*W*P){ugw|F2s2(?ltLdt zMT$K8*jToYJ|E?tz(ZaxV-5bv=%qE+ULH_%BAqwlbD`c6(mI zcDvmuXdMR!shx+>B!mq& zJ+baKDnh&GvfyP>9`OLdywprky_s{{{_tdd{an^hn@P#rJ~o4GyCE?JGT~LUleC@a zS7z#aY=u4N4uYKsV*`AJ-||ayia&+ByFTlhh{8VCpZ_gYt3M91Bh6~2jzWy!}Z(%g5pGT4v zlh>c!D*{_;MFWbd)I&hn^79|~%p|$SpsI^t&M3E6ZpMV!P_RYKzYMq4TJ`Nt|7bGq zG-^$Q=yQdjDuHwT$?n6OKKXpccy(nbk4=iXJ>Iz3YmJy1cR#>g-}$JX$Af?5zj*F4 z;|#nz0cy#$?LW?Rx*7aL<2e zl;MLA^z8#ePuV|LRvkp(OCoxYm(m>ig@aYfu%uaqQU1fHAvl-a&o)$dMBiq!Mqti| zaJMh`H1sT5Bl3aYISsZHm@Sjxg{P?_&g^Loh~=Zq4k+=IB8>2hgS+F2h~=X%R-2>0 z9N9t0}2PAl6j3(ElvGnf;};36IFffClcI*W$LRUV6@T(~6WbbUsmQZ_{#p;ez zkxa298S-Fh(TUyXgJo!G{&UYwX%*8O>CZN5z#lqi6>v9{=79EM3el=f%dFHsHS@?1 za5ZY)#E=2G@rGulti7*muE}2+&yEMosDDby0hwMk1oMaVOp;a$F-cQIZhZc5QB=?U9%JLLbB)Eu2Y*{O zV&W00oSFX#d+~s?Scki#H%GSOksf2hA^vM2yG*UH3@LST@< zkKAgv)O}6&1<26PGW4l(Gbh$X<<+Y9Vf_HsH-jBa<*F;2 z^Z5&)%@0rZKQdNMg0seT-Ij=5c|?zW0gzAgKsjK`9E6clc$LNdzXyQ) zEa%)4eNv1CQ1G2tF>>B_!a`p>ZBY{SOs~x#oC|%;4GNO5)wLP$BG}Q7Js)C~R5^70 zbGWRStg^TF#Q4XvBIx;og8f-bZr(EMD(mHv69}Ia2#%W`R6M=f&K1G&fZ``}X>)Ix zOTL^*xQ+oEp;O5)(nCVi1!gNHA@LNijsnh$5An=90*|D822Fpl*y6sxRawG0rLS(% zrm>B+-yOydI_UYUKpS~6EW1#M1BuCU-6@R0AxE!$u@k_F6 zD3?dw)khz~-V3^nWAjQ^<|wi8mTxNIr~W)qw_TBlv{1?3=S&OWtSjPEAb<2Y5${So z@K^|6dge)%z%ddCQC@kbzSc0?jIIQfr{@U>MVMdK*zUiuau(_G{}iHv zFRIt%)(uy4UrR5tA{@n&tLv&x+^Y7ga)NIEUV0=kAaItdw|bVF&2lf3E1KEHgpKm- z6LD*Dus*31FzuYof9CB7MYdr}^$MuE^hJrcFPsu)qh7B~ar)NS^;K1@+iqu}Kbd|$ z@P_(M;a3o7psvMq;X>K7rFz_$T1*21tSB&BUWK5NY{;pP&;9s~`LVNd&t-DhL^#L9 z-ZA-S73AfkAbOGGir%WXw7UG&P#>RP<$4R%40~lBclO4o>=wYFDq<;1^?|Ly(2eAPW&r^pzO|p}Ajcc0Xw;&1oG}GJdQm`z?;b42IENSsmg`en z=^yTg(DC>^d~hGfvjMFo6Oe3d$)>&E<6?=NV)^nSrpr#_kQ1TDG$Ut@6K{>dX4DJz zC=Hut=EC`vrMnhVN5Sstl{fcgG6;_^m7GN9Nsf$#uZG2-5M}Zea9MrCS+mNus5W}i z>NB!DI7L%_WI%+&j~$XQAsT;Uzi_X6Ls;fb(}zK^CpM9a^DoE1$;69IA5)i{;T`r* zmJEj{sNxw(iug=PD>Z;76C&}dCyGf%eLu{E%RaV6sLzy7x#>Dhd?x$tQaey<{C~9o zjcFeXj{Qdh8Ur)a)2R&);otk+B1Tb;j5?Udy;d(A0|G`Z`Us{yNvsp$rp+`>C}R>;3HVoNfo-PHulGqR*PNyQKOFjYGyoY$seoP z4F@Nm)h@4Te4i0d?y7Gbc@ur6uDI73XK=&Va!8327`irff41}bp@6VQy*`MqbLmw7 z<&-iKTd_k=l2#R(lniS6gNogfi%B-o0qc`ZX!joU;vE1Y)4C>2DN_U6sOG*Z`SDN} zzvkKWk%MqHCJpo__QuVU)9(%&jcHr5i1Ve~?;G{$)Erk!K1uOFR=H%M@M=uc7yn$d zZA-`j!nJJO$PJWLam7+wHpM?&$MPwoRO>4If+~dGDDKaIVH9C8@24_!WJsUHJXl=f zk1zM;s4xokh&d&0^`Lg_$Ops@amF&GjJ~Wq$N;2A_Pp9r-(5KewI{su8Ic||yApQm z5B^l;P4?!c*s>6DS?=c_pxk}~436(8yY25J*;?ZbcF z@%?*#f3Ia-yUYvHR)K?t*yj$$UPf;7X9T8cH}j&-0!n%&SQ^#w-?O+PbNU`Q$lBP9 zIK7loNr8f<`8w}KPEmx@{9*Ac6dn6l(LUbQLp;ZG14i?j<@=Ze@-)SP)ksRHk)_ovxV|u--BgKU2f5NmE)&UG-^Zm@hs(42k4cc!0Wd!5A zn~Fo7(Y9qs9^a!kqkc}qTZ0Rj+q~YOMJTOiL&glzW1fcpNAvPOmG;(TSwKY4Cx+~! zzD$3=u|05UQ>~KXrJM86Ysd)_eBG0sFF#`sUaBop-|VA4m=bz&9+T{JIy0jtF->7GnhD%IA4)&MBKpe$M*$FlQN$mN=d?(+s125`!#crO zL3Pl8XmwhCLw{Mhc2{HvV;GFjfDbSIMyvXJE$YhhAU}4s%z~z=l;bMLGw-o4q=jCe zC##W5xG99w)x@jeV?aqucrD-O@-jU)Cl4vsfWCSw8~`#lSUU92EJgwmEM0grMLo8;ad`#ElagCiV^c(w)y64=sUJ0E z5<}Gwo|G4&T6%?-lr_ksJ)EUR$Jx63?NHdRykF6fOjM z7315K!QpQNw-xwR`liR}xmt`J-Xc15+^jR%uVx#_0C*i^kng^9>0BHKpk)=jzx^pY zh<7@{Gmp&nXJubGMkKx>v=9Z&R9ooEChu(^stkfXtBkI^bEi!Hk9D^d46N9z0BAvH zjMO5I>QKkqBM-CFI$wt$d-_V!7I=Uq3u^5eZp6hBHDcTTNH92D`QYd-7UfnrC1h)Zsi*`6A2 zgAbVJs>7bbKF>mM>IK2IPbJBms2`Y2HuCi(t8%fThoW_q5zOg1cKP&fo~7}>D&_lq zlU-p$ftun}lBbaH5p>kXoXn8^W z0u6OUQ?vHX-v9g-P5j(Ewdo1{i%!0ykLjQ~p$u0ML-=BURMouTz4G~DGm9qcHWr1w zni)uVUhyOSAlE**>HGWlp~t*9p7!qo0ru6FV6RzRkf`i?fckybb%1Ea$pYmlS`#Do zHKUisyxhi!yfOnO$ggFnB1rLldbJa?w%|N-ZGb=RH8r}IGdc$}}%j7==95VdgI(exWBEl*b_;%Z z?<7sw2eIYR0N7%cLvx9TvEu~cT!f}L+}AjK*W*k#8fXjR{feVU!sFvGb-jl6l4hop z^}hMohHjunQmGW<8RL++M_+Y*hWGLGM0D(^s(p}u_XrDLXM4bKwTrx!_+rvoerR90 zf&dq|7UH+P(oRZUHN=m{OudvS-sXwwM){~vw8Cu6jTh&xZySPmx z0b>J}EpTd067Xo8uZ9EGk~X;0^ji)2q-)YKpiApjnzbgQ@yg*`P51Q`#^T^Z&2zZ+ zp`8iJL0WF7n1p8U$}TC~B+v&BU6#>DYPC8gqVkrpQ@2->Ga@71FYgGRTflvjC#HAv z%3oHDYITdH8y$l49Ws4`0#0WiG*us0_?>6*P%_V8#;tqhqcEOAEke-uMo*hXilnPw zF?>u7tMM2qYG3baky2`UtmLLW zGINGcN(Z{uoIpW5T)EYNwvGS|fS*_K7VSIXa@(>Tf%V-*nM$+h%B~w;>z1WcFOn<9 zmox*!J(K4yE}Vfsf=h=3dq3yk}s0HI+>`=NsX1P87%^GlSSOUK*^- zTqOSK22!TFgeefRkmK9yf{>-FbcI}04d0+>&&Yh=8@eqOWuoA&=fDtW{xwWx0%j+P zcwfuwv2qcyEA|6PCPKX&Fa6HV*StV=#pl#(&B6A8kt-4zU7q7$$NZGvDZ1EU#w)&g z`7u?5;AhXyZgrg-rLU;zKhnrr+f({24?qD-W}Ft@0!PV_SC2?{ch zB~Pi{+O8VLVZiW`DDqds=2yJ77zoy+OT@p#5?-o>13%3jFPZ@NYgr{J!@p%W#;X2o z&E8?&7*fvh;#eihC{dCiZKcufH00H{{P&&ZzACPeY}(ABhFIL4#5x>4G2YAR%0Gk~ zZ}_uRM^p9fjd*w7IP6AQ}HuP{&oQCHbD=%e?ckp)!_3xXPIXHfg&h5#h0Ybpt(@2jSJ>|N2kR0>~)L zo0_)bW%#2~a5E2PlmYk0@7**cG&MZ#>>3cQce0%l+pa-Rp+Ai(`k7Pg09nc!2W9Yj z;Uo{fcj5}??qshtT$~PP8{>#~^rYRT9>B`J@WU#$tV9z~RJL&r7G~2pAfH-CFlF8C ze0yqHNF26V&8*N;+e2&&UmyoMA5Q7RCo7Ipn+?fpgoI1!QR5BaJg7T(Ct@?G?L@e8 z;H&o)a9Jt$b|PuyZQDE|kB^r{JLWzBgW*TizsbF{*T_Y=245d`e z2lKr8VCei>AZkVYyYkRA<=V&M9c!U46cvo7e{4dnu#3Vo{|u;SjKeFEyWEN=_k6h8 zXHfR{x5tf6YF^TUd9^Q6@;q<60Vq{#<6k!2;$L^VKA}Amb+$JK zt-azB6~ZE84n9v3r`$;%KosA)Os|q|pu@O`Iw?M~H+m4TDyo2CNPJRl) zLIA6Oon0xu*~Ilb+mUs{*JeuF+asA1A4(I<5>v7{yxdMPRjmF?eNtf_WzTKBo_M3j zg&GWzERwieVW!9p(}S*80j$Tf1k|MT(>109N^Fh+->4tD3*;62A2Nq;VVcduw*t&k z!>QSEOEr=evPa8~2R6|>{yqxlxBd0c$gnPYP^YfXNtyRA5E#-qwYcZqa(gxLN-IYa zJpjSo>6F(AE}f^YX7t2kT1lbHtT zO3ycK0ndmkie(m;zL?LJ`+pOna;)cpw#rG|!+6|JXtXVAdEt(R4mf&-+1V!b*-<6) zU)N2XQP{=}6UFy!BJpl;{?L0`Mz!`H+WxNH7K9ru+lv~G@A`v*@j@^pc|$@{xf#7j zYy`%vAn^dCX&o;+(K)X()=_ZcqWw4y@MzYt*u7wF1KZ|OKIriV3WNRzjDAqe%l#zBAo}XfH zfNP#9V4Z}fghu%hPGEg`&k6ZwYhP~glA4vj9~JmMZg$9)6<&06Qt}H$>tgQ>iVrLI zyy~^hZ?PEYKX zbwY9g9o!9TRz55nYuwHAEH$i3u&WHaL z9)Tb+#hb94ZI!H3>sYDi1+};g#VMS_{HgM_p*0faA);81Z59GAN@l9dG2CrH)V>6~ zMtAxAk;S&c*wdSZl)cbTusknD>|TN2{d95IxQ~{)f1lUtCkJI553{;DPanZyME6U) z@q=}x7U{lwdJS~v^8#keD|*k$SVBbNJsrSh(=bDBY4)Jn;Q&W3xkc!!%5&@ZfQXY9 z*n0G5k*$CNa0K)#Lvz-ku%M6@oB=uL;I8p`%p~8{1m77L7EN;_14a3I8?roSh{etf zI_~50kgGcDDV$SK4`(h=!NI!P+)ezmIh6B~&6V?~3;n=veo+49PS%k3%n$yy4Sm+U zbzJq**X`>pyJY1IU46}iBh@m&_lD*%1(C#Clr+3&wOT=2KWcCz%d}JP!|Z7vfievS zwA{ROw{IudjGi&(tEbO%VG=sl*)kZu+YKGsViCm=@>Y!)Om#u^BoC*!0M-#3;2N|( z3XDz+VcD?ZW|FM>RRm};GF@|kLhyxvo+>IpO&k^@$GUJxHXsL2$ys? z$&*t3OF4ac{*?H>9i@Y3;Bz)BjN0f`@-e2Rvx@jqqk){E0r!3!T`xpgpxqXTY%J&)7sfyB-;po& z8pZh=EPdEJq{2&+3=cHgoAF6tbwjMNw=bvo7j4BH2d3K*;jH^m1ko*}{vWru1F9Q! zYJ5B;WJzdyn`g$mH)eOm96p*$LzV=x@zBTzjLE`ueo3Txv9=e_ z>#**&AO7#8&Q<&0hSJ;$t|is7-WSCjF&)!Vx`N~8a;rJ1XixSGL-}^~y1okR^z2GH zw^#a3lCTO?v9q%vlASI2=kmYbAorGnkKXd<(7(i_&lm!N(^pgSDiw(S{XT5T2?KiG zc4P~3O1@V$gGg>XnT|msjvqR_ykbE3?IEBBN!I!K{BrQ`yg+g?`t}q2TQ017h_csV z_G@W-(m_KO!Mpw#<`BXVBjSPVZ&ll&W4}eaEcm@H#PnN~uiA_4Y#<~UKa`S3evnw@b@ z*f{D8^qJg?jnBBJUa0F}Z}H2606yh4FWJCXkrSV9{AB!=DSl98s(dB&o$wjRn4;6T z6>eO<;qurXXf6D_ccSx-L{xj*M8-F{8bxdltFe2u0^OyPd<5a5K%MR&N8B3e~Bq z{I~dpy@KP7Zc{^or)M1I;Gj)!`SU_h@orGzrj>EWyX2mQPoQ1P&ziYTMf}YtN)g-yP~;lzYscthk@&@Q+&k>NR$JKm)c06*s>9(wx+|CP#{p~+2DPVO>Fpo0dfe2jt+ z@=}VzvEPGC0K2Cs!Vop;Iz1nqDsaNyt;F6t#Y~hO@R$A$kGm^0Ov?UlxWzsxDVFOr zeRe{I?MDZ3U}_fDH@Fv~JRN2%pfFXV#*D@Rg#16GBlZ zOzN3T{wIOqKA!)pJDRZg@J&x@XH+z1z^SdDea%|B>pTi3HuuF^iDD2ZF6oRWj| zLlm*2gO0fLAmfN}Jj~iN{)7z;o-lH6R6f(M|A-QQnh-!*buYF3@5((rbQG^2!Or+% zWMfNS<2B270Q)%Z^l0H-YBmWho<_!%_gkR1;~|Gc4P$}z1G>hYakU&qEqo$7M}E3x zrwKc)TvP4(`{i)uv)L!{WEJ*@YX1N5qFy(0OV8K*Y1wd7!O3RI^L-|7QjZC`bind2 z~ahc?7uGWUU zY5Z~Of!$^1ohc>2N4lL#?O}p8b*jqX=VxKpaXCMOn?JY~gbm#;3J!=C`nCPY((o~z z9StN5gG7j3HW(z86E1=dzg8d0Ap@vS9MF#p+< zPiW=P^p@^Fh(~}J{%OM!c8>PpmO)A)B@=fAGGMykLo_msB?{xv!yDMWg)6wkE}ykd6s&wJ?&sCpLsflF`R58RUo*E- z`L~Wx{iwF82Y>DmN?1QyaV1yxJF7%7J7*^Og!e>8z2wCi4+he9HpWWvD-Hiycp>K^ zXTnt6z~DB;RyInwW^u5bm&(Kqhq{>A0UnSbuj0T?Cvzh{D3-`QU*ygqZif1zfBz_b4tOi&1*pR7pAY@ zNm_YJtRe!>(&Ek=g_|M9h=Kyqi7S!c-3zJO?_|?U+xvlY2jyV&8I2lG*XWY92q|NL zutN1DO>pXUO>4UlE1?zhLG3|H$*^mw&m0p;O*AJx;xV{Pl1Y|l9s4n?bZPOFN7}6tohBt7dIWwKEnE-z`=sX{@{0u{M;W0 zqski2CO&D?+*^}+jZu7Ocz4b|=KebWmdoVniiE{gu@z@di&$4yWVxxBl8OiD5y|6z z1cdw0cxQ5*ucO~n`;X4>8IOgIds0GR;@4ok&rt7a$^tf#FLplBtse&rKOf`sG-}D@ zob4S&efQTyzGpJuR_&3{THRJd)5P*<1S(tV55XAz6xZyPPhP9NJQ$#}ieTg=W9Y$DTK zz!xMTxMdi>M06|6U+=i&S2;ovQtiYtAfdk4q8FI-&M6>P%8Y|&qOyJeNo@)Kj!Gvh zQ$Z7=8*bXdb^gPuxF4K~#&n&!e#x;puboD|-apYsGje~NqiS%P&cM;xnqJ2W$&wN+ zo@9SmZn?9d{&4ku_XB@2vbL1vu@de(aTe2nr@Gs#{HiOoS{aBRGTLm+uZWRFhY6s> zb?3s)V=*9qO>HE;k^@Iv#Y5P*&eTd?R_b+AU6B!b4BzXt5%JIkK8p2!Z$V4gEa7qr zD+VD5Ui%y5-90hu#O@hA%}t{ucQYEl%tu~KCi8lSYF4lN&RnpYuA~7$tmozEbImiG zdiln_1U+(xWjD`8LFdMjy&B?_WV2`3h!YXES*+0tRHWa#A2++Bg6A}H=wrg5>jT$f zh?ew^;BxN|u=m^J3o5?%bk8?p;+(>5HK@aFd{pG06DdJ1Edh9%gqYP&F&W1Pl;rJQDKI}&|fSnKc)wGRiyf$LQpdLTQ*a{U?-TfG8tPrDV zaPXAVHw1H^W8p00Ul_S1&ymp)VD5Uhu1qlW(8#709AM$19)>>nt(Jhf{eRr9;!C5>#JJYtRURfPsiWy6m3jvJ)&2M z{1oRMIDg}7I9MdUlhP9zq<5;zWOcgH-I&l>cHJH9@ru#t@qN2Z?Q!I&n!*=r3tVZh zS=pIWIhA-6j$pRsBr2aHMo8b>Yz#Yw_;{~HjNa~KVlv^~jk^t@-~-Tt#h*2P`mUqJJ_JFV`5v-Jak>J_00EGoJn z6z}pw6y`o8E1lk?l%4PBs$V?+TEp>(GFUoK8*oEd^s^0m^!J0O$U?E1%H)JG%sGn* zbIKBA8(Bvl)>Y=FZsc;0&IAQ&@z#)iYNjZ&O*z=s|8C;X0)GPJBu=QSw*6UrHTm8; zTC*!ihjAiPA&kK$;N9|9Cw;G{K`UV5*4;;igntohDb33APH}J@1R;E|!lK`W?vB4o zGOoGIYx1_I2Ir=hjBk2%_J`iZ?H_{q&ODCB|9p!((D9?*C;oLWq`rY9mX}q9syAh& z?Rd@{6_T&K3k3Mk01al|`gf@=FK!fBh@u@=;`Ki^iTJmmhph53#WZhuw!osCo4b_P z^m(4fh0S83F+EjZT_-!^OV_+j0-IFIZ)=VM{m>&hL6UtbdSdZRytl2!Q7_X?dL=}% z`}9<#A7N^XgDea5Z?yO&tm{cjr;Y3j?bNgKt8P(w;|Tth%oODsuh3g$GU<4~uw-gN zR2~^MH|*-)Y?0|~G_`kT@+~`>lrCF$R-f{y&t%)H-h_ltp4$qo+4<%b>^k51knxNt z`4rFNusTaNh^v){Xo5bIKj5@khA{B%F6=fH_7VW=umF)(jo>fuODFn)b2ah*hHa%W zO2)LdQ7k`yzvwDhtSMY^s%vQ4!z8ueBO#)p8#{c<)z7TKva-?bX{wE|ET7PM?Mot5 z>=QA_pH$F)=OImv})KlD4U9DLc}{t@D~1 ztk<`}lTALgM|72Z7*D{TkjuZksid)Jo=RO7X4lAOW)oG_e+S$lH+*g^5OuD+DxJLG zz_E_~=k|BGr`xJA6f)^)cHFt4x!N>4$X;mE zjdq7XwLs<30qnC{lulmaXXMJ9d-BT-z>aD6U){8a>DylN({-2g+e32@CA;p3%pYaVYxhoAn|GzL;g%7KQStRVkiph3!zZ`;&hIV6D|5J;#{iEa*dHRBG4B>OJM{mP*iJIeJii?+FETy-XtGcT6!HtNjp z2(HQI*BQ)7|!^byUl8B9>WQ|iM6lsFVU0dMtN_vxbh;;j$uUTMhd6PI~xOAH5$X? zk~^B70e;Av3kJo|kEog!g?A^lGxy^}ZV$mWn5lw0<&t5Wk|i_BwW{2p^^;O-4G70x zPpovNrJ6*u4ydfNY&oPH;Wgggjp?>nfc12yY)Ae9-cj3H@6gxxL1JzY(uB+?I0Wf( z5OfBH{mdwPM?NA}!P>u0nu2N^`HLh-w?gb^t(4{NW3z$R++xe)%6kN-bUUhqYE!H5 zbFYZECN3&KQ*;(hSLTEdpGMnuO8Zw5(=iL)(W{!>%=J&H^98J{jj_BHPhUjJCr;8Y zu5p@&Kc)%F32n6uJ3E*@YdBwhO!@%Dfr?6U6YEF482?ivS>({s3UH~DvTq3EeO?^k zb;tRlsf2bD*RTfV_q5cIaFU+~Oh(0T_|rMWfnI66#5A!eVEi&p)xt8kEe$5leh3&* z)JI)Ed#+!kgz?#Wbsf&>XV`ddqrp&spiP%`0~8G(B?G|wHAjsTI#KqQ$pp`xi(>UN zlbcuCZF^;(OSc+_);+zun=pKGI{O`HrH2GX2xHp`jkL+0E6Z-U(%OcHTA?*v}%uDguP zppf?*<`4hHW=$bD`=x-6nsL?VsG+0EAKyFI#slr*Tb2iKxSbG@dr%Nk`(79Bwuf4Ixq%#Gy)3b9iiHynqWk?l@g zJ|=LFn-sf%&!a`kf?3S=vUrWG7`SUX>^h^7@?ys0?2Xsd2O`0z?-YQy#q4=XSEg|O zLvDQ+IgF~_z8A-jB+q9UFE^}(uqbD(M`yE$y=K2!BBs9^^7%)BQkvWT_E@Nv9P`M> zab7r|3vvTeUJ*vWYPXz-2z&zdb?sQ?*725g0=MILE}3)o3q@pkAC z#EIx`7c3Mr9L&^i*CcwzJ*sMHl1Q3sX*UC;B=|e#L$LJBfzOG4!Z~~i+j?hJ?qtpF zSGd623j@3fo!+)9Usr(kP$Pn}O_t-`fMSge(I|pBVd#;=4-A9M41}v+%Urha#fMId zCoY9E_ISS5e`WbFCt?_<*GuVW0^Vp{1tsm&~8vjsrBM=RY zKNQ*cG^SjceZKzqJWK{*ShI*mc4@M2)^v;5F2~z?RjFTjUnL|*2n3YDg=GpqPSqGMY(iA}J zM5p>mC5<+TR;7P(EP}W_`!H{+q;hI+KUIIz^?T8v_f*mhv04^D*7|EiaDg`bKyYE( zI%&IVqFyi4i=d*tkuMdRH74Y^+|LZ+U#A=dAY)HN4z%?QAx_asvICae6RKHMGEdD3 z2|#UjG8Xgd<)&;q>f61M@?KmU3bJ1R@ko4IP|5ESY=2|_daCtwRYp+s zG73I7e?%<7PPf>s?3+MO(n_nkV9zq`__DqDea{(RK_X;RFkF%*udziDT>B)Cc)W_| z*w)#goA;Bqv7#)uO zfRTMdN&ROgHW6clNe(rncwfDYm=ZmSf=#Qbm66HP=8S~&XfYQy~x|DduV$B8hkar-?~_hRn9Q{qkV@Wil->o4wjH%o*f;p_v|1Sq&{;~kS{S?ER>(MhPQLC4}^%bkKuWI{RRoTu50 z$mjhjd%6~$PpO?HPYvAD5!%~M9WAAF≫E&-NGMqXdn5eUeOizz!4P(iwxSMX1qb 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 z zS`Mu)a#V#fQ!qY zF_1TBT^-#s0PkP9vS^*I$ZvjqrCh`EO0Cm9;=^|y941CX5&)r599N9Eg9GWb{=QxH zwx)-VSE<_c+>DGw@b09*BGMha-2r*ns++T4hVaHDP-Z1 zH2{Z8(QfHz_nH4TM!c&gxCWQozH zL(|P^pS5VYscg|Lkj(>--Vhad7p+z;kd2$Vq+a=c)>r+#aInixtjG_JU{ep>#z!GU z#3W=CG;DGqa$sETcqf&^qo=ufU zA>RI2Z}v6l!+16fGD71(-KfrsoHtY87-@Ln-<|*85eBS?iQQsdGfL_Htt}@vLwJt) z-cVg9nomr-F$ihYf*zhZo>%Nwga zZN@mI^b3Czh#o8rg6`}sxVz7EcPiAx-jTVAEf%JN@gM)RhW^>TnFZ!ujm*cScQrMN zJCJ*y&#I0U*#vW04n9>i6$bE>a{j%b82};8_V6Kv0rTEsNv*agH`w>3hPSji6bkYBx zXynLW=DfHNvU_EK@sStlJ7l8T{e@}@D~}Nu@(7je5t8;hwf9#0R30H?oC{vJh^u-} zcu%w?Hsa#N=H@k7-=)YeW-3ZEiIA=pt4F1v335YJdzH4eHL?!j2I8rLPyvHcg9*nG zl0OEZ?uuy{$2|Xr~=>5Kq1~8>86JrJL#I9Bd!HO zRu5qNkC!)F((j9r&O)#4Pvq+<_0KvpbF{UJK0Z!3#I^M+3EydyT{Y1}y-kS~!YB40 zfhuqwLpZPvTT+WIdE5CExWIdx81}Y#s)mUhtPiu89M=^LypG-fgSxu5Yw*#twU_4Rn+SmB{wxBFqUqsomk4(JTU z!5&pp;jrmqMzxy7kB9desSsDze3g$!HFpL7WJaarP_qb=!M1~(honYB^UX$sU|W6< zZLhFKuJJ<_8hfz1+`fr7sy0&Oz`?OfjX9WPBRdrb;w`R`amvwK{~U i#>~O6F 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 RYy^h>IDO$%?n#GR{|`&ys(1hZ literal 0 HcmV?d00001 diff --git a/assets/wireframe3.png b/assets/wireframe3.png new file mode 100644 index 0000000000000000000000000000000000000000..1f2de2f031135ae3364bb032b2fc4722cbfa16c9 GIT binary patch literal 258956 zcmeFZcRbbaA3uB?hpZw>WSx=-Ari?rWfd|)$WBJ~-s>bI^Akc5q9MtM>~Un3P0A`W znb~!0zsq@_hVJvZ@9+J`{m1=yd>#*d>hm7g^}1fK=j-_z*Y$QsRat&7#bF8<47T^u zMVTuw*dG6#KV+of3V)hHJ@|{<{-TZ(3`R+}^M?rbAc+B7eY(^GY{ zvoy7GHr10ewZ7@DXJhPSW#{Z{Vqt1)XnoVx)QRu9wW;k5M#kb=@Fv5~n=;1ErZ7PP zK|y{2QGUU*NC5#cAyF}50m{cWOu#cVJI`p`v@wN&8~C5oNzXekgL`{$GdmiCo2Lg? zP|v}oy*rnr!4*ei81$FL_S_`6LAi57-Ne+^6o&in*b)6WaG7rB@)aPGspHQ{PKojf zh|~u+R)E_qJGV_dOss+A&{Imr9;S|bPR2I&;2KOw@Z#&Me&E65|MH--owKpEq4Q7q z1^Gk;R~WS)gEu(;}0SDZX-O)MPkY;SrRJKwak{r#>W zpP+~^oy#W}3<X2bOaD*m$y6@_2H7+qHEYpC8So;~uTOUf*6zTBR(ByZNQO#@=P8ha<>n zkSKo`(SQH=PYM4a;Xg0<&kO$Zg8#hWKQH*t3;y$h|6h9n5)pajXJ#8qBf2%uq7ven z9ktlWWymnbsFuvi5ib?B*uljXwm6NIn$3K_U~zjeMv4e?`68Y zx>rqbqlLyjam-MLY=f>p%Yub4UV03M9Qt!CFXQiGPq`H**XL8@SWd2$cbtD@JX-RZW(QYGmb^!&ZdfI0D`vZhMM*Bh>-zr=7da z2zRT9b*?tc2qjoZyr-vusd#M^B;)Q<9i=h;me;fJA<)g&XLwCRo)FB?Ul9mQ%ifZG zbUQXgABD%up42+aQ{!s?xHEwAtECCL&E*|i;P=lWO|Mz1vgBmjuNsg zDhwEwUS2GuuoHOr$umR>rqLq=Sb!6%eho|oRB_YL`1nJc(qL&Rb_{rAuevZ*b_t$6Fflp zgH(pJkRf#`yNdVZGGcU>bng;;JP{~9QD0mU8lIWYer7)YTm?65w$_ZDpyI`W;(eRn zXyFzA15RyIHTBVo!oTS0tD^*+=L{v8zet%oqm@m* z38C;X?TT|?{F;GQx&C?EORC{!rh6P#?rG?VuAf#;@ax(w^!*&%MI3PVi z%<^b`}+u`6xkTql`1b;e*9h7phud z+5VXdgn-gVO9Lws9`J;ar2xeGUu^=Mlg;L>iWcNee=Sl~76sD_)O-SI1E5c1;?bZY zcWP$zU(({}tq_r9Ve^OI3lJB_KK3M}W~8br7??&~6E|?`5r844!`Awc8h5MANDRPj zGW=c~&d1QF$i=lEotpihLG=HP3|(aYn+AeU_kSeVc{+Y#NM`z2@a1%f(uUx|a3d^? z)mvMbfIGp^&w2p1mdq$dg4&OCCiV3Xf zOuY_2M2$Chs4*-vilAvoKxRNfqj?@T&*1|=Vm7PxEAfQgPziWT_!U{mTTYAu4u_kSAIwU@m=p8l-CuiF^u(9Hy2@7)@h9 z=h}7voVr5fX z5RV%sTpB|)B9c0l}J!JQjmgF-7@lyZ8lbWQ!x6I#|7 zAd9ifA1*?ZIUg!6UVmB$S^WPZ?(eLMA;zB(V{&+}4I$4ras;?}xA#6N&^Q;`u}$2v$aG2Weo~X&XCewU}YJ8SGz+6lQKDOft4140;yT29N(yE>#BAV}EH2 zlLcHY|FH5yNJBA)fP?swx$Igz{uT5Qpakiueki#`=JFw728R|T2w4l^3g9y5Z;G#> zQcE!$AFxJy{+b(7TtXfIVST_0E8Jb9TVP=-_U)%3`0Vyf^a2@~e}fSHwF{7Z%x4{$ z;RNR=a|R1>E6T^`QmP=4*Bj7?ASA$PP|?|11< z!7EbWI3VVR(}(-;I^Jag%ol)`7$(8JP?*mLb!wZZy9*(oLHB`W^}U(G5&GN?w;h!ctJ@xN|_YuJzYcaATuxqVu2dgs&m~wdni%@nA(QhVLvd zRiAM~!uiB*c!XrvQRXh_lOZ zI!jFjVEa{L?sj4rnii~*HgpO~P;Dqc-rfSUUDEC(*c74wW}!Tv303;1xl~7K+kHiD z&Z9a_32D5MT=d_TL3#hzV7NOj>L{)n#~=|tfaEpQFJN4{ThFQMuEQR!gya(fJlAa@}G)}};e z-Xh@KL~stU4i4cDkWTw(K?VA9;iE1g2<^_a7@h;Jc}$$HLrB&F5aev#X1*ukrknx) zH=x!2gV2*ST)ZI2QDutZW^DflsOnMmM}mFRr$+#7*NfhS;_>dh^RHav^hq$k=ZXu| z{G8#K#~A4L6CyWYgiuh>hQ(z5gA?^MNOkRnq+g~Jl2u6-Sm55>PG!gflIZpN?qeqj zhC@_8us~sh;T+Ba7)g+j%%z(XR4bVV$a8+RY%F9zkd-67CPIj)5+Z@l#Y~>yI~>+v z)F>O70z%y^^jBcl7B)BxhdPuwfWW!;z0e|eMFOyF7vMQAdLI;UO1wr>TokB0#r_xi zK_CEEo`O6lxzpk%lo2q*12P*uO#PBjx=vg(#xVkwH#}ZiQpr20DWXS(OHh1oe;MNd1{80QeEvn~O2w^OD_GNR0%`{{w!YA0W`Uc9DQeF^_jL$HROP zkfG9P-7Pd;b}$f96d8>@xkUrcrD>4uIzY}==QD&X>W^Xpt}$Jl2`#Ar3H+ZjJu7Or zjF2!&pqVB9e7I8^@_%mdqP#HkVS?62v-1&sL*iRaVw6Cq_ge|WFJp&tShQY4kfH}m zJQ@B;^C-Adkx3|(@W;#m7RqP4&H}0a10u5-7Wr{) z^Ksul&k4~nx`a}+S`54YqZCfXswyBjwq0!@WDJ@Kz(v1zB9MsIt5@vFClqoCN@BDH zbg&wg#|mlr8vOMv(F```8v9cNLhv!;A3{ve1Z(fXX&NQG(_q>3y<+oLLx~VBKanIE zJzOW7X2X$Y2B)eOX|5uwn@LERU?SlJ%-Fm~8w*jhEHD7iNah1PSRtZ?{FVr=4{WU8 zWsQf}W7JDVOv5}OY@qy6BEZQ+M0D}ZCHcs%2SmIuS7*Y_rgRW!*^^rE{9w7WypbWo zp-i5LQ~TVT-f&1j0pgxhyJf^%2c5UWhG&lULBbwCYQH_2?U`{!T_0Xbn`KFe`x2@E zoo|_B1>=S=vII7I9+B{a(E0=p1EpC6U69609Ow`0c|=%_NH9#K{TX~_lnJDI(UJKt zXe09SLz?ixdB@>Po@gdRow)!RW)gE)=# zw?0G&#?9)0Q`#Ip@Iahm3c&D8+_O)a5X@4+!p^ULgOVzm9^i-r{v#&{;g`%B>>&-v zy%U3`M5TZ?C0~CFBY-iq4p5M}aFQ5gHnW{1t4?4FL1<;tAT$Q67O6l}4haC07>gMY zOhGY6z?9PVR3!Xuw&tCFNx=Co5=aL^KnLb$QcEF$etH6aC4OMo zt*mc%pq2C}53RVq&>^%gApb`|KGR1l@!f+UdO#141X(^#$cW(eC z+{P?iD!9T<$OK4%3qSy}J+d*70HZ+7_0+J>cs=hLJhcqaSJ}gp&^YLwO*gS@OF|(i zl?bpRaX=Q-$27VQKctdX@c`c?`pd8#0N(OK2M*)AR=mJmu3WpH!7C#*eK&mq2iHp1 zBuE@ipo!S#bNf5AucD+flr|}>6Gm78`+x#O>(BE*YXxTon*Z2N-)&f$o=c$HLKlAz zuL4%^>?~0)-!3)bNhIMJ0C)0eCbV^Hw1eLhQOSh_V^aorRMqz!Ug>9mMnqEG37;_O z2RDnuh*SHaDi3L& z0kXs3MR&p{6!rj5pe|gXfJ6`o2hY|N_v8DOyFF3}R9S6CG%jeI9;vwIQGq^*|GqH` zXwcRq={vM@+(j#@`{+86J&A@Uq1e+5@n==X4?-f>9L3h~@MHmH4D`x1}-jz^cOyC`#OAOe~3IGwjFu zyVxi)8$u3bqzZ!ip0Oe)h;lu4Hut??DqFejgxnnw1oD1r4m+qXVZ;jOBa(=6=%OS< zIc7&e0C|U+BE=2Fa51%>YABufdz~#|$a?_De+gFI1Bsmqr`GH#8&vtXJ^M3=BqN(Y z%#yJm25e|m&_&3h|4KeJNi6l?eRG_e!AfIA^&(bD!USwFrn7~M!Q7{_Yhhm znKkGy3_NHIg~q{<;?72>oI!d0o2Q6YmqtXpKqf;6AS@A>St9R$3dad5#U60hJc)lf zKG$UC2FH4UEgyX`AXvd*s^QAHtk$CkAyJ3k?Cju!4Z#`Py@Z87Km)V8v4G#)%zc82 zfUWeztrs39XnL~UjrEyh^Fzv3x`cLC!0VY{2mi%lCX}Hx8|>J=H+>RGa9~Ri8m-=C zLcP6$BcKRk8qJC)WEmwHkRRMdcPinQBX9+1=i(l@d`O$S$F>0J)Tgh-)55sRyEjn& zN~w13Mp|ft_vVMD#dZ$|x!Ne`jz`%k6+rvUN`QF9pLBFW=W}+G48n{bpnsEQ8d`D& zx4qwoK21W&9AKeyKml$euLPkfbC1ur_hBmu5&;ZN1X3B|k$z}d324A`LJTtcgqXlc z5)i>^_>*KDYoLz+wvo>0=OnZ)#6G}@Y_QRr5KN4CfMTyIT_s!vNP%H}lfDJw=(AaK z2wmc;R7J=HNC8k1oQ71Tq&l=kUZ@j8NK&MLE>M+q@YM!rRs3L81_|G8 z<8+K4?UzIJ1Gp49y`sm%MF)ic-n#r>xBvVH!;Zs{l|6()OfQ+ZKw|O)*ow>1Nz<2=^fsiTpDV2gL6@~b)B>uiz&Srgj5^ENZ(yGg#epVsijw=#v>3j! zc3-XXSmQyp#dRv@l*1gv1H4Tbk$}%sc2-+b!dNZGcSG2L2`AEOMl$}IVee+l3Z0rH z{aCu1B<)xm{oweTIlHJNQ`BEap;R?ezxri`ozXDGD}sxJmD%*gX&j$tl4l{x;~SJK zMHNWP3=fZ;4a*UlX=xX!88D?uigMD6lz;Z>M##g>iuP!KkWR1xY2juP($3~!9pSLymh(FZXdQgCPMUQ$A#2%wF@cqhP!#_QfeP@IvQL8+v zKw81LVm6;hG%q+5!GBVhjJG2Bz_gjiY>-Xd5eHI?TfOKFWK#7!o2-XlEVb-Aow}6M z0ip+Z|3n1RKG`3(B2KG<*Y!DY!lj%zP7|O~Kn_jD5G7l-*!h-m#(-|jD(%KlVznJ9 zh7qB=MyDNA>v4aE*U!eLn~`RG?5Pv!Lh#6`fMKlc{(XCH?Y7_4fbJcB2xS6(V0jx2 z+SKGU33oAlSpzwt*`_^SF0oX8LWov@9zk0)RY=M!uC}m-_?**j>Y^J1?wb;7k_=nV^77MckrNHV!2-_LX$QF26Nkj&8*b41S!aC*V25s<8!>x?xgcsH{ z!C3mii#`U8=gd9LOI!m@Bp9{=+`m0kTO6pt)`lBPO>5%=-gmHH4dQaiC^QiFBrTlptq4=(&4WqKfZRTii#x&1^RI|ep8zbO&P;BjNXWsU0IjtK&MEi z(lNrSxYsqjY!gC2_J~WksoH6WaP_)Q~Du4jZ#kdP-of{JIaU`zEE;M zpUjDL&MECn_&`p?(V4x7CToP?N(GMsY4u#lVk=inY0CW3jm-fItcvVe>$5CX`Fd_W z6ubHk7#d*IBVFI1Lk-O`NacUb{1?!jpZCM!=`}%L&WEyg+{EAl_7#_wOv&+3MbSOC zo?JqI*LlN8F-UJ(kbir0bDgfEGQeyrn|j1$!K-QVJEzZ|JLkJkt|Szrl8`M%qe_#u z;PC3ssX6om0G=F0(Ud5kGs%sM_jkT=Fjt!mU%bo37UgId>y`ecxnmFgAb(ZsT)sF1 z$Mjp5rBhXHMyJ@cx^;Xjy!9%59kSfiV!icFM(K*DpnWPUy_<95O4^4j=U63s~ z#+rX)XnXnIBFVz{n6xihb9&v|Rm8@5S*^6KO>*O7>GG!(MF-lt<#cT$UVXbxKVNv| z;~%}5R1ukvQ{XHV`AnCJ)KyNM0#5#~ULx7Uex#a(k&HfwA6fRVMaa`i&4Q zr`lpvz@i{#Rgbiial;JeeMWNBX|tE#A?wR_k z$uTv@MEdQNN=Zdg>EZtLW$<_Xw~sw`L6|aLGorr^ab!{!tgtmrWw=5i>DvB~n8$_( zd^Rm6wkspyGy$V%8r*|6 zk3A@B?{p@;i_I@p;BR0@v^Ke214>iXHs%mne87Z>@E4pR0^y^Eu7krN`M|}Qj5`l$OCTxFN&WUmzQqMfQoc7Cw74|4{V6I*z~{>H zMw)Ym$j`F?F$X=jYsvhb;_mM#n+bqz+`W9hnTtPS@f8=}C^H$I_F{CW$Fx7yt-&&` zxu^yZX77VAYbAQX(_myX7F*K#!t(}M(%ciOz;Rc`$q%TNlO0uw@qX6yn^nS$g8po zjgHzuwe|fw!q+#j?Q#c`P|1j{-n9Gl5*@~ z)PCDLj_R>RawlFVkmxB~k@&+L&fw&g+td6b_=HmQl%C1cSyP9!ZGLh(WP7$hrs#8? z;j~9krN;|26-bobo(op#M zX!Q26xd8Z#JKTU8BM>2#f-X~8e=pPvI?bO;W;go+wy;d*zik-k3BEePU_cPNOO&Hi zNgO3DU1mrP!sME-S8UnHc=P7ovs42gUQ4Z53`-7}!#DdxTNgX<4Mxc04S@guKHeRV zN@}j)@?1s*8c47!Cv559W&p=8tsX_`R7$M(f0jd2`Obw#pPxUMmcYSG=EHB5ve#+v zZGDQ;IpU_RpRpa-*&S2?GbntGC`MWPuHPhY!BDoO*oh-iWMhQPf9XqkAPh|obQ7Rc zNyl6ilvob&H5mBQ==nT)vMOFziTHIgL)NPIpWd@S(f@NVX($BNa~@I<*$f8_r}YwT zy9ZlabkjkHSIa7jS2OtFh$#x*3xn|u2DTy5@$RiOJr|5J;V<$5M?JLfok*4!lvH1g zYUT@bl#P9nuCyxo=2`k?PL!k5hVN3Zd%+*Rf=bNkgh4` z_4TdV5UXli93tW{PvPtCU1s2ydZov_ZOhFVJvO!yAGP}ZRaQ=lUzXFQSZ_(T{4e9! zF||s8Mxiuswb*C!9@k^NPj0tOY)7OpwUrCjeN#icK?~HENjHFc@ zecx6lClm6Re!JF7vVvu{<*W4?QaF{Pa^Mb&-{0rewDFX`A8)v{j6IaC?gDnYj?m0~ z9|PfGr3L10sTg$9O@7rV7Avz_!^IW?s-d8AMp&EJr--eCx>s+FY)F~n*jzLze%i-2 zmOpB7hKrF^>TKhu?YR>)k>^=GbykzsA}yLgf$4BRKd7NHi&d)XaD?zV_Zjx5e;g>2 z;}gJc-;PQ$T!NArkXhcC=1f1N!u=`ckPK|YkFxtYI8h`yD zyI9~mk!^9_pF0CEM~}76i%1Wd%fC}y;YkzcZ_H0`KFe&dcX@!`r$Qo>@eR7Yo3_D_ zw2Bd?vf$XUdiGv?sIR`a*~3VA%0FvqS5WWI)tcgu-5Kd4m2(H^+9XUjS0$>pr$mSE zKZ*cuMuZsgkqGRq^qBj!vGIrLgH+ulXGF@d)|QbnlDtRdXt6k2Yy2hIET?9$a&vUKiUWJh%tyDmIi0Ozk2g> zrIgHHs5uXue2Bp)On4o2_3(+!3$$y3ot(S38p*}DX13y`;%#t)!TSCk%!qa~OmruQ z1Ar4&TU_j1UHYmW`<%atF?n`dto>p($s6@zzxl<4k`r%lR}-^{xc+Xo8gT;=o`=V} zLY;=Y6t(1CRUuD(e22eQh{7KZp459bMFw^%Y37FW3`RVJ=Y70Rf97x&2{+_XsdISn z$S$ag5pKvbmdWKr9vI)?$vWzhHO_XnSPw*)lG;;oe#_B*8;dMz^}gFfrVKN*9X_nb z@E=I*7~bdtn4WxZ+*4@!Q(*e{Qc{4~uEa`(rK`aZJ4RS~r7<2bl^Z zoZ7lhg};56Cy|~u8w0Vsn*`z@i*QBa zNy&@6_EKk*9Eo9p7RR{VMyKfA`$CUE#eLvF2zI*1Y@N?M&-ATnkX?12?d#0FkLH=p zD7;dryiqwMZ%ium3XtwYqqVcYQz%g6q>OL8>dJdDuL|5iBxw%!_N==*`SfKrFXZ z)nbWQeUq#?%|QMm+yxh2mz{riQx46ZQP%_s#u8T?GEm^ z_XFAx>{o5G^{+E^iRm|ntm5p{<%iwRG0jDt&>z7Hyd9eviplG2S;!ZvDq7~sb>%fh zZY*-G28&4ZH<{G<+zMtTU;n-PAm9%Y9+-0(RNXq!hR~(3g>Q+M*{4*VQog=zwqq=# zAMgcV<|gYw(|LRK)WpCu>+E)GEP9j+l_xxxqq#g>!l*)@z2Y5o<9jYS6!Ox0-}sZX z21n+xtRbzsxvS=+kMsUKE9(h5-PjNt{JvKt+#zi#D&5fVYO$Rkzw(tWPuz@ga315D zI}=0S)q;{d;*JC;Mzt>}-&77~w zC$wf!)UKbD9^4tQQmj!#o^g$uFO6K6zp1y{Y|QTRRo^<%$T+Q=qWfP{yKLNmZCpEV zzq+9L`*_}8$Fq-f(Qpb4GPP_qzPY@eEqZG8>l>HMNX!=!`r-2fhKurPH(=sj(Z*K> zy0JG7#Jlf9D0+eQ4Z))>Wy4#>Ue6ys@V+nX15WR{7SEc-*>qW2tjD*N4OSCt0GjHERmLcOIUXi>G*slHWtBf`h}vhlnLeSo(xrj0lsy@&DUxj%;f z^P`c}6KK)1t5Rt-eiio541t$1;lfnC{?ZO*@Q%42PpzqPGai-Zww~;pIc31c`xc+0ILI+>a$@SbGI?=q(AgG#; zP6D(4aD$=&$4EWbsQ>X5->;G z8Q*gxtB}^8T#$5P?5>WaICtFM7`-y1{g5RIZSNa-10`N>%1D|LUSFc*tioQfvKs9t zpt`i!Zbpnfo$M<8tBs!uj+g%W2pAlqb{JXs*73bcy?EU&+-T|p&VvU?MmF!}k2VPO zi>M5g)jG||`?Jt;@#NC}h}aycZW8Ee9(omwdGz|E@7JWzd)ea7b+-J;cUqcBXU)u^ zLq52ixdPM_UYteJxQt7HA1&IuGMFasS7e`~EC=&W+gVzB7)Al5?sVqk86O=|0ltOu zh&UHAB_*V!)m8I7QL6*hl3||Wg(Jmpce0ob;>U-ZCNsJ!&{l6Vp)S}?s6w3weU0-< zn$VsmJ;{j7s9%JypYCwwHrRt4)Y(a#Gq`Ey0>yi63+*&bK?B78ACx!g$vKuJKa}vY zL_M{oSx|7coc%w_)#HbxVr;{?tq|4bX$JXd%ExR;CNo7en1<+2Z6jIhA0exJc#7#o1r`d?!K&{Z$A6 z9;#rwSjztBj2bBd(uq^OitlEf0qvPO!$_@4uca3cQzTe8>2jvaU+*Q?pw~`P73nW} zl|MyJ(_@H~%>%KCzL0F#i^oZA#iod*hSXL7p*=G)2C-$VLOks-m$!+oR~a0B-Vv zG!LLJte$eya2^;uU?ZhgyjjJ>No%OLqpTi9WaRg;G0o5YZv2-(?Jn>b(`c@gUyq#og0qW50L86EpP|Hg+rtF z<_0$`$IS;1aqh2rwe<1KF;!J$wu*!LLU_OC;=>5Uf&!i__FO;DquTfC)`euXO z2ekdWu^Sp+quV)TKY(sHJ}v$0cuE^cR%%7+wWPFrM%f)Yu{t;)za*i56ymjRd(uo6 z9PH-Hr6rA;tgOB@q_F2|xZ6%%1`@G*dU~{_yH55vgOKWWJ0JRb4LN@nEs9>T8+pOT zGvlCwz{KOK0zNL9h9w4&1n~!Ws-IqobLanp-N|g0kJF?Cnv~h)B8xjG_AoaxH(xA!4_2XS;IN#u_T>2*BLzJjWD@AjqT3B!Z4nmc7c;;J^oRhMy!aO8@9 z>kl7&<~c^|ooyWfOZ45_)vF$>nJb^fg)Fn~2-_|QEohuB`(kYre>=IyA+_WesV&in zibdH@;7<+;#G;aTH_$y;evO{(F^B8eWQy;Z(U`mY5mk&}CvaMumyf2wl~g1rbn&2C zGUHe$7gnysN^O8G3e*q7TplHxpyzWTH3r3O*L1%+=MIHJ8*7DX;?A$h5tULo8Hk`y zIr1#6GHw_1KMB4^K*Qxfp3V6 zCy(c@c()*n=M-hkVKcAVKL>royu2=M7jkHjVeHPH?1FVlP7}KL+XJ6l=zojk3K~*# zN@m1R6>6l3RHoV5T-oZrn!>aET}uwOQF+1T`BMk9tiUOa`NZMdy_FGc0k6y08dmP* zMa@M-V@>B?Wd*-+li`>PKYCy`t#|&6123OBNeWqzWX;e8S&%*O?!-n6T`tr13Qq%cFEM28UV?TWqeAqvi znJ;%mZ+4otV^s%OBAEJ}at>epoQ8F*78BR&r0`JS;jvFWe-n8YU_mW`pSxQ#d^DVh z6gJ%t#TrXRGO!J%vZA;2Cn#{N6rhccf>yK|}F?ZSFMqob? z2fAF)enWUWYS^p9c2;R6h0vinv6e{@=KM4bh7r9NgG)+^=D>+pCMDzmr4KmQ3{o+3 z@-l1ZL)G`~=o;+4NsYYoUkDz>hKjT#y(*fmOQ;ZV{lTNQnAhbf$Sr76_NSsB&~y2u z72Z^O2vtZYLGg;&@HuMkeQ&Gcs7lwCci7Xl@`sqC0-^`4%*ph;&a#{n=r1aKwRVoO zc71rTu711NiDc83i)OalOVCT#JA05}Z!4;}K00MACv=d%wJW3iwU|k{Bk4R-nzvzf zWn!NG&tGA(gY|C|%r-^Sp7^sVu{0queyi&;t+3Yn7?3bV(G^JPzPjMjBApuSZ*-8m z=2mxoUIHkH(+_Hw^V_o65L4Ur04v9DRdEbBo$Vj!%s`E`tqN5?IFj4;{X&CQc=ukl zdjQpo8oz(F2Kc^FUQr`$ALQRVP2q)jEUeXwC|=K(Pq}r=;vK~YVH#HSWXz5Qc~X*VVk zbNIVk8lszW>ek2m6|QDv-z2ZiOBkN}u2y-r@q^l84=6nw(v&=OKvS8|vyr{Tr2mi< zwQYEd<;JP@cNy5=5vQg1=gu@uF(IyJ*@iq*G^AY%Ht`-PFm_A+GEU3TdiqfM7Rf|*nn7>Q#EB|+fLmW4~x=TYcfrQtdG+>5G?@ zxVM#Ygo>yJVhF;l>gYMXW5k#}pr?&+aJ)2eAujWGev|tGu$|Va zY5W=7agZ)oZZoL(wt4W+U}bi44Y1X76NQXS7r*Og65GkSto2<1QT4jNxNpFxa;t4& z%VSLPU{B#mv^#Zn@Eb!mIRBmKcwQ;V^AWhcr>(?M3FE69h&_v`$N7D2lR~?NX!uIL zw1t+7%-@f`S9nb;{QcezxA@z(-(l@`KT(E0kBHp&O6zC+Y6kM3AB&F%sOe|BdNcU> zi5|w^Ds0w9My7~6Z1-_-a=Qwte4TT8K5k{Q&XoRTRD+&qUPI2Z_FFjC99qK0<*
    xzb{o}1c)9oBOJ>C=IaiDcIV~N~&mEo3& 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

    Eu4Va#0%^ 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%0DQo~*73L={jlt~G0cJ%cl#9PARhz3 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
  1. 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¿_GQD4460M7u414s*WkswXP;VCldRm zh3Qk;atxa}NWU@sR$#u-yT-)K!d1YDpj5JYUzW%n@+Of^U6~)Q`1*|{gJiZeW_+=- zbQx?V!?GO01q3b&)NBlv8l$VBt?)>9NFss^lD(||b~b7&Y$HvYy+|Kdv=6s69*qz! zl6RO65@R2S@A^4TgRHv$qkU}!kXQf}+GpNUPT(Qa74q}N()oPgOnF_A!;Pv4^Ftar0g&;EunmsX_>S>8DZ7BDdEVdoXj3HN6JvdfTul=-pBIN>l zZRM>^FQ`vqYv^NGN*OHWsy^HW15XDtMnrIN{N+jSod~Oc=oM_6m{B2D8uXVgAwARC zd|RSQgRPy#-mRzFeG5tK3Vfe2!mhE!+K}6!>Ar#LUAac@guF&+wl;}g~#$!Y?!fsRt>QcEn7*1FOLOOqL!@Rwan#mu*y+OFI zs#s(o+~?Z=QA}Siso+ClB~{gDFn-Tm8<*6p-ja+V$^!^1A-+?xPW}Y>D>`5XMJff+ zhH(Fiso#ngvsmi+wfMfnS{$7h+Rs0qF}maBXHYfS)b&ZY)A zeui3Lf%ibS%yvv2JhdzY78E-rkb8fW{Ppj+hvY2(*50b;P#LzR$4VijBX#GQapvV;ZtG3 zt5^SXv8U5cNBxjt9x~l3(S^=DDRWQhpx3LwjKKivbK%Hq1`E>)I)e-X^1o_ca=Bfk z5&fRy_7vLW^r=#nu#l9h4=?gu{UVFQ7=9cF(6Bzpw*`^}TnSgdI5+jmhao37rV4tn z<6*dUhdv?~k)<0;edO9z`NssQ()KQ-$_U(_bmw{n8NU-!)ch@rE}3IjJ~Sn`Fae>z z(GcuM&;7Town~$={vZd7Kd)oR_8bEl(S4qePDgD>CC-#HNcLh>;gh#b2;e_#?!8M{ zLK&Tiru7MCUWU+8LY@_nQz~h%7qlV@%^XilG$ro+^qvPrp~+kpd(zGxp!$4*wDSxv z#6Sd2ita>yafv?&?_S{6BxZKC>Y6zDzNal)4s|u=9$(i;u*XL^?;!7+<(M^u|WA6SFLMlFjPNb)jF$6eL$g8?$=hPvf7Je zFjNc8GN1>%xEqfY;HS&80Q!j}9n+WC2m(>}nJHV_mj75MUi6L=1np6W?ZDT)eh4nk z{U5Il0Z!qCltV0w30t|rqqpuCy!Hjp_gRWcU^&L<^2>rB+MK2e$ zU5oi4w;m4+Nc-F?GdN0mEWDo=VIl%proL=!5qMoZbKu*zusn<$Wd`mL0wejrSh(hm zlLM)*;pi8?NxM@0*9#94iMi0jZ%LageIJz|V5kD)WQ!?4+&25}UWkL+@`20kDaGT-3^~-<(ahVx5Y3ooL0KhY8f&%f@gM?G2PaJ#eZ8G7dOLZd(Zz=T6TP z-m32kj0=S2rFHtw#75S7;<@yYwVfZNtB`qaxf5E-^A?>b1 zIuWleB=YiR&HUX$@!G<{3)>62zt1*XKYh_};5c^-i&9|&vJ=Na{zSvfY7v8Dc~SALuvFGDv!QKt zQk($dB;Gg-HO?V9<_^r<#vk`1k?<%L1((*z6cvT78}s7n>Wbs!de0p2V+eMaSRZJ1 zo4UI2Lp2|GnT{_wZEo_eS@^VV%)#p@?Nxat6EX&LK-{qh%)H^bM}R5T@mQxDv=GxK zzuJl!)=AJGtx|cR=5d%OLJkw}_*z`rdNf4~sI`%>}TVXLz+)$S$Gym@Tg& z%BH7xWOFz}h(xE63=rBMQ#(SyDGgpr(_4F>Aqrbwsa}t>@c7**DvNS{lwDKp`v~Z5}}RH5~=!$XBN;sEHi*4EJpu0#8keh~m#v z&mn%|HY3A+{{?&*dzGQ01&oT;1z)})n*oL5xFpso&c>zj5#%9r2x<+DFW#L literal 0 HcmV?d00001 diff --git a/assets/wireframe5.png b/assets/wireframe5.png new file mode 100644 index 0000000000000000000000000000000000000000..202f0b8d32255b689bd88fa25fc397bcc74a9f7f GIT binary patch literal 250513 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�OSt-fdhm`{fx}_X%`2e?-p3*s{fJ+j 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

    ~pK6*mE2Y<1Q0ICY+1m@T8mKKdi!`7|L6 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 hour during the Compacting Database stage with no log messages at all. This is normal, and the pruning should be left to run until finally a log message containing the phrase `State pruning successful` appears (i.e. do not restart Geth yet!). That message indicates that the pruning is complete and Geth can be started. @@ -51,10 +54,12 @@ The pruning could take 4-5 hours to complete. Once finished, restart Geth. ## Troubleshooting -Messages about "state snapshot generation" indicate that a snapshot does not actually exist. This suggests either the `--datadir` is not correct or Geth ran out of time to complete the snapshot generation and the pruning began before the snapshot was completed. In either case, the best course of action is to stop Geth, run it normally again (no pruning) until the snapshot is definitely complete and at least 128 blocks exist on top of it, then try pruning again. +Messages about "state snapshot generation" indicate that a snapshot is not fully generated. This suggests either the `--datadir` is not correct or Geth ran out of time to complete the snapshot generation and the pruning began before the snapshot was completed. In either case, the best course of action is to stop Geth, run it normally again (no pruning) until the snapshot is definitely complete and at least 128 blocks exist on top of it, then try pruning again. ## Further Reading [Ethereum Foundation blog post for Geth v1.10.0](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) + [Pruning Geth guide (@yorickdowne)](https://gist.github.com/yorickdowne/3323759b4cbf2022e191ab058a4276b2) + [Pruning Geth in a RocketPool node](https://docs.rocketpool.net/guides/node/geth-pruning.html) \ No newline at end of file From e2527b2dff7c3c67f3e3b5299b2ec099c64687b8 Mon Sep 17 00:00:00 2001 From: Joe Date: Tue, 6 Sep 2022 11:00:45 +0100 Subject: [PATCH 050/432] update sync modes --- content/docs/fundamentals/sync-modes.md | 40 ++++++++++++++++++------- 1 file changed, 30 insertions(+), 10 deletions(-) diff --git a/content/docs/fundamentals/sync-modes.md b/content/docs/fundamentals/sync-modes.md index d462500102..dfb03b6a26 100644 --- a/content/docs/fundamentals/sync-modes.md +++ b/content/docs/fundamentals/sync-modes.md @@ -7,28 +7,48 @@ Syncing is the process by which Geth catches up to the latest Ethereum block and ## Full nodes -There are three types of full node with different sync modes: +There are two types of full node that use different mechanisms to sync up to the head of the chain: + +### Snap (default) + +A snap sync'd node holds the most recent 128 blocks in memory, so transactions in that range are always accessible. However, snap-sync only starts processing from a relatively recent block (as opposed to genesis for a full node). Between the initial sync block and the 128 most recent blocks, the node stores occasional checkpoints that can be used to rebuild the state on-the-fly. This means transactions can be traced back as far as the block that was used for the initial sync. Tracing a single transaction requires reexecuting all preceding transactions in the same block **and** all preceding blocks until the previous stored snapshot. Snap-sync'd nodes are therefore functionally equal to full nodes, but the initial synchronization required a checkpoint block to sync from instead of independently verifying the chain all the way from genesis. Snap sync then only verifies the proof-of-work and ancestor-child block progression and assumes that the state transitions are correct rather than re-executing the transactions in each block to verify the state changes. Snap sync is much faster than full sync. To start a node with snap sync pass `--syncmode snap` at startup. + +Snap sync starts by downloading the blocks between the head of the chain and the previous checkpoint. Then it downloads the leaves of the state trie for each block without the intermediate nodes. The state trie is then regenerated locally. The state download is the part of the snap-sync that takes the most time to complete and the progress can be monitored using the ETA values in the log messages. However, the blockchain is also progressing at the same time and invalidating some of the regenerated state data. This means it is also necessary to have a 'healing' phase where errors in the state are fixed. It is not possible to monitor the progress of the state heal because the extent of the errors cannot be known until the current state has already been regenerated. The healing has to outpace the growth of the blockchain, otherwise the node will never catch up to the current state. There are some hardware factors that determine the speed of the state healing (speed of disk read/write and internet connection) and also the total gas used in each block (more gas means more changes to the state that have to be handled). + +**Note** Snap sync is the default behaviour, so if the `--syncmode` value is not passed to Geth at startup, Geth will use snap sync. A node that is started using `snap` will switch to block-by-block sync once it has caught up to the head of the chain. ### Full -A full sync generates the current state by executing every block starting from the genesis block. A full sync is the trust-minimized option since there it does not rely upon any information from any trusted source apart from the genesis configuration. All other information is indendently verified as the node re-executes the entire historical sequence of blocks. Only the most recent 128 blocks are stored in a full node - older blocks are pruned periodically and represented as a series of checkpoints from which any previous state can be regenerated on request. 128 blocks is about 25.6 minutes of history with a block time of 12 seconds. To create a full node pass `--syncmode full` at startup. +A full sync generates the current state by executing every block starting from the genesis block. A full sync indendently verifies proof-of-work and block provenance as well as all state transitions by re-executing the transactions in the entire historical sequence of blocks. Only the most recent 128 blocks are stored in a full node - older blocks are pruned periodically and represented as a series of checkpoints from which any previous state can be regenerated on request. 128 blocks is about 25.6 minutes of history with a block time of 12 seconds. To create a full node pass `--syncmode full` at startup. -### Archive +## Archive nodes -An archive node is a full-sync'd node that retains all historical data right back to genesis. There is no need to regenerate any data from checkpoints because all data is directly available in the node's own storage. Archive nodes are therefore ideal for making fast queries about historical states. At the time of writing (August 2022) an archive node occupies nearly 12 TB of disk space (keep up with the current size on [Etherscan](https://etherscan.io/chartsync/chainarchive)). Archive nodes are created by configuring Geth's garbage collection so that old data is never deleted: `geth --syncmode full --gcmode archive`. +An archive node is a node that retains all historical data right back to genesis. There is no need to regenerate any data from checkpoints because all data is directly available in the node's own storage. Archive nodes are therefore ideal for making fast queries about historical states. At the time of writing (September 2022) a full archive node that stores all data since genesis occupies nearly 12 TB of disk space (keep up with the current size on [Etherscan](https://etherscan.io/chartsync/chainarchive)). Archive nodes are created by configuring Geth's garbage collection so that old data is never deleted: `geth --syncmode full --gcmode archive`. -### Snap - -A snap sync'd node holds the most recent 128 blocks in memory, so transactions in that range are always accessible. However, snap-sync only starts processing from a relatively recent block (as opposed to genesis for a full node). Between the initial sync block and the 128 most recent blocks, the node stores occasional checkpoints that can be used to rebuild the state on-the-fly. This means transactions can be traced back as far as the block that was used for the initial sync. Tracing a single transaction requires reexecuting all preceding transactions in the same block **and** all preceding blocks until the previous stored snapshot. Snap-sync'd nodes are therefore functionally equal to full nodes, but the initial synchronization required some trusted information (a checkpoint block) to sync from instead of independently verifying the chain all the way from genesis. Snap sync is much faster than full sync. To start a node with snap sync pass `--syncmode snap` at startup. +It is also possible to create a partial/recent archive node where the node was synced using `snap` but the state is never pruned. This creates an archive node that saves all state data from the point that the node first syncs. This is configured by starting Geth with `--syncmode snap gcmode archive`. ## Light nodes -A light node syncs very quickly and stores the bare minimum of blockchain data. Light nodes only process block headers, not entire blocks. This greatly reduces the computation time, storage and bandwidth required relative to a full node. This means light nodes are suitable for resource-constrained devices and can catch up to the head of the chain much faster when they are new or have been offline for a while. The trade-off is that light nodes rely heavily on data served by altruistic full nodes. A light client can be used to query data from Ethereum and submit transactions, acting as a locally-hosted Ethereum wallet. However, because they don't keep local copies of the Ethereum state, light nodes can't validate blocks in the same way as full nodes - they have to trust that the data they receive is honest. To start a node in light mode, pass `--syncmode light`. Be aware that full nodes serving light data are relative scarce so light nodes can struggle to find peers. +A light node syncs very quickly and stores the bare minimum of blockchain data. Light nodes only process block headers, not entire blocks. This greatly reduces the computation time, storage and bandwidth required relative to a full node. Light nodes are suitable for resource-constrained devices and can catch up to the head of the chain much faster when they are new or have been offline for a while. The trade-off is that light nodes rely heavily on data served by altruistic full nodes. A light client can be used to query data from Ethereum and submit transactions, acting as a locally-hosted Ethereum wallet. However, because they don't keep local copies of the Ethereum state, light nodes can't validate blocks in the same way as full nodes - they have to trust that the data they receive is honest. To start a node in light mode, pass `--syncmode light`. Be aware that full nodes serving light data are relative scarce so light nodes can struggle to find peers. Read more about light nodes on our [LES page](/content/docs/fundamentals/les.md). -{% include note.html content="Light nodes do not currently work on proof-of-stake Ethereum, but they are expected to ship soon!" %} +## Consensus layer syncing + +Since Ethereum transitioned to proof-of-stake, all consensus logic and block propagation was handed over to consensus clients. This means that syncing the blockchain is now a process shared between the consensus and execution clients. Blocks are downloaded by the consensus client and verified by the execution client. There are two ways to sync a consensus client: optimistic sync and checkpoint sync. + +### Optimistic sync + +Optimistic sync downloads blocks before the execution client has validated them. This means the execution client can constantly be fed with up-to-date states to snap-sync to. Assuming the blocks are valid, eventually the sync catches up to the optimistically downloaded head and the blockchain is in sync. From this point, verification is done block-by-block (i.e. the sync mode switches to `full`). In optimistic sync the node assumes the data it receives from its peers is correct during the downloading phase but then retroactively verifies each downloaded block. Nodes are not allowed to attest or propose blocks while they are still 'optimistic' because they can't yet guarantee their view of the ehad of the chain is correct. + +Read more in the [optimistic sync specs](https://github.com/ethereum/consensus-specs/blob/dev/sync/optimistic.md). + +### Checkpoint sync + +Alternatively, the consensus client can grab a checkpoint from a trusted source which provides a target state to sync up to, before switching to full sync and verifying each block in turn. In this mode, the node trusts that the checkpoint is correct. There are many possible sources for this checkpoint - the gold standard would be to get it out-of-band from a trusted friend, but it could also come from block explorers or public APIs/web apps. + +**Note** it is not currently possible to use a Geth light node as an execution client on proof-of-stake Ethereum. ## Summary -There are several ways to sync a Geth node. The default is to use snap sync to create a full node. This verifies all blocks starting at a recent checkpoint. A trust-minimized alternative is full-sync, which verifies every block since genesis. These modes prune the blockchain data older than 128 blocks, keeping only checkpoints that enable on-request regeneration of historical states. For rapid queries of historical data an archive node is required. Archive nodes keep local copies of all historical data right back to genesis - currently about 12 TB and growing. The opposite extreme is a light node that doesn't store any blockchain data - it requests everything from full nodes. These configurations are controlled by passing `full`, `snap` or `light` to `--syncmode` at startup. For an archive node, `--syncmode` should be `full` and `--gcmode` should be set to `archive`. \ No newline at end of file +There are several ways to sync a Geth node. The default is to use snap sync to create a full node. This verifies all blocks starting at a recent checkpoint. A trust-minimized alternative is full-sync, which verifies every block since genesis. These modes prune the blockchain data older than 128 blocks, keeping only checkpoints that enable on-request regeneration of historical states. For rapid queries of historical data an archive node is required. Archive nodes keep local copies of all historical data right back to genesis - currently about 12 TB and growing. The opposite extreme is a light node that doesn't store any blockchain data - it requests everything from full nodes. These configurations are controlled by passing `full`, `snap` or `light` to `--syncmode` at startup. For an archive node, `--syncmode` should be `full` and `--gcmode` should be set to `archive`. At the transition to proof-of-stake, light-sync will no longer work (until new light client protocols are shipped). \ No newline at end of file From 0113da0f5e00f8955a654d6371f0bc83a3c2a284 Mon Sep 17 00:00:00 2001 From: Joe Date: Wed, 7 Sep 2022 10:08:36 +0100 Subject: [PATCH 051/432] update FAQs --- content/docs/faq.md | 37 +++++++++++++------------------------ 1 file changed, 13 insertions(+), 24 deletions(-) diff --git a/content/docs/faq.md b/content/docs/faq.md index c0c82d6c9c..5bbfdfe44a 100644 --- a/content/docs/faq.md +++ b/content/docs/faq.md @@ -3,7 +3,7 @@ title: FAQ description: Frequently asked questions related to Geth --- -This page contains answers to common questions about Geth. The Geth team have also started to run AMA's on Reddit: +This page contains answers to common questions about Geth. The Geth team have also recently started to run AMA's on Reddit: [Aug 2022 AMA](https://www.reddit.com/r/ethereum/comments/wpqmo1/ama_we_are_the_go_ethereum_geth_team_18_august/) @@ -19,6 +19,7 @@ RPC stands for Remote Procedure Call. RPC is a mode of communication between pro The `jwtsecret` file is required to create an authenticated connection between Geth and a consensus client. JWT stands for JSON Web Token - it is signed using a secret key, proving each party's identity. Read about how to create `jwt-secret` in Geth on our [Connecting to consensus clients](/content/docs/getting_started/consensus-clients.md) page. + #### I noticed my peercount slowly decreasing, and now it is at 0. Restarting doesn't get any peers. This may be because your clock has fallen out of sync with other nodes. You can [force a clock update using ntp](https://askubuntu.com/questions/254826/how-to-force-a-clock-update-using-ntp) like so: @@ -43,9 +44,11 @@ Additional details and/or any updates on more robust handling are at Date: Thu, 8 Sep 2022 16:17:57 -0300 Subject: [PATCH 052/432] docs: update README --- README.md | 42 +++++++++++++++++++++++++++++++++++++++--- 1 file changed, 39 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 62509f9fe6..3c633bc383 100644 --- a/README.md +++ b/README.md @@ -5,11 +5,47 @@ This repo will act as a shared workspace for the geth website team in developing Resources: - the project management notes: https://www.notion.so/efdn/Build-new-Geth-website-bf35a46cfe5848db83ac3acb5191eb1c -- some draft figma files for design sketching: https://www.figma.com/file/ekzIgwyeVKLtFSAcnA0Q0D/geth-website?node-id=6%3A31 +- some draft figma files for design sketching: https://www.figma.com/file/ekzIgwyeVKLtFSAcnA0Q0D/geth-website?node-id=6%3A31 - content planning notes: https://www.notion.so/efdn/Content-Strategy-3252234338814a749374fa7f11049083 - meeting notes: https://www.notion.so/efdn/Call-notes-46aa0202810a402ebfda07b046761cbd - Notes: -**Dev note**: Remember that the fiules in `vulnerabilities` must be served at the same URLs as they are currently to avoid breaking some Geth functions related to security auditing. \ No newline at end of file +**Dev note**: Remember that the fiules in `vulnerabilities` must be served at the same URLs as they are currently to avoid breaking some Geth functions related to security auditing. + +--- + +This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app). + +## Getting Started + +First, run the development server: + +```bash +npm run dev +# or +yarn dev +``` + +Open [http://localhost:3000](http://localhost:3000) with your browser to see the result. + +You can start editing the page by modifying `pages/index.tsx`. The page auto-updates as you edit the file. + +[API routes](https://nextjs.org/docs/api-routes/introduction) can be accessed on [http://localhost:3000/api/hello](http://localhost:3000/api/hello). This endpoint can be edited in `pages/api/hello.ts`. + +The `pages/api` directory is mapped to `/api/*`. Files in this directory are treated as [API routes](https://nextjs.org/docs/api-routes/introduction) instead of React pages. + +## Learn More + +To learn more about Next.js, take a look at the following resources: + +- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API. +- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial. + +You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome! + +## Deploy on Vercel + +The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js. + +Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details. From 142aa33af80a7fa0880044d3f9305f73a552b976 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nicol=C3=A1s=20Quiroz?= Date: Thu, 8 Sep 2022 16:18:30 -0300 Subject: [PATCH 053/432] setup: init --- .eslintignore | 3 + .eslintrc.json | 3 + .gitignore | 36 + .prettierignore | 6 + .prettierrc | 10 + next.config.js | 7 + package.json | 30 + pages/_app.tsx | 11 + pages/api/hello.ts | 13 + pages/index.tsx | 72 + public/favicon.ico | Bin 0 -> 25931 bytes public/vercel.svg | 4 + styles/Home.module.css | 129 ++ styles/globals.css | 26 + tsconfig.json | 20 + yarn.lock | 3048 ++++++++++++++++++++++++++++++++++++++++ 16 files changed, 3418 insertions(+) create mode 100644 .eslintignore create mode 100644 .eslintrc.json create mode 100644 .gitignore create mode 100644 .prettierignore create mode 100644 .prettierrc create mode 100644 next.config.js create mode 100644 package.json create mode 100644 pages/_app.tsx create mode 100644 pages/api/hello.ts create mode 100644 pages/index.tsx create mode 100644 public/favicon.ico create mode 100644 public/vercel.svg create mode 100644 styles/Home.module.css create mode 100644 styles/globals.css create mode 100644 tsconfig.json create mode 100644 yarn.lock diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 0000000000..422c3919cb --- /dev/null +++ b/.eslintignore @@ -0,0 +1,3 @@ +.next +dist +node_modules/ diff --git a/.eslintrc.json b/.eslintrc.json new file mode 100644 index 0000000000..4d765f2817 --- /dev/null +++ b/.eslintrc.json @@ -0,0 +1,3 @@ +{ + "extends": ["next/core-web-vitals", "prettier"] +} diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000000..c87c9b392c --- /dev/null +++ b/.gitignore @@ -0,0 +1,36 @@ +# See https://help.github.com/articles/ignoring-files/ for more about ignoring files. + +# dependencies +/node_modules +/.pnp +.pnp.js + +# testing +/coverage + +# next.js +/.next/ +/out/ + +# production +/build + +# misc +.DS_Store +*.pem + +# debug +npm-debug.log* +yarn-debug.log* +yarn-error.log* +.pnpm-debug.log* + +# local env files +.env*.local + +# vercel +.vercel + +# typescript +*.tsbuildinfo +next-env.d.ts diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 0000000000..ed8032e23c --- /dev/null +++ b/.prettierignore @@ -0,0 +1,6 @@ +.next +node_modules +yarn.lock +package-lock.json +public +build diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000000..c4e3a5c973 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,10 @@ +{ + "printWidth": 100, + "trailingComma": "none", + "semi": true, + "arrowParens": "avoid", + "singleQuote": true, + "jsxSingleQuote": true, + "tabWidth": 2, + "useTabs": false +} diff --git a/next.config.js b/next.config.js new file mode 100644 index 0000000000..ae887958d3 --- /dev/null +++ b/next.config.js @@ -0,0 +1,7 @@ +/** @type {import('next').NextConfig} */ +const nextConfig = { + reactStrictMode: true, + swcMinify: true, +} + +module.exports = nextConfig diff --git a/package.json b/package.json new file mode 100644 index 0000000000..47e53957e0 --- /dev/null +++ b/package.json @@ -0,0 +1,30 @@ +{ + "name": "geth-site", + "private": false, + "description": "The website for geth.ethereum.org", + "version": "2.0.0", + "author": "Nicolás Quiroz ", + "scripts": { + "dev": "next dev", + "build": "next build", + "start": "next start", + "lint": "next lint" + }, + "dependencies": { + "@chakra-ui/react": "^2.3.2", + "@emotion/react": "^11.10.4", + "@emotion/styled": "^11.10.4", + "framer-motion": "^7.3.2", + "next": "12.2.5", + "react": "18.2.0", + "react-dom": "18.2.0" + }, + "devDependencies": { + "@types/node": "18.7.16", + "@types/react": "18.0.18", + "@types/react-dom": "18.0.6", + "eslint": "8.23.0", + "eslint-config-next": "12.2.5", + "typescript": "4.8.2" + } +} diff --git a/pages/_app.tsx b/pages/_app.tsx new file mode 100644 index 0000000000..7a11bda4c9 --- /dev/null +++ b/pages/_app.tsx @@ -0,0 +1,11 @@ +import { ChakraProvider } from '@chakra-ui/react' +import { AppProps } from 'next/app' + +export default function App({ Component, pageProps }: AppProps) { + return ( + + + + ) +} + diff --git a/pages/api/hello.ts b/pages/api/hello.ts new file mode 100644 index 0000000000..f8bcc7e5ca --- /dev/null +++ b/pages/api/hello.ts @@ -0,0 +1,13 @@ +// Next.js API route support: https://nextjs.org/docs/api-routes/introduction +import type { NextApiRequest, NextApiResponse } from 'next' + +type Data = { + name: string +} + +export default function handler( + req: NextApiRequest, + res: NextApiResponse +) { + res.status(200).json({ name: 'John Doe' }) +} diff --git a/pages/index.tsx b/pages/index.tsx new file mode 100644 index 0000000000..86b5b3b5bf --- /dev/null +++ b/pages/index.tsx @@ -0,0 +1,72 @@ +import type { NextPage } from 'next' +import Head from 'next/head' +import Image from 'next/image' +import styles from '../styles/Home.module.css' + +const Home: NextPage = () => { + return ( +

    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

    + ) +} + +export default Home diff --git a/public/favicon.ico b/public/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..718d6fea4835ec2d246af9800eddb7ffb276240c GIT binary patch literal 25931 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 LrJugUA?W`A8`#=m literal 0 HcmV?d00001 diff --git a/public/vercel.svg b/public/vercel.svg new file mode 100644 index 0000000000..fbf0e25a65 --- /dev/null +++ b/public/vercel.svg @@ -0,0 +1,4 @@ + + + \ No newline at end of file diff --git a/styles/Home.module.css b/styles/Home.module.css new file mode 100644 index 0000000000..bd50f42ffe --- /dev/null +++ b/styles/Home.module.css @@ -0,0 +1,129 @@ +.container { + padding: 0 2rem; +} + +.main { + min-height: 100vh; + padding: 4rem 0; + flex: 1; + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; +} + +.footer { + display: flex; + flex: 1; + padding: 2rem 0; + border-top: 1px solid #eaeaea; + justify-content: center; + align-items: center; +} + +.footer a { + display: flex; + justify-content: center; + align-items: center; + flex-grow: 1; +} + +.title a { + color: #0070f3; + text-decoration: none; +} + +.title a:hover, +.title a:focus, +.title a:active { + text-decoration: underline; +} + +.title { + margin: 0; + line-height: 1.15; + font-size: 4rem; +} + +.title, +.description { + text-align: center; +} + +.description { + margin: 4rem 0; + line-height: 1.5; + font-size: 1.5rem; +} + +.code { + background: #fafafa; + border-radius: 5px; + padding: 0.75rem; + font-size: 1.1rem; + font-family: Menlo, Monaco, Lucida Console, Liberation Mono, DejaVu Sans Mono, + Bitstream Vera Sans Mono, Courier New, monospace; +} + +.grid { + display: flex; + align-items: center; + justify-content: center; + flex-wrap: wrap; + max-width: 800px; +} + +.card { + margin: 1rem; + padding: 1.5rem; + text-align: left; + color: inherit; + text-decoration: none; + border: 1px solid #eaeaea; + border-radius: 10px; + transition: color 0.15s ease, border-color 0.15s ease; + max-width: 300px; +} + +.card:hover, +.card:focus, +.card:active { + color: #0070f3; + border-color: #0070f3; +} + +.card h2 { + margin: 0 0 1rem 0; + font-size: 1.5rem; +} + +.card p { + margin: 0; + font-size: 1.25rem; + line-height: 1.5; +} + +.logo { + height: 1em; + margin-left: 0.5rem; +} + +@media (max-width: 600px) { + .grid { + width: 100%; + flex-direction: column; + } +} + +@media (prefers-color-scheme: dark) { + .card, + .footer { + border-color: #222; + } + .code { + background: #111; + } + .logo img { + filter: invert(1); + } +} diff --git a/styles/globals.css b/styles/globals.css new file mode 100644 index 0000000000..4f1842163d --- /dev/null +++ b/styles/globals.css @@ -0,0 +1,26 @@ +html, +body { + padding: 0; + margin: 0; + font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Oxygen, + Ubuntu, Cantarell, Fira Sans, Droid Sans, Helvetica Neue, sans-serif; +} + +a { + color: inherit; + text-decoration: none; +} + +* { + box-sizing: border-box; +} + +@media (prefers-color-scheme: dark) { + html { + color-scheme: dark; + } + body { + color: white; + background: black; + } +} diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000000..99710e8578 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,20 @@ +{ + "compilerOptions": { + "target": "es5", + "lib": ["dom", "dom.iterable", "esnext"], + "allowJs": true, + "skipLibCheck": true, + "strict": true, + "forceConsistentCasingInFileNames": true, + "noEmit": true, + "esModuleInterop": true, + "module": "esnext", + "moduleResolution": "node", + "resolveJsonModule": true, + "isolatedModules": true, + "jsx": "preserve", + "incremental": true + }, + "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"], + "exclude": ["node_modules"] +} diff --git a/yarn.lock b/yarn.lock new file mode 100644 index 0000000000..9715ac034d --- /dev/null +++ b/yarn.lock @@ -0,0 +1,3048 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@babel/code-frame@^7.0.0": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.18.6.tgz#3b25d38c89600baa2dcc219edfa88a74eb2c427a" + integrity sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q== + dependencies: + "@babel/highlight" "^7.18.6" + +"@babel/helper-module-imports@^7.16.7": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz#1e3ebdbbd08aad1437b428c50204db13c5a3ca6e" + integrity sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA== + dependencies: + "@babel/types" "^7.18.6" + +"@babel/helper-plugin-utils@^7.18.6": + version "7.19.0" + resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.19.0.tgz#4796bb14961521f0f8715990bee2fb6e51ce21bf" + integrity sha512-40Ryx7I8mT+0gaNxm8JGTZFUITNqdLAgdg0hXzeVZxVD6nFsdhQvip6v8dqkRHzsz1VFpFAaOCHNn0vKBL7Czw== + +"@babel/helper-string-parser@^7.18.10": + version "7.18.10" + resolved "https://registry.yarnpkg.com/@babel/helper-string-parser/-/helper-string-parser-7.18.10.tgz#181f22d28ebe1b3857fa575f5c290b1aaf659b56" + integrity sha512-XtIfWmeNY3i4t7t4D2t02q50HvqHybPqW2ki1kosnvWCwuCMeo81Jf0gwr85jy/neUdg5XDdeFE/80DXiO+njw== + +"@babel/helper-validator-identifier@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.18.6.tgz#9c97e30d31b2b8c72a1d08984f2ca9b574d7a076" + integrity sha512-MmetCkz9ej86nJQV+sFCxoGGrUbU3q02kgLciwkrt9QqEB7cP39oKEY0PakknEO0Gu20SskMRi+AYZ3b1TpN9g== + +"@babel/highlight@^7.18.6": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.18.6.tgz#81158601e93e2563795adcbfbdf5d64be3f2ecdf" + integrity sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g== + dependencies: + "@babel/helper-validator-identifier" "^7.18.6" + chalk "^2.0.0" + js-tokens "^4.0.0" + +"@babel/plugin-syntax-jsx@^7.17.12": + version "7.18.6" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz#a8feef63b010150abd97f1649ec296e849943ca0" + integrity sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q== + dependencies: + "@babel/helper-plugin-utils" "^7.18.6" + +"@babel/runtime-corejs3@^7.10.2": + version "7.19.0" + resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.19.0.tgz#0df75cb8e5ecba3ca9e658898694e5326d52397f" + integrity sha512-JyXXoCu1N8GLuKc2ii8y5RGma5FMpFeO2nAQIe0Yzrbq+rQnN+sFj47auLblR5ka6aHNGPDgv8G/iI2Grb0ldQ== + dependencies: + core-js-pure "^3.20.2" + regenerator-runtime "^0.13.4" + +"@babel/runtime@^7.0.0", "@babel/runtime@^7.10.2", "@babel/runtime@^7.12.13", "@babel/runtime@^7.12.5", "@babel/runtime@^7.18.3", "@babel/runtime@^7.18.9": + version "7.19.0" + resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.19.0.tgz#22b11c037b094d27a8a2504ea4dcff00f50e2259" + integrity sha512-eR8Lo9hnDS7tqkO7NsV+mKvCmv5boaXFSZ70DnfhcgiEne8hv9oCEd36Klw74EtizEqLsy4YnW8UWwpBVolHZA== + dependencies: + regenerator-runtime "^0.13.4" + +"@babel/types@^7.18.6": + version "7.19.0" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.19.0.tgz#75f21d73d73dc0351f3368d28db73465f4814600" + integrity sha512-YuGopBq3ke25BVSiS6fgF49Ul9gH1x70Bcr6bqRLjWCkcX8Hre1/5+z+IiWOIerRMSSEfGZVB9z9kyq7wVs9YA== + dependencies: + "@babel/helper-string-parser" "^7.18.10" + "@babel/helper-validator-identifier" "^7.18.6" + to-fast-properties "^2.0.0" + +"@chakra-ui/accordion@2.0.12": + version "2.0.12" + resolved "https://registry.yarnpkg.com/@chakra-ui/accordion/-/accordion-2.0.12.tgz#dd260fbecb639748314f440c89052ed45006c585" + integrity sha512-O3qq8mILo1QODjCGr2xwxC5LNFakBoMzTjEgpvpIMynxWc/1RKfGuFLis3IDfpHIicXmBTK6sNiZXewmna88CQ== + dependencies: + "@chakra-ui/descendant" "3.0.9" + "@chakra-ui/icon" "3.0.9" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-use-controllable-state" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/transition" "2.0.9" + +"@chakra-ui/alert@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/alert/-/alert-2.0.9.tgz#25e88c105e095def374c9fe1e3c8a3f6fab08f6c" + integrity sha512-hFRIh6ZzQJ0sAESRym15mW/mcZE/yu4z6lFtdToBhpfSlhZLuE7gDdOTxqGkg417hY//48NiNXOCoQ2dUUuHKw== + dependencies: + "@chakra-ui/icon" "3.0.9" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/spinner" "2.0.9" + +"@chakra-ui/anatomy@2.0.6": + version "2.0.6" + resolved "https://registry.yarnpkg.com/@chakra-ui/anatomy/-/anatomy-2.0.6.tgz#83164841d27eaa271ffa747534519bcd323c312f" + integrity sha512-Vgop2FFdhVtX7BydjZdJWZAWy+DdXBU1IMaBppz6COaH+/7OXxoI2ec2bs17ehJyBO0M+ud3OLj5UCFQ79YsoQ== + +"@chakra-ui/avatar@2.1.0": + version "2.1.0" + resolved "https://registry.yarnpkg.com/@chakra-ui/avatar/-/avatar-2.1.0.tgz#009b4e126c58ef0183618cfbfb29f8e7e3357ee9" + integrity sha512-SRQeH6NNvIBgUc4OsO14ypvcn8I66ndw7r4piIkm+R2zqbYnrzpp1d2zNPNHkChc4xQY71/GenenYO5Fhsi2DA== + dependencies: + "@chakra-ui/image" "2.0.10" + "@chakra-ui/react-children-utils" "2.0.1" + "@chakra-ui/react-context" "2.0.3" + +"@chakra-ui/breadcrumb@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/breadcrumb/-/breadcrumb-2.0.9.tgz#357e4e2a50cdad87c0b3b59656aafa85671e6142" + integrity sha512-cc3WbxrJNRUph4v45qCdcIKJI0xECeV9VikQNIactBB+iexN4d+5P66xZABAkD8wWGmyH5KuSZcd9sFYNmC13w== + dependencies: + "@chakra-ui/react-children-utils" "2.0.1" + "@chakra-ui/react-context" "2.0.3" + +"@chakra-ui/breakpoint-utils@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/breakpoint-utils/-/breakpoint-utils-2.0.3.tgz#af7f7603f31a7d8d0166307a47e88cf5902401b4" + integrity sha512-smi41ZtaiPw4mXaCgicyAh5M45Drt20wypThP+qQUT2CQ51UFZhYlItRA2lCXKQ9QB83POcHPC/oAwIsNOAfTg== + +"@chakra-ui/button@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/button/-/button-2.0.9.tgz#f005f98bb5f1d5673a244957e6b3e2396acdf395" + integrity sha512-4BuDBiBlChHW1rQ9iod9MKs87AY3IyvZQwjV3DZTU4IG0KcDDfLQf++jj4dkg9Ttu+pIWhwF42pzA40JxW1oNg== + dependencies: + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/spinner" "2.0.9" + +"@chakra-ui/checkbox@2.1.8": + version "2.1.8" + resolved "https://registry.yarnpkg.com/@chakra-ui/checkbox/-/checkbox-2.1.8.tgz#d04a9a65494cf22e8bcfafa161bb7185d92dc13b" + integrity sha512-HhRs3nwTFoIE/UpX4N2AZxxW39Xm/Vw01HjwP/59X60kdKs3RBXlm52cODkfUDfveyT9o5ezLhU/jRf0qA909Q== + dependencies: + "@chakra-ui/form-control" "2.0.9" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-callback-ref" "2.0.3" + "@chakra-ui/react-use-controllable-state" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/react-use-safe-layout-effect" "2.0.1" + "@chakra-ui/react-use-update-effect" "2.0.3" + "@chakra-ui/visually-hidden" "2.0.9" + "@zag-js/focus-visible" "0.1.0" + +"@chakra-ui/clickable@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/clickable/-/clickable-2.0.9.tgz#c06486d36f4a4cb517ea75176e05021dfde117cd" + integrity sha512-tGXYM6M6I954fif98QkNu5M76oBZmksCTj2mILOan9/BSimpFpu06aPGX3ZIkNsz300nIObn0FdtMvKpIEQueA== + dependencies: + "@chakra-ui/react-use-merge-refs" "2.0.3" + +"@chakra-ui/close-button@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/close-button/-/close-button-2.0.9.tgz#dab2d66c7a240c4d3d150e370980709336a4a266" + integrity sha512-0RI/zLR+/mycGbYCCwDAc9hAVG7IIVmdikmo1ET7+rYip4TN94aWR0hA4dYtWqqghG1oW/pYQ9Yja6fEY90V5w== + dependencies: + "@chakra-ui/icon" "3.0.9" + +"@chakra-ui/color-mode@2.1.7": + version "2.1.7" + resolved "https://registry.yarnpkg.com/@chakra-ui/color-mode/-/color-mode-2.1.7.tgz#91c02e82e551c5448081e4934efeddb10bb732c5" + integrity sha512-GAoKJzVRQeuEfCa2i0BZdMwxuOoaGknU3+5wgvLuaSpwlov4OyqpjKMRdSdpjr4IFiqqHK47dsr3H4LQsbO+9w== + dependencies: + "@chakra-ui/react-use-safe-layout-effect" "2.0.1" + +"@chakra-ui/control-box@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/control-box/-/control-box-2.0.9.tgz#b3cd98ceb1ce683c00445ab7469e65ba3d90c3cc" + integrity sha512-/viS9OBah1wCLNZbgfwkoQOnVRUYgp8Gypjqk9QNQwnNdFUTEgWc1RWN+1RYO85esJzHLkA2hZFIrYu1TZeZ6g== + +"@chakra-ui/counter@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/counter/-/counter-2.0.9.tgz#b1b7c74c4e5d1ac506d699d93da57d535370a702" + integrity sha512-LuqtpyxCOZM19gAmV0vtVeaFd9ccPmEjoGJQ0NoO8CFheltgLC/7m/8YpDbgWiG4+BAkTUfIG+5nLg5hwvvQxw== + dependencies: + "@chakra-ui/number-utils" "2.0.3" + "@chakra-ui/react-use-callback-ref" "2.0.3" + +"@chakra-ui/css-reset@2.0.7": + version "2.0.7" + resolved "https://registry.yarnpkg.com/@chakra-ui/css-reset/-/css-reset-2.0.7.tgz#28f4284c36230e30892dc3f2de2464aaacc4f623" + integrity sha512-ztGdFQ6U1hX2k6a3HZ8D3A/dZWVxlGe2F5mvUrRU554mFWBYmsq0ydZ7UBEPlykv9NoCz4nN8VCkIxcKJ3p29Q== + +"@chakra-ui/descendant@3.0.9": + version "3.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/descendant/-/descendant-3.0.9.tgz#6574a1ce00067c49a070c5b005f8f1ca399006ea" + integrity sha512-30E5yMWvxgBx43PoI/67r9h9OhbpDfLb/MLOCjtEwebSbD0V5+fmnmCoUELScQbhozQVjA9t195X6UP0VQWj8w== + dependencies: + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + +"@chakra-ui/dom-utils@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/dom-utils/-/dom-utils-2.0.1.tgz#3061819ac365f5947423d63a5fcc26a281bbb5c2" + integrity sha512-sbob9AHQq1+KIQ3XKslafislwtC8pYcpwM0S1SLzgyZumHRwhDimKwdi4MtRQfOCenub0E3diRjp4RpGRL0JuQ== + +"@chakra-ui/editable@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/editable/-/editable-2.0.9.tgz#a31d2e1c176c0817574e98a8567314c1a74444ab" + integrity sha512-s5F3UMR09s6ga3eVhw0UBMGmegtxg6jCp29VLqaEwP5BuWIEOjcJz358gTlnFr3dhvb31e3rcr+B1XiYv4wxqg== + dependencies: + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-controllable-state" "2.0.3" + "@chakra-ui/react-use-focus-on-pointer-down" "2.0.1" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/react-use-safe-layout-effect" "2.0.1" + "@chakra-ui/react-use-update-effect" "2.0.3" + "@chakra-ui/shared-utils" "2.0.1" + +"@chakra-ui/event-utils@2.0.4": + version "2.0.4" + resolved "https://registry.yarnpkg.com/@chakra-ui/event-utils/-/event-utils-2.0.4.tgz#eeb3eb4f37c3828955dbbc182ea43a8a3238a599" + integrity sha512-J2YgAM5Dw9hMkwfMsWhsiAG848GfTMxNclUIUcgV9RQhLEs0eTFhelzNiKVOMA3vBxlT6lOARuRun/ESiFZgGg== + +"@chakra-ui/focus-lock@2.0.10": + version "2.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/focus-lock/-/focus-lock-2.0.10.tgz#8f17d212786bd2977afc07f72b520aeae30b9434" + integrity sha512-LeRZYzwfJp0eq84oO8e1pC2qC8v8fJw/P4nYDrCDjuJU753DV6nVjp5MKMRqbkp+6IAElPc+ojy/sp2a9GCocw== + dependencies: + "@chakra-ui/dom-utils" "2.0.1" + react-focus-lock "^2.9.1" + +"@chakra-ui/form-control@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/form-control/-/form-control-2.0.9.tgz#10678857e6586e7d1be0a34c8d045c6484c1180b" + integrity sha512-P8Tr45z/XSAa1m6uAma0eKf1h7Ltg2sLj2jK5YhaXJER9VUUY18iGe96D4JrAXlgEWDhTyWMb63nB+eYO1tKtw== + dependencies: + "@chakra-ui/icon" "3.0.9" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + +"@chakra-ui/hooks@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/hooks/-/hooks-2.0.9.tgz#1f6d6157968a60dd9678112763d8f5fd3bdeffad" + integrity sha512-0JRgEPtsBaXr9nQW1xEKlWGA7WwFbLNqac7fQXp9zQvoHOWTfNJkK/NJaVBvyFPgfTLxy37WKHooVSwNG/Lwmg== + dependencies: + "@chakra-ui/react-utils" "2.0.6" + "@chakra-ui/utils" "2.0.9" + compute-scroll-into-view "1.0.14" + copy-to-clipboard "3.3.1" + +"@chakra-ui/icon@3.0.9": + version "3.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/icon/-/icon-3.0.9.tgz#ba127d9eefd727f62e9bce07a23eca39ae506744" + integrity sha512-P2Pwm/za6m1W1oqL2kGHH6XrrymsBjqYAFwOW2lB5Q6mI1e+RYe/iMxDoPSLHMYhqdfH7vyib/ffE3Vv3a5oTA== + dependencies: + "@chakra-ui/shared-utils" "2.0.1" + +"@chakra-ui/image@2.0.10": + version "2.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/image/-/image-2.0.10.tgz#712c0e1c579d959225bd8316d8d8f66cbeb95bb8" + integrity sha512-Atc1bdog4V5xv7IbpF2F2UkKWfgG/TD74cIac09JuSpQcYyh7lrJ7iVvhTkeP+LDdCs+QCD7SnTUM4Y0ZlaHbA== + dependencies: + "@chakra-ui/react-use-safe-layout-effect" "2.0.1" + +"@chakra-ui/input@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/input/-/input-2.0.9.tgz#905b82ed647a20080a25a6a7e6740e3bb65586c1" + integrity sha512-6MKydxTyF7JV7PtQHircQ5HBTd6Ik9Vn7p8fCLeAieT0TK8UQTxMWZVPminS7TRWMutrq8W99DcQOBlMz0cKrw== + dependencies: + "@chakra-ui/form-control" "2.0.9" + "@chakra-ui/object-utils" "2.0.3" + "@chakra-ui/react-children-utils" "2.0.1" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/shared-utils" "2.0.1" + +"@chakra-ui/layout@2.1.6": + version "2.1.6" + resolved "https://registry.yarnpkg.com/@chakra-ui/layout/-/layout-2.1.6.tgz#3dfdd8b3f08d9ff34fc923d44ebe4bc86291b889" + integrity sha512-QDNaVu44UI46c+YlSF1KrzJkiwua0UtRXNTnR3jBE1uzcuqRow7xgr3E60dLphY2cPFqAljfQZUNlP3sgvCLww== + dependencies: + "@chakra-ui/breakpoint-utils" "2.0.3" + "@chakra-ui/icon" "3.0.9" + "@chakra-ui/object-utils" "2.0.3" + "@chakra-ui/react-children-utils" "2.0.1" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/shared-utils" "2.0.1" + +"@chakra-ui/lazy-utils@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/lazy-utils/-/lazy-utils-2.0.1.tgz#6814836552028fa0823563ce3d39d22bccb203e1" + integrity sha512-986YjYq+hEzHDLZiqYlYbdqfiKdC3h2g896Eoe5K2UXtAVxqZI3UOnMH781X6N1R7rGJWquskzG681qFigW/BA== + +"@chakra-ui/live-region@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/live-region/-/live-region-2.0.9.tgz#f26cf1b96df51515cd3a0897f9516f8b5f6bbfec" + integrity sha512-ilbo/C5wcUoSHDU5owFPQP3KsabPYGzDEbwV+Z76BlyNdFN2PD0j13RGEH+sBNNZ3HzLyyuuc1YmkVcJi7ycQg== + +"@chakra-ui/media-query@3.2.5": + version "3.2.5" + resolved "https://registry.yarnpkg.com/@chakra-ui/media-query/-/media-query-3.2.5.tgz#c0b9dc4bc6245d9abddcbe17693e40bf5dfe34f8" + integrity sha512-V+Dngi/r7u/uj7JhsZerM1RI597Oo4wED2ojNfclnnEVb/IoqktiuFy6RQgbo3HmE7M/E5B1i4yYzt7tQJhXlg== + dependencies: + "@chakra-ui/breakpoint-utils" "2.0.3" + "@chakra-ui/react-env" "2.0.9" + +"@chakra-ui/menu@2.0.13": + version "2.0.13" + resolved "https://registry.yarnpkg.com/@chakra-ui/menu/-/menu-2.0.13.tgz#3ac5f448efc894045769c606ebe1376051556be9" + integrity sha512-XZYoq9k/txAELUgn5OokyxfXEpVZwBueVYXiT9ji0XvMuzXVxeHd40klJEkiJUctNsOahZf10t5yxlT4B00pwA== + dependencies: + "@chakra-ui/clickable" "2.0.9" + "@chakra-ui/descendant" "3.0.9" + "@chakra-ui/lazy-utils" "2.0.1" + "@chakra-ui/popper" "3.0.7" + "@chakra-ui/react-children-utils" "2.0.1" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-use-animation-state" "2.0.3" + "@chakra-ui/react-use-controllable-state" "2.0.3" + "@chakra-ui/react-use-disclosure" "2.0.3" + "@chakra-ui/react-use-focus-effect" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/react-use-outside-click" "2.0.3" + "@chakra-ui/react-use-update-effect" "2.0.3" + "@chakra-ui/transition" "2.0.9" + +"@chakra-ui/modal@2.1.7": + version "2.1.7" + resolved "https://registry.yarnpkg.com/@chakra-ui/modal/-/modal-2.1.7.tgz#dba55bddd407689f4c2bba886b03a5355578a20d" + integrity sha512-A+CbvhQYpmLH3SrqJ1wJysUCGm0mNoSDxRjP4wX98j56nMTDAsMYlzttpuLmKaSzvbJ7uEQDLtQV8lZjB0gUuw== + dependencies: + "@chakra-ui/close-button" "2.0.9" + "@chakra-ui/focus-lock" "2.0.10" + "@chakra-ui/portal" "2.0.9" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/transition" "2.0.9" + aria-hidden "^1.1.1" + react-remove-scroll "^2.5.4" + +"@chakra-ui/number-input@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/number-input/-/number-input-2.0.9.tgz#c5ebfa0311f7586fb4c1e5f4284355b1d1f04383" + integrity sha512-RsDzoNvSBZMgyXjN543AtQ2v99U1p/0xnGWZy4NCkgCDWMBn3kIXqSzQq5CB9Ot0MD8nnKF5VYdVdXWguXExEQ== + dependencies: + "@chakra-ui/counter" "2.0.9" + "@chakra-ui/form-control" "2.0.9" + "@chakra-ui/icon" "3.0.9" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-callback-ref" "2.0.3" + "@chakra-ui/react-use-event-listener" "2.0.3" + "@chakra-ui/react-use-interval" "2.0.1" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/react-use-safe-layout-effect" "2.0.1" + "@chakra-ui/react-use-update-effect" "2.0.3" + +"@chakra-ui/number-utils@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/number-utils/-/number-utils-2.0.3.tgz#2cf1190647ac5a17c90baaf8176226a98eb3bfff" + integrity sha512-oN03kYAUCCp/FNtpLr5mh+cvd/sRTzZWTBoFydmxc955psXq/X950gzs6o5kzoeFCpgXaxMmHAXQm3ReEK2NsQ== + +"@chakra-ui/object-utils@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/object-utils/-/object-utils-2.0.3.tgz#0bc8d1c7c452fe1ce8fcda439336e0392e867d7e" + integrity sha512-36prckrqTynVD/JTzyCr8OCWVOrMs/awZo3djVbIiNxRIcJ5iEwUVy26h3MWN4ENSopipBtxNfAwPNTLU5Si/g== + +"@chakra-ui/pin-input@2.0.12": + version "2.0.12" + resolved "https://registry.yarnpkg.com/@chakra-ui/pin-input/-/pin-input-2.0.12.tgz#1ff927fdc61433a7b9b4421ceafad5674299e91a" + integrity sha512-gaMRp5AFW+qAJCUj93V1WluuYBBZ/5A3Wy5q796g8Auvw7vufgkVtl6EBznwvtynZN8gJwbRFpMtJxQyXCkUiw== + dependencies: + "@chakra-ui/descendant" "3.0.9" + "@chakra-ui/react-children-utils" "2.0.1" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-use-controllable-state" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + +"@chakra-ui/popover@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/popover/-/popover-2.0.9.tgz#7f2df4cbbc3eee7440c311750e18ba00150f973f" + integrity sha512-+7tH4RVuheFQOyAZ5KT9x+qsLvz7rGuKaHtb0427+5bhUzLaSAghtr/afzOKHDwUVBwF2tTUNanR23ipW1fXDg== + dependencies: + "@chakra-ui/close-button" "2.0.9" + "@chakra-ui/hooks" "2.0.9" + "@chakra-ui/lazy-utils" "2.0.1" + "@chakra-ui/popper" "3.0.7" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-disclosure" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + +"@chakra-ui/popper@3.0.7": + version "3.0.7" + resolved "https://registry.yarnpkg.com/@chakra-ui/popper/-/popper-3.0.7.tgz#af3428bf5d64ad9372210a70181f69a9d79eefb2" + integrity sha512-xLYhuNsk1gOjymtek1ZdZlG21hmg2a7Iu2KsD9Hi7+aUxc2K5/XxX+/vyjjz8u4s0gmj83pTqnauQRynb/TCXA== + dependencies: + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@popperjs/core" "^2.9.3" + +"@chakra-ui/portal@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/portal/-/portal-2.0.9.tgz#b427c383a9d602c5b52b21312b4b1c0ffecaf583" + integrity sha512-9e9S0MLbkpofPGlyYA12jNYSdndugy6ylPi5pC9nr3/VqG2Kn+8VcBChAeXW8K4ms7WFc74rNX1pBY/UVwr4qg== + dependencies: + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-use-safe-layout-effect" "2.0.1" + +"@chakra-ui/progress@2.0.10": + version "2.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/progress/-/progress-2.0.10.tgz#9191ae9061ef08066d37c5cb8341fedc10214a29" + integrity sha512-my0Pi3NG1PYhlvCav4fybg3gL5HBNe+7lO4PVdri4QHEyfJlrDeBWID+1GgqlpUWdTj3sOf7ysku+FEgkeOeSA== + dependencies: + "@chakra-ui/react-context" "2.0.3" + +"@chakra-ui/provider@2.0.16": + version "2.0.16" + resolved "https://registry.yarnpkg.com/@chakra-ui/provider/-/provider-2.0.16.tgz#a4afdb4c8f2050beb5d2b61db8971a145481c6f2" + integrity sha512-4t/PmjJ7WXPPaPfoYgw8F1/rVtorZuvknugHfOZcOtAPGQmOPotSv28qjKpu/mCvc1GMGV0swMsvCeInYz7g0w== + dependencies: + "@chakra-ui/css-reset" "2.0.7" + "@chakra-ui/portal" "2.0.9" + "@chakra-ui/react-env" "2.0.9" + "@chakra-ui/system" "2.2.9" + "@chakra-ui/utils" "2.0.9" + +"@chakra-ui/radio@2.0.10": + version "2.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/radio/-/radio-2.0.10.tgz#82eb02313efafc460da3030d011bfd434b1ecabc" + integrity sha512-LhAWsY22cmb+M/iyhFgkzf2+V9TJmAC77Cd+GbP3M3sxDSEUDtq08KOc3JjoYc3GzeZml3JL1yssbxh+liY3xA== + dependencies: + "@chakra-ui/form-control" "2.0.9" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@zag-js/focus-visible" "0.1.0" + +"@chakra-ui/react-children-utils@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-children-utils/-/react-children-utils-2.0.1.tgz#321ac05362ade1495a34ea74052d3c7da3d9e923" + integrity sha512-sEgpuh/vWSt2+W0F49EGYXXUyjmg0lbosjVg6qUKHv9sAyx5tbrOrZ6df/TaMUSAe9m3AUOMGqUIPLpxno0DjA== + +"@chakra-ui/react-context@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-context/-/react-context-2.0.3.tgz#e988be62f5f5fe29d6a8496c79cbf934f840fa5a" + integrity sha512-KmPq6sb1y05WsOUqXZtBBC4LsNKZIFrp2thTsLBwcuH7lkXZwPMHmJGKa9K980P+SWEgfH2s2PY2z+QrIuqWGg== + +"@chakra-ui/react-env@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-env/-/react-env-2.0.9.tgz#d51efc31d77197a3526e2c4b2f2fde557396bb3c" + integrity sha512-4AJHNUGBR19hzVyOILYpZZgq8jGrpEcbhvR++CppbvPH7vfPZpoz6L/cBtHxS07YwDtUeBL8yCNiLlTxctV//Q== + +"@chakra-ui/react-types@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-types/-/react-types-2.0.3.tgz#dc454c4703b4de585e6461fd607304ede06fe595" + integrity sha512-1mJYOQldFTALE0Wr3j6tk/MYvgQIp6CKkJulNzZrI8QN+ox/bJOh8OVP4vhwqvfigdLTui0g0k8M9h+j2ub/Mw== + +"@chakra-ui/react-use-animation-state@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-animation-state/-/react-use-animation-state-2.0.3.tgz#c10e575de76e907a84358595884a819039b24200" + integrity sha512-sjGgzMMmxurwKDSFhDLpLNn3SWUERI5iAZOOa0pYnyOLGVXMowgIjK6jpZxre1vc3A+unjJk5P4qeiyY+C4uwQ== + dependencies: + "@chakra-ui/dom-utils" "2.0.1" + "@chakra-ui/react-use-event-listener" "2.0.3" + +"@chakra-ui/react-use-callback-ref@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-callback-ref/-/react-use-callback-ref-2.0.3.tgz#532f993ae0dda27b2638d41e98f42c83751cd3b6" + integrity sha512-kdYlhgnQKWWLNwl3WSv/Oq3+mlnu2p3y4Xc1AqKVHVcBOdQE9lpW3d7ZaOoK2aIXXWq1rocscOiXBUtM0Vqd2A== + +"@chakra-ui/react-use-controllable-state@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-controllable-state/-/react-use-controllable-state-2.0.3.tgz#7aa3f9c038513763332f6754e69ece90aed55a9c" + integrity sha512-su8efwCWWnY2LQUU6PEnYwSGJX8kvPSO2KyUKuymx8q3fNWuyhzAZriG/TbeeCxESLp70+wuniUlSGRa4vxylQ== + dependencies: + "@chakra-ui/react-use-callback-ref" "2.0.3" + +"@chakra-ui/react-use-disclosure@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-disclosure/-/react-use-disclosure-2.0.3.tgz#c27bfc7e3af0728423b9e2def1e1665d0ba941bb" + integrity sha512-3IdrzvQZcgjqSx5wTVffInOyhMU+d3ZlIE26JmqejMyN/B+qAs932iKfm0A1mTMPTz38ZnNtuaKazmzyfR1ePg== + dependencies: + "@chakra-ui/react-use-callback-ref" "2.0.3" + +"@chakra-ui/react-use-event-listener@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-event-listener/-/react-use-event-listener-2.0.3.tgz#11b5409c4442888e7981d5288c9e781acdacd685" + integrity sha512-m3ZdJjo3QQ1HcQGnehlBTgHaCVewz5fwIRTXVzbZTraVJr4k589Zf87eagW57tT4dyv656lSmdhaFGZ8p5Snww== + dependencies: + "@chakra-ui/react-use-callback-ref" "2.0.3" + +"@chakra-ui/react-use-focus-effect@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-focus-effect/-/react-use-focus-effect-2.0.3.tgz#3e221a5e9b06a7b832a6fca1f883e6335fd69f19" + integrity sha512-N0rho7P+rH5cn13dbS8GUOye+6RYXAmXhmlS+WW/3lWidGH3HAbMoOVf56UiuSnE1+2or8/U7qRshUryj2H1nA== + dependencies: + "@chakra-ui/dom-utils" "2.0.1" + "@chakra-ui/react-use-event-listener" "2.0.3" + "@chakra-ui/react-use-update-effect" "2.0.3" + +"@chakra-ui/react-use-focus-on-pointer-down@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-focus-on-pointer-down/-/react-use-focus-on-pointer-down-2.0.1.tgz#be0668ff844dec8bbfe978d6eaff50534f290c48" + integrity sha512-f0qL2iWvajUo+0jwDZyJpUMJ6J6BH3WjDZE2Rp6cns4pgI6uYuv2gj+FqQ5jnoYdXkeER6lBI56a+aIW/1RYiA== + dependencies: + "@chakra-ui/react-use-event-listener" "2.0.3" + +"@chakra-ui/react-use-interval@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-interval/-/react-use-interval-2.0.1.tgz#a8f5dbf83607f5dc53022aa2a766fdcb09d8a081" + integrity sha512-6ZLzKA7Ga894UZcXO3bbGYThlhviiau1oxZ1UcJG5pUXNM9Up7O/4Joq31sL+KcpteCN45vd1etomilsv/blxw== + dependencies: + "@chakra-ui/react-use-callback-ref" "2.0.3" + +"@chakra-ui/react-use-merge-refs@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-merge-refs/-/react-use-merge-refs-2.0.3.tgz#cd8dac79c62dd45daaf4acc4507721d23dc5dc51" + integrity sha512-n35BmVbasy5Esa6qxznWmiV3NaRxGpqMpZH0n+X7aXt8VkGAJzRpAVjUmKCLNYyCLpqsQceCmAEK8a5SR6vxqw== + +"@chakra-ui/react-use-outside-click@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-outside-click/-/react-use-outside-click-2.0.3.tgz#d0136d1c2fb45d86361224e98e3a50648bf9b85f" + integrity sha512-r5OohM8lOuZTz6e3vVHvfm/3sEkd06nUPBNU+r3rWh1I7bR9z5Gia/BOQD6GE4jUTanDkHcH76Pf9qJ45kpibQ== + dependencies: + "@chakra-ui/react-use-callback-ref" "2.0.3" + +"@chakra-ui/react-use-pan-event@2.0.4": + version "2.0.4" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-pan-event/-/react-use-pan-event-2.0.4.tgz#bfc2c1a2a44b2996951a729182566f02c7dc05e4" + integrity sha512-lcEjngfCgIjE5qZeJiaDx+aJzZPLjbjUmbWumi8pIgWOnDL8Ffjh7AMKW4CddP5OgcRnDDb+7aqJbb55wraboA== + dependencies: + "@chakra-ui/event-utils" "2.0.4" + framesync "5.3.0" + +"@chakra-ui/react-use-previous@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-previous/-/react-use-previous-2.0.1.tgz#e19f6b363271f62c36c9f3bd91dc60caa4c4e340" + integrity sha512-ROi+/puVd8D1QaxBSOcGlJNqV2x02ppSgmXzZZJhM8ryFLZjY9ojV3HhamB2IJ/7SIb1rMSSV1GPedFw7YMCwA== + +"@chakra-ui/react-use-safe-layout-effect@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-safe-layout-effect/-/react-use-safe-layout-effect-2.0.1.tgz#76f8882abaf17078c3b6eb93e1bb26f8c319f3f7" + integrity sha512-H+ZOjkPqv3KBPEoP68JKpQBNdLOI0mwzEiTT397UdvBVCCJ+1/ijWVUT+Ub/pYic60O6xUghy5ORaWqJHhnKDA== + +"@chakra-ui/react-use-size@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-size/-/react-use-size-2.0.3.tgz#ae3bd683eb87a40208cf0dd467a5dafb68d87b3e" + integrity sha512-hr4hKepPUmM2paXseSZiOTK2y+ZqnSzYNusDEB01f+cDerFjdN1jSfNJKXpiKF0+hNESXfOPQb3Zt0eDusRdoA== + dependencies: + "@zag-js/element-size" "0.1.0" + +"@chakra-ui/react-use-timeout@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-timeout/-/react-use-timeout-2.0.1.tgz#acacadfb7c1443aacf634ddce710b1cd7cf3b6ec" + integrity sha512-zXh9RH+GciKr8hvaOADHOoHP72B7UZUEymA8CWCV4WEs/9s/PfQJH7X1bwvaj43CcOmfVQg4oODWqCYQM1lSsg== + dependencies: + "@chakra-ui/react-use-callback-ref" "2.0.3" + +"@chakra-ui/react-use-update-effect@2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-use-update-effect/-/react-use-update-effect-2.0.3.tgz#5b0128fe1325b5b1413690db6bc8dd0712d01e29" + integrity sha512-8hkP1o/UUUA49w/R+XyAlPiCjxXTCWCNsHWUOEhAitjJfoCNUjgaNKOD52hT07kc5ACJEcJQHA5327LnwtiIlg== + +"@chakra-ui/react-utils@2.0.6": + version "2.0.6" + resolved "https://registry.yarnpkg.com/@chakra-ui/react-utils/-/react-utils-2.0.6.tgz#bb471ce2bff724b99563685962145a2cc56bf61d" + integrity sha512-ZL0FPaolovXOxMzYRSLHgBYtvxIkA/c5GTSYpXL8DcC+TBLZnAmQ8BPTS2b6xys6xvwdQjkZRUeQ0cBNFaryJg== + dependencies: + "@chakra-ui/utils" "2.0.9" + +"@chakra-ui/react@^2.3.2": + version "2.3.2" + resolved "https://registry.yarnpkg.com/@chakra-ui/react/-/react-2.3.2.tgz#4ffcd5b79d21d14e240efc37adab7831f2aac37f" + integrity sha512-qOcDLbA1x4pnpJPtF4YJ7pZzK/ki6SoQl9Vj7fsR+hJw1lt3y1475NSyYGiA6qgho/8twUgYLhcdrTbQPcmOHg== + dependencies: + "@chakra-ui/accordion" "2.0.12" + "@chakra-ui/alert" "2.0.9" + "@chakra-ui/avatar" "2.1.0" + "@chakra-ui/breadcrumb" "2.0.9" + "@chakra-ui/button" "2.0.9" + "@chakra-ui/checkbox" "2.1.8" + "@chakra-ui/close-button" "2.0.9" + "@chakra-ui/control-box" "2.0.9" + "@chakra-ui/counter" "2.0.9" + "@chakra-ui/css-reset" "2.0.7" + "@chakra-ui/editable" "2.0.9" + "@chakra-ui/form-control" "2.0.9" + "@chakra-ui/hooks" "2.0.9" + "@chakra-ui/icon" "3.0.9" + "@chakra-ui/image" "2.0.10" + "@chakra-ui/input" "2.0.9" + "@chakra-ui/layout" "2.1.6" + "@chakra-ui/live-region" "2.0.9" + "@chakra-ui/media-query" "3.2.5" + "@chakra-ui/menu" "2.0.13" + "@chakra-ui/modal" "2.1.7" + "@chakra-ui/number-input" "2.0.9" + "@chakra-ui/pin-input" "2.0.12" + "@chakra-ui/popover" "2.0.9" + "@chakra-ui/popper" "3.0.7" + "@chakra-ui/portal" "2.0.9" + "@chakra-ui/progress" "2.0.10" + "@chakra-ui/provider" "2.0.16" + "@chakra-ui/radio" "2.0.10" + "@chakra-ui/react-env" "2.0.9" + "@chakra-ui/select" "2.0.10" + "@chakra-ui/skeleton" "2.0.15" + "@chakra-ui/slider" "2.0.10" + "@chakra-ui/spinner" "2.0.9" + "@chakra-ui/stat" "2.0.9" + "@chakra-ui/switch" "2.0.11" + "@chakra-ui/system" "2.2.9" + "@chakra-ui/table" "2.0.9" + "@chakra-ui/tabs" "2.1.1" + "@chakra-ui/tag" "2.0.9" + "@chakra-ui/textarea" "2.0.10" + "@chakra-ui/theme" "2.1.11" + "@chakra-ui/toast" "3.0.10" + "@chakra-ui/tooltip" "2.0.10" + "@chakra-ui/transition" "2.0.9" + "@chakra-ui/utils" "2.0.9" + "@chakra-ui/visually-hidden" "2.0.9" + +"@chakra-ui/select@2.0.10": + version "2.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/select/-/select-2.0.10.tgz#827028484769a32205f99baed3098a115da292b3" + integrity sha512-7AslBWwI/JyczjMMGtPuN34M/C38koVd+N/pb6swHoIP9TRkkdvDlonIakcmtO1oLEzlNIFKmt4FQ7bUp9ea5Q== + dependencies: + "@chakra-ui/form-control" "2.0.9" + +"@chakra-ui/shared-utils@2.0.1": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/shared-utils/-/shared-utils-2.0.1.tgz#41e314e42c96039e8ffb265e73145cf755813ab4" + integrity sha512-NXDBl/u4wrSNp0ON5R3r3evkRurrAz2yuO7neooaG+O5HEenVouGqm4CsXd6lUAPmjwiGzA0LQFNCt0Hj92dXg== + +"@chakra-ui/skeleton@2.0.15": + version "2.0.15" + resolved "https://registry.yarnpkg.com/@chakra-ui/skeleton/-/skeleton-2.0.15.tgz#fd41383bf84319e47c6ea1f4f3138f5f5e0dabca" + integrity sha512-QVMkXwrH9jLfim8uJTZcjHeGjzoquNcHGXD5wapd7eDqp9BygvmMXAHBxFm8eEJLHuvIqLX94P6DLeiieYwX7Q== + dependencies: + "@chakra-ui/media-query" "3.2.5" + "@chakra-ui/react-use-previous" "2.0.1" + +"@chakra-ui/slider@2.0.10": + version "2.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/slider/-/slider-2.0.10.tgz#ffd7376d4a7fd9aa02e72b148e3ad4739c880498" + integrity sha512-F0RGl2ruADbXO/GnoBUiTEl+przxhZo2e0tfw9VTtS+RsJZ22uHrTNVvVJHNmjK7/E3++kBfaLCacoJFz/io+g== + dependencies: + "@chakra-ui/number-utils" "2.0.3" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-callback-ref" "2.0.3" + "@chakra-ui/react-use-controllable-state" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/react-use-pan-event" "2.0.4" + "@chakra-ui/react-use-size" "2.0.3" + "@chakra-ui/react-use-update-effect" "2.0.3" + +"@chakra-ui/spinner@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/spinner/-/spinner-2.0.9.tgz#1d8544cc136699a590c3f5c518ae2c14abb459cf" + integrity sha512-9ALl51fiVWptDu2J2xcv0TSfGf4buumpHrEXHvV2Qy+HZ6rYnUmSThBSb/VgoQS+rASG8bAbLUPlQTQ+v9ibFg== + +"@chakra-ui/stat@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/stat/-/stat-2.0.9.tgz#cecf35a4392a88227c3b85e80a45f0f5ac5f298d" + integrity sha512-C9cytqegWSGJ/hh3/qwsgGlerXLYHrU0iQcJQ+pKSRFJhshXsv3go5IR6kVL72Yf2s4Gs5c3GsMZrLM22ePpDg== + dependencies: + "@chakra-ui/icon" "3.0.9" + "@chakra-ui/react-context" "2.0.3" + +"@chakra-ui/styled-system@2.3.1": + version "2.3.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/styled-system/-/styled-system-2.3.1.tgz#abf7c4e1638aaa9d92e7cf9acde17785703d166e" + integrity sha512-jyR9s2yk5TEyq4HUfjrgUeaOzd9ZTZrbjK96UjtiTCZGO/q4j2RXtYvfheUjUyW1UnzI2A1ffHOJca8tBMDjpA== + dependencies: + csstype "^3.0.11" + lodash.mergewith "4.6.2" + +"@chakra-ui/switch@2.0.11": + version "2.0.11" + resolved "https://registry.yarnpkg.com/@chakra-ui/switch/-/switch-2.0.11.tgz#57117417d1bb072f506c8c30e1a961ee7f78496b" + integrity sha512-gY8OGBnoPosZpq7dDNVf432t67pTc/cz5VkGhbtER7bbjXSoXe0DAiAYL+HT2kD7mbTJQzzHK/y0St0WimR1Mw== + dependencies: + "@chakra-ui/checkbox" "2.1.8" + +"@chakra-ui/system@2.2.9": + version "2.2.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/system/-/system-2.2.9.tgz#d6e7dfb9a954b8ab03c28e14c69aad56a9fcffbd" + integrity sha512-SyTeIGm+goyYK8vqX4dU6oeLhxUAeGI3Cl+mxA+aiKIX01YTALhTWhpbrsuMYBevV+l9EGK12egPUQE+Mo3WlQ== + dependencies: + "@chakra-ui/color-mode" "2.1.7" + "@chakra-ui/react-utils" "2.0.6" + "@chakra-ui/styled-system" "2.3.1" + "@chakra-ui/utils" "2.0.9" + react-fast-compare "3.2.0" + +"@chakra-ui/table@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/table/-/table-2.0.9.tgz#2ddb0202e8146e517bf602e62195d13fee8f1b0a" + integrity sha512-XRz6+x4dMeQX3xyViyG2H/P1STI/2vwvgU2cjzzwS+5fZ2JdGaTgYzBb+IZoH9agEq1Ma3rlKMUPDrRCFb7kLQ== + dependencies: + "@chakra-ui/react-context" "2.0.3" + +"@chakra-ui/tabs@2.1.1": + version "2.1.1" + resolved "https://registry.yarnpkg.com/@chakra-ui/tabs/-/tabs-2.1.1.tgz#0fb540782c2e4122b63a203fc1f04eff850f2c0e" + integrity sha512-xA+vwqpAHb0nBLrkiO5Lea2UDGROyAIBqsyp/8XXXEr6eKxtNe1I6WJPbDQy0aazB2ToAA0R6fT34HjLaXP8MQ== + dependencies: + "@chakra-ui/clickable" "2.0.9" + "@chakra-ui/descendant" "3.0.9" + "@chakra-ui/lazy-utils" "2.0.1" + "@chakra-ui/react-children-utils" "2.0.1" + "@chakra-ui/react-context" "2.0.3" + "@chakra-ui/react-use-controllable-state" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + "@chakra-ui/react-use-safe-layout-effect" "2.0.1" + +"@chakra-ui/tag@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/tag/-/tag-2.0.9.tgz#bf8530aa766bd6b9196d374ff75b0b1ce62cd0d3" + integrity sha512-NKARwhsZ04t2vkrdRhNcakEiVtg1q44yUUsDw2Jwdu4idAWQupZGGochQI2Ac4T2MI1b66zQUkaGnm3l1mhTtg== + dependencies: + "@chakra-ui/icon" "3.0.9" + "@chakra-ui/react-context" "2.0.3" + +"@chakra-ui/textarea@2.0.10": + version "2.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/textarea/-/textarea-2.0.10.tgz#dbbc8df8adddb488d0ee97164917e7be33d6b247" + integrity sha512-HSo0EPsY8XKGA+Af6jTob1oe1T6NKZwgjLmX0binK3MMM9pDTXsUTw8GD0g971lxw9oktVMLK/O9QVAgVAm5mw== + dependencies: + "@chakra-ui/form-control" "2.0.9" + +"@chakra-ui/theme-tools@2.0.11": + version "2.0.11" + resolved "https://registry.yarnpkg.com/@chakra-ui/theme-tools/-/theme-tools-2.0.11.tgz#de97b422799627b5a514ae424ca08c1d348bc2a5" + integrity sha512-0Juf98bAyOgnBeQ39nMKWqRsOxZDw75BbAB8o0oVyjhYVS1wJh7tFX1ZRV8N/+AN6fuRXEznZPpyUh3J+ZTiRg== + dependencies: + "@chakra-ui/anatomy" "2.0.6" + "@ctrl/tinycolor" "^3.4.0" + +"@chakra-ui/theme@2.1.11": + version "2.1.11" + resolved "https://registry.yarnpkg.com/@chakra-ui/theme/-/theme-2.1.11.tgz#cdfca3e84fc6913c5bb1a06e24b7cbb1246e127e" + integrity sha512-gI0NLU6wO/5cRq8gbDHuy24Y/ZhJxN4D/2uucNN9is3h+d58/En5jV3fwzZW8PLiLKW/T2CmbYWEZWV2YkcUVA== + dependencies: + "@chakra-ui/anatomy" "2.0.6" + "@chakra-ui/theme-tools" "2.0.11" + +"@chakra-ui/toast@3.0.10": + version "3.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/toast/-/toast-3.0.10.tgz#5918beb208ca592f72a9e24923254341fa38df58" + integrity sha512-i/oEtzmarO0hM6fxa55OmA8ZGkZv9b+vIC2xs5kQ/C0rJaC0ycibok8srq2Stjq9309fZNezyzThQp6e9acUYQ== + dependencies: + "@chakra-ui/alert" "2.0.9" + "@chakra-ui/close-button" "2.0.9" + "@chakra-ui/portal" "2.0.9" + "@chakra-ui/react-use-timeout" "2.0.1" + "@chakra-ui/react-use-update-effect" "2.0.3" + "@chakra-ui/theme" "2.1.11" + +"@chakra-ui/tooltip@2.0.10": + version "2.0.10" + resolved "https://registry.yarnpkg.com/@chakra-ui/tooltip/-/tooltip-2.0.10.tgz#2166753f9f246dd217d3170fd85f95a86392d9b6" + integrity sha512-pBILBdZoux2K3EW9V6JuyZYUWz2/Y7oYCVO6AwNOesiEBGAONyzoDwFV728EzPEHe9e+YBcKOSZ9tEpDdrzHMA== + dependencies: + "@chakra-ui/popper" "3.0.7" + "@chakra-ui/portal" "2.0.9" + "@chakra-ui/react-types" "2.0.3" + "@chakra-ui/react-use-disclosure" "2.0.3" + "@chakra-ui/react-use-event-listener" "2.0.3" + "@chakra-ui/react-use-merge-refs" "2.0.3" + +"@chakra-ui/transition@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/transition/-/transition-2.0.9.tgz#1967fd77f44b57681a9efe4e87561c82420cd2a2" + integrity sha512-cVfKdZl128AEj0LDS8M9dzXao4wmTVj3gRJBnm91Qcg243Pm8OlgIBNbHEwsq/Fps+PsN431BtEGfL4w79wQEA== + +"@chakra-ui/utils@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/utils/-/utils-2.0.9.tgz#1af3882b31fb46e0a411998d8e3607656f8d5043" + integrity sha512-7ct5562Jw6pZdtj63XfUkEUXXsCCVqdqIXyLtQ9VgOKtRQWwDxzc8uPI5Zjdw9AleEITZFUH8TNKWn75nm54kQ== + dependencies: + "@types/lodash.mergewith" "4.6.6" + css-box-model "1.2.1" + framesync "5.3.0" + lodash.mergewith "4.6.2" + +"@chakra-ui/visually-hidden@2.0.9": + version "2.0.9" + resolved "https://registry.yarnpkg.com/@chakra-ui/visually-hidden/-/visually-hidden-2.0.9.tgz#b43a3dd0bc1108954ad0eeb50d0261887ab5e31c" + integrity sha512-PkNxrRGp9H3bdqEaoo8XGt/AL9UuGRTom0/9XJa+G/Dj8Cy1sDuamOWk3pN/ZQs46RokfK9Uh5LqPY5dwSDweg== + +"@ctrl/tinycolor@^3.4.0": + version "3.4.1" + resolved "https://registry.yarnpkg.com/@ctrl/tinycolor/-/tinycolor-3.4.1.tgz#75b4c27948c81e88ccd3a8902047bcd797f38d32" + integrity sha512-ej5oVy6lykXsvieQtqZxCOaLT+xD4+QNarq78cIYISHmZXshCvROLudpQN3lfL8G0NL7plMSSK+zlyvCaIJ4Iw== + +"@emotion/babel-plugin@^11.10.0": + version "11.10.2" + resolved "https://registry.yarnpkg.com/@emotion/babel-plugin/-/babel-plugin-11.10.2.tgz#879db80ba622b3f6076917a1e6f648b1c7d008c7" + integrity sha512-xNQ57njWTFVfPAc3cjfuaPdsgLp5QOSuRsj9MA6ndEhH/AzuZM86qIQzt6rq+aGBwj3n5/TkLmU5lhAfdRmogA== + dependencies: + "@babel/helper-module-imports" "^7.16.7" + "@babel/plugin-syntax-jsx" "^7.17.12" + "@babel/runtime" "^7.18.3" + "@emotion/hash" "^0.9.0" + "@emotion/memoize" "^0.8.0" + "@emotion/serialize" "^1.1.0" + babel-plugin-macros "^3.1.0" + convert-source-map "^1.5.0" + escape-string-regexp "^4.0.0" + find-root "^1.1.0" + source-map "^0.5.7" + stylis "4.0.13" + +"@emotion/cache@^11.10.0": + version "11.10.3" + resolved "https://registry.yarnpkg.com/@emotion/cache/-/cache-11.10.3.tgz#c4f67904fad10c945fea5165c3a5a0583c164b87" + integrity sha512-Psmp/7ovAa8appWh3g51goxu/z3iVms7JXOreq136D8Bbn6dYraPnmL6mdM8GThEx9vwSn92Fz+mGSjBzN8UPQ== + dependencies: + "@emotion/memoize" "^0.8.0" + "@emotion/sheet" "^1.2.0" + "@emotion/utils" "^1.2.0" + "@emotion/weak-memoize" "^0.3.0" + stylis "4.0.13" + +"@emotion/hash@^0.9.0": + version "0.9.0" + resolved "https://registry.yarnpkg.com/@emotion/hash/-/hash-0.9.0.tgz#c5153d50401ee3c027a57a177bc269b16d889cb7" + integrity sha512-14FtKiHhy2QoPIzdTcvh//8OyBlknNs2nXRwIhG904opCby3l+9Xaf/wuPvICBF0rc1ZCNBd3nKe9cd2mecVkQ== + +"@emotion/is-prop-valid@^0.8.2": + version "0.8.8" + resolved "https://registry.yarnpkg.com/@emotion/is-prop-valid/-/is-prop-valid-0.8.8.tgz#db28b1c4368a259b60a97311d6a952d4fd01ac1a" + integrity sha512-u5WtneEAr5IDG2Wv65yhunPSMLIpuKsbuOktRojfrEiEvRyC85LgPMZI63cr7NUqT8ZIGdSVg8ZKGxIug4lXcA== + dependencies: + "@emotion/memoize" "0.7.4" + +"@emotion/is-prop-valid@^1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@emotion/is-prop-valid/-/is-prop-valid-1.2.0.tgz#7f2d35c97891669f7e276eb71c83376a5dc44c83" + integrity sha512-3aDpDprjM0AwaxGE09bOPkNxHpBd+kA6jty3RnaEXdweX1DF1U3VQpPYb0g1IStAuK7SVQ1cy+bNBBKp4W3Fjg== + dependencies: + "@emotion/memoize" "^0.8.0" + +"@emotion/memoize@0.7.4": + version "0.7.4" + resolved "https://registry.yarnpkg.com/@emotion/memoize/-/memoize-0.7.4.tgz#19bf0f5af19149111c40d98bb0cf82119f5d9eeb" + integrity sha512-Ja/Vfqe3HpuzRsG1oBtWTHk2PGZ7GR+2Vz5iYGelAw8dx32K0y7PjVuxK6z1nMpZOqAFsRUPCkK1YjJ56qJlgw== + +"@emotion/memoize@^0.8.0": + version "0.8.0" + resolved "https://registry.yarnpkg.com/@emotion/memoize/-/memoize-0.8.0.tgz#f580f9beb67176fa57aae70b08ed510e1b18980f" + integrity sha512-G/YwXTkv7Den9mXDO7AhLWkE3q+I92B+VqAE+dYG4NGPaHZGvt3G8Q0p9vmE+sq7rTGphUbAvmQ9YpbfMQGGlA== + +"@emotion/react@^11.10.4": + version "11.10.4" + resolved "https://registry.yarnpkg.com/@emotion/react/-/react-11.10.4.tgz#9dc6bccbda5d70ff68fdb204746c0e8b13a79199" + integrity sha512-j0AkMpr6BL8gldJZ6XQsQ8DnS9TxEQu1R+OGmDZiWjBAJtCcbt0tS3I/YffoqHXxH6MjgI7KdMbYKw3MEiU9eA== + dependencies: + "@babel/runtime" "^7.18.3" + "@emotion/babel-plugin" "^11.10.0" + "@emotion/cache" "^11.10.0" + "@emotion/serialize" "^1.1.0" + "@emotion/use-insertion-effect-with-fallbacks" "^1.0.0" + "@emotion/utils" "^1.2.0" + "@emotion/weak-memoize" "^0.3.0" + hoist-non-react-statics "^3.3.1" + +"@emotion/serialize@^1.1.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@emotion/serialize/-/serialize-1.1.0.tgz#b1f97b1011b09346a40e9796c37a3397b4ea8ea8" + integrity sha512-F1ZZZW51T/fx+wKbVlwsfchr5q97iW8brAnXmsskz4d0hVB4O3M/SiA3SaeH06x02lSNzkkQv+n3AX3kCXKSFA== + dependencies: + "@emotion/hash" "^0.9.0" + "@emotion/memoize" "^0.8.0" + "@emotion/unitless" "^0.8.0" + "@emotion/utils" "^1.2.0" + csstype "^3.0.2" + +"@emotion/sheet@^1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@emotion/sheet/-/sheet-1.2.0.tgz#771b1987855839e214fc1741bde43089397f7be5" + integrity sha512-OiTkRgpxescko+M51tZsMq7Puu/KP55wMT8BgpcXVG2hqXc0Vo0mfymJ/Uj24Hp0i083ji/o0aLddh08UEjq8w== + +"@emotion/styled@^11.10.4": + version "11.10.4" + resolved "https://registry.yarnpkg.com/@emotion/styled/-/styled-11.10.4.tgz#e93f84a4d54003c2acbde178c3f97b421fce1cd4" + integrity sha512-pRl4R8Ez3UXvOPfc2bzIoV8u9P97UedgHS4FPX594ntwEuAMA114wlaHvOK24HB48uqfXiGlYIZYCxVJ1R1ttQ== + dependencies: + "@babel/runtime" "^7.18.3" + "@emotion/babel-plugin" "^11.10.0" + "@emotion/is-prop-valid" "^1.2.0" + "@emotion/serialize" "^1.1.0" + "@emotion/use-insertion-effect-with-fallbacks" "^1.0.0" + "@emotion/utils" "^1.2.0" + +"@emotion/unitless@^0.8.0": + version "0.8.0" + resolved "https://registry.yarnpkg.com/@emotion/unitless/-/unitless-0.8.0.tgz#a4a36e9cbdc6903737cd20d38033241e1b8833db" + integrity sha512-VINS5vEYAscRl2ZUDiT3uMPlrFQupiKgHz5AA4bCH1miKBg4qtwkim1qPmJj/4WG6TreYMY111rEFsjupcOKHw== + +"@emotion/use-insertion-effect-with-fallbacks@^1.0.0": + version "1.0.0" + resolved "https://registry.yarnpkg.com/@emotion/use-insertion-effect-with-fallbacks/-/use-insertion-effect-with-fallbacks-1.0.0.tgz#ffadaec35dbb7885bd54de3fa267ab2f860294df" + integrity sha512-1eEgUGmkaljiBnRMTdksDV1W4kUnmwgp7X9G8B++9GYwl1lUdqSndSriIrTJ0N7LQaoauY9JJ2yhiOYK5+NI4A== + +"@emotion/utils@^1.2.0": + version "1.2.0" + resolved "https://registry.yarnpkg.com/@emotion/utils/-/utils-1.2.0.tgz#9716eaccbc6b5ded2ea5a90d65562609aab0f561" + integrity sha512-sn3WH53Kzpw8oQ5mgMmIzzyAaH2ZqFEbozVVBSYp538E06OSE6ytOp7pRAjNQR+Q/orwqdQYJSe2m3hCOeznkw== + +"@emotion/weak-memoize@^0.3.0": + version "0.3.0" + resolved "https://registry.yarnpkg.com/@emotion/weak-memoize/-/weak-memoize-0.3.0.tgz#ea89004119dc42db2e1dba0f97d553f7372f6fcb" + integrity sha512-AHPmaAx+RYfZz0eYu6Gviiagpmiyw98ySSlQvCUhVGDRtDFe4DBS0x1bSjdF3gqUDYOczB+yYvBTtEylYSdRhg== + +"@eslint/eslintrc@^1.3.1": + version "1.3.1" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-1.3.1.tgz#de0807bfeffc37b964a7d0400e0c348ce5a2543d" + integrity sha512-OhSY22oQQdw3zgPOOwdoj01l/Dzl1Z+xyUP33tkSN+aqyEhymJCcPHyXt+ylW8FSe0TfRC2VG+ROQOapD0aZSQ== + dependencies: + ajv "^6.12.4" + debug "^4.3.2" + espree "^9.4.0" + globals "^13.15.0" + ignore "^5.2.0" + import-fresh "^3.2.1" + js-yaml "^4.1.0" + minimatch "^3.1.2" + strip-json-comments "^3.1.1" + +"@humanwhocodes/config-array@^0.10.4": + version "0.10.4" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.10.4.tgz#01e7366e57d2ad104feea63e72248f22015c520c" + integrity sha512-mXAIHxZT3Vcpg83opl1wGlVZ9xydbfZO3r5YfRSH6Gpp2J/PfdBP0wbDa2sO6/qRbcalpoevVyW6A/fI6LfeMw== + dependencies: + "@humanwhocodes/object-schema" "^1.2.1" + debug "^4.1.1" + minimatch "^3.0.4" + +"@humanwhocodes/gitignore-to-minimatch@^1.0.2": + version "1.0.2" + resolved "https://registry.yarnpkg.com/@humanwhocodes/gitignore-to-minimatch/-/gitignore-to-minimatch-1.0.2.tgz#316b0a63b91c10e53f242efb4ace5c3b34e8728d" + integrity sha512-rSqmMJDdLFUsyxR6FMtD00nfQKKLFb1kv+qBbOVKqErvloEIJLo5bDTJTQNTYgeyp78JsA7u/NPi5jT1GR/MuA== + +"@humanwhocodes/module-importer@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c" + integrity sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA== + +"@humanwhocodes/object-schema@^1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz#b520529ec21d8e5945a1851dfd1c32e94e39ff45" + integrity sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA== + +"@motionone/animation@^10.13.1": + version "10.14.0" + resolved "https://registry.yarnpkg.com/@motionone/animation/-/animation-10.14.0.tgz#2f2a3517183bb58d82e389aac777fe0850079de6" + integrity sha512-h+1sdyBP8vbxEBW5gPFDnj+m2DCqdlAuf2g6Iafb1lcMnqjsRXWlPw1AXgvUMXmreyhqmPbJqoNfIKdytampRQ== + dependencies: + "@motionone/easing" "^10.14.0" + "@motionone/types" "^10.14.0" + "@motionone/utils" "^10.14.0" + tslib "^2.3.1" + +"@motionone/dom@10.13.1": + version "10.13.1" + resolved "https://registry.yarnpkg.com/@motionone/dom/-/dom-10.13.1.tgz#fc29ea5d12538f21b211b3168e502cfc07a24882" + integrity sha512-zjfX+AGMIt/fIqd/SL1Lj93S6AiJsEA3oc5M9VkUr+Gz+juRmYN1vfvZd6MvEkSqEjwPQgcjN7rGZHrDB9APfQ== + dependencies: + "@motionone/animation" "^10.13.1" + "@motionone/generators" "^10.13.1" + "@motionone/types" "^10.13.0" + "@motionone/utils" "^10.13.1" + hey-listen "^1.0.8" + tslib "^2.3.1" + +"@motionone/easing@^10.14.0": + version "10.14.0" + resolved "https://registry.yarnpkg.com/@motionone/easing/-/easing-10.14.0.tgz#d8154b7f71491414f3cdee23bd3838d763fffd00" + integrity sha512-2vUBdH9uWTlRbuErhcsMmt1jvMTTqvGmn9fHq8FleFDXBlHFs5jZzHJT9iw+4kR1h6a4SZQuCf72b9ji92qNYA== + dependencies: + "@motionone/utils" "^10.14.0" + tslib "^2.3.1" + +"@motionone/generators@^10.13.1": + version "10.14.0" + resolved "https://registry.yarnpkg.com/@motionone/generators/-/generators-10.14.0.tgz#e05d9dd56da78a4b92db99185848a0f3db62242d" + integrity sha512-6kRHezoFfIjFN7pPpaxmkdZXD36tQNcyJe3nwVqwJ+ZfC0e3rFmszR8kp9DEVFs9QL/akWjuGPSLBI1tvz+Vjg== + dependencies: + "@motionone/types" "^10.14.0" + "@motionone/utils" "^10.14.0" + tslib "^2.3.1" + +"@motionone/types@^10.13.0", "@motionone/types@^10.14.0": + version "10.14.0" + resolved "https://registry.yarnpkg.com/@motionone/types/-/types-10.14.0.tgz#148c34f3270b175397e49c3058b33fab405c21e3" + integrity sha512-3bNWyYBHtVd27KncnJLhksMFQ5o2MSdk1cA/IZqsHtA9DnRM1SYgN01CTcJ8Iw8pCXF5Ocp34tyAjY7WRpOJJQ== + +"@motionone/utils@^10.13.1", "@motionone/utils@^10.14.0": + version "10.14.0" + resolved "https://registry.yarnpkg.com/@motionone/utils/-/utils-10.14.0.tgz#a19a3464ed35b08506747b062d035c7bc9bbe708" + integrity sha512-sLWBLPzRqkxmOTRzSaD3LFQXCPHvDzyHJ1a3VP9PRzBxyVd2pv51/gMOsdAcxQ9n+MIeGJnxzXBYplUHKj4jkw== + dependencies: + "@motionone/types" "^10.14.0" + hey-listen "^1.0.8" + tslib "^2.3.1" + +"@next/env@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/env/-/env-12.2.5.tgz#d908c57b35262b94db3e431e869b72ac3e1ad3e3" + integrity sha512-vLPLV3cpPGjUPT3PjgRj7e3nio9t6USkuew3JE/jMeon/9Mvp1WyR18v3iwnCuX7eUAm1HmAbJHHLAbcu/EJcw== + +"@next/eslint-plugin-next@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/eslint-plugin-next/-/eslint-plugin-next-12.2.5.tgz#4f3acccd2ed4f9300fbf9fd480cc8a0b261889a8" + integrity sha512-VBjVbmqEzGiOTBq4+wpeVXt/KgknnGB6ahvC/AxiIGnN93/RCSyXhFRI4uSfftM2Ba3w7ZO7076bfKasZsA0fw== + dependencies: + glob "7.1.7" + +"@next/swc-android-arm-eabi@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-android-arm-eabi/-/swc-android-arm-eabi-12.2.5.tgz#903a5479ab4c2705d9c08d080907475f7bacf94d" + integrity sha512-cPWClKxGhgn2dLWnspW+7psl3MoLQUcNqJqOHk2BhNcou9ARDtC0IjQkKe5qcn9qg7I7U83Gp1yh2aesZfZJMA== + +"@next/swc-android-arm64@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-android-arm64/-/swc-android-arm64-12.2.5.tgz#2f9a98ec4166c7860510963b31bda1f57a77c792" + integrity sha512-vMj0efliXmC5b7p+wfcQCX0AfU8IypjkzT64GiKJD9PgiA3IILNiGJr1fw2lyUDHkjeWx/5HMlMEpLnTsQslwg== + +"@next/swc-darwin-arm64@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-darwin-arm64/-/swc-darwin-arm64-12.2.5.tgz#31b1c3c659d54be546120c488a1e1bad21c24a1d" + integrity sha512-VOPWbO5EFr6snla/WcxUKtvzGVShfs302TEMOtzYyWni6f9zuOetijJvVh9CCTzInnXAZMtHyNhefijA4HMYLg== + +"@next/swc-darwin-x64@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-darwin-x64/-/swc-darwin-x64-12.2.5.tgz#2e44dd82b2b7fef88238d1bc4d3bead5884cedfd" + integrity sha512-5o8bTCgAmtYOgauO/Xd27vW52G2/m3i5PX7MUYePquxXAnX73AAtqA3WgPXBRitEB60plSKZgOTkcpqrsh546A== + +"@next/swc-freebsd-x64@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-freebsd-x64/-/swc-freebsd-x64-12.2.5.tgz#e24e75d8c2581bfebc75e4f08f6ddbd116ce9dbd" + integrity sha512-yYUbyup1JnznMtEBRkK4LT56N0lfK5qNTzr6/DEyDw5TbFVwnuy2hhLBzwCBkScFVjpFdfiC6SQAX3FrAZzuuw== + +"@next/swc-linux-arm-gnueabihf@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-linux-arm-gnueabihf/-/swc-linux-arm-gnueabihf-12.2.5.tgz#46d8c514d834d2b5f67086013f0bd5e3081e10b9" + integrity sha512-2ZE2/G921Acks7UopJZVMgKLdm4vN4U0yuzvAMJ6KBavPzqESA2yHJlm85TV/K9gIjKhSk5BVtauIUntFRP8cg== + +"@next/swc-linux-arm64-gnu@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-12.2.5.tgz#91f725ac217d3a1f4f9f53b553615ba582fd3d9f" + integrity sha512-/I6+PWVlz2wkTdWqhlSYYJ1pWWgUVva6SgX353oqTh8njNQp1SdFQuWDqk8LnM6ulheVfSsgkDzxrDaAQZnzjQ== + +"@next/swc-linux-arm64-musl@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-12.2.5.tgz#e627e8c867920995810250303cd9b8e963598383" + integrity sha512-LPQRelfX6asXyVr59p5sTpx5l+0yh2Vjp/R8Wi4X9pnqcayqT4CUJLiHqCvZuLin3IsFdisJL0rKHMoaZLRfmg== + +"@next/swc-linux-x64-gnu@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-12.2.5.tgz#83a5e224fbc4d119ef2e0f29d0d79c40cc43887e" + integrity sha512-0szyAo8jMCClkjNK0hknjhmAngUppoRekW6OAezbEYwHXN/VNtsXbfzgYOqjKWxEx3OoAzrT3jLwAF0HdX2MEw== + +"@next/swc-linux-x64-musl@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-12.2.5.tgz#be700d48471baac1ec2e9539396625584a317e95" + integrity sha512-zg/Y6oBar1yVnW6Il1I/08/2ukWtOG6s3acdJdEyIdsCzyQi4RLxbbhkD/EGQyhqBvd3QrC6ZXQEXighQUAZ0g== + +"@next/swc-win32-arm64-msvc@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-12.2.5.tgz#a93e958133ad3310373fda33a79aa10af2a0aa97" + integrity sha512-3/90DRNSqeeSRMMEhj4gHHQlLhhKg5SCCoYfE3kBjGpE63EfnblYUqsszGGZ9ekpKL/R4/SGB40iCQr8tR5Jiw== + +"@next/swc-win32-ia32-msvc@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-12.2.5.tgz#4f5f7ba0a98ff89a883625d4af0125baed8b2e19" + integrity sha512-hGLc0ZRAwnaPL4ulwpp4D2RxmkHQLuI8CFOEEHdzZpS63/hMVzv81g8jzYA0UXbb9pus/iTc3VRbVbAM03SRrw== + +"@next/swc-win32-x64-msvc@12.2.5": + version "12.2.5" + resolved "https://registry.yarnpkg.com/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-12.2.5.tgz#20fed129b04a0d3f632c6d0de135345bb623b1e4" + integrity sha512-7h5/ahY7NeaO2xygqVrSG/Y8Vs4cdjxIjowTZ5W6CKoTKn7tmnuxlUc2h74x06FKmbhAd9agOjr/AOKyxYYm9Q== + +"@nodelib/fs.scandir@2.1.5": + version "2.1.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" + integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== + dependencies: + "@nodelib/fs.stat" "2.0.5" + run-parallel "^1.1.9" + +"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": + version "2.0.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" + integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== + +"@nodelib/fs.walk@^1.2.3": + version "1.2.8" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" + integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== + dependencies: + "@nodelib/fs.scandir" "2.1.5" + fastq "^1.6.0" + +"@popperjs/core@^2.9.3": + version "2.11.6" + resolved "https://registry.yarnpkg.com/@popperjs/core/-/core-2.11.6.tgz#cee20bd55e68a1720bdab363ecf0c821ded4cd45" + integrity sha512-50/17A98tWUfQ176raKiOGXuYpLyyVMkxxG6oylzL3BPOlA6ADGdK7EYunSa4I064xerltq9TGXs8HmOk5E+vw== + +"@rushstack/eslint-patch@^1.1.3": + version "1.1.4" + resolved "https://registry.yarnpkg.com/@rushstack/eslint-patch/-/eslint-patch-1.1.4.tgz#0c8b74c50f29ee44f423f7416829c0bf8bb5eb27" + integrity sha512-LwzQKA4vzIct1zNZzBmRKI9QuNpLgTQMEjsQLf3BXuGYb3QPTP4Yjf6mkdX+X1mYttZ808QpOwAzZjv28kq7DA== + +"@swc/helpers@0.4.3": + version "0.4.3" + resolved "https://registry.yarnpkg.com/@swc/helpers/-/helpers-0.4.3.tgz#16593dfc248c53b699d4b5026040f88ddb497012" + integrity sha512-6JrF+fdUK2zbGpJIlN7G3v966PQjyx/dPt1T9km2wj+EUBqgrxCk3uX4Kct16MIm9gGxfKRcfax2hVf5jvlTzA== + dependencies: + tslib "^2.4.0" + +"@types/json5@^0.0.29": + version "0.0.29" + resolved "https://registry.yarnpkg.com/@types/json5/-/json5-0.0.29.tgz#ee28707ae94e11d2b827bcbe5270bcea7f3e71ee" + integrity sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ== + +"@types/lodash.mergewith@4.6.6": + version "4.6.6" + resolved "https://registry.yarnpkg.com/@types/lodash.mergewith/-/lodash.mergewith-4.6.6.tgz#c4698f5b214a433ff35cb2c75ee6ec7f99d79f10" + integrity sha512-RY/8IaVENjG19rxTZu9Nukqh0W2UrYgmBj5sdns4hWRZaV8PqR7wIKHFKzvOTjo4zVRV7sVI+yFhAJql12Kfqg== + dependencies: + "@types/lodash" "*" + +"@types/lodash@*": + version "4.14.184" + resolved "https://registry.yarnpkg.com/@types/lodash/-/lodash-4.14.184.tgz#23f96cd2a21a28e106dc24d825d4aa966de7a9fe" + integrity sha512-RoZphVtHbxPZizt4IcILciSWiC6dcn+eZ8oX9IWEYfDMcocdd42f7NPI6fQj+6zI8y4E0L7gu2pcZKLGTRaV9Q== + +"@types/node@18.7.16": + version "18.7.16" + resolved "https://registry.yarnpkg.com/@types/node/-/node-18.7.16.tgz#0eb3cce1e37c79619943d2fd903919fc30850601" + integrity sha512-EQHhixfu+mkqHMZl1R2Ovuvn47PUw18azMJOTwSZr9/fhzHNGXAJ0ma0dayRVchprpCj0Kc1K1xKoWaATWF1qg== + +"@types/parse-json@^4.0.0": + version "4.0.0" + resolved "https://registry.yarnpkg.com/@types/parse-json/-/parse-json-4.0.0.tgz#2f8bb441434d163b35fb8ffdccd7138927ffb8c0" + integrity sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA== + +"@types/prop-types@*": + version "15.7.5" + resolved "https://registry.yarnpkg.com/@types/prop-types/-/prop-types-15.7.5.tgz#5f19d2b85a98e9558036f6a3cacc8819420f05cf" + integrity sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w== + +"@types/react-dom@18.0.6": + version "18.0.6" + resolved "https://registry.yarnpkg.com/@types/react-dom/-/react-dom-18.0.6.tgz#36652900024842b74607a17786b6662dd1e103a1" + integrity sha512-/5OFZgfIPSwy+YuIBP/FgJnQnsxhZhjjrnxudMddeblOouIodEQ75X14Rr4wGSG/bknL+Omy9iWlLo1u/9GzAA== + dependencies: + "@types/react" "*" + +"@types/react@*", "@types/react@18.0.18": + version "18.0.18" + resolved "https://registry.yarnpkg.com/@types/react/-/react-18.0.18.tgz#9f16f33d57bc5d9dca848d12c3572110ff9429ac" + integrity sha512-6hI08umYs6NaiHFEEGioXnxJ+oEhY3eRz8VCUaudZmGdtvPviCJB8mgaMxaDWAdPSYd4eFavrPk2QIolwbLYrg== + dependencies: + "@types/prop-types" "*" + "@types/scheduler" "*" + csstype "^3.0.2" + +"@types/scheduler@*": + version "0.16.2" + resolved "https://registry.yarnpkg.com/@types/scheduler/-/scheduler-0.16.2.tgz#1a62f89525723dde24ba1b01b092bf5df8ad4d39" + integrity sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew== + +"@typescript-eslint/parser@^5.21.0": + version "5.36.2" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-5.36.2.tgz#3ddf323d3ac85a25295a55fcb9c7a49ab4680ddd" + integrity sha512-qS/Kb0yzy8sR0idFspI9Z6+t7mqk/oRjnAYfewG+VN73opAUvmYL3oPIMmgOX6CnQS6gmVIXGshlb5RY/R22pA== + dependencies: + "@typescript-eslint/scope-manager" "5.36.2" + "@typescript-eslint/types" "5.36.2" + "@typescript-eslint/typescript-estree" "5.36.2" + debug "^4.3.4" + +"@typescript-eslint/scope-manager@5.36.2": + version "5.36.2" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-5.36.2.tgz#a75eb588a3879ae659514780831370642505d1cd" + integrity sha512-cNNP51L8SkIFSfce8B1NSUBTJTu2Ts4nWeWbFrdaqjmn9yKrAaJUBHkyTZc0cL06OFHpb+JZq5AUHROS398Orw== + dependencies: + "@typescript-eslint/types" "5.36.2" + "@typescript-eslint/visitor-keys" "5.36.2" + +"@typescript-eslint/types@5.36.2": + version "5.36.2" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-5.36.2.tgz#a5066e500ebcfcee36694186ccc57b955c05faf9" + integrity sha512-9OJSvvwuF1L5eS2EQgFUbECb99F0mwq501w0H0EkYULkhFa19Qq7WFbycdw1PexAc929asupbZcgjVIe6OK/XQ== + +"@typescript-eslint/typescript-estree@5.36.2": + version "5.36.2" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-5.36.2.tgz#0c93418b36c53ba0bc34c61fe9405c4d1d8fe560" + integrity sha512-8fyH+RfbKc0mTspfuEjlfqA4YywcwQK2Amcf6TDOwaRLg7Vwdu4bZzyvBZp4bjt1RRjQ5MDnOZahxMrt2l5v9w== + dependencies: + "@typescript-eslint/types" "5.36.2" + "@typescript-eslint/visitor-keys" "5.36.2" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + semver "^7.3.7" + tsutils "^3.21.0" + +"@typescript-eslint/visitor-keys@5.36.2": + version "5.36.2" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-5.36.2.tgz#2f8f78da0a3bad3320d2ac24965791ac39dace5a" + integrity sha512-BtRvSR6dEdrNt7Net2/XDjbYKU5Ml6GqJgVfXT0CxTCJlnIqK7rAGreuWKMT2t8cFUT2Msv5oxw0GMRD7T5J7A== + dependencies: + "@typescript-eslint/types" "5.36.2" + eslint-visitor-keys "^3.3.0" + +"@zag-js/element-size@0.1.0": + version "0.1.0" + resolved "https://registry.yarnpkg.com/@zag-js/element-size/-/element-size-0.1.0.tgz#dfdb3f66a70328d0c3149aae29b8f99c10590c22" + integrity sha512-QF8wp0+V8++z+FHXiIw93+zudtubYszOtYbNgK39fg3pi+nCZtuSm4L1jC5QZMatNZ83MfOzyNCfgUubapagJQ== + +"@zag-js/focus-visible@0.1.0": + version "0.1.0" + resolved "https://registry.yarnpkg.com/@zag-js/focus-visible/-/focus-visible-0.1.0.tgz#9777bbaff8316d0b3a14a9095631e1494f69dbc7" + integrity sha512-PeaBcTmdZWcFf7n1aM+oiOdZc+sy14qi0emPIeUuGMTjbP0xLGrZu43kdpHnWSXy7/r4Ubp/vlg50MCV8+9Isg== + +acorn-jsx@^5.3.2: + version "5.3.2" + resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" + integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== + +acorn@^8.8.0: + version "8.8.0" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.8.0.tgz#88c0187620435c7f6015803f5539dae05a9dbea8" + integrity sha512-QOxyigPVrpZ2GXT+PFyZTl6TtOFc5egxHIP9IlQ+RbupQuX4RkT/Bee4/kQuC02Xkzg84JcT7oLYtDIQxp+v7w== + +ajv@^6.10.0, ajv@^6.12.4: + version "6.12.6" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" + integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== + dependencies: + fast-deep-equal "^3.1.1" + fast-json-stable-stringify "^2.0.0" + json-schema-traverse "^0.4.1" + uri-js "^4.2.2" + +ansi-regex@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" + integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== + +ansi-styles@^3.2.1: + version "3.2.1" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" + integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== + dependencies: + color-convert "^1.9.0" + +ansi-styles@^4.1.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" + integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== + dependencies: + color-convert "^2.0.1" + +argparse@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" + integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== + +aria-hidden@^1.1.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/aria-hidden/-/aria-hidden-1.2.1.tgz#ad8c1edbde360b454eb2bf717ea02da00bfee0f8" + integrity sha512-PN344VAf9j1EAi+jyVHOJ8XidQdPVssGco39eNcsGdM4wcsILtxrKLkbuiMfLWYROK1FjRQasMWCBttrhjnr6A== + dependencies: + tslib "^2.0.0" + +aria-query@^4.2.2: + version "4.2.2" + resolved "https://registry.yarnpkg.com/aria-query/-/aria-query-4.2.2.tgz#0d2ca6c9aceb56b8977e9fed6aed7e15bbd2f83b" + integrity sha512-o/HelwhuKpTj/frsOsbNLNgnNGVIFsVP/SW2BSF14gVl7kAfMOJ6/8wUAUvG1R1NHKrfG+2sHZTu0yauT1qBrA== + dependencies: + "@babel/runtime" "^7.10.2" + "@babel/runtime-corejs3" "^7.10.2" + +array-includes@^3.1.4, array-includes@^3.1.5: + version "3.1.5" + resolved "https://registry.yarnpkg.com/array-includes/-/array-includes-3.1.5.tgz#2c320010db8d31031fd2a5f6b3bbd4b1aad31bdb" + integrity sha512-iSDYZMMyTPkiFasVqfuAQnWAYcvO/SeBSCGKePoEthjp4LEMTe4uLc7b025o4jAZpHhihh8xPo99TNWUWWkGDQ== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + es-abstract "^1.19.5" + get-intrinsic "^1.1.1" + is-string "^1.0.7" + +array-union@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" + integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== + +array.prototype.flat@^1.2.5: + version "1.3.0" + resolved "https://registry.yarnpkg.com/array.prototype.flat/-/array.prototype.flat-1.3.0.tgz#0b0c1567bf57b38b56b4c97b8aa72ab45e4adc7b" + integrity sha512-12IUEkHsAhA4DY5s0FPgNXIdc8VRSqD9Zp78a5au9abH/SOBrsp082JOWFNTjkMozh8mqcdiKuaLGhPeYztxSw== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.2" + es-shim-unscopables "^1.0.0" + +array.prototype.flatmap@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/array.prototype.flatmap/-/array.prototype.flatmap-1.3.0.tgz#a7e8ed4225f4788a70cd910abcf0791e76a5534f" + integrity sha512-PZC9/8TKAIxcWKdyeb77EzULHPrIX/tIZebLJUQOMR1OwYosT8yggdfWScfTBCDj5utONvOuPQQumYsU2ULbkg== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.2" + es-shim-unscopables "^1.0.0" + +ast-types-flow@^0.0.7: + version "0.0.7" + resolved "https://registry.yarnpkg.com/ast-types-flow/-/ast-types-flow-0.0.7.tgz#f70b735c6bca1a5c9c22d982c3e39e7feba3bdad" + integrity sha512-eBvWn1lvIApYMhzQMsu9ciLfkBY499mFZlNqG+/9WR7PVlroQw0vG30cOQQbaKz3sCEc44TAOu2ykzqXSNnwag== + +axe-core@^4.4.3: + version "4.4.3" + resolved "https://registry.yarnpkg.com/axe-core/-/axe-core-4.4.3.tgz#11c74d23d5013c0fa5d183796729bc3482bd2f6f" + integrity sha512-32+ub6kkdhhWick/UjvEwRchgoetXqTK14INLqbGm5U2TzBkBNF3nQtLYm8ovxSkQWArjEQvftCKryjZaATu3w== + +axobject-query@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/axobject-query/-/axobject-query-2.2.0.tgz#943d47e10c0b704aa42275e20edf3722648989be" + integrity sha512-Td525n+iPOOyUQIeBfcASuG6uJsDOITl7Mds5gFyerkWiX7qhUTdYUBlSgNMyVqtSJqwpt1kXGLdUt6SykLMRA== + +babel-plugin-macros@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/babel-plugin-macros/-/babel-plugin-macros-3.1.0.tgz#9ef6dc74deb934b4db344dc973ee851d148c50c1" + integrity sha512-Cg7TFGpIr01vOQNODXOOaGz2NpCU5gl8x1qJFbb6hbZxR7XrcE2vtbAsTAbJ7/xwJtUuJEw8K8Zr/AE0LHlesg== + dependencies: + "@babel/runtime" "^7.12.5" + cosmiconfig "^7.0.0" + resolve "^1.19.0" + +balanced-match@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" + integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== + +brace-expansion@^1.1.7: + version "1.1.11" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" + integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== + dependencies: + balanced-match "^1.0.0" + concat-map "0.0.1" + +braces@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" + integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== + dependencies: + fill-range "^7.0.1" + +call-bind@^1.0.0, call-bind@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" + integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== + dependencies: + function-bind "^1.1.1" + get-intrinsic "^1.0.2" + +callsites@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" + integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== + +caniuse-lite@^1.0.30001332: + version "1.0.30001393" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001393.tgz#1aa161e24fe6af2e2ccda000fc2b94be0b0db356" + integrity sha512-N/od11RX+Gsk+1qY/jbPa0R6zJupEa0lxeBG598EbrtblxVCTJsQwbRBm6+V+rxpc5lHKdsXb9RY83cZIPLseA== + +chalk@^2.0.0: + version "2.4.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" + integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== + dependencies: + ansi-styles "^3.2.1" + escape-string-regexp "^1.0.5" + supports-color "^5.3.0" + +chalk@^4.0.0: + version "4.1.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" + integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + +color-convert@^1.9.0: + version "1.9.3" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" + integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== + dependencies: + color-name "1.1.3" + +color-convert@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" + integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== + dependencies: + color-name "~1.1.4" + +color-name@1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" + integrity sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw== + +color-name@~1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" + integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== + +compute-scroll-into-view@1.0.14: + version "1.0.14" + resolved "https://registry.yarnpkg.com/compute-scroll-into-view/-/compute-scroll-into-view-1.0.14.tgz#80e3ebb25d6aa89f42e533956cb4b16a04cfe759" + integrity sha512-mKDjINe3tc6hGelUMNDzuhorIUZ7kS7BwyY0r2wQd2HOH2tRuJykiC06iSEX8y1TuhNzvz4GcJnK16mM2J1NMQ== + +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== + +convert-source-map@^1.5.0: + version "1.8.0" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.8.0.tgz#f3373c32d21b4d780dd8004514684fb791ca4369" + integrity sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA== + dependencies: + safe-buffer "~5.1.1" + +copy-to-clipboard@3.3.1: + version "3.3.1" + resolved "https://registry.yarnpkg.com/copy-to-clipboard/-/copy-to-clipboard-3.3.1.tgz#115aa1a9998ffab6196f93076ad6da3b913662ae" + integrity sha512-i13qo6kIHTTpCm8/Wup+0b1mVWETvu2kIMzKoK8FpkLkFxlt0znUAHcMzox+T8sPlqtZXq3CulEjQHsYiGFJUw== + dependencies: + toggle-selection "^1.0.6" + +core-js-pure@^3.20.2: + version "3.25.1" + resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.25.1.tgz#79546518ae87cc362c991d9c2d211f45107991ee" + integrity sha512-7Fr74bliUDdeJCBMxkkIuQ4xfxn/SwrVg+HkJUAoNEXVqYLv55l6Af0dJ5Lq2YBUW9yKqSkLXaS5SYPK6MGa/A== + +cosmiconfig@^7.0.0: + version "7.0.1" + resolved "https://registry.yarnpkg.com/cosmiconfig/-/cosmiconfig-7.0.1.tgz#714d756522cace867867ccb4474c5d01bbae5d6d" + integrity sha512-a1YWNUV2HwGimB7dU2s1wUMurNKjpx60HxBB6xUM8Re+2s1g1IIfJvFR0/iCF+XHdE0GMTKTuLR32UQff4TEyQ== + dependencies: + "@types/parse-json" "^4.0.0" + import-fresh "^3.2.1" + parse-json "^5.0.0" + path-type "^4.0.0" + yaml "^1.10.0" + +cross-spawn@^7.0.2: + version "7.0.3" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + +css-box-model@1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/css-box-model/-/css-box-model-1.2.1.tgz#59951d3b81fd6b2074a62d49444415b0d2b4d7c1" + integrity sha512-a7Vr4Q/kd/aw96bnJG332W9V9LkJO69JRcaCYDUqjp6/z0w6VcZjgAcTbgFxEPfBgdnAwlh3iwu+hLopa+flJw== + dependencies: + tiny-invariant "^1.0.6" + +csstype@^3.0.11, csstype@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/csstype/-/csstype-3.1.0.tgz#4ddcac3718d787cf9df0d1b7d15033925c8f29f2" + integrity sha512-uX1KG+x9h5hIJsaKR9xHUeUraxf8IODOwq9JLNPq6BwB04a/xgpq3rcx47l5BZu5zBPlgD342tdke3Hom/nJRA== + +damerau-levenshtein@^1.0.8: + version "1.0.8" + resolved "https://registry.yarnpkg.com/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz#b43d286ccbd36bc5b2f7ed41caf2d0aba1f8a6e7" + integrity sha512-sdQSFB7+llfUcQHUQO3+B8ERRj0Oa4w9POWMI/puGtuf7gFywGmkaLCElnudfTiKZV+NvHqL0ifzdrI8Ro7ESA== + +debug@^2.6.9: + version "2.6.9" + resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" + integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== + dependencies: + ms "2.0.0" + +debug@^3.2.7: + version "3.2.7" + resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.7.tgz#72580b7e9145fb39b6676f9c5e5fb100b934179a" + integrity sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ== + dependencies: + ms "^2.1.1" + +debug@^4.1.1, debug@^4.3.2, debug@^4.3.4: + version "4.3.4" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" + integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== + dependencies: + ms "2.1.2" + +deep-is@^0.1.3: + version "0.1.4" + resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831" + integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== + +define-properties@^1.1.3, define-properties@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/define-properties/-/define-properties-1.1.4.tgz#0b14d7bd7fbeb2f3572c3a7eda80ea5d57fb05b1" + integrity sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA== + dependencies: + has-property-descriptors "^1.0.0" + object-keys "^1.1.1" + +detect-node-es@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/detect-node-es/-/detect-node-es-1.1.0.tgz#163acdf643330caa0b4cd7c21e7ee7755d6fa493" + integrity sha512-ypdmJU/TbBby2Dxibuv7ZLW3Bs1QEmM7nHjEANfohJLvE0XVujisn1qPJcZxg+qDucsr+bP6fLD1rPS3AhJ7EQ== + +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + +doctrine@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-2.1.0.tgz#5cd01fc101621b42c4cd7f5d1a66243716d3f39d" + integrity sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw== + dependencies: + esutils "^2.0.2" + +doctrine@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" + integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== + dependencies: + esutils "^2.0.2" + +emoji-regex@^9.2.2: + version "9.2.2" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-9.2.2.tgz#840c8803b0d8047f4ff0cf963176b32d4ef3ed72" + integrity sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg== + +error-ex@^1.3.1: + version "1.3.2" + resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf" + integrity sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g== + dependencies: + is-arrayish "^0.2.1" + +es-abstract@^1.19.0, es-abstract@^1.19.1, es-abstract@^1.19.2, es-abstract@^1.19.5: + version "1.20.2" + resolved "https://registry.yarnpkg.com/es-abstract/-/es-abstract-1.20.2.tgz#8495a07bc56d342a3b8ea3ab01bd986700c2ccb3" + integrity sha512-XxXQuVNrySBNlEkTYJoDNFe5+s2yIOpzq80sUHEdPdQr0S5nTLz4ZPPPswNIpKseDDUS5yghX1gfLIHQZ1iNuQ== + dependencies: + call-bind "^1.0.2" + es-to-primitive "^1.2.1" + function-bind "^1.1.1" + function.prototype.name "^1.1.5" + get-intrinsic "^1.1.2" + get-symbol-description "^1.0.0" + has "^1.0.3" + has-property-descriptors "^1.0.0" + has-symbols "^1.0.3" + internal-slot "^1.0.3" + is-callable "^1.2.4" + is-negative-zero "^2.0.2" + is-regex "^1.1.4" + is-shared-array-buffer "^1.0.2" + is-string "^1.0.7" + is-weakref "^1.0.2" + object-inspect "^1.12.2" + object-keys "^1.1.1" + object.assign "^4.1.4" + regexp.prototype.flags "^1.4.3" + string.prototype.trimend "^1.0.5" + string.prototype.trimstart "^1.0.5" + unbox-primitive "^1.0.2" + +es-shim-unscopables@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz#702e632193201e3edf8713635d083d378e510241" + integrity sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w== + dependencies: + has "^1.0.3" + +es-to-primitive@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/es-to-primitive/-/es-to-primitive-1.2.1.tgz#e55cd4c9cdc188bcefb03b366c736323fc5c898a" + integrity sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA== + dependencies: + is-callable "^1.1.4" + is-date-object "^1.0.1" + is-symbol "^1.0.2" + +escape-string-regexp@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" + integrity sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg== + +escape-string-regexp@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== + +eslint-config-next@12.2.5: + version "12.2.5" + resolved "https://registry.yarnpkg.com/eslint-config-next/-/eslint-config-next-12.2.5.tgz#76ce83f18cc02f6f42ed407a127f83db54fabd3c" + integrity sha512-SOowilkqPzW6DxKp3a3SYlrfPi5Ajs9MIzp9gVfUDxxH9QFM5ElkR1hX5m/iICJuvCbWgQqFBiA3mCMozluniw== + dependencies: + "@next/eslint-plugin-next" "12.2.5" + "@rushstack/eslint-patch" "^1.1.3" + "@typescript-eslint/parser" "^5.21.0" + eslint-import-resolver-node "^0.3.6" + eslint-import-resolver-typescript "^2.7.1" + eslint-plugin-import "^2.26.0" + eslint-plugin-jsx-a11y "^6.5.1" + eslint-plugin-react "^7.29.4" + eslint-plugin-react-hooks "^4.5.0" + +eslint-import-resolver-node@^0.3.6: + version "0.3.6" + resolved "https://registry.yarnpkg.com/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.6.tgz#4048b958395da89668252001dbd9eca6b83bacbd" + integrity sha512-0En0w03NRVMn9Uiyn8YRPDKvWjxCWkslUEhGNTdGx15RvPJYQ+lbOlqrlNI2vEAs4pDYK4f/HN2TbDmk5TP0iw== + dependencies: + debug "^3.2.7" + resolve "^1.20.0" + +eslint-import-resolver-typescript@^2.7.1: + version "2.7.1" + resolved "https://registry.yarnpkg.com/eslint-import-resolver-typescript/-/eslint-import-resolver-typescript-2.7.1.tgz#a90a4a1c80da8d632df25994c4c5fdcdd02b8751" + integrity sha512-00UbgGwV8bSgUv34igBDbTOtKhqoRMy9bFjNehT40bXg6585PNIct8HhXZ0SybqB9rWtXj9crcku8ndDn/gIqQ== + dependencies: + debug "^4.3.4" + glob "^7.2.0" + is-glob "^4.0.3" + resolve "^1.22.0" + tsconfig-paths "^3.14.1" + +eslint-module-utils@^2.7.3: + version "2.7.4" + resolved "https://registry.yarnpkg.com/eslint-module-utils/-/eslint-module-utils-2.7.4.tgz#4f3e41116aaf13a20792261e61d3a2e7e0583974" + integrity sha512-j4GT+rqzCoRKHwURX7pddtIPGySnX9Si/cgMI5ztrcqOPtk5dDEeZ34CQVPphnqkJytlc97Vuk05Um2mJ3gEQA== + dependencies: + debug "^3.2.7" + +eslint-plugin-import@^2.26.0: + version "2.26.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-import/-/eslint-plugin-import-2.26.0.tgz#f812dc47be4f2b72b478a021605a59fc6fe8b88b" + integrity sha512-hYfi3FXaM8WPLf4S1cikh/r4IxnO6zrhZbEGz2b660EJRbuxgpDS5gkCuYgGWg2xxh2rBuIr4Pvhve/7c31koA== + dependencies: + array-includes "^3.1.4" + array.prototype.flat "^1.2.5" + debug "^2.6.9" + doctrine "^2.1.0" + eslint-import-resolver-node "^0.3.6" + eslint-module-utils "^2.7.3" + has "^1.0.3" + is-core-module "^2.8.1" + is-glob "^4.0.3" + minimatch "^3.1.2" + object.values "^1.1.5" + resolve "^1.22.0" + tsconfig-paths "^3.14.1" + +eslint-plugin-jsx-a11y@^6.5.1: + version "6.6.1" + resolved "https://registry.yarnpkg.com/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.6.1.tgz#93736fc91b83fdc38cc8d115deedfc3091aef1ff" + integrity sha512-sXgFVNHiWffBq23uiS/JaP6eVR622DqwB4yTzKvGZGcPq6/yZ3WmOZfuBks/vHWo9GaFOqC2ZK4i6+C35knx7Q== + dependencies: + "@babel/runtime" "^7.18.9" + aria-query "^4.2.2" + array-includes "^3.1.5" + ast-types-flow "^0.0.7" + axe-core "^4.4.3" + axobject-query "^2.2.0" + damerau-levenshtein "^1.0.8" + emoji-regex "^9.2.2" + has "^1.0.3" + jsx-ast-utils "^3.3.2" + language-tags "^1.0.5" + minimatch "^3.1.2" + semver "^6.3.0" + +eslint-plugin-react-hooks@^4.5.0: + version "4.6.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz#4c3e697ad95b77e93f8646aaa1630c1ba607edd3" + integrity sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g== + +eslint-plugin-react@^7.29.4: + version "7.31.7" + resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.31.7.tgz#36fb1c611a7db5f757fce09cbbcc01682f8b0fbb" + integrity sha512-8NldBTeYp/kQoTV1uT0XF6HcmDqbgZ0lNPkN0wlRw8DJKXEnaWu+oh/6gt3xIhzvQ35wB2Y545fJhIbJSZ2NNw== + dependencies: + array-includes "^3.1.5" + array.prototype.flatmap "^1.3.0" + doctrine "^2.1.0" + estraverse "^5.3.0" + jsx-ast-utils "^2.4.1 || ^3.0.0" + minimatch "^3.1.2" + object.entries "^1.1.5" + object.fromentries "^2.0.5" + object.hasown "^1.1.1" + object.values "^1.1.5" + prop-types "^15.8.1" + resolve "^2.0.0-next.3" + semver "^6.3.0" + string.prototype.matchall "^4.0.7" + +eslint-scope@^7.1.1: + version "7.1.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-7.1.1.tgz#fff34894c2f65e5226d3041ac480b4513a163642" + integrity sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw== + dependencies: + esrecurse "^4.3.0" + estraverse "^5.2.0" + +eslint-utils@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-3.0.0.tgz#8aebaface7345bb33559db0a1f13a1d2d48c3672" + integrity sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA== + dependencies: + eslint-visitor-keys "^2.0.0" + +eslint-visitor-keys@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz#f65328259305927392c938ed44eb0a5c9b2bd303" + integrity sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw== + +eslint-visitor-keys@^3.3.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz#f6480fa6b1f30efe2d1968aa8ac745b862469826" + integrity sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA== + +eslint@8.23.0: + version "8.23.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.23.0.tgz#a184918d288820179c6041bb3ddcc99ce6eea040" + integrity sha512-pBG/XOn0MsJcKcTRLr27S5HpzQo4kLr+HjLQIyK4EiCsijDl/TB+h5uEuJU6bQ8Edvwz1XWOjpaP2qgnXGpTcA== + dependencies: + "@eslint/eslintrc" "^1.3.1" + "@humanwhocodes/config-array" "^0.10.4" + "@humanwhocodes/gitignore-to-minimatch" "^1.0.2" + "@humanwhocodes/module-importer" "^1.0.1" + ajv "^6.10.0" + chalk "^4.0.0" + cross-spawn "^7.0.2" + debug "^4.3.2" + doctrine "^3.0.0" + escape-string-regexp "^4.0.0" + eslint-scope "^7.1.1" + eslint-utils "^3.0.0" + eslint-visitor-keys "^3.3.0" + espree "^9.4.0" + esquery "^1.4.0" + esutils "^2.0.2" + fast-deep-equal "^3.1.3" + file-entry-cache "^6.0.1" + find-up "^5.0.0" + functional-red-black-tree "^1.0.1" + glob-parent "^6.0.1" + globals "^13.15.0" + globby "^11.1.0" + grapheme-splitter "^1.0.4" + ignore "^5.2.0" + import-fresh "^3.0.0" + imurmurhash "^0.1.4" + is-glob "^4.0.0" + js-yaml "^4.1.0" + json-stable-stringify-without-jsonify "^1.0.1" + levn "^0.4.1" + lodash.merge "^4.6.2" + minimatch "^3.1.2" + natural-compare "^1.4.0" + optionator "^0.9.1" + regexpp "^3.2.0" + strip-ansi "^6.0.1" + strip-json-comments "^3.1.0" + text-table "^0.2.0" + +espree@^9.4.0: + version "9.4.0" + resolved "https://registry.yarnpkg.com/espree/-/espree-9.4.0.tgz#cd4bc3d6e9336c433265fc0aa016fc1aaf182f8a" + integrity sha512-DQmnRpLj7f6TgN/NYb0MTzJXL+vJF9h3pHy4JhCIs3zwcgez8xmGg3sXHcEO97BrmO2OSvCwMdfdlyl+E9KjOw== + dependencies: + acorn "^8.8.0" + acorn-jsx "^5.3.2" + eslint-visitor-keys "^3.3.0" + +esquery@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.4.0.tgz#2148ffc38b82e8c7057dfed48425b3e61f0f24a5" + integrity sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w== + dependencies: + estraverse "^5.1.0" + +esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^5.1.0, estraverse@^5.2.0, estraverse@^5.3.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + +fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525" + integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== + +fast-glob@^3.2.9: + version "3.2.11" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.2.11.tgz#a1172ad95ceb8a16e20caa5c5e56480e5129c1d9" + integrity sha512-xrO3+1bxSo3ZVHAnqzyuewYT6aMFHRAd4Kcs92MAonjwQZLsK9d0SF1IyQ3k5PoirxTW0Oe/RqFgMQ6TcNE5Ew== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.2" + merge2 "^1.3.0" + micromatch "^4.0.4" + +fast-json-stable-stringify@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" + integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== + +fast-levenshtein@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" + integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== + +fastq@^1.6.0: + version "1.13.0" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.13.0.tgz#616760f88a7526bdfc596b7cab8c18938c36b98c" + integrity sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw== + dependencies: + reusify "^1.0.4" + +file-entry-cache@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" + integrity sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg== + dependencies: + flat-cache "^3.0.4" + +fill-range@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" + integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== + dependencies: + to-regex-range "^5.0.1" + +find-root@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/find-root/-/find-root-1.1.0.tgz#abcfc8ba76f708c42a97b3d685b7e9450bfb9ce4" + integrity sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng== + +find-up@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" + integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== + dependencies: + locate-path "^6.0.0" + path-exists "^4.0.0" + +flat-cache@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.0.4.tgz#61b0338302b2fe9f957dcc32fc2a87f1c3048b11" + integrity sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg== + dependencies: + flatted "^3.1.0" + rimraf "^3.0.2" + +flatted@^3.1.0: + version "3.2.7" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.2.7.tgz#609f39207cb614b89d0765b477cb2d437fbf9787" + integrity sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ== + +focus-lock@^0.11.2: + version "0.11.2" + resolved "https://registry.yarnpkg.com/focus-lock/-/focus-lock-0.11.2.tgz#aeef3caf1cea757797ac8afdebaec8fd9ab243ed" + integrity sha512-pZ2bO++NWLHhiKkgP1bEXHhR1/OjVcSvlCJ98aNJDFeb7H5OOQaO+SKOZle6041O9rv2tmbrO4JzClAvDUHf0g== + dependencies: + tslib "^2.0.3" + +framer-motion@^7.3.2: + version "7.3.2" + resolved "https://registry.yarnpkg.com/framer-motion/-/framer-motion-7.3.2.tgz#9768092cd98cf0ebaf70864f1248f2e703305a15" + integrity sha512-BTG0BqJSwxoFBWpwaaxS/954DGZFsluF+dUv9Hfq53VNkwUt5g+wYTEM66oTUhiH/+6R/y0Rq+BmkUBcmzbyMQ== + dependencies: + "@motionone/dom" "10.13.1" + framesync "6.1.2" + hey-listen "^1.0.8" + popmotion "11.0.5" + style-value-types "5.1.2" + tslib "2.4.0" + optionalDependencies: + "@emotion/is-prop-valid" "^0.8.2" + +framesync@5.3.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/framesync/-/framesync-5.3.0.tgz#0ecfc955e8f5a6ddc8fdb0cc024070947e1a0d9b" + integrity sha512-oc5m68HDO/tuK2blj7ZcdEBRx3p1PjrgHazL8GYEpvULhrtGIFbQArN6cQS2QhW8mitffaB+VYzMjDqBxxQeoA== + dependencies: + tslib "^2.1.0" + +framesync@6.1.2: + version "6.1.2" + resolved "https://registry.yarnpkg.com/framesync/-/framesync-6.1.2.tgz#755eff2fb5b8f3b4d2b266dd18121b300aefea27" + integrity sha512-jBTqhX6KaQVDyus8muwZbBeGGP0XgujBRbQ7gM7BRdS3CadCZIHiawyzYLnafYcvZIh5j8WE7cxZKFn7dXhu9g== + dependencies: + tslib "2.4.0" + +fs.realpath@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" + integrity sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw== + +function-bind@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d" + integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A== + +function.prototype.name@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/function.prototype.name/-/function.prototype.name-1.1.5.tgz#cce0505fe1ffb80503e6f9e46cc64e46a12a9621" + integrity sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.0" + functions-have-names "^1.2.2" + +functional-red-black-tree@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" + integrity sha512-dsKNQNdj6xA3T+QlADDA7mOSlX0qiMINjn0cgr+eGHGsbSHzTabcIogz2+p/iqP1Xs6EP/sS2SbqH+brGTbq0g== + +functions-have-names@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/functions-have-names/-/functions-have-names-1.2.3.tgz#0404fe4ee2ba2f607f0e0ec3c80bae994133b834" + integrity sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ== + +get-intrinsic@^1.0.2, get-intrinsic@^1.1.0, get-intrinsic@^1.1.1, get-intrinsic@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.1.2.tgz#336975123e05ad0b7ba41f152ee4aadbea6cf598" + integrity sha512-Jfm3OyCxHh9DJyc28qGk+JmfkpO41A4XkneDSujN9MDXrm4oDKdHvndhZ2dN94+ERNfkYJWDclW6k2L/ZGHjXA== + dependencies: + function-bind "^1.1.1" + has "^1.0.3" + has-symbols "^1.0.3" + +get-nonce@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/get-nonce/-/get-nonce-1.0.1.tgz#fdf3f0278073820d2ce9426c18f07481b1e0cdf3" + integrity sha512-FJhYRoDaiatfEkUK8HKlicmu/3SGFD51q3itKDGoSTysQJBnfOcxU5GxnhE1E6soB76MbT0MBtnKJuXyAx+96Q== + +get-symbol-description@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/get-symbol-description/-/get-symbol-description-1.0.0.tgz#7fdb81c900101fbd564dd5f1a30af5aadc1e58d6" + integrity sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw== + dependencies: + call-bind "^1.0.2" + get-intrinsic "^1.1.1" + +glob-parent@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" + integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== + dependencies: + is-glob "^4.0.1" + +glob-parent@^6.0.1: + version "6.0.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== + dependencies: + is-glob "^4.0.3" + +glob@7.1.7: + version "7.1.7" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.7.tgz#3b193e9233f01d42d0b3f78294bbeeb418f94a90" + integrity sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.0.4" + once "^1.3.0" + path-is-absolute "^1.0.0" + +glob@^7.1.3, glob@^7.2.0: + version "7.2.3" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.3.tgz#b8df0fb802bbfa8e89bd1d938b4e16578ed44f2b" + integrity sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.1.1" + once "^1.3.0" + path-is-absolute "^1.0.0" + +globals@^13.15.0: + version "13.17.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-13.17.0.tgz#902eb1e680a41da93945adbdcb5a9f361ba69bd4" + integrity sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw== + dependencies: + type-fest "^0.20.2" + +globby@^11.1.0: + version "11.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" + integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.2.9" + ignore "^5.2.0" + merge2 "^1.4.1" + slash "^3.0.0" + +grapheme-splitter@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz#9cf3a665c6247479896834af35cf1dbb4400767e" + integrity sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ== + +has-bigints@^1.0.1, has-bigints@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/has-bigints/-/has-bigints-1.0.2.tgz#0871bd3e3d51626f6ca0966668ba35d5602d6eaa" + integrity sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ== + +has-flag@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" + integrity sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw== + +has-flag@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" + integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== + +has-property-descriptors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz#610708600606d36961ed04c196193b6a607fa861" + integrity sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ== + dependencies: + get-intrinsic "^1.1.1" + +has-symbols@^1.0.2, has-symbols@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" + integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== + +has-tostringtag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/has-tostringtag/-/has-tostringtag-1.0.0.tgz#7e133818a7d394734f941e73c3d3f9291e658b25" + integrity sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ== + dependencies: + has-symbols "^1.0.2" + +has@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" + integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw== + dependencies: + function-bind "^1.1.1" + +hey-listen@^1.0.8: + version "1.0.8" + resolved "https://registry.yarnpkg.com/hey-listen/-/hey-listen-1.0.8.tgz#8e59561ff724908de1aa924ed6ecc84a56a9aa68" + integrity sha512-COpmrF2NOg4TBWUJ5UVyaCU2A88wEMkUPK4hNqyCkqHbxT92BbvfjoSozkAIIm6XhicGlJHhFdullInrdhwU8Q== + +hoist-non-react-statics@^3.3.1: + version "3.3.2" + resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45" + integrity sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw== + dependencies: + react-is "^16.7.0" + +ignore@^5.2.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-5.2.0.tgz#6d3bac8fa7fe0d45d9f9be7bac2fc279577e345a" + integrity sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ== + +import-fresh@^3.0.0, import-fresh@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + +imurmurhash@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" + integrity sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA== + +inflight@^1.0.4: + version "1.0.6" + resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" + integrity sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA== + dependencies: + once "^1.3.0" + wrappy "1" + +inherits@2: + version "2.0.4" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + +internal-slot@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/internal-slot/-/internal-slot-1.0.3.tgz#7347e307deeea2faac2ac6205d4bc7d34967f59c" + integrity sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA== + dependencies: + get-intrinsic "^1.1.0" + has "^1.0.3" + side-channel "^1.0.4" + +invariant@^2.2.4: + version "2.2.4" + resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.4.tgz#610f3c92c9359ce1db616e538008d23ff35158e6" + integrity sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA== + dependencies: + loose-envify "^1.0.0" + +is-arrayish@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d" + integrity sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg== + +is-bigint@^1.0.1: + version "1.0.4" + resolved "https://registry.yarnpkg.com/is-bigint/-/is-bigint-1.0.4.tgz#08147a1875bc2b32005d41ccd8291dffc6691df3" + integrity sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg== + dependencies: + has-bigints "^1.0.1" + +is-boolean-object@^1.1.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/is-boolean-object/-/is-boolean-object-1.1.2.tgz#5c6dc200246dd9321ae4b885a114bb1f75f63719" + integrity sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA== + dependencies: + call-bind "^1.0.2" + has-tostringtag "^1.0.0" + +is-callable@^1.1.4, is-callable@^1.2.4: + version "1.2.4" + resolved "https://registry.yarnpkg.com/is-callable/-/is-callable-1.2.4.tgz#47301d58dd0259407865547853df6d61fe471945" + integrity sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w== + +is-core-module@^2.8.1, is-core-module@^2.9.0: + version "2.10.0" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.10.0.tgz#9012ede0a91c69587e647514e1d5277019e728ed" + integrity sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg== + dependencies: + has "^1.0.3" + +is-date-object@^1.0.1: + version "1.0.5" + resolved "https://registry.yarnpkg.com/is-date-object/-/is-date-object-1.0.5.tgz#0841d5536e724c25597bf6ea62e1bd38298df31f" + integrity sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ== + dependencies: + has-tostringtag "^1.0.0" + +is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== + +is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + +is-negative-zero@^2.0.2: + version "2.0.2" + resolved "https://registry.yarnpkg.com/is-negative-zero/-/is-negative-zero-2.0.2.tgz#7bf6f03a28003b8b3965de3ac26f664d765f3150" + integrity sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA== + +is-number-object@^1.0.4: + version "1.0.7" + resolved "https://registry.yarnpkg.com/is-number-object/-/is-number-object-1.0.7.tgz#59d50ada4c45251784e9904f5246c742f07a42fc" + integrity sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ== + dependencies: + has-tostringtag "^1.0.0" + +is-number@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" + integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== + +is-regex@^1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/is-regex/-/is-regex-1.1.4.tgz#eef5663cd59fa4c0ae339505323df6854bb15958" + integrity sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg== + dependencies: + call-bind "^1.0.2" + has-tostringtag "^1.0.0" + +is-shared-array-buffer@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz#8f259c573b60b6a32d4058a1a07430c0a7344c79" + integrity sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA== + dependencies: + call-bind "^1.0.2" + +is-string@^1.0.5, is-string@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/is-string/-/is-string-1.0.7.tgz#0dd12bf2006f255bb58f695110eff7491eebc0fd" + integrity sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg== + dependencies: + has-tostringtag "^1.0.0" + +is-symbol@^1.0.2, is-symbol@^1.0.3: + version "1.0.4" + resolved "https://registry.yarnpkg.com/is-symbol/-/is-symbol-1.0.4.tgz#a6dac93b635b063ca6872236de88910a57af139c" + integrity sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg== + dependencies: + has-symbols "^1.0.2" + +is-weakref@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/is-weakref/-/is-weakref-1.0.2.tgz#9529f383a9338205e89765e0392efc2f100f06f2" + integrity sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ== + dependencies: + call-bind "^1.0.2" + +isexe@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" + integrity sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw== + +"js-tokens@^3.0.0 || ^4.0.0", js-tokens@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" + integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== + +js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + +json-parse-even-better-errors@^2.3.0: + version "2.3.1" + resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d" + integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== + +json-schema-traverse@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" + integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== + +json-stable-stringify-without-jsonify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" + integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw== + +json5@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json5/-/json5-1.0.1.tgz#779fb0018604fa854eacbf6252180d83543e3dbe" + integrity sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow== + dependencies: + minimist "^1.2.0" + +"jsx-ast-utils@^2.4.1 || ^3.0.0", jsx-ast-utils@^3.3.2: + version "3.3.3" + resolved "https://registry.yarnpkg.com/jsx-ast-utils/-/jsx-ast-utils-3.3.3.tgz#76b3e6e6cece5c69d49a5792c3d01bd1a0cdc7ea" + integrity sha512-fYQHZTZ8jSfmWZ0iyzfwiU4WDX4HpHbMCZ3gPlWYiCl3BoeOTsqKBqnTVfH2rYT7eP5c3sVbeSPHnnJOaTrWiw== + dependencies: + array-includes "^3.1.5" + object.assign "^4.1.3" + +language-subtag-registry@~0.3.2: + version "0.3.22" + resolved "https://registry.yarnpkg.com/language-subtag-registry/-/language-subtag-registry-0.3.22.tgz#2e1500861b2e457eba7e7ae86877cbd08fa1fd1d" + integrity sha512-tN0MCzyWnoz/4nHS6uxdlFWoUZT7ABptwKPQ52Ea7URk6vll88bWBVhodtnlfEuCcKWNGoc+uGbw1cwa9IKh/w== + +language-tags@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/language-tags/-/language-tags-1.0.5.tgz#d321dbc4da30ba8bf3024e040fa5c14661f9193a" + integrity sha512-qJhlO9cGXi6hBGKoxEG/sKZDAHD5Hnu9Hs4WbOY3pCWXDhw0N8x1NenNzm2EnNLkLkk7J2SdxAkDSbb6ftT+UQ== + dependencies: + language-subtag-registry "~0.3.2" + +levn@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" + integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== + dependencies: + prelude-ls "^1.2.1" + type-check "~0.4.0" + +lines-and-columns@^1.1.6: + version "1.2.4" + resolved "https://registry.yarnpkg.com/lines-and-columns/-/lines-and-columns-1.2.4.tgz#eca284f75d2965079309dc0ad9255abb2ebc1632" + integrity sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg== + +locate-path@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" + integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw== + dependencies: + p-locate "^5.0.0" + +lodash.merge@^4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" + integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== + +lodash.mergewith@4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/lodash.mergewith/-/lodash.mergewith-4.6.2.tgz#617121f89ac55f59047c7aec1ccd6654c6590f55" + integrity sha512-GK3g5RPZWTRSeLSpgP8Xhra+pnjBC56q9FZYe1d5RN3TJ35dbkGy3YqBSMbyCrlbi+CM9Z3Jk5yTL7RCsqboyQ== + +loose-envify@^1.0.0, loose-envify@^1.1.0, loose-envify@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf" + integrity sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q== + dependencies: + js-tokens "^3.0.0 || ^4.0.0" + +lru-cache@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94" + integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA== + dependencies: + yallist "^4.0.0" + +merge2@^1.3.0, merge2@^1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + +micromatch@^4.0.4: + version "4.0.5" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.5.tgz#bc8999a7cbbf77cdc89f132f6e467051b49090c6" + integrity sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA== + dependencies: + braces "^3.0.2" + picomatch "^2.3.1" + +minimatch@^3.0.4, minimatch@^3.1.1, minimatch@^3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" + integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== + dependencies: + brace-expansion "^1.1.7" + +minimist@^1.2.0, minimist@^1.2.6: + version "1.2.6" + resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" + integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== + +ms@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" + integrity sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A== + +ms@2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" + integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== + +ms@^2.1.1: + version "2.1.3" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" + integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== + +nanoid@^3.3.4: + version "3.3.4" + resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.4.tgz#730b67e3cd09e2deacf03c027c81c9d9dbc5e8ab" + integrity sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw== + +natural-compare@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" + integrity sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw== + +next@12.2.5: + version "12.2.5" + resolved "https://registry.yarnpkg.com/next/-/next-12.2.5.tgz#14fb5975e8841fad09553b8ef41fe1393602b717" + integrity sha512-tBdjqX5XC/oFs/6gxrZhjmiq90YWizUYU6qOWAfat7zJwrwapJ+BYgX2PmiacunXMaRpeVT4vz5MSPSLgNkrpA== + dependencies: + "@next/env" "12.2.5" + "@swc/helpers" "0.4.3" + caniuse-lite "^1.0.30001332" + postcss "8.4.14" + styled-jsx "5.0.4" + use-sync-external-store "1.2.0" + optionalDependencies: + "@next/swc-android-arm-eabi" "12.2.5" + "@next/swc-android-arm64" "12.2.5" + "@next/swc-darwin-arm64" "12.2.5" + "@next/swc-darwin-x64" "12.2.5" + "@next/swc-freebsd-x64" "12.2.5" + "@next/swc-linux-arm-gnueabihf" "12.2.5" + "@next/swc-linux-arm64-gnu" "12.2.5" + "@next/swc-linux-arm64-musl" "12.2.5" + "@next/swc-linux-x64-gnu" "12.2.5" + "@next/swc-linux-x64-musl" "12.2.5" + "@next/swc-win32-arm64-msvc" "12.2.5" + "@next/swc-win32-ia32-msvc" "12.2.5" + "@next/swc-win32-x64-msvc" "12.2.5" + +object-assign@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== + +object-inspect@^1.12.2, object-inspect@^1.9.0: + version "1.12.2" + resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.12.2.tgz#c0641f26394532f28ab8d796ab954e43c009a8ea" + integrity sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ== + +object-keys@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/object-keys/-/object-keys-1.1.1.tgz#1c47f272df277f3b1daf061677d9c82e2322c60e" + integrity sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA== + +object.assign@^4.1.3, object.assign@^4.1.4: + version "4.1.4" + resolved "https://registry.yarnpkg.com/object.assign/-/object.assign-4.1.4.tgz#9673c7c7c351ab8c4d0b516f4343ebf4dfb7799f" + integrity sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + has-symbols "^1.0.3" + object-keys "^1.1.1" + +object.entries@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/object.entries/-/object.entries-1.1.5.tgz#e1acdd17c4de2cd96d5a08487cfb9db84d881861" + integrity sha512-TyxmjUoZggd4OrrU1W66FMDG6CuqJxsFvymeyXI51+vQLN67zYfZseptRge703kKQdo4uccgAKebXFcRCzk4+g== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.1" + +object.fromentries@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/object.fromentries/-/object.fromentries-2.0.5.tgz#7b37b205109c21e741e605727fe8b0ad5fa08251" + integrity sha512-CAyG5mWQRRiBU57Re4FKoTBjXfDoNwdFVH2Y1tS9PqCsfUTymAohOkEMSG3aRNKmv4lV3O7p1et7c187q6bynw== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.1" + +object.hasown@^1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/object.hasown/-/object.hasown-1.1.1.tgz#ad1eecc60d03f49460600430d97f23882cf592a3" + integrity sha512-LYLe4tivNQzq4JdaWW6WO3HMZZJWzkkH8fnI6EebWl0VZth2wL2Lovm74ep2/gZzlaTdV62JZHEqHQ2yVn8Q/A== + dependencies: + define-properties "^1.1.4" + es-abstract "^1.19.5" + +object.values@^1.1.5: + version "1.1.5" + resolved "https://registry.yarnpkg.com/object.values/-/object.values-1.1.5.tgz#959f63e3ce9ef108720333082131e4a459b716ac" + integrity sha512-QUZRW0ilQ3PnPpbNtgdNV1PDbEqLIiSFB3l+EnGtBQ/8SUTLj1PZwtQHABZtLgwpJZTSZhuGLOGk57Drx2IvYg== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.1" + +once@^1.3.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" + integrity sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w== + dependencies: + wrappy "1" + +optionator@^0.9.1: + version "0.9.1" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" + integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== + dependencies: + deep-is "^0.1.3" + fast-levenshtein "^2.0.6" + levn "^0.4.1" + prelude-ls "^1.2.1" + type-check "^0.4.0" + word-wrap "^1.2.3" + +p-limit@^3.0.2: + version "3.1.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-3.1.0.tgz#e1daccbe78d0d1388ca18c64fea38e3e57e3706b" + integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== + dependencies: + yocto-queue "^0.1.0" + +p-locate@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834" + integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw== + dependencies: + p-limit "^3.0.2" + +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + +parse-json@^5.0.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd" + integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg== + dependencies: + "@babel/code-frame" "^7.0.0" + error-ex "^1.3.1" + json-parse-even-better-errors "^2.3.0" + lines-and-columns "^1.1.6" + +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + +path-is-absolute@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" + integrity sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg== + +path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + +path-parse@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" + integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== + +path-type@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" + integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== + +picocolors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" + integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== + +picomatch@^2.3.1: + version "2.3.1" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" + integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== + +popmotion@11.0.5: + version "11.0.5" + resolved "https://registry.yarnpkg.com/popmotion/-/popmotion-11.0.5.tgz#8e3e014421a0ffa30ecd722564fd2558954e1f7d" + integrity sha512-la8gPM1WYeFznb/JqF4GiTkRRPZsfaj2+kCxqQgr2MJylMmIKUwBfWW8Wa5fml/8gmtlD5yI01MP1QCZPWmppA== + dependencies: + framesync "6.1.2" + hey-listen "^1.0.8" + style-value-types "5.1.2" + tslib "2.4.0" + +postcss@8.4.14: + version "8.4.14" + resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.14.tgz#ee9274d5622b4858c1007a74d76e42e56fd21caf" + integrity sha512-E398TUmfAYFPBSdzgeieK2Y1+1cpdxJx8yXbK/m57nRhKSmk1GB2tO4lbLBtlkfPQTDKfe4Xqv1ASWPpayPEig== + dependencies: + nanoid "^3.3.4" + picocolors "^1.0.0" + source-map-js "^1.0.2" + +prelude-ls@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" + integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== + +prop-types@^15.6.2, prop-types@^15.8.1: + version "15.8.1" + resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.8.1.tgz#67d87bf1a694f48435cf332c24af10214a3140b5" + integrity sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg== + dependencies: + loose-envify "^1.4.0" + object-assign "^4.1.1" + react-is "^16.13.1" + +punycode@^2.1.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" + integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== + +queue-microtask@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== + +react-clientside-effect@^1.2.6: + version "1.2.6" + resolved "https://registry.yarnpkg.com/react-clientside-effect/-/react-clientside-effect-1.2.6.tgz#29f9b14e944a376b03fb650eed2a754dd128ea3a" + integrity sha512-XGGGRQAKY+q25Lz9a/4EPqom7WRjz3z9R2k4jhVKA/puQFH/5Nt27vFZYql4m4NVNdUvX8PS3O7r/Zzm7cjUlg== + dependencies: + "@babel/runtime" "^7.12.13" + +react-dom@18.2.0: + version "18.2.0" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-18.2.0.tgz#22aaf38708db2674ed9ada224ca4aa708d821e3d" + integrity sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g== + dependencies: + loose-envify "^1.1.0" + scheduler "^0.23.0" + +react-fast-compare@3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/react-fast-compare/-/react-fast-compare-3.2.0.tgz#641a9da81b6a6320f270e89724fb45a0b39e43bb" + integrity sha512-rtGImPZ0YyLrscKI9xTpV8psd6I8VAtjKCzQDlzyDvqJA8XOW78TXYQwNRNd8g8JZnDu8q9Fu/1v4HPAVwVdHA== + +react-focus-lock@^2.9.1: + version "2.9.1" + resolved "https://registry.yarnpkg.com/react-focus-lock/-/react-focus-lock-2.9.1.tgz#094cfc19b4f334122c73bb0bff65d77a0c92dd16" + integrity sha512-pSWOQrUmiKLkffPO6BpMXN7SNKXMsuOakl652IBuALAu1esk+IcpJyM+ALcYzPTTFz1rD0R54aB9A4HuP5t1Wg== + dependencies: + "@babel/runtime" "^7.0.0" + focus-lock "^0.11.2" + prop-types "^15.6.2" + react-clientside-effect "^1.2.6" + use-callback-ref "^1.3.0" + use-sidecar "^1.1.2" + +react-is@^16.13.1, react-is@^16.7.0: + version "16.13.1" + resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" + integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== + +react-remove-scroll-bar@^2.3.3: + version "2.3.3" + resolved "https://registry.yarnpkg.com/react-remove-scroll-bar/-/react-remove-scroll-bar-2.3.3.tgz#e291f71b1bb30f5f67f023765b7435f4b2b2cd94" + integrity sha512-i9GMNWwpz8XpUpQ6QlevUtFjHGqnPG4Hxs+wlIJntu/xcsZVEpJcIV71K3ZkqNy2q3GfgvkD7y6t/Sv8ofYSbw== + dependencies: + react-style-singleton "^2.2.1" + tslib "^2.0.0" + +react-remove-scroll@^2.5.4: + version "2.5.5" + resolved "https://registry.yarnpkg.com/react-remove-scroll/-/react-remove-scroll-2.5.5.tgz#1e31a1260df08887a8a0e46d09271b52b3a37e77" + integrity sha512-ImKhrzJJsyXJfBZ4bzu8Bwpka14c/fQt0k+cyFp/PBhTfyDnU5hjOtM4AG/0AMyy8oKzOTR0lDgJIM7pYXI0kw== + dependencies: + react-remove-scroll-bar "^2.3.3" + react-style-singleton "^2.2.1" + tslib "^2.1.0" + use-callback-ref "^1.3.0" + use-sidecar "^1.1.2" + +react-style-singleton@^2.2.1: + version "2.2.1" + resolved "https://registry.yarnpkg.com/react-style-singleton/-/react-style-singleton-2.2.1.tgz#f99e420492b2d8f34d38308ff660b60d0b1205b4" + integrity sha512-ZWj0fHEMyWkHzKYUr2Bs/4zU6XLmq9HsgBURm7g5pAVfyn49DgUiNgY2d4lXRlYSiCif9YBGpQleewkcqddc7g== + dependencies: + get-nonce "^1.0.0" + invariant "^2.2.4" + tslib "^2.0.0" + +react@18.2.0: + version "18.2.0" + resolved "https://registry.yarnpkg.com/react/-/react-18.2.0.tgz#555bd98592883255fa00de14f1151a917b5d77d5" + integrity sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ== + dependencies: + loose-envify "^1.1.0" + +regenerator-runtime@^0.13.4: + version "0.13.9" + resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.13.9.tgz#8925742a98ffd90814988d7566ad30ca3b263b52" + integrity sha512-p3VT+cOEgxFsRRA9X4lkI1E+k2/CtnKtU4gcxyaCUreilL/vqI6CdZ3wxVUx3UOUg+gnUOQQcRI7BmSI656MYA== + +regexp.prototype.flags@^1.4.1, regexp.prototype.flags@^1.4.3: + version "1.4.3" + resolved "https://registry.yarnpkg.com/regexp.prototype.flags/-/regexp.prototype.flags-1.4.3.tgz#87cab30f80f66660181a3bb7bf5981a872b367ac" + integrity sha512-fjggEOO3slI6Wvgjwflkc4NFRCTZAu5CnNfBd5qOMYhWdn67nJBBu34/TkD++eeFmd8C9r9jfXJ27+nSiRkSUA== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + functions-have-names "^1.2.2" + +regexpp@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.2.0.tgz#0425a2768d8f23bad70ca4b90461fa2f1213e1b2" + integrity sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg== + +resolve-from@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" + integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== + +resolve@^1.19.0, resolve@^1.20.0, resolve@^1.22.0: + version "1.22.1" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.1.tgz#27cb2ebb53f91abb49470a928bba7558066ac177" + integrity sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw== + dependencies: + is-core-module "^2.9.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + +resolve@^2.0.0-next.3: + version "2.0.0-next.4" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-2.0.0-next.4.tgz#3d37a113d6429f496ec4752d2a2e58efb1fd4660" + integrity sha512-iMDbmAWtfU+MHpxt/I5iWI7cY6YVEZUQ3MBgPQ++XD1PELuJHIl82xBmObyP2KyQmkNB2dsqF7seoQQiAn5yDQ== + dependencies: + is-core-module "^2.9.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + +reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + +rimraf@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" + integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== + dependencies: + glob "^7.1.3" + +run-parallel@^1.1.9: + version "1.2.0" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== + dependencies: + queue-microtask "^1.2.2" + +safe-buffer@~5.1.1: + version "5.1.2" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" + integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== + +scheduler@^0.23.0: + version "0.23.0" + resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.23.0.tgz#ba8041afc3d30eb206a487b6b384002e4e61fdfe" + integrity sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw== + dependencies: + loose-envify "^1.1.0" + +semver@^6.3.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" + integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== + +semver@^7.3.7: + version "7.3.7" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.7.tgz#12c5b649afdbf9049707796e22a4028814ce523f" + integrity sha512-QlYTucUYOews+WeEujDoEGziz4K6c47V/Bd+LjSSYcA94p+DmINdf7ncaUinThfvZyu13lN9OY1XDxt8C0Tw0g== + dependencies: + lru-cache "^6.0.0" + +shebang-command@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + +side-channel@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" + integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== + dependencies: + call-bind "^1.0.0" + get-intrinsic "^1.0.2" + object-inspect "^1.9.0" + +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + +source-map-js@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c" + integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw== + +source-map@^0.5.7: + version "0.5.7" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" + integrity sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ== + +string.prototype.matchall@^4.0.7: + version "4.0.7" + resolved "https://registry.yarnpkg.com/string.prototype.matchall/-/string.prototype.matchall-4.0.7.tgz#8e6ecb0d8a1fb1fda470d81acecb2dba057a481d" + integrity sha512-f48okCX7JiwVi1NXCVWcFnZgADDC/n2vePlQ/KUCNqCikLLilQvwjMO8+BHVKvgzH0JB0J9LEPgxOGT02RoETg== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.3" + es-abstract "^1.19.1" + get-intrinsic "^1.1.1" + has-symbols "^1.0.3" + internal-slot "^1.0.3" + regexp.prototype.flags "^1.4.1" + side-channel "^1.0.4" + +string.prototype.trimend@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/string.prototype.trimend/-/string.prototype.trimend-1.0.5.tgz#914a65baaab25fbdd4ee291ca7dde57e869cb8d0" + integrity sha512-I7RGvmjV4pJ7O3kdf+LXFpVfdNOxtCW/2C8f6jNiW4+PQchwxkCDzlk1/7p+Wl4bqFIZeF47qAHXLuHHWKAxog== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + es-abstract "^1.19.5" + +string.prototype.trimstart@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/string.prototype.trimstart/-/string.prototype.trimstart-1.0.5.tgz#5466d93ba58cfa2134839f81d7f42437e8c01fef" + integrity sha512-THx16TJCGlsN0o6dl2o6ncWUsdgnLRSA23rRE5pyGBw/mLr3Ej/R2LaqCtgP8VNMGZsvMWnf9ooZPyY2bHvUFg== + dependencies: + call-bind "^1.0.2" + define-properties "^1.1.4" + es-abstract "^1.19.5" + +strip-ansi@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== + dependencies: + ansi-regex "^5.0.1" + +strip-bom@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3" + integrity sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA== + +strip-json-comments@^3.1.0, strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + +style-value-types@5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/style-value-types/-/style-value-types-5.1.2.tgz#6be66b237bd546048a764883528072ed95713b62" + integrity sha512-Vs9fNreYF9j6W2VvuDTP7kepALi7sk0xtk2Tu8Yxi9UoajJdEVpNpCov0HsLTqXvNGKX+Uv09pkozVITi1jf3Q== + dependencies: + hey-listen "^1.0.8" + tslib "2.4.0" + +styled-jsx@5.0.4: + version "5.0.4" + resolved "https://registry.yarnpkg.com/styled-jsx/-/styled-jsx-5.0.4.tgz#5b1bd0b9ab44caae3dd1361295559706e044aa53" + integrity sha512-sDFWLbg4zR+UkNzfk5lPilyIgtpddfxXEULxhujorr5jtePTUqiPDc5BC0v1NRqTr/WaFBGQQUoYToGlF4B2KQ== + +stylis@4.0.13: + version "4.0.13" + resolved "https://registry.yarnpkg.com/stylis/-/stylis-4.0.13.tgz#f5db332e376d13cc84ecfe5dace9a2a51d954c91" + integrity sha512-xGPXiFVl4YED9Jh7Euv2V220mriG9u4B2TA6Ybjc1catrstKD2PpIdU3U0RKpkVBC2EhmL/F0sPCr9vrFTNRag== + +supports-color@^5.3.0: + version "5.5.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" + integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== + dependencies: + has-flag "^3.0.0" + +supports-color@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" + integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== + dependencies: + has-flag "^4.0.0" + +supports-preserve-symlinks-flag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" + integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== + +text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== + +tiny-invariant@^1.0.6: + version "1.2.0" + resolved "https://registry.yarnpkg.com/tiny-invariant/-/tiny-invariant-1.2.0.tgz#a1141f86b672a9148c72e978a19a73b9b94a15a9" + integrity sha512-1Uhn/aqw5C6RI4KejVeTg6mIS7IqxnLJ8Mv2tV5rTc0qWobay7pDUz6Wi392Cnc8ak1H0F2cjoRzb2/AW4+Fvg== + +to-fast-properties@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" + integrity sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog== + +to-regex-range@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" + integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== + dependencies: + is-number "^7.0.0" + +toggle-selection@^1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/toggle-selection/-/toggle-selection-1.0.6.tgz#6e45b1263f2017fa0acc7d89d78b15b8bf77da32" + integrity sha512-BiZS+C1OS8g/q2RRbJmy59xpyghNBqrr6k5L/uKBGRsTfxmu3ffiRnd8mlGPUVayg8pvfi5urfnu8TU7DVOkLQ== + +tsconfig-paths@^3.14.1: + version "3.14.1" + resolved "https://registry.yarnpkg.com/tsconfig-paths/-/tsconfig-paths-3.14.1.tgz#ba0734599e8ea36c862798e920bcf163277b137a" + integrity sha512-fxDhWnFSLt3VuTwtvJt5fpwxBHg5AdKWMsgcPOOIilyjymcYVZoCQF8fvFRezCNfblEXmi+PcM1eYHeOAgXCOQ== + dependencies: + "@types/json5" "^0.0.29" + json5 "^1.0.1" + minimist "^1.2.6" + strip-bom "^3.0.0" + +tslib@2.4.0, tslib@^2.0.0, tslib@^2.0.3, tslib@^2.1.0, tslib@^2.3.1, tslib@^2.4.0: + version "2.4.0" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.4.0.tgz#7cecaa7f073ce680a05847aa77be941098f36dc3" + integrity sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ== + +tslib@^1.8.1: + version "1.14.1" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" + integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== + +tsutils@^3.21.0: + version "3.21.0" + resolved "https://registry.yarnpkg.com/tsutils/-/tsutils-3.21.0.tgz#b48717d394cea6c1e096983eed58e9d61715b623" + integrity sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA== + dependencies: + tslib "^1.8.1" + +type-check@^0.4.0, type-check@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" + integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== + dependencies: + prelude-ls "^1.2.1" + +type-fest@^0.20.2: + version "0.20.2" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" + integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== + +typescript@4.8.2: + version "4.8.2" + resolved "https://registry.yarnpkg.com/typescript/-/typescript-4.8.2.tgz#e3b33d5ccfb5914e4eeab6699cf208adee3fd790" + integrity sha512-C0I1UsrrDHo2fYI5oaCGbSejwX4ch+9Y5jTQELvovfmFkK3HHSZJB8MSJcWLmCUBzQBchCrZ9rMRV6GuNrvGtw== + +unbox-primitive@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/unbox-primitive/-/unbox-primitive-1.0.2.tgz#29032021057d5e6cdbd08c5129c226dff8ed6f9e" + integrity sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw== + dependencies: + call-bind "^1.0.2" + has-bigints "^1.0.2" + has-symbols "^1.0.3" + which-boxed-primitive "^1.0.2" + +uri-js@^4.2.2: + version "4.4.1" + resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" + integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== + dependencies: + punycode "^2.1.0" + +use-callback-ref@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/use-callback-ref/-/use-callback-ref-1.3.0.tgz#772199899b9c9a50526fedc4993fc7fa1f7e32d5" + integrity sha512-3FT9PRuRdbB9HfXhEq35u4oZkvpJ5kuYbpqhCfmiZyReuRgpnhDlbr2ZEnnuS0RrJAPn6l23xjFg9kpDM+Ms7w== + dependencies: + tslib "^2.0.0" + +use-sidecar@^1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/use-sidecar/-/use-sidecar-1.1.2.tgz#2f43126ba2d7d7e117aa5855e5d8f0276dfe73c2" + integrity sha512-epTbsLuzZ7lPClpz2TyryBfztm7m+28DlEv2ZCQ3MDr5ssiwyOwGH/e5F9CkfWjJ1t4clvI58yF822/GUkjjhw== + dependencies: + detect-node-es "^1.1.0" + tslib "^2.0.0" + +use-sync-external-store@1.2.0: + version "1.2.0" + resolved "https://registry.yarnpkg.com/use-sync-external-store/-/use-sync-external-store-1.2.0.tgz#7dbefd6ef3fe4e767a0cf5d7287aacfb5846928a" + integrity sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA== + +which-boxed-primitive@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz#13757bc89b209b049fe5d86430e21cf40a89a8e6" + integrity sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg== + dependencies: + is-bigint "^1.0.1" + is-boolean-object "^1.1.0" + is-number-object "^1.0.4" + is-string "^1.0.5" + is-symbol "^1.0.3" + +which@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +word-wrap@^1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" + integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== + +wrappy@1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" + integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ== + +yallist@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72" + integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A== + +yaml@^1.10.0: + version "1.10.2" + resolved "https://registry.yarnpkg.com/yaml/-/yaml-1.10.2.tgz#2301c5ffbf12b467de8da2333a459e29e7920e4b" + integrity sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg== + +yocto-queue@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/yocto-queue/-/yocto-queue-0.1.0.tgz#0294eb3dee05028d31ee1a5fa2c556a6aaf10a1b" + integrity sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q== From fb285b898d08618b5e356b2de6410d87cb6fe06b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nicol=C3=A1s=20Quiroz?= Date: Thu, 8 Sep 2022 17:09:53 -0300 Subject: [PATCH 054/432] chore: prettier fix .md files --- content/docs/developers/contributing.md | 10 +- .../dapp-developer/built-in-tracers.md | 55 ++-- .../dapp-developer/custom-tracer.md | 254 ++++++++------- .../docs/developers/dapp-developer/mobile.md | 39 ++- .../dapp-developer/native-accounts.md | 36 +-- .../dapp-developer/native-bindings.md | 71 +++-- .../docs/developers/dapp-developer/native.md | 15 +- .../docs/developers/dapp-developer/tracing.md | 65 ++-- .../geth-developer/Private-Network.md | 41 +-- .../geth-developer/code-review-guidelines.md | 20 +- .../developers/geth-developer/dev-mode.md | 36 +-- .../developers/geth-developer/devguide.md | 2 - .../geth-developer/dns-discovery-setup.md | 8 +- .../geth-developer/issue-handling-workflow.md | 54 ++-- .../geth-developer/vulnerabilities.md | 16 +- content/docs/faq.md | 5 +- content/docs/fundamentals/Backup--restore.md | 6 +- .../docs/fundamentals/Command-Line-Options.md | 6 +- .../docs/fundamentals/account-management.md | 30 +- content/docs/fundamentals/les.md | 4 +- content/docs/fundamentals/mining.md | 29 +- .../docs/fundamentals/node-architecture.md | 5 +- content/docs/fundamentals/peer-to-peer.md | 20 +- content/docs/fundamentals/pruning.md | 25 +- content/docs/fundamentals/security.md | 9 +- content/docs/fundamentals/sync-modes.md | 2 +- .../docs/getting_started/Backup--restore.md | 7 +- .../docs/getting_started/Installing-Geth.md | 62 ++-- .../docs/getting_started/consensus-clients.md | 20 +- .../getting-started-with-clef.md | 62 ++-- .../docs/getting_started/getting_started.md | 60 ++-- .../JavaScript-Console.md | 21 +- .../docs/interacting_with_geth/RPC/batch.md | 38 ++- .../docs/interacting_with_geth/RPC/graphql.md | 35 ++- .../interacting_with_geth/RPC/ns-admin.md | 53 ++-- .../interacting_with_geth/RPC/ns-clique.md | 30 +- .../interacting_with_geth/RPC/ns-debug.md | 291 ++++++++---------- .../docs/interacting_with_geth/RPC/ns-eth.md | 45 +-- .../docs/interacting_with_geth/RPC/ns-les.md | 92 +++--- .../interacting_with_geth/RPC/ns-miner.md | 48 +-- .../docs/interacting_with_geth/RPC/ns-net.md | 7 +- .../interacting_with_geth/RPC/ns-personal.md | 146 +++++---- .../interacting_with_geth/RPC/ns-txpool.md | 20 +- .../docs/interacting_with_geth/RPC/objects.md | 40 +-- .../docs/interacting_with_geth/RPC/pubsub.md | 11 +- .../docs/interacting_with_geth/RPC/server.md | 17 +- content/docs/monitoring/dashboards.md | 4 +- content/docs/monitoring/ethstats.md | 36 +-- content/docs/monitoring/metrics.md | 33 +- content/docs/tools/Clef/CliqueSigning.md | 134 ++++---- content/docs/tools/Clef/Introduction.md | 11 +- content/docs/tools/Clef/Rules.md | 204 ++++++------ content/docs/tools/Clef/Setup.md | 50 +-- content/docs/tools/Clef/Tutorial.md | 137 +++++---- content/docs/tools/Clef/apis.md | 243 ++++++++------- content/docs/tools/Clef/datatypes.md | 21 ++ content/docs/tools/abigen/index.md | 30 +- content/docs/tools/devp2p/index.md | 16 +- content/docs/tools/puppeth/index.md | 3 +- content/homepage.md | 10 +- content/resources.md | 5 +- 61 files changed, 1431 insertions(+), 1474 deletions(-) diff --git a/content/docs/developers/contributing.md b/content/docs/developers/contributing.md index 126395d0a5..522ecf8845 100644 --- a/content/docs/developers/contributing.md +++ b/content/docs/developers/contributing.md @@ -11,11 +11,11 @@ If you'd like to contribute to the Geth source code, please fork the [Github rep Please make sure your contributions adhere to our coding guidelines: -* Code must adhere to the official Go formatting guidelines (i.e. uses gofmt). -* Code must be documented adhering to the official Go commentary guidelines. -* Pull requests need to be based on and opened against the master branch. -* Commit messages should be prefixed with the package(s) they modify. - E.g. "eth, rpc: make trace configs optional" +- Code must adhere to the official Go formatting guidelines (i.e. uses gofmt). +- Code must be documented adhering to the official Go commentary guidelines. +- Pull requests need to be based on and opened against the master branch. +- Commit messages should be prefixed with the package(s) they modify. + E.g. "eth, rpc: make trace configs optional" Pull requests generally need to be based on and opened against the `master` branch, unless by explicit agreement because the work is contributing to some more complex feature branch. diff --git a/content/docs/developers/dapp-developer/built-in-tracers.md b/content/docs/developers/dapp-developer/built-in-tracers.md index fc01d24aea..2c93414daf 100644 --- a/content/docs/developers/dapp-developer/built-in-tracers.md +++ b/content/docs/developers/dapp-developer/built-in-tracers.md @@ -5,25 +5,24 @@ description: Explanation of the tracers that come bundled in Geth as part of the Geth comes bundled with a choice of tracers ready for usage through the [tracing API](/docs/rpc/ns-debug). Some of them are implemented natively in Go, and others in JS. In this page a summary of each of these will be outlined. They have to be specified by name when sending a request. The only exception is the opcode logger (otherwise known as struct logger) which is the default tracer for all the methods and cannot be specified by name. - ## Struct logger Struct logger or opcode logger is a native Go tracer which executes a transaction and emits the opcode and execution context at every step. This is the tracer that will be used when no name is passed to the API, e.g. `debug.traceTransaction()`. The following information is emitted at each step: -| field | type | description | -|------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------| -| pc | uint64 | program counter | -| op | byte | opcode to be executed | -| gas | uint64 | remaining gas | -| gasCost | uint64 | cost for executing op | -| memory | []byte | EVM memory. Enabled via `enableMemory` | -| memSize | int | Size of memory | -| stack | []uint256 | EVM stack. Disabled via `disableStack` | -| returnData | []byte | Last call's return data. Enabled via `enableReturnData` | -| storage | map[hash]hash | Storage slots of current contract read from and written to. Only emitted for `SLOAD` and `SSTORE`. Disabled via `disableStorage` | -| depth | int | Current call depth | -| refund | uint64 | Refund counter | -| error | string | Error message if any | +| field | type | description | +| ---------- | ------------- | -------------------------------------------------------------------------------------------------------------------------------- | +| pc | uint64 | program counter | +| op | byte | opcode to be executed | +| gas | uint64 | remaining gas | +| gasCost | uint64 | cost for executing op | +| memory | []byte | EVM memory. Enabled via `enableMemory` | +| memSize | int | Size of memory | +| stack | []uint256 | EVM stack. Disabled via `disableStack` | +| returnData | []byte | Last call's return data. Enabled via `enableReturnData` | +| storage | map[hash]hash | Storage slots of current contract read from and written to. Only emitted for `SLOAD` and `SSTORE`. Disabled via `disableStorage` | +| depth | int | Current call depth | +| refund | uint64 | Refund counter | +| error | string | Error message if any | Note that the fields `memory`, `stack`, `returnData`, and `storage` have dynamic size and depending on the exact transaction they could grow large in size. This is specially true for `memory` which could blow up the trace size. It is recommended to keep them disabled unless they are explicitly required for a given use-case. @@ -52,18 +51,18 @@ The `4byteTracer` collects the function selectors of every function executed in The `callTracer` tracks all the call frames executed during a transaction, including depth 0. The result will be a nested list of call frames, resembling how EVM works. They form a tree with the top-level call at root and sub-calls as children of the higher levels. Each call frame has the following fields: -| field | type | description | -|---------|-------------|-------------------------------------------| -| type | string | CALL or CREATE | -| from | string | address | -| to | string | address | -| value | string | hex-encoded amount of value transfer | -| gas | string | hex-encoded gas provided for call | -| gasUsed | string | hex-encoded gas used during call | -| input | string | call data | -| output | string | return data | -| error | string | error, if any | -| calls | []callframe | list of sub-calls | +| field | type | description | +| ------- | ----------- | ------------------------------------ | +| type | string | CALL or CREATE | +| from | string | address | +| to | string | address | +| value | string | hex-encoded amount of value transfer | +| gas | string | hex-encoded gas provided for call | +| gasUsed | string | hex-encoded gas used during call | +| input | string | call data | +| output | string | return data | +| error | string | error, if any | +| calls | []callframe | list of sub-calls | Things to note about the call tracer: @@ -79,7 +78,7 @@ This tracer is noop. It returns an empty object and is only meant for testing th Executing a transaction requires the prior state, including account of sender and recipient, contracts that are called during execution, etc. The `prestateTracer` replays the tx and tracks every part of state that is touched. This is similar to the concept of a [stateless witness](https://ethresear.ch/t/the-stateless-client-concept/172), the difference being this tracer doesn't return any cryptographic proof, rather only the trie leaves. The result is an object. The keys are addresses of accounts. The value is an object with the following fields: | field | type | description | -|---------|-------------------|-------------------------------| +| ------- | ----------------- | ----------------------------- | | balance | string | balance in Wei | | nonce | uint64 | nonce | | code | string | hex-encoded bytecode | diff --git a/content/docs/developers/dapp-developer/custom-tracer.md b/content/docs/developers/dapp-developer/custom-tracer.md index 231760a4c6..a025c87dcd 100644 --- a/content/docs/developers/dapp-developer/custom-tracer.md +++ b/content/docs/developers/dapp-developer/custom-tracer.md @@ -11,42 +11,41 @@ Transaction traces include the complete status of the EVM at every point during ### A simple filter -Filters are Javascript functions that select information from the trace to persist and discard based on some conditions. The following Javascript function returns only the sequence of opcodes executed by the transaction as a comma-separated list. The function could be written directly in the Javascript console, but it is cleaner to write it in a separate re-usable file and load it into the console. +Filters are Javascript functions that select information from the trace to persist and discard based on some conditions. The following Javascript function returns only the sequence of opcodes executed by the transaction as a comma-separated list. The function could be written directly in the Javascript console, but it is cleaner to write it in a separate re-usable file and load it into the console. 1. Create a file, `filterTrace_1.js`, with this content: ```javascript - - tracer = function(tx) { - return debug.traceTransaction(tx, {tracer: + tracer = function (tx) { + return debug.traceTransaction(tx, { + tracer: '{' + - 'retVal: [],' + - 'step: function(log,db) {this.retVal.push(log.getPC() + ":" + log.op.toString())},' + - 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + - 'result: function(ctx,db) {return this.retVal}' + + 'retVal: [],' + + 'step: function(log,db) {this.retVal.push(log.getPC() + ":" + log.op.toString())},' + + 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + + 'result: function(ctx,db) {return this.retVal}' + '}' - }) // return debug.traceTransaction ... - } // tracer = function ... - + }); // return debug.traceTransaction ... + }; // tracer = function ... ``` 2. Run the [JavaScript console](https://geth.ethereum.org/docs/interface/javascript-console). - 3. Get the hash of a recent transaction from a node or block explorer. 4. Run this command to run the script: ```javascript - loadScript("filterTrace_1.js") + loadScript('filterTrace_1.js'); ``` 5. Run the tracer from the script. Be patient, it could take a long time. ```javascript - tracer("") + tracer(''); ``` The bottom of the output looks similar to: + ```sh "3366:POP", "3367:JUMP", "1355:JUMPDEST", "1356:PUSH1", "1358:MLOAD", "1359:DUP1", "1360:DUP3", "1361:ISZERO", "1362:ISZERO", "1363:ISZERO", "1364:ISZERO", "1365:DUP2", "1366:MSTORE", "1367:PUSH1", "1369:ADD", "1370:SWAP2", "1371:POP", "1372:POP", "1373:PUSH1", @@ -56,10 +55,10 @@ Filters are Javascript functions that select information from the trace to persi 6. Run this line to get a more readable output with each string in its own line. ```javascript - console.log(JSON.stringify(tracer(""), null, 2)) + console.log(JSON.stringify(tracer(''), null, 2)); ``` -More information about the `JSON.stringify` function is available [here](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify). +More information about the `JSON.stringify` function is available [here](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify). The commands above worked by calling the same `debug.traceTransaction` function that was previously explained in [basic traces](https://geth.ethereum.org/docs/dapp/tracing), but with a new parameter, `tracer`. This parameter takes the JavaScript object formated as a string. In the case of the trace above, it is: @@ -71,6 +70,7 @@ The commands above worked by calling the same `debug.traceTransaction` function result: function(ctx,db) {return this.retVal} } ``` + This object has three member functions: - `step`, called for each opcode. @@ -86,21 +86,22 @@ The `step` function adds to `retVal` the program counter and the name of the opc For actual filtered tracing we need an `if` statement to only log relevant information. For example, to isolate the transaction's interaction with storage, the following tracer could be used: ```javascript -tracer = function(tx) { - return debug.traceTransaction(tx, {tracer: +tracer = function (tx) { + return debug.traceTransaction(tx, { + tracer: '{' + - 'retVal: [],' + - 'step: function(log,db) {' + - ' if(log.op.toNumber() == 0x54) ' + - ' this.retVal.push(log.getPC() + ": SLOAD");' + - ' if(log.op.toNumber() == 0x55) ' + - ' this.retVal.push(log.getPC() + ": SSTORE");' + - '},' + - 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + - 'result: function(ctx,db) {return this.retVal}' + + 'retVal: [],' + + 'step: function(log,db) {' + + ' if(log.op.toNumber() == 0x54) ' + + ' this.retVal.push(log.getPC() + ": SLOAD");' + + ' if(log.op.toNumber() == 0x55) ' + + ' this.retVal.push(log.getPC() + ": SSTORE");' + + '},' + + 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + + 'result: function(ctx,db) {return this.retVal}' + '}' - }) // return debug.traceTransaction ... -} // tracer = function ... + }); // return debug.traceTransaction ... +}; // tracer = function ... ``` The `step` function here looks at the opcode number of the op, and only pushes an entry if the opcode is `SLOAD` or `SSTORE` ([here is a list of EVM opcodes and their numbers](https://github.com/wolflo/evm-opcodes)). We could have used `log.op.toString()` instead, but it is faster to compare numbers rather than strings. @@ -120,7 +121,6 @@ The output looks similar to this: ] ``` - ### Stack Information The trace above reports the program counter (PC) and whether the program read from storage or wrote to it. That alone isn't particularly useful. To know more, the `log.stack.peek` function can be used to peek into the stack. `log.stack.peek(0)` is the stack top, `log.stack.peek(1)` the entry below it, etc. @@ -129,28 +129,28 @@ The values returned by `log.stack.peek` are Go `big.Int` objects. By default the #### Storage Information -The function below provides a trace of all the storage operations and their parameters. This gives a more complete picture of the program's interaction with storage. +The function below provides a trace of all the storage operations and their parameters. This gives a more complete picture of the program's interaction with storage. ```javascript -tracer = function(tx) { - return debug.traceTransaction(tx, {tracer: +tracer = function (tx) { + return debug.traceTransaction(tx, { + tracer: '{' + - 'retVal: [],' + - 'step: function(log,db) {' + - ' if(log.op.toNumber() == 0x54) ' + - ' this.retVal.push(log.getPC() + ": SLOAD " + ' + - ' log.stack.peek(0).toString(16));' + - ' if(log.op.toNumber() == 0x55) ' + - ' this.retVal.push(log.getPC() + ": SSTORE " +' + - ' log.stack.peek(0).toString(16) + " <- " +' + - ' log.stack.peek(1).toString(16));' + - '},' + - 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + - 'result: function(ctx,db) {return this.retVal}' + + 'retVal: [],' + + 'step: function(log,db) {' + + ' if(log.op.toNumber() == 0x54) ' + + ' this.retVal.push(log.getPC() + ": SLOAD " + ' + + ' log.stack.peek(0).toString(16));' + + ' if(log.op.toNumber() == 0x55) ' + + ' this.retVal.push(log.getPC() + ": SSTORE " +' + + ' log.stack.peek(0).toString(16) + " <- " +' + + ' log.stack.peek(1).toString(16));' + + '},' + + 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + + 'result: function(ctx,db) {return this.retVal}' + '}' - }) // return debug.traceTransaction ... -} // tracer = function ... - + }); // return debug.traceTransaction ... +}; // tracer = function ... ``` The output is similar to: @@ -176,35 +176,36 @@ storage, so here we can't. The solution is to have a flag, `afterSload`, which is only true in the opcode right after an `SLOAD`, when we can see the result at the top of the stack. ```javascript -tracer = function(tx) { - return debug.traceTransaction(tx, {tracer: +tracer = function (tx) { + return debug.traceTransaction(tx, { + tracer: '{' + - 'retVal: [],' + - 'afterSload: false,' + - 'step: function(log,db) {' + - ' if(this.afterSload) {' + - ' this.retVal.push(" Result: " + ' + - ' log.stack.peek(0).toString(16)); ' + - ' this.afterSload = false; ' + - ' } ' + - ' if(log.op.toNumber() == 0x54) {' + - ' this.retVal.push(log.getPC() + ": SLOAD " + ' + - ' log.stack.peek(0).toString(16));' + - ' this.afterSload = true; ' + - ' } ' + - ' if(log.op.toNumber() == 0x55) ' + - ' this.retVal.push(log.getPC() + ": SSTORE " +' + - ' log.stack.peek(0).toString(16) + " <- " +' + - ' log.stack.peek(1).toString(16));' + - '},' + - 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + - 'result: function(ctx,db) {return this.retVal}' + + 'retVal: [],' + + 'afterSload: false,' + + 'step: function(log,db) {' + + ' if(this.afterSload) {' + + ' this.retVal.push(" Result: " + ' + + ' log.stack.peek(0).toString(16)); ' + + ' this.afterSload = false; ' + + ' } ' + + ' if(log.op.toNumber() == 0x54) {' + + ' this.retVal.push(log.getPC() + ": SLOAD " + ' + + ' log.stack.peek(0).toString(16));' + + ' this.afterSload = true; ' + + ' } ' + + ' if(log.op.toNumber() == 0x55) ' + + ' this.retVal.push(log.getPC() + ": SSTORE " +' + + ' log.stack.peek(0).toString(16) + " <- " +' + + ' log.stack.peek(1).toString(16));' + + '},' + + 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + + 'result: function(ctx,db) {return this.retVal}' + '}' - }) // return debug.traceTransaction ... -} // tracer = function ... + }); // return debug.traceTransaction ... +}; // tracer = function ... ``` -The output now contains the result in the line that follows the `SLOAD`. +The output now contains the result in the line that follows the `SLOAD`. ```javascript [ @@ -229,64 +230,55 @@ So the storage has been treated as if there are only 2256 cells. Howe However, `log.contract.getAddress()` returns an array of bytes. To convert this to the familiar hexadecimal representation of Ethereum addresses, `this.byteHex()` and `array2Hex()` can be used. ```javascript -tracer = function(tx) { - return debug.traceTransaction(tx, {tracer: +tracer = function (tx) { + return debug.traceTransaction(tx, { + tracer: '{' + - 'retVal: [],' + - 'afterSload: false,' + - 'callStack: [],' + - - 'byte2Hex: function(byte) {' + - ' if (byte < 0x10) ' + - ' return "0" + byte.toString(16); ' + - ' return byte.toString(16); ' + - '},' + - - 'array2Hex: function(arr) {' + - ' var retVal = ""; ' + - ' for (var i=0; i

*FFBL zgWi-K;+9wB7^~5Xg1hdFqkb+7mNpD6{BH%@E~LV0$K&dcK4bEoCw&FqqKEIQV&LtM zwUdX_*H;mNcb->=ih=KZZiElkV~8XCu8QMU?;rXW9;*EoNLm(Z8JpkymrF&ZKOT0C zAm3Wcm9f#AOP}Bs#HemgfIyGBV?(*>bnQ#*{e-(OS4J;J@M#7(SCh$E(vlXD3?)x8 zKjqOghxW0S^>IWw(!(aI!sO(_VGwGoG3+UVc7RP8J!4{hM@qMm;s-FlvYLWoc?lzF z&A7>yFDOwF8DojirQ{VFp26sr@!4?|cBVbni%DfYAD+RzV%fBbDF`bdJhVwaH0k8_ zs$$t9>*ziyra28Z#%3Gll@|qWO?U)p??{uwNT;$wlg^{E&G#u&jw#-K%6v!Y*0N@S zKOrD3Bms0FQsH+iODf^%e7p)j|7IWwP{5utSqGmWEWecCGKeW)dzl<(+Xn^0l~V{* zZjMdWYvV=G`Af~nk_c_(Sb!=(+La;BIqSJ zmI`XT>Og+5F2MJmyIP`A&`RWG>QSJ*DD7_vXpj z1Vad+Jy7AYJ|dL}I^iz>nNnArTTHXq)}Nw@dmp!ICOrq+h+GH21~d%O0|ayd5l(; zdbrGFRYiK2h+dYcPcY|0oa{+Ez^Bq0y)nQoNRas;w5h1`zsWN-5x*?hTx^{zmj zmJR6zevUY%M6;XzxTS-|+lAhRn{3Z+$@vdTkMa>2u;;vcoYdiUgwrZ=yXF6C?{xk{ z*XX5jnmBx<(Q^3NE%7yT!7lW%uCa^#DI_S73Gy^3T%~J;`vhBwc)*IoatpHy@1Kg? zR6AVnKGCWRJoO}$mjNhX{}=3ELw;_+r7Y@xm-$NuM=wQ)`MvbHU5mT0Bu1P}BY5;1 zSs$(Zcq}Y|DX}^8wk90Ih&jF|7de5BEd0AjqWImc2z;pjBz2&)(H+xFXV{8T-&rF8Q(9tCnF(q?`a+tnd(8UahonQ`R0GvZdd4Y& z!OBNS)UFN!sP({*g1N*K9(0358UZTgO6K)+nIlVIPzz44{5dXuWb4Y0eF#y?VK=wR_z}y&iQBA1ID_?X~M_9!WOS zM7O51+;pun1o;x+eBs1hI54`Ikm2`k6@Keb69M!UWGnxxIg`vGE)D>10#F@3SZyX% zMsJS@gPyvEt;#9=o?o3|HGxIFXgj3O7JxS#-B7QZIonSq*@qLXd`r&#Yl{O{oOs6R zJ2e!9C2N38`iqg|>P4byLlt}|9YLTLy(nU%G+*|eF9T4Yh5h-Ry_C>h2*$8CAMMe4 zEzauJRtl*1k@I=?3*!4cX|<+X=!2~XY3{z0Z7I1p`{!w2#bOIJV#aPky#`eHfr&Ba zl4Ge~?3Ik-f-=MZK7H6{1dFwvy@SKOl(5TH z;XD|y{OascAlG4<4+?G!kCP&^5hn8?0EEdP?&`x?{V^Du-PBD{6=%Znwfct~Qn zU%7GW=ysJ_P6pGfw8ncBQ@LhjZpWlW<}PSqt=^XYs*Q z3P5%qSaO{UAi%2jA_+|_Vb5uqCrQ_z>>cN`9)Q1)^dXaoA|0hvzAFi2Uo{KRpA4_e z|BzoPKxI$*{u#96A%!yeDN7e#-kY zF1n%Zyc!#*aXm4IL(|Bt+N5wlascJsp6ItYP&moUs$ZD`Sq)^f8~2C6 z4sJj9nLF}en`KIX?M0YVIXaVXJGvix8IC*`K~na;7Vew56;X9w#tQmcOr+9Ii*n)n zNT$P9eHuJuVplhV(I_YL5naqKF>bUCNnuNbEWS^^$B!b7_V3i_hdz7S_uh{-%91m0 z?stLV98RI};sGzcr*S?^koQWa_u|)>k7N0-Rv+2_$_az%*f4{WDZM8=15$3!I3Akd zDZW0}tc;rI!y%YlTHHf7Q_rN*lB6WTsq-Xf9aH_=SO#gMDvi6)|DoaIAOG?6S#(*! zBm=PRopSxwQx!y3k)yN^t57#VOv%mQWd5-^XF!aV!&y3lC zFGRbU--=!?zj6}0j{dkur21QJ4F1e*Ijk?=E`)*?$;S#nekmXM_dOkR{Ht2UM6n-5 zWxlbH#Jbw9q8?Kx>nMugs>$_TbP&gYtDpGb(9)|z-pORpz&2UtzqMB~gIkBa=ccA@ z0cui~!Y!s`s883MM;3sZ=T24-x{vv})y-eVcmVb5?G8rZt~Ps9X%U>9`hpu3(y`t=*cr$j*s= zXy{)sLq93`&fl}05cbN0l0y;i@R4^C6ow8qfp5{#E&wm*_K#j$TT-DvyGFkPs&H`iK&DnUF6twwP?+3E~TNpOw?{GxigbHfZX zyBztz3a|r}o6KW+=X_@sE%>Uap}~W1$&P5JB zwVIwepp31o?uFvh6Vg7Y0c!<1vzw&Zwghh81dBA+CE!z9+ZCN(?nQ=6F-qR~lIvLgY^5=@G)>q(jpY<6so zzb?M{J+EMMwl}s>du?p8lWBhv6zX8j$%)HjJ0c{&C&0U7u-{yGY3`78u)1c#epS`=+=PN z$R&W5#5n9)-54vNa&;9Q`EyeBlpLRf=L@Zi73&X3+b-0B^ zC!umOx>7!;9S@lWbdNpuL3*vcnipg*%|nanA7|vz2>*iPPhV|T&Yu18TWJoCma2Y| zBVtz2A^^B$O{^$jio$Xs-fDZFUM^6Rv3Cv%BCU!`P1%3P^KfMOE^_`dy&uq)4~@|8 zUKe^f34eRIO$?DOp=)l4++#O4js16WAoMuvaNBIcO_?co!R|^I)s*P3!g6 z{;)Akz%e3uvgZalmP)66yE|GIe*SG?#>Bj#cufyaG88`=5)!Sp!l(>J$hgO;OLKHB zIx67}X}jWUr^5ZoQ>6&Y(Re|jo**ZFp4Z+~Qe30GwvS-wXZi@gHI_t8Oj0#8c$GI! z{$&lVf@RUUPPIP}CA`2!S1lhAW%<)8Gv#N_O7L!D0e(VO!MP?M9~y$dU{g}@Hi3-( z`X@8y#H13VlvDR(dKn80_SBXct;f+)@h6`EGz)hV&boLuT5P!;ku5+jqgf#pyMG>q?K6bCkMTr{l8eg?)Yo3?}BQL%IZjF?ckTFwE$gkZ8GqgC)laMJrszBgCINj6|ckt;%THny+_kIm#eyP*gyGPyU{K zURz)-Etd~Qz-_2SF#H9UmJrzCWzI-5FPhThDjj<457!h7w2oBLc;bNxppSTN3Sqy_ z>IdKtPBNvH&|~PGGFD*&6@Jvc5jsbQ8>eFCjsEo#O4)$3a?FgJq}{Wlz7PfjDcTws ztIT<8o$vqvwZgIMXgsg!v=b$lplG@C4g~51h|8*_K+^fX3ekr7jNqF7PYsqJ0JdC1 z*pty&Rh7$Qi&G8^!R|YINhAaF=(1p>pm49+f<;uA46B~^aWwj$)lPU|k9bjPWhW+d z5OlNIVvhRX>MTirAuQzA&RE~Bh{Gj4|4<;jtpeu`ad~m_pXzF@VG9ed^!oxX=RR3x_3YKuc}Ms; zE@zB@5NBE^a^A+-{DnsYs8YM8sy*4E8wPTytR-xbMoyrCT?>NuUYJqUO7BaG{dg}d zy#R#^C#B9O+yz#E9_){gzRgXWlva&Z%e9D}!S}^NY&fbIznB8dNnR6kLwSMT+6n~u zd|YAIh3YL=z8nUhRscLaSL-x5tC!66yPe;JtM(-LznA|zC$`?30 z)LbL=Uew;3{P*GlwaFF4TsR-_?EcR8ZY|2pTl}J3QRZ6mIIZ{92rUYb__B)di?(t9S3AM_HghXjC+I`y=&K2muU2#SgEBeYW-clh@eRprZ~Rs@4y(G|!(;nC(-+F*bWe#64< zE)0H0dX`Y2NI78yl2hn$b4y6bK`Ilx?1`77#BFP_6^tm6i&Vvt%O`Jp`cDKi__W{; zNbn93jT>w$hI3d_;Ols8_U+0_>}2+rBMJI)t1tiAR00wq?0YO!ZhfVh_fq%`XXHl5 zt8)B&1ciEaDruRgT6PRqj+1}#5ZkHzY~7`3b*(Il-ikO_;sJ(;v1?y zQX{|`aLJG`OpXIK;^$nmO_pKH;H%;*grAg<1qm1cGyY+G*Sb8Ktaj zs*Iap<4#_=n2^DkL+Q(sp)TmR5YBm}&O0hOO0WIIylXg50Q>_om+pg0Ona=$m%*8fexsz z^zZ%|d5A3FWlNL$>v{OpK~<_Wbzj%os#2_W5ARoZtCEw-O5NZCbMM-kkKJ~4y#NDW z11SzKXLN=LuTM=X;{Ew1^d3cMJxzpy$RO4>9sAvg2ZkB38dz(t4dvp3ICQBLokd31 z+zZ+&zO`a3h`j`MR}n?SN=@T3IwWW|C(40SUJ3w3fWe_rR_K)*B)j18~9M@cliGf4d4_US~=n*L7kryM|R*-U03>X z(kIK4$gpkzbkas6Gj;8iBY}}9IjiNp_>t|a!d4o!&!0euydAb_U@V)U zEnF=+kx$w1t?+I%j45IC92Rqo2b%0~iPw$n=ByIhVSt2It5hWl>qnEaN8bT@2qmP} zydjN*s5&o;#6F6U51=bFew6}fB`4_P;QeRr#7`4?d|#=fHpQ)={c@y}cpgy<1jEKo zK7!2VZyTEd)Z#Szm=sBEk*By&s7eBVFk8D!Vu1?#dJR5FJ{ewknO<4x{2oW)Bw)*g zUunqI(kcl2H?;Hu`n3E~HzIK049vrPLL{ju7 zHn8U%?W2d#d7umEW3~39|7Jw9f8Gk(_tOeU)@oX+OYpD!B=AV8n&FyLk0T?yTqsIJv{DlyA(Sx=JCf zT=<74DwxKb&~gPIvW(EGe@zqBgui1wBS)fC(8+#W9>&<~;jRxR36G-55cmrF!g@kW zASBAwYas@0^7S3C$>~kdtWgK(g{$>BMr^gZQ|A?{sw==0iQRtkjS#)ZcjFepp|lB< zcNNY$DwM{Cy2v(N^;Pz_8uFKD_k18{42NrvTny6U7&&nz=+q>8V=X>^WO6Ia>MH=X zR{3dort=I<>cF6k0+RbrMb9e6jeeX-mUD0u3!-sXzvUT)Tm;tvG6`Q~tTB2CX9q1T z&uVWS>8Q?~@%Lik!wV9M49ioqxIx23m#7Q6`9?32(XWu)|2{7M@Ws)SaAS*}Q##5C|vdgt{nP-9LR5{68n@GQXXPJ-w&rR!I{-4#f z_e+F)z0MG|R=Z?t3F?Wutp=^Ef|puu?;Nl{^}E)(j3 zOjya+%!R;Zk5m^6$@GbXn~hlT&zY^nXy8xDb@EeafV>$E+eXD^AH8J(GEC6#$|dw- ziu6$GsSLuNmSLmfC-qbjnqb2qLJR}xTc+z~Q1u}rrx^{zFTD}a` zVu#(?jJvr*gy{27E=t{95g)Vk&^rR?wEON@-xtYsmdX$rHM#6xL@SSy0!Ca6+N#`w z5mW#otQVXZV;Kqscj1M))v3Z}4yO&NBanPSdMZb0G@%9CWgd-b{hL@Wa^>oeIQ8mX zaNA8AVSZqFml7KR@N%az=C}IUAW8FpTg5b>THNH3{)fep9Sj~Fcn^;sNmGv-m>{XdTx0=Nc( z0+N7Z=}DiupcEp}h1}`8_q+KRZ(}Bb6}z*$Nwc0ivcz4nT;4+r01UkQGAm=yd$CN~ zj{03)w@eO-4Yvr%Rw-~Dw#T{@wS-3m^QhhBWL8ciuZegLa_RZE{wZ#%gcSX`RU76+ zTM$R??M+>+T9M>%xOKD{qwjljovRyN3L@0^EMWAJTay0UH!)V> zYFEXs6FxMwWq_FeKYbs;dyV+VwzeQBjdUB)BjlsUgl@+gF5% zWx@P8Mqz4#F+l^=)ar0p&4Cjc6+77uS(fkO%_(<&iQ2JJZ-Jdin3~Jx^)8l3f`Dd{9Z&&E~5$OO` zNg5c;2eJ+*@k|A>i`r3xnK{ZNtRu{_U&$;!)M4ON*;W`Biw|N6djS|YyL7q!{gq&6 zkTBN(C+zll2OYs{-`01ewMzwyc+?p+JyrkSMBMHES!&*dQATF{*Jk3yp~}l*H&QiLd#&lTiz)zRwLy8e zDIk~ywnF2I;qXI#sqvqFRptDX1~X&BZh5DbyLUnWzQnEWB8elz)IyEfI4F|40r3gk z=k#!%88J&SOtq@D$uB|u+eD}vyUl~=sb%k5fa&iq0s9_x<>-^xX!Ls@qfG(yB)%Xr zJMxqd9w49FPghmA9{Rf?^;y_Px=G=&VKS=~qqio+0Ex_7m+pgMC72gAEfKbA>2%N1 zxI!ks;4tU>1_~q16}4LMG`n=hC0zl~8Fjz|H8H@D7xKxm;L)3I2naeVFnrf(RdlEK z`)+pEs-vorkY?nh+8f*AgSSF=!nv2QnqZG(`c!}v2PhJc7=k__!KoGf-EI#1sDlJdALJDI+ zRY~`y-G|V~8pACxGIcG4RmIm`Bw^`m?;Y*o!nMfN`{?LVJf&V;q1-He+pcUVk*&@8@U zXe%;DTa&M{?4Sw75wB}-|4_4m@y_F4TZ7V6jhAF^kCAE^TIo_$`azE=Sqx}h4Rf_$ z2-{ABKXwmz$RAWDJVEJW3ODL}cEWr<5(3KB|B8a@uqa-%kNw6T;}|cYpGWvo4s{jOoC5s)*z&r&AH$r+s|E zqS=Ze-`Ak++8_T_Wl89)IQ;f{7M0iu9~q8{Z#$xyqV0c?(#f+FLh( zA6^J~^_8;XGHPIee(ds1l@s>37|P+y{1%ep0JbFR79SHyG-IQ;2UyBM!W%>Uv6k+C z#g&aXzz6`|9VM6Lb}%7-8dX#BA3FaA*X<707P{7c*b;Q2MG&QTNeDDzn%p%$OP@0>4f|xyN1dIW3Xn@RKhX{1s4miRc=?V4jG1QK!%Gb|Kmx>* zj8(Y9VGYz~vE0dNBEM1FbYZ(ID$Ba)AngQXB~|n*ANGVIMW$xHmiv-hTjo3yZ_sj@ zITaGdb~&+Wr**MrTLFk!^v*RlUtn-l`JF)!AMIONQ>MPT!53@-K(4Qnr$%Y2w<0Vt zt9GfOrH>W@p?}W?Dll-jtn~R)7a};adAZ#Vz7tiI6Ihpgj5W_pO@g254g-$RDBVu{6EWx>a-qfSzW6ReKx-x-_|M=TwG2U(9DW8WrpSDE~N|r~w1bD6{jmT)jv93{vEP_ul>-G4*!HUlqKXbx7$3MjO?p3ERhp}X`+{EuO5|Sz_ zHXKO;>oAPJJ$aU9q=1k+<%Y(}AJR1; znx5&SzWDlIGJX}9Hm0mtftWM%M5N7-Oyu{@aP|_VYGWVqgQm3*W2MNJjG~V7``PxrEUfsP~CJaJlEV0z<8fD4R zWC?&=yMNuB57hm%bOgFMpudisAb08B9VBHP#^>L1 z(S(zE@}Npg*=p?38MJE>$@Am)KDo7HHIJo4pzs+F?5JBH6YgB(&gy53n_6G7Zm1nD z>@Yt8d;KL~{WIg|F;Lo1jp#uIj(mS#DRSvJS63PWM^O(YSg5{5N>A&9j(fCS52?6` zfhnRtTc$$B#K5mYK0D&m-u(Jr)zc_)^amnw3^&%6V=BcKv7wB&ig&^lMF$?rn3>LY z$4Yj<9#W0+d~Idd1_12G^0J4V#neWMy1#i^MqE@^OovIbW?p8cnVmWDnHOs_?t>f7 zZ7S8)1aaWI5)XSVo=n;bgfm$!7O|o6Ux^McLzIlhZlcOpB7T9`EL7#4aGYg>x7x3c z&|2!8PLCBx*fBp+?A%OA-aijdg@5WgW<|*T%2Hr)60z5xOmu0aBOCMEtxNR!-8Z7w zT?6L@my-s`A#|9)$bydNZXvHZr|8#i%u;W@iR$$EuhY|Rd?0JEVd`%n5slE5)lc_b zxt(CSVC%|uowx66{kA^)>{SN1UkOTcyhF5MK2nBHNtiRw*QE2d#;R& zZ2dRbYZm&LL$XMlv)e*Mx4PI&f|kCR6Ue#l)kF_dk!-})+Z^;Cv&fz&jtoz6almeG z9v=3)9^!n{sD;=WqOl zMI`vmuIdEFYJP-E=@Ytr+CyNox+Byo0PO07$z~0hoe}G-xC+J?uuus!(nX~49|&A9 zu18K*0i=LU@=?24@Dzb=NO2vo3*TquJtGx8e7P5(ssKqw{5X1>tK+uM7G*YETtFcl zHNidY`OF4p+4oviQ|rVyepo@!nu+}1Y_w2&15%JZr(3DWhL9mDqyvYfeLR|J)#B$1m-OhDrW~b{6M(+N$Fo>* zMg^vYP%>wwD)#c4jlQT1mwXSNzh;FpcAUmfdqIxghd z^}%(dA^HoyQzd0r<=#dvN8VpE+WJqN8+lppg$^3h5>}iTE<6u;jpJ8`RwXF^>^aYZ zMEdbwmn0nLf2ss#GQFRQz&j7{##_UCmby|f$@7Kb?DkQ3+!;n@ruOHpQ*{$E>k|`3 zXf~``!iz{VXllmyU9r*ZAKz9SRNfS1&^Q~qy1(vt?AabRxMK%}jzfqqYB2ZbupGf& z8`#zM>^sZ`hn7#xI^V)BRsu0d;QF*BWha2V`AHwGF_e981Qy8&gk~sKyB~g^gs&1@ zB{h|bIrwy;xNPzM_13PTlFMk$B<&nb+yi6r=Hlo$5t_0Q@u{zk-}56h_e{L=qD6}| z@j#!1H}bos8zFDgjL>`;0L4n`NZjM8&7Dw{I|Foh*tpCqNN@SJH~7j-oAkO3Y%{5-9cp6(|7J<0vL^p&0ct@T#@j$-)C(*h(2jk&Gp3^=sFk6GT{=v z2WP`9SCAXSVWMbj@sNE50qh_!TJ~E{PWY!XvN*+@w~JmP(2B}9rjeQMVQ-p%02L{( zg*1jpmgDWkAfHyl9dOi{vJ$2y)GZ0tMaQfx6`!5Z2y`0xk+`_{ZhF7V zKq5>krDeXSCb8;af+w-nxUqa=;kHE&5Cjm;lySBAwtzKMiie7yVbFqRO|;+O<)8S& zw4>zxT447Sfwz}Ua&H^@0@P0cN3#Z6*sx(dm=MWl;A2Fqnpdz1h;$v=OaNfc0x)k> z-#nKPMwzkbeess&E0jE$LP#ec+5YOkgqtvW68PCww*HX7!Tk)BVw&$^P_G%E%}-K{g_S2Cy9=C=;>a)@+STgW!RI{%#W_=>xmhxvCV-50M8j#j%& zOB?E9r8%hQ1DJv)c3+{sxS6@`>gM=b&i)t;`_G`ds?>kCZ=$YoI%mlJS`}_ z&XPIpWs2`&y8C^Zfr&-220E6xRBh!BJnN3@JsFf?Tet{4=z5TS)_PO9P}1Ut%nv^N zdzt#-qi1hK;EAQ%dY`TLE}dELnCk*&#HzgPiKWPxp{jY0pWB)&$D|F4*bX>E9sz$} zklV!BCfM;$2ulu2|xpi;Mo3dJ)H+KwPC-Mnld#4&kcYGrLCvr6GU#Uu(WI z4GVg)Kh8o)=%6C_7TG60EcS$?R|8$#Kj-puowKgF?uC%&#~co@ zT8bx~y<&kJ`ou+R=Dzy|6BL%Eu-QvfnDCVy|LwnXmi9VQ3WEhixgRXGWO;}IS(Zvw z-0R&tfZ4q0f>IPKnb_z`8p4Op1zsrxLE2EVy zyr|NHpN^|4qr|V`tLgZ}Key2*0aW+q3Fo~-;lRtv2X?O`HOi~YOXCbKh~8H_j~&NG@(1AUeML1i>Kq?U;FVUcTutjequ1BwGL|JBFlBC>tC3% z8soohe?jTCr{C4}kg2z5BX=$QG~>b-ZOjRTA@sVdFJykssV&5 z)bBl6Xn)GQA>k{V%${u!8K}JOThGjy@-XNX+DH>>^N<_Hi}DwK{6e^E%DwBTS7(Di zFXZI!i4Co+6#Kev1K`dFp9oZTGjy#s>dULN0DoQJ#D(*ZhH<}0yb zH$FY1KK|Bkehbe&`Ba{!IuJqz$38(9{{AIZsL>8)ADsh~`?Lwt%0fy_sWT48FFMhf zh%~#@e2a| zV@$n0uHSe6{&^MLSL~!OY4CY{t7pMjf^z-FE!qp_me2a!u zC>8MV$oY%5kYr*)ne-AyAWGY+bVfRcaqa3n?Q3Aoz0PSCy9s<-y z#Jw8(gx$<^fIp8P?qp;d-Kx!vCF1OiJ>wR=hsWK972Yr zWu>@d2VnFb^WP^4v7b4G2UD5@6vKM?{|*}VW^>l6*4%HF8Xw1xv)_QFBxT-@qdFZ5 zN~<(k+q{G;V&5m60wQhe9hW+H?ceP9`_^B+p6-7B?SV8Aq2Z}jq~Kac;(l*P$_&{W zB-084k{zOM=yCVbGKDz#9+Yb#ov7 zg0+gjK7f9`PtodrL`}8ah}_0+X^-<~Zk)R=>S;T-0iGzRa~|M-{*_lAH8~jH-|!}` zeKh}GX6>ce4hNM(m29T0dqp7nD@!AFro@_o-OC4eOZ=HD&6_sA3?e^NTG7&&hyzjjjV@}fUR%eB0)B;;~`AApueG2y+Nu02i?s_M;36dR1jM&M?j!f}) zuU=}garQ8553WYvSUM~+4t;hI8 z(0ndGvhk6rqY)eym+h>#&fxg^$4xp68>4)93b(HIWfeqrSWrTSKNw2D3ZG3#7s&p^ zaee!rAYecQNiPe@gBZ4Lcn9oxYhb%V!yPK?xGV6`w}Fwt=aAX^bceJC&;rnFaZ)UvT0N_Hzw-+Vg1*((I%o~suNGB?v-Q1V(R#Pgl(_s5 zOCDQS{OFc9kDq|-ivO>q^k61(g}UB>fpJ>dW4))zQ6fnjt6C$ce*1pdBV-5bD-WO{ zP;n+`c&&DGsFr%g6{0^PZ25MRZZfi6ck=mX z;C9&|Tgd|~@D?rs)jyc7&{Np!`=mK1Iu3Md<{K3!C|SC+ir>XaR#%ZWRa}R@!Hx@W z9gJI720m_3{1acd0EET;y-HX2(-Oo- z2(8P?&RDn~melFB`%o=eV11qE@?-N;Pxi+wz5iXsJi0A0!_B%4`%~}k3gYnlt~1=l zwgdD#R>*;5{`W9=;8J5rvv}&iMnhqCiLgPcm+mF3Gm9@SFH&+xshx}0wZez^`6E#D zC3uKFT=exmjA|Zk)#C^FheDqC)~CrOUl&>P#P?|;LDyWz9}_8m$+-OUQsSwV;sWWk zW=4b_M&j=2LK+ve1UyYDH&=8oed69FA4VjX9TLiaDCS6nn`2WR@&^7j;t=L&nT~Ru zD6g0R;HC(URr#2^DXKQwJe{gJ&+|S06=0qWs8pcZyJ~c2`V)YpB@;YuhFK|T;qq$y ziumwFbe^2uRq3OuYJTT~}S_yI|rb&Fo=W5X5uF zKB#5kU{g%s#5A?zG|SJLZN2GWq@sU*p5dnCSz8h(KrvGY(RisJ+DytMk)8pKox6Ri z1-Bze3~Q9e$Taay>G&6BmW;zzqUFrZt#G%XjNP5>zQbKf@kBdV4?$Or0k5RasocaA zWS|G*KqKRvnef;L0nlzHsH=Y=voQcTY|rwAPb zB?Tk1=d{tSD1g{3S7Zk|Bc%CoorQ4e-BiR$}}sJ@1dw9`>(04trE( zB<8FumZ_61(GDl*Q-dX=dWGB5C2rLweGo5|fid7BrvM-0h%vg=`k5lY1!<%^8mUs9 z9qkiDs+jygW1|bYuxff?8m?%I5?hzX9j{|dK>KXMQbaRZyou+#!g>X;{lP!NUsS?( z>0-|HOHy=XG#g8xgJt_qj7n@-g6tU*c#a(tYchrtUQvzzPyjT5MPwq;e#pw!o^t+! zW$BxywE4DobqFJFe?#bG3y$)DA5)g~L{U4>W%9*jwKjPWV@FhMp{me-ET*y+j`n;p z?E0DQGjUJ3?WFB6KGav6*uywSB3KSsbNWl)VXeqSJGiuo3aqfe*b-}EEQmfxh%W1& z=mtgP!p#tc2AY6-Oo&q#aeq}Zq=~2dYNo!7CGxb5t@?TIAVLX>Vjj=vl$4q2!BYqh z+ao>YGm_&`rKhofAEEhokk>M{3%KL^h%jzDMnh`nCJ=EE$N8wT%8$R}v$JLpmw09- z2b&dDcMG_!tEJ!wZfQ9Q(Z!}p8E2CxtmmZulhlKOd22>`5BNc9@ElU<1uE^=`xxjf zXo$h*r>2S~Qe1_AbG=-q()(!bR9u~#D*SjoVYA%d!mAuE^toNE9T{G;Yp%93MyXvr zk4v>J@m4FT?h)XQ8(Qg<06`)p_sbaCR)sF^c7qE%2P%YVhIC&3_C8#u7UJElV*QE zNfiHXy}FGyi?oavd1FgM5@i2VqBgX#v(GW-hZVV_dI!f2-p3HuVoKrvyjgv{D&l6H z|6!^rJz}EMZ^4DkOZtb47yr6O^~gPmE80T}dLQ=H`^Mrd1z1ApuudUvHi^Moxdl0~ zv9YPh=rcX6DAC<@U9~v1u#q zzv>n=)lJ-_+CI(BiPaK6aH*bb#qM|uD2PQ!ik?{IxZl2{PM*Su1aHeq3{LK7viR44 z>1b6)PHsCOXHpMpjB!&M(QKwgQn^S>8>ZcU=Q4_tj6ohdQ%~sHeg(gm>R=#i zHLIRHY_WU~g$46L>1pFBGnCUXX26MA4(HYW&AhJIRQ9}5dYP3}<#w%9yWA@GbIe&O zU`fZCWqn5JC!_1L>*#f=qaju)!bConXDW%HRY;P8n~hjb4!u;Av%IzB)E)ib5z(?<9@}u{b$W7Sh3**f|Y2}EX z_XP_o?BS-2X_=4S7-wo~B2xU{UMxxsisqDCELs8X)L1DAte<5lGP*)JfTEAHy}uA7 zsl{prbov)RnKBq;^&IguAYZYC@v%2O{K$+b6|#$cwMkiG8QK^4F;9f)(6L^V9Q;_P z+$WBx)YoDQcwvuK1q_>_8g+=ss}PJPpcj_V^Gd_dCyywiX0)w7gx}jzUvCDEfr&^u zFp|8#F_c6jKOw`Lk3%p|jjVtUMNeh{Dgkj6KLorfTiq-On5XmkZ0Yn797GASB#ARC zsI|&`rOnIueYl$O&w$_Ua^=An&K;SY-HO9~onV4kz)gKap+3plh$V92|o2`_}FB}nDvCU)T_tChiP`J9*<+0mSOEnko z|DK9?Pg=z3Q0OkYKXHl24@K7+Zk5#&jSUK-ww@*1st~NFt<${&o&4C?1~=torWof( zPy~{07}0bLhH4Z3nJLeJ7iD|+AA&>97 zz-7|LGRd;}CdAc8QAzYo2g6YBZ`5TI#ZM+S zwoaee=>C*f+~0^@L0k;x3j`+39;`m&Tk?s~sekOW>&PdrA#X4~#rv^&3;s6i5B8!7 zE8M%jW5;wN&0@IEQ}ezR(;pEx{pT*nn_H*xy(qAB6{8)DM*UA|i#;z(fA}dXGma9? ziUdvm--e?@^Y68Ph`e`CJShVEZkF-q@=xRlXEnhn{8Km&hV48y;ss7X_2r>Q%cX%V$G5ihxiXa4c2*L=a#5sIkrqB99zUb zj~F~(DXuA1?_NmK%6vcJsVW=!#_MGVikY*ng*A&7r#g@I%MP4g)9gnjUWDZo6vcSb zvM*D-RJTl8;9qsg;I?Gkz%yS51S+iE@3ACo4+)dY!FlM|#v4-Aq3nO8x&;Bb6kx$} zIM@u=Yv?zD2=qNqwI-aEeP|dQ8j>EJ%8&9E_(zX`LEW27!A|L|(u6(y7cJA?2iB23 z(x_$gyUonzZ{rdjt59 zG|_d+1yInOKe{6wCG_JiXM;38=(>rn*vq)()WI!bdeoDU{PO;+It0`MN_Ip#?wFg^ zOp0o#LX1+ad{n=6r}b4TP`KoH9r`$(tV8AWlD)lou%>HW`$k(~`4$=DHK(|pY%9vqyPQ^TzKhsam{ zcK~E}$JJe(*NdyK_{UYurwpObUB=B??c^R?tUUm!?Iw=*Z3*oJ+e9eqbGo+Ji&6&R zFQ227&*SGu9@E0s=dGtN@ukN}`^~uT^I%(zm^hXmXvc-DLL24z29D7|ToxD!>t*%h zfGG$fj8dF}vW^?%&BOco15-~JuZ#ibg3uq+{+f~cmMzR1{{k;jGeQ|Z^jKK-csn{& z27unAsK$1huyuz`sXALG$V2I2Mp@3hf`TqjX80Z%6WTc+q~XF6i`Jj48I2N|Z{vtS z#0H;=6rZ-B>d5S5ilF4&ABYd1*gO+WZ~k{9C!#0(g6w55M#Se=;=`^HLRr_gfo$f| zrGubS<6iK_>?i@A=%Z~IMoN!~{%ZhDR9MvzKm&R1eBgI*IU&(UXgN0QPP4K}qQr7u zf+|(sWh}cOb+r&q!gC~=k~4M;XGy(Rn)!cg)?pI@Dg)#Dt z+G*}oVF^4x{pFWuov6tz7a6uO$U!f@uj3D$kFdf}*n^el$gNZC+dhy9=Ntk8C459} zU5cIScE%wbb17(RQA!u|U3h6wigh*N0Rg`v1f#L9pBO^=f^qsZ#}LIx@(BW14>1pa znunb2lJ9*>wgijOd)rBZ&s7g%4(ne^Z{lAxEInh#$w-T%-cu~o2S2&w+t=XTeh4(- zi+HN_KJMqbz)Vk=V_G<>lewSx>|oYQcNjeOdTz=xvL$gmuZX*z2t{y}mAL;4kDw@# z7roC&tyL6>XK(e7A5n7qmB}J}r1$>S#K}!XvSCiM#JGp6`RtXwR`2hbRfT_@oh<}f zwuaLJ56y0X7BHu@1-%;LiU=f2$fbpp$fLZ#K>n=)MkWD^Og<`= z&q6_~D+laE(}swP&I*)tuNQzujxbOp9hn}bLY6qDPb1WVjgbt#0z>|xkM!;|&|k1K zqCXAYMSY=8Ll{NrCsPY|)ny-`442pAF5~V4gqi~OXPEwakEm&I4a+9`5t@b)vn)d?`3cubO@jI3jaJi=_40S#1k-F$0>F=UMCKaU>762|FUTvmXg(d7ACmM%}B>b+iXN_5lXievny#wJ?GeHk3_f zTX#)vU`<*myI~;M;E5RNTb+5sNBNT1;dOoW(zsz%V+Hd}B1GXLBs2`xQartZ502al7s7SqxCXo1Yd5_^pVBUgRUM{@fT@2j2=u}tv zP`fWnzkzn4qN5FRWbqp3Tia4%rwxBa>!igVcfW~JHlG{(?U0-*qNVeJ%xpR(p!M@^ zLbDh6DI4m!L~(jvKEpLjw?? z^xb``iS@gC;&^nT*i(8d~Wq@ZGST#a;A22 zaFGJ@(*nw)dQo{m5V(r^;8B~fpOPspw^6+u&2FA zYJv>W!ZuIO#JrlL=r!H|96Now>U7s%Lcpk=9LE8N#+SG$YlQUTgc%lTjPe$A0C#Iv zU}2+uez?~R#8;w0fvHpFYftI$uE zd9{*l++#02NF5%eI^279r8U7>a#2q=b|5}S%9u{+C+^!pEBD1YJWML2eAfh94fgdY zT!MMOToXGYkbPlV=PbXn%Ay=q^BFGEwnnv6+HunKQ5`o>J9C{+HOb*9xuI4DGl;uP zY$F{et(BgNnO(%KN-X)&sWB`ye{CFe>)m?VC6UQ9h1#z5bM=mZtC(9tIw{+ga@nmM z61x?~0Of?{%E#}`BU44O7{e4b7oJgg=nR^4Q}41p5qi5bK5wRyO422D1%1eDsPP4 zoGtG|tBDq$!NosD*M-}eP1CqcIZI13`{Hjw+kE=Tva!ZAArsHq%6l>49A}gO&|+;{ zkD0#T(4%%VzER+DIn^+Imv>{a4fEwPNa|XkUQZsLK)rkGsTGO|@6NEKb+5oNvOaj8 z(vfq*tC;oik!?9j#n-9w=v~^TFl*nd0Q|~DU#QKDdGVWO|6UWdI|9|Lt)_s76O?zF zOnj$+2ayuLbVZuvJ^iw{GokvzQK>~zS^&MABvl4m#Yt|Tat(g%DAfWW(<~yfbYy!3 z_2qB%1_(NW^%8ea7tI?_;HFJ&L@~8P+w=D^e_rFF2!;{{-T@PS$%)oey6f3Ry$ zFEA0v+lOyVDiuo^>!2l1?+^DC6?3_GQkX+{GPpAUF*5@>n|JAcK0OIhxeP4!`8F58 z!ykWVrZ8hWGC16sSjiQAf4=9O%Sib$NiKdrB7s1BMc;ymFY);*|0%)$aoS1Ic~dPv z)Ld(}H_77HDm;F2ex5|c`>yl6XZs%Q_43G{UvmTk4pZ_v9LavIe|;n$Hk@Pdh4BR! z{;hT|>ct-%sNSSbzJD|Pm%4w|&9U#f`SB<`Ul!_}tHCy&9!*S4KgUB+dQqHIfhqyI zMjT~IU!=o0<&Djt>CWS0owD`2C(!$A@4#0=Q6w(NqI|jxcK{|N5x^M_Zcr`Ullx_{ zS=dd9VYxQL1G!*`y0y(Cajqtz4OVnj&u#o<=u*W3EJ(xyKm;2~{kDPIBGp?#@bq-| zTg;08XfxwfvjPA`-bd4aw7?OE*IpAo5+(vC1TWr~qe^ zgch53()`<-g_l*o_dtR}K3=if&k5E z=8(Tgjne9Q@@tfZYx~PO$S`G4Fio4Scox&d~5S7vBW#!gB|=2Z}x2~E8M@htiVmF(|M(B^S# z#F0XbB^@EC=${pkn@pAO<0}Xi1Kmw5(TT^fSD5HhW?7(@R{jkRrmS&csLL4$T&H(| z+!O0cI)hY@D(>sI$}tn8Z3F-S+4uo>w6am(0NvFjBld+UgYE<<2StW0R^UYI=+Wv=YSrlI$uDi! zC+;6`d`(?lSo;`L*9AQvSXx%UI<5|!lb%E=IDl%`oA39Nw2qz(@6ox<`1N!~Kh|u8 zy?J1_{M{vzObkW=&o#_Pua2V=_tM)+ERPI(`8|Vhi>X;0R79AtiUAE(CKp+Z^8PGX zEx(_?(JJ^=k6v}%@G3Okenm0~J*-)E=PcmRL4?d;C_8d(Xpy<8*N4xBJq;w5R&l!E zZel$+;dVD*tp1_NL##6WvvT%CC`L_)*YGdE(6EF^-exe?lu-Ry5%EzgRseILA)`2n zF{5TJ@_|-R!DRm3E03-%pcY?5JF-*gu9oh4>5Y;gyHx=|!QWta$bBaF*&%>s8* zDVY2nh{)S3+!Uw_m!Q~%y)*$(c+yRh0wYWW`(Zdl$8r)*W|CnAziJ#p?vq%FGf2jX zm_^EFpxrlx#qyH#NHgC^{bIB2CjY`8ejUoWUAvU!OhjI(ioe@{u**W|e|cwLbP;p+ zw8t4^xY~0aeLHq#Vv}YAy%GXK37kx|*u~}#Vim^8Lz&UnK-G}(*T!|*ziP^xnJw!2 z2}wyMq|Ih9fiz1;MfC`(1TM10Dns8WId5l9`*WYC{<%KeViEC8BKNL{iFrb(5aJqu z^vaF0r7hQg`@!TRs50Z7a6{l#oJoJxjstHy%Rl!}Y6g)7sS#`0W1n8GP3tAQG+@sk z*p#(jY9DDCV5vQDJ#sCrN7;zBbl{!br9r*V63{WgDYu1F)DS-zJy#3tU<|rEOdyJ- z>|R0NN(BbScX13>-cSI{{C-2gJKHG=gjk>PSpoc4{JhfNALEH$_uB}wpr0O3J74~^ zy{GbUudeR(UVaYGRoHsnM-+EvdE9*j9BzDWkpUoPpYLQoU*z?$K3Xy8mNNM43zpb4 z+Ep%?r6GvL3Z8#vxWOchT;(Hc$o5x+Yo+R@5Oy1rVf&`4A#TM0AgqxEsc^9Bh$$<0 zqvWasmxWR}aKYdP(9Z^#p5u3>-FCrsNPLEoLup0TOTuy9iax^twOQ zCz%+}oPzXxiODlsXsR4+ZC`;^IZQ!C#Yn8T2&BN`H!fw0u#J)ibFD*8`4P#N#Hq#E z*^x}FH)%;G1?O>PtblugNSz%jQ+>fvwFDU<902Gn?Z&MOFu@)+NXMdWNAj+0fFLK7 zp+=5XgACq6_7ep9!~{Cy1b56Pi+!k4W_LS>c$Na+Op7U?O6e>6I%%J$he~h!Y b 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 literal 0 HcmV?d00001 diff --git a/content/docs/monitoring/metrics.md b/content/docs/monitoring/metrics.md new file mode 100644 index 0000000000..51fed3ecd5 --- /dev/null +++ b/content/docs/monitoring/metrics.md @@ -0,0 +1,116 @@ +--- +title: Metrics +sort_key: G +--- + + +Geth includes a variety of optional metrics that can be reported to the user. However, metrics are disabled by default to save on the computational overhead for the average user. Users that choose to see more detailed metrics can enable them using the `--metrics` flag when starting Geth. Some metrics are classed as especially expensive and are only enabled when the `--metrics.expensive` flag is supplied. For example, per-packet network traffic data is considered expensive. + +The goal of the Geth metrics system is that - similar to logs - arbitrary metric collections can be added to any part of the code without requiring fancy constructs to analyze them (counter variables, public interfaces, crossing over the APIs, console hooks, etc). Instead, metrics should be "updated" whenever and wherever needed and be automatically collected, surfaced through the APIs, queryable and visualizable for analysis. + + +## Metric types + +Geth's metrics can be classified into four types: meters, timers, counters and guages. + +### Meters + +Analogous to physical meters (electricity, water, etc), Geth's meters are capable of measuring the *amount* of "things" that pass through and at the *rate* at which they do. A meter doesn't have a specific unit of measure (byte, block, malloc, etc), it just counts arbitrary *events*. At any point in time a meter can report: + +* *Total number of events* that passed through the meter +* *Mean throughput rate* of the meter since startup (events / second) +* *Weighted throughput rate* in the last *1*, *5* and *15* minutes (events / second) + ("weighted" means that recent seconds count more that in older ones*) + + +### Timers + +Timers are extensions of *meters*, the *duration* of an event is collected alongside a log of its occurrence. Similarly to meters, a timer can also measure arbitrary events but each requires a duration to be assigned individually. In addition generating all of the meter report types, a timer also reports: + +* *Percentiles (5, 20, 50, 80, 95)*, reporting that some percentage of the events took less than the reported time to execute (*e.g. Percentile 20 = 1.5s would mean that 20% of the measured events took less time than 1.5 seconds to execute; inherently 80%(=100%-20%) took more that 1.5s*) +* Percentile 5: minimum durations (this is as fast as it gets) +* Percentile 50: well behaved samples (boring, just to give an idea) +* Percentile 80: general performance (these should be optimised) +* Percentile 95: worst case outliers (rare, just handle gracefully) + +### Counters: + +A counter is a single int64 value that can be incremented and decremented. The current value of the counter can be queried. + +### Gauges: + +A gauge is a single int64 value. Its value can increment and decrement - as with a counter - but can also be set arbitrarily. + + +## Querying metrics + +Geth collects metrics if the `--metrics` flag is provided at startup. Those metrics are available via an HTTP server if the `--metrics.addr` flag is also provided. By default the metrics are served at `127.0.0.1:6060/debug/metrics` but a custom IP address can be provided. A custom port can also be provided to the `--metrics.port` flag. More computationally expensive metrics are toggled on or off by providing or omitting the `--metrics.expensive` flag. For example, to serve all metrics at the default address and port: + +``` +geth --metrics --metrics.addr 127.0.0.1 --metrics.expensive +``` + +Navigating the browser to the given metrics address displays all the available metrics in the form +of JSON data that looks similar to: + +``` +chain/account/commits.50-percentile: 374072 +chain/account/commits.75-percentile: 830356 +chain/account/commits.95-percentile: 1783005.3999976 +chain/account/commits.99-percentile: 3991806 +chain/account/commits.99.999-percentile: 3991806 +chain/account/commits.count: 43 +chain/account/commits.fifteen-minute: 0.029134344092314267 +chain/account/commits.five-minute: 0.029134344092314267 + +... + +``` + +Any developer is free to add, remove or modify the available metrics as they see fit. The precise list of available metrics is always available by opening the metrics server in the browser. + +Geth also supports dumping metrics directly into an influx database. In order to activate this, the `--metrics.influxdb` flag must be provided at startup. The API endpoint,username, password and other influxdb tags can also be provided. The available tags are: + +``` +--metrics.influxdb.endpoint value InfluxDB API endpoint to report metrics to (default: "http://localhost:8086") +--metrics.influxdb.database value InfluxDB database name to push reported metrics to (default: "geth") +--metrics.influxdb.username value Username to authorize access to the database (default: "test") +--metrics.influxdb.password value Password to authorize access to the database (default: "test") +--metrics.influxdb.tags value Comma-separated InfluxDB tags (key/values) attached to all measurements (default: "host=localhost") +--metrics.influxdbv2 Enable metrics export/push to an external InfluxDB v2 database +--metrics.influxdb.token value Token to authorize access to the database (v2 only) (default: "test") +--metrics.influxdb.bucket value InfluxDB bucket name to push reported metrics to (v2 only) (default: "geth") +--metrics.influxdb.organization value InfluxDB organization name (v2 only) (default: "geth") +``` + +## Creating and updating metrics + +Metrics can be added easily in the Geth source code: + +```go +meter := metrics.NewMeter("system/memory/allocs") +timer := metrics.NewTimer("chain/inserts") +``` + +In order to use the same meter from two different packages without creating dependency cycles, the metrics can be created using `NewOrRegisteredX()` functions. This creates a new meter if no meter with this name is available or returns the existing meter. + +```go +meter := metrics.NewOrRegisteredMeter("system/memory/allocs") +timer := metrics.NewOrRegisteredTimer("chain/inserts") +``` + +The name given to the metric can be any arbitrary string. However, since Geth assumes it to be some meaningful sub-system hierarchy, it should be named accordingly. + +Metrics can then be updated: + +```go +meter.Mark(n) // Record the occurrence of `n` events + +timer.Update(duration) // Record an event that took `duration` +timer.UpdateSince(time) // Record an event that started at `time` +timer.Time(function) // Measure and record the execution of `function` +``` + +## Summary + +Geth can be configured to report metrics to an HTTP server or database. These functions are disabled by default but can be configured by passing the appropriate commands on startup. Users can easily create custom metrics by adding them to the Geth source code, following the instructions on this page. diff --git a/content/docs/tools/Clef/CliqueSigning.md b/content/docs/tools/Clef/CliqueSigning.md new file mode 100644 index 0000000000..a4e4cf33cc --- /dev/null +++ b/content/docs/tools/Clef/CliqueSigning.md @@ -0,0 +1,393 @@ +--- +title: Clique-signing with Clef +sort_key: C +--- + +The 'classic' way to sign PoA blocks is to use the "unlock"-feature of `geth`. This is a highly dangerous thing to do, because "unlock" is totally un-discriminatory. Meaning: if an account is unlocked and an attacker obtains access to the RPC api, the attacker can have anything signed by that account, without supplying a password. + +The idea with `clef` was to remove the `unlock` capability, yet still provide sufficient usability to make it possible to automate some things while maintaining a high level of security. This post will show how to integrate `clef` as a sealer of clique-blocks. + +## Part 0: Prepping a Clique network + +Feel free to skip this section if you already have a Clique-network. + +First of all, we'll set up a rudimentary testnet to have something to sign on. We create a new keystore (password `testtesttest`) +``` +$ geth account new --datadir ./ddir +INFO [06-16|11:10:39.600] Maximum peer count ETH=50 LES=0 total=50 +Your new account is locked with a password. Please give a password. Do not forget this password. +Password: +Repeat password: + +Your new key was generated + +Public address of the key: 0x9CD932F670F7eDe5dE86F756A6D02548e5899f47 +Path of the secret key file: ddir/keystore/UTC--2022-06-16T09-10-48.578523828Z--9cd932f670f7ede5de86f756a6d02548e5899f47 + +- You can share your public address with anyone. Others need it to interact with you. +- You must NEVER share the secret key with anyone! The key controls access to your funds! +- You must BACKUP your key file! Without the key, it's impossible to access account funds! +- You must REMEMBER your password! Without the password, it's impossible to decrypt the key! +``` + +And create a genesis with that account as a sealer: +```json +{ + "config": { + "chainId": 15, + "homesteadBlock": 0, + "eip150Block": 0, + "eip155Block": 0, + "eip158Block": 0, + "byzantiumBlock": 0, + "constantinopleBlock": 0, + "petersburgBlock": 0, + "clique": { + "period": 30, + "epoch": 30000 + } + }, + "difficulty": "1", + "gasLimit": "8000000", + "extradata": "0x00000000000000000000000000000000000000000000000000000000000000009CD932F670F7eDe5dE86F756A6D02548e5899f470000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "alloc": { + "0x9CD932F670F7eDe5dE86F756A6D02548e5899f47": { + "balance": "300000000000000000000000000000000" + } + } +} +``` +And init `geth` +``` +$ geth --datadir ./ddir init genesis.json +... +INFO [06-16|11:14:54.123] Writing custom genesis block +INFO [06-16|11:14:54.125] Persisted trie from memory database nodes=1 size=153.00B time="64.715µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B +INFO [06-16|11:14:54.125] Successfully wrote genesis state database=lightchaindata hash=187412..4deb98 +``` + +At this point, we have a Clique network which we can start sealing on. + +## Part 1: Prepping Clef + +In order to make use of `clef` for signing, we need to do a couple of things. + +1. Make sure that `clef` knows the password for the keystore. +2. Make sure that `clef` auto-approves clique signing requests. + +These two things are independent of each other. First of all, however, we need to `init` clef (for this test I use the password `clefclefclef`) + +``` +$ clef --keystore ./ddir/keystore --configdir ./clef --chainid 15 --suppress-bootwarn init + +The master seed of clef will be locked with a password. +Please specify a password. Do not forget this password! +Password: +Repeat password: + +A master seed has been generated into clef/masterseed.json + +This is required to be able to store credentials, such as: +* Passwords for keystores (used by rule engine) +* Storage for JavaScript auto-signing rules +* Hash of JavaScript rule-file + +You should treat 'masterseed.json' with utmost secrecy and make a backup of it! +* The password is necessary but not enough, you need to back up the master seed too! +* The master seed does not contain your accounts, those need to be backed up separately! +``` + +After this operation, `clef` has it's own vault where it can store secrets and attestations, which we will utilize going forward. + +### Storing passwords in `clef` + +With that done, we can now make `clef` aware of the password. We invoke `setpw

Aak(K)o`I}mJLBfE5HGZ>G5Q9JYAX#|D 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
6&BKVhsN+wqlc&(hd8s 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%0D$VHI^7E5=uqI#noBScQ3=?OU?kv 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�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 R-wTkxJYD@<);T3K0RZw>pW^@k literal 0 HcmV?d00001 diff --git a/content/docs/monitoring/ethstats.md b/content/docs/monitoring/ethstats.md new file mode 100644 index 0000000000..bc27d5a171 --- /dev/null +++ b/content/docs/monitoring/ethstats.md @@ -0,0 +1,46 @@ +--- +title: Monitoring with Ethstats +--- + +Ethstats is a service that displays real time and historical statistics about individual +nodes connected to a network and about the network itself. Individual node statistics include +the last received block, block time, propagation time, connected peers, latency etc. Network +metrics include the number of nodes, average block times, node geolocation, +transaction counts etc. + +These statistics are presented to the user in the form of a dashboard served to a web browser. +This can be configured using the public Ethstats server for Ethereum mainnet or some +public testnets, or using a local copy of Ethstats for private networks. This page will +demonstrate how to set up an Ethstats dashboard for private and public networks. + +## Prerequisites + +To follow the instructions on this page the following are required: + +* Geth +* Node +* NPM +* Git + +## Ethstats + +Ethstats has three components: +* a server that consumes data sent to it by each individual node on a network and serves + statistics generated from that data. +* a client that queries a node and sends its data to the server +* a dashboard that displays the statistics generated by the server + +The summary dashboard for Ethereum Mainnet can be viewed at [ethstats.net](https://ethstats.net/). + +![Ethstats](/ethstats-mainnet.png) + +Note that the Ethstats dashboard is not a reliable source of information about the entire Ethereum +network because submitting data to the Ethstats server is voluntary and has to be configured by +individual nodes. Therefore, many nodes are omitted from the summary statistics. + + + + +.. UNFINISHED + +Reporting URL of a ethstats service (nodename:secret@host:port) diff --git a/content/docs/monitoring/grafana1.png b/content/docs/monitoring/grafana1.png new file mode 100644 index 0000000000000000000000000000000000000000..24afabebdddc70b907609eb1fe602f1f457e3279 GIT binary patch literal 122043 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%0D`zsCdK5 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

!?FPoy!*wywn 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 L=VT)Q+x52NfbUSNokf>{CGqFk(k) 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 z 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ⅈ`EUb=9rPDaN{29OB&}Xb?R#t(Csv&^|Ue-XM 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�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 literal 0 HcmV?d00001 diff --git a/content/about-geth/about_geth.md b/content/about-geth/about_geth.md new file mode 100644 index 0000000000..c66810c594 --- /dev/null +++ b/content/about-geth/about_geth.md @@ -0,0 +1,86 @@ +--- +title: What is Geth +root: .. +--- + +## What is Geth? + +Geth (go-ethereum) is a [Go](https://go.dev/) implementation of [Ethereum](http://ethereum.org) - a +gateway into the decentralized web. + +Running Geth alongside a consensus client turns a computer into an Ethereum node. +Nodes communicate with one another, agreeing on the data they should each add to their local databases. +Ethereum itself is the network of connected nodes running Ethereum software. + + +## Why run a node? + +Running your own node enables you to use Ethereum in a truly private, self-sufficient and trustless +manner. You don't need to trust information you receive because you can verify the data yourself +using your Geth instance. + +**"Don't trust, verify"** + +![node basic](/assets/node-basic.png) + +Your node verifies all changes to its database by itself. This means: + +- you don’t have to trust any other nodes in the network. +- You never have to leak your addresses and balances to other nodes. +- You can use Ethereum securely and privately. Most wallet software can be pointed to your own local node. +- You can program your own custom RPC endpoints and make your own modifications to the source code. +- You get low latency, fast access to Ethereum. + +A large and diverse set of nodes independently verifying new information is critical for Ethereum’s health, +security and operational resiliency. + +**If you run a full node, the whole Ethereum network benefits.** + + +## Node architecture + +Geth is an [execution client](https://ethereum.org/en/developers/docs/nodes-and-clients/#execution-clients). +Originally, an execution client alone was enough to run a full Ethereum node. +However, ever since Ethereum turned off proof-of-work and implemented proof-of-stake, +Geth must to be coupled to another piece of software called a +[“consensus client”](https://ethereum.org/en/developers/docs/nodes-and-clients/#consensus-clients). + +The execution client is responsible for transaction handling, transaction gossip, state management and +the Ethereum Virtual Machine (EVM). However, Geth is **not** responsible for block building, block gossiping +or handling consensus logic. These are in the remit of the consensus client. + +The relationship between the two Ethereum clients is shown in the schematic below. The two clients each +connect to their own respective peer-to-peer (P2P) networks. This is because the execution clients gossip +transactions over their P2P network enabling them to manage their local transaction pool. The consensus clients +gossip blocks over their P2P network, enabling consensus and chain growth. + +![node-architecture](/assets/node_architecture.png) + +For this two-client structure to work, consensus clients must be able to pass bundles of transactions to +Geth to be executed. Executing the transactions locally is how the client validates that the transactions +do not violate any Ethereum rules and that the proposed update to Ethereum’s state is correct. Likewise, +when the node is selected to be a block producer the consensus client must be able to request bundles of +transactions from Geth to include in the new block. This inter-client communication is handled by a local +RPC connection using the engine API which is part of the JSON-RPC API exposed by Geth. + + + +## What does Geth do? + +As an execution client, Geth is responsible for creating the execution payloads - the bundles of transactions - +that consensus clients include in their blocks. Geth is also responsible for re-executing transactions that arrive +in new blocks to ensure they are valid. Executing transactions is done on Geth's embedded computer, known as the +Ethereum Virtual Machine (EVM). + +Geth also offers a user-interface to Ethereum by exposing a set of RPC methods that enable users to query the +Ethereum blockchain, submit transactions and deploy smart contracts using the command line, programmatically +using Geth's built-in console, web3 development frameworks such as Hardhat and Truffle or via web-apps and wallets. + +In summary, Geth is: + - a user gateway to Ethereum + - home to the Ethereum Virtual Machine, Ethereum's state and transaction pool. + + + + + diff --git a/content/about-geth/about_us.md b/content/about-geth/about_us.md new file mode 100644 index 0000000000..e69de29bb2 diff --git a/content/about-geth/contributing.md b/content/about-geth/contributing.md new file mode 100644 index 0000000000..f01d2c1a59 --- /dev/null +++ b/content/about-geth/contributing.md @@ -0,0 +1,34 @@ +--- +title: Contributing +--- + +We welcome contributions from anyone on the internet, and are grateful for even the smallest of fixes! + +## Contributing to the Geth source code + +If you'd like to contribute to the Geth source code, please fork the +[Github repository](https://github.com/ethereum/go-ethereum), fix, commit and send a pull request for the +maintainers to review and merge into the main code base. If you wish to submit more complex changes +though, please check up with the core devs first on our Discord Server to ensure those changes are in +line with the general philosophy of the project and/or get some early feedback which can make both your +efforts much lighter as well as our review and merge procedures quick and simple. + +Please make sure your contributions adhere to our coding guidelines: + +* Code must adhere to the official Go formatting guidelines (i.e. uses gofmt). +* Code must be documented adhering to the official Go commentary guidelines. +* Pull requests need to be based on and opened against the master branch. +* Commit messages should be prefixed with the package(s) they modify. + E.g. "eth, rpc: make trace configs optional" + + +## Contributing to the Geth website + +The Geth website is hosted separately from Geth itself. The contribution guidelines are the same. Please +for the Geth website Github repository and raise pull requests for the maintainers to review and merge. + +## License + +The go-ethereum library (i.e. all code outside of the cmd directory) is licensed under the GNU Lesser General Public License v3.0, also included in our repository in the COPYING.LESSER file. + +The go-ethereum binaries (i.e. all code inside of the cmd directory) is licensed under the GNU General Public License v3.0, also included in our repository in the COPYING file. diff --git a/content/about-geth/ethereum.md b/content/about-geth/ethereum.md new file mode 100644 index 0000000000..7515053e4c --- /dev/null +++ b/content/about-geth/ethereum.md @@ -0,0 +1,56 @@ +--- +title: Intro to Ethereum +description: A brief introduction to Ethereum. +--- + + +Ethereum is a technology for building apps and organizations, holding assets, transacting and +communicating without being controlled by a central authority. There is no need to hand over all +your personal details to use Ethereum - you keep control of your own data and what is being shared. +Ethereum has its own cryptocurrency, Ether (ETH), which is used to pay for certain activities on +the Ethereum network. In essence, Ethereum is a blockchain with an embedded computer. + + +## What is a blockchain? + +A blockchain is a database of transactions that is updated and shared across many computers in a +network. Every time a new set of transactions is added, its called a “block” - hence the name +blockchain. Most blockchains are public and immutable, and you can only add data, not remove. If someone +wanted to alter any of the information or cheat the system, they’d need to do so in such a way that the +majority of computers on the network accept. There are very strong crypto-economic defenses against this +on Ethereum. This makes established blockchains like Ethereum highly secure base-layers for organizations +and applications. + + +## What are smart contracts? + +Smart contracts are computer programs living on the Ethereum blockchain. They only execute when +triggered by a transaction from a user (or another contract). They make Ethereum very flexible in what +it can do and distinguish it from other cryptocurrencies. These programs are what we now call +decentralized apps, or dapps. + +Once a smart contract is published to Ethereum, it will be online and operational for as long as Ethereum +exists. Not even the author can take it down. Since smart contracts are automated, they do not discriminate +against any user and are always ready to use. + +Popular examples of smart contracts are lending apps, decentralized trading exchanges, insurance, +crowdfunding apps - basically anything you can think of. + + +## Who runs Ethereum? + +Ethereum is not controlled by any one entity. It exists solely through the decentralized participation +and cooperation of the community. Ethereum makes use of nodes (a computer with a copy of the Ethereum +blockchain data) run by volunteers to replace individual server and cloud systems owned by major +internet providers and services. + +These distributed nodes, run by individuals and businesses all over the world, provide resiliency to +the Ethereum network infrastructure. It is therefore much less vulnerable to hacks or shutdowns. +Since its launch in 2015, Ethereum has never suffered downtime. There are thousands of individual nodes +running Ethereum network. + + +## Learn more about Ethereum + +[ethereum.org](https://ethereum.org/) + diff --git a/content/about-geth/faq.md b/content/about-geth/faq.md new file mode 100644 index 0000000000..8b04b29e3d --- /dev/null +++ b/content/about-geth/faq.md @@ -0,0 +1,74 @@ +--- +title: FAQ +permalink: docs/faq +sort_key: C +--- + +* TOC +{:toc} + +#### I noticed my peercount slowly decreasing, and now it is at 0. Restarting doesn't get any peers. + +Check and sync your clock with ntp. For example, you can [force a clock update using ntp](https://askubuntu.com/questions/254826/how-to-force-a-clock-update-using-ntp) like so: + +```sh +sudo ntpdate -s time.nist.gov +``` + +#### I would like to run multiple geth instances but got the error "Fatal: blockchain db err: resource temporarily unavailable". + +Geth uses a datadir to store the blockchain, accounts and some additional information. This directory cannot be shared between running instances. If you would like to run multiple instances follow [these](getting-started/private-net) instructions. + +#### When I try to use the --password command line flag, I get the error "Could not decrypt key with given passphrase" but the password is correct. Why does this error appear? + +Especially if the password file was created on Windows, it may have a Byte Order Mark or other special encoding that the go-ethereum client doesn't currently recognize. You can change this behavior with a PowerShell command like: + +```sh +echo "mypasswordhere" | out-file test.txt -encoding ASCII +``` + +Additional details and/or any updates on more robust handling are at . + +#### How does Ethereum syncing work? + +The current default syncing mode used by Geth is called [snap sync](https://github.com/ethereum/devp2p/blob/master/caps/snap.md). Instead of starting from the genesis block and processing all the transactions that ever occurred (which could take weeks), snap sync downloads the blocks, and only verifies the associated proof-of-works. Downloading all the blocks is a straightforward and fast procedure and will relatively quickly reassemble the entire chain. + +Many people falsely assume that because they have the blocks, they are in sync. Unfortunately this is not the case. Since no transaction was executed, so we do not have any account state available (ie. balances, nonces, smart contract code and data). These need to be downloaded separately and cross-checked with the latest blocks. This phase is called the state trie download phase. Snap sync tries to hasten this process by downloading contiguous chunks of useful state data, instead of doing so one-by-one, as in previous synchronization methods. + +#### So, what's the state trie? + +In the Ethereum mainnet, there are a ton of accounts already, which track the balance, nonce, etc of each user/contract. The accounts themselves are however insufficient to run a node, they need to be cryptographically linked to each block so that nodes can actually verify that the accounts are not tampered with. + +This cryptographic linking is done by creating a tree-like data structure, where each leaf corresponds to an account, and each intermediary level aggregates the layer below it into an ever smaller layer, until you reach a single root. This gigantic data structure containing all the accounts and the intermediate cryptographic proofs is called the state trie. + +#### Why does the state trie download phase require a special syncing mode? + +The trie data structure is an intricate interlink of hundreds of millions of tiny cryptographic proofs (trie nodes). To truly have a synchronized node, you need to download all the account data, as well as all the tiny cryptographic proofs to verify that no one in the network is trying to cheat you. This itself is already a crazy number of data items. + +The part where it gets even messier is that this data is constantly morphing: at every block (roughly 13s), about 1000 nodes are deleted from this trie and about 2000 new ones are added. This means your node needs to synchronize a dataset that is changing more than 200 times per second. Until you actually do gather all the data, your local node is not usable since it cannot cryptographically prove anything about any accounts. But while you're syncing the network is moving forward and most nodes on the network keep the state for only a limited number of recent blocks. Any sync algorithm needs to consider this fact. + +#### What happened to fast sync? + +Snap syncing was introduced by version [1.10.0](https://blog.ethereum.org/2021/03/03/geth-v1-10-0/) and was adopted as the default mode in version [1.10.4](https://github.com/ethereum/go-ethereum/releases/tag/v1.10.4). Before that, the default was the "fast" syncing mode, which was dropped in version [1.10.14](https://github.com/ethereum/go-ethereum/releases/tag/v1.10.14). Even though support for fast sync was dropped, Geth still serves the relevant `eth` requests to other client implementations still relying on it. The reason being that snap sync relies on an alternative data structure called the [snapshot](https://blog.ethereum.org/2020/07/17/ask-about-geth-snapshot-acceleration/) which not all clients implement. + +You can read more in the article posted above why snap sync replaced fast sync in Geth. Below is a table taken from the article summarising the benefits: + +![snap-fast](https://user-images.githubusercontent.com/129561/109820169-6ee0af00-7c3d-11eb-9721-d8484eee4709.png) + +#### When doing a fast sync, the node just hangs on importing state enties?! + +The node doesn’t hang, it just doesn’t know how large the state trie is in advance so it keeps on going and going and going until it discovers and downloads the entire thing. + +The reason is that a block in Ethereum only contains the state root, a single hash of the root node. When the node begins synchronizing, it knows about exactly 1 node and tries to download it. That node, can refer up to 16 new nodes, so in the next step, we’ll know about 16 new nodes and try to download those. As we go along the download, most of the nodes will reference new ones that we didn’t know about until then. This is why you might be tempted to think it’s stuck on the same numbers. It is not, rather it’s discovering and downloading the trie as it goes along. + +During this phase you might see that your node is 64 blocks behind mainnet. You aren't actually synchronized. That's a side-effect of how fast sync works and you need to wait out until all state entries are downloaded. + +#### I have good bandwidth, so why does downloading the state take so long when using fast sync? + +State sync is mostly limited by disk IO, not bandwidth. + +The state trie in Ethereum contains hundreds of millions of nodes, most of which take the form of a single hash referencing up to 16 other hashes. This is a horrible way to store data on a disk, because there's almost no structure in it, just random numbers referencing even more random numbers. This makes any underlying database weep, as it cannot optimize storing and looking up the data in any meaningful way. Snap sync solves this issue by adopting the Snapshot data structure. + +#### Wait, so I can't use fast sync on an HDD? + +Doing a "fast" sync on an HDD will take more time than you're willing to wait, because the data structures used are not optimized for HDDs. Even if you do wait it out, an HDD will not be able to keep up with the read/write requirements of transaction processing on mainnet. You however should be able to run a light client on an HDD with minimal impact on system resources. diff --git a/content/docs/developers/dapp-developer/custom-tracer.md b/content/docs/developers/dapp-developer/custom-tracer.md new file mode 100644 index 0000000000..4817ed4053 --- /dev/null +++ b/content/docs/developers/dapp-developer/custom-tracer.md @@ -0,0 +1,458 @@ +--- +title: Custom EVM tracer +sort_key: B +--- + +In addition to the default opcode tracer and the built-in tracers, Geth offers the possibility to write custom code +that hook to events in the EVM to process and return the data in a consumable format. Custom tracers can be +written either in Javascript or Go. JS tracers are good for quick prototyping and experimentation as well as for +less intensive applications. Go tracers are performant but require the tracer to be compiled together with the Geth source code. + +* TOC +{:toc} + +## Custom Javascript tracing + +Transaction traces include the complete status of the EVM at every point during the transaction execution, which +can be a very large amount of data. Often, users are only interested in a small subset of that data. Javascript trace +filters are available to isolate the useful information. Detailed information about `debug_traceTransaction` and its +component parts is available in the [reference documentation](/docs/rpc/ns-debug#debug_tracetransaction). + +### A simple filter + +Filters are Javascript functions that select information from the trace to persist and discard based on some +conditions. The following Javascript function returns only the sequence of opcodes executed by the transaction as a +comma-separated list. The function could be written directly in the Javascript console, but it is cleaner to +write it in a separate re-usable file and load it into the console. + +1. Create a file, `filterTrace_1.js`, with this content: + + ```javascript + + tracer = function(tx) { + return debug.traceTransaction(tx, {tracer: + '{' + + 'retVal: [],' + + 'step: function(log,db) {this.retVal.push(log.getPC() + ":" + log.op.toString())},' + + 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + + 'result: function(ctx,db) {return this.retVal}' + + '}' + }) // return debug.traceTransaction ... + } // tracer = function ... + + ``` + +2. Run the [JavaScript console](https://geth.ethereum.org/docs/interface/javascript-console). + +3. Get the hash of a recent transaction from a node or block explorer. + +4. Run this command to run the script: + + ```javascript + loadScript("filterTrace_1.js") + ``` + +5. Run the tracer from the script. Be patient, it could take a long time. + + ```javascript + tracer("") + ``` + + The bottom of the output looks similar to: + ```sh + "3366:POP", "3367:JUMP", "1355:JUMPDEST", "1356:PUSH1", "1358:MLOAD", "1359:DUP1", "1360:DUP3", "1361:ISZERO", "1362:ISZERO", + "1363:ISZERO", "1364:ISZERO", "1365:DUP2", "1366:MSTORE", "1367:PUSH1", "1369:ADD", "1370:SWAP2", "1371:POP", "1372:POP", "1373:PUSH1", + "1375:MLOAD", "1376:DUP1", "1377:SWAP2", "1378:SUB", "1379:SWAP1", "1380:RETURN" + ``` + +6. Run this line to get a more readable output with each string in its own line. + + ```javascript + console.log(JSON.stringify(tracer(""), null, 2)) + ``` + +More information about the `JSON.stringify` function is available +[here](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify). + +The commands above worked by calling the same `debug.traceTransaction` function that was previously +explained in [basic traces](https://geth.ethereum.org/docs/dapp/tracing), but with a new parameter, `tracer`. +This parameter takes the JavaScript object formated as a string. In the case of the trace above, it is: + +```javascript +{ + retVal: [], + step: function(log,db) {this.retVal.push(log.getPC() + ":" + log.op.toString())}, + fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))}, + result: function(ctx,db) {return this.retVal} +} +``` +This object has three member functions: + +- `step`, called for each opcode. +- `fault`, called if there is a problem in the execution. +- `result`, called to produce the results that are returned by `debug.traceTransaction` after the execution is done. + +In this case, `retVal` is used to store the list of strings to return in `result`. + +The `step` function adds to `retVal` the program counter and the name of the opcode there. Then, in `result`, this +list is returned to be sent to the caller. + + +### Filtering with conditions + +For actual filtered tracing we need an `if` statement to only log relevant information. For example, to isolate +the transaction's interaction with storage, the following tracer could be used: + +```javascript +tracer = function(tx) { + return debug.traceTransaction(tx, {tracer: + '{' + + 'retVal: [],' + + 'step: function(log,db) {' + + ' if(log.op.toNumber() == 0x54) ' + + ' this.retVal.push(log.getPC() + ": SLOAD");' + + ' if(log.op.toNumber() == 0x55) ' + + ' this.retVal.push(log.getPC() + ": SSTORE");' + + '},' + + 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + + 'result: function(ctx,db) {return this.retVal}' + + '}' + }) // return debug.traceTransaction ... +} // tracer = function ... +``` + +The `step` function here looks at the opcode number of the op, and only pushes an entry if the opcode is +`SLOAD` or `SSTORE` ([here is a list of EVM opcodes and their numbers](https://github.com/wolflo/evm-opcodes)). +We could have used `log.op.toString()` instead, but it is faster to compare numbers rather than strings. + +The output looks similar to this: + +```javascript +[ + "5921: SLOAD", + . + . + . + "2413: SSTORE", + "2420: SLOAD", + "2475: SSTORE", + "6094: SSTORE" +] +``` + + +### Stack Information + +The trace above reports the program counter (PC) and whether the program read from storage or wrote to it. +That alone isn't particularly useful. To know more, the `log.stack.peek` function can be used to peek +into the stack. `log.stack.peek(0)` is the stack top, `log.stack.peek(1)` the entry below it, etc. + +The values returned by `log.stack.peek` are Go `big.Int` objects. By default they are converted to JavaScript +floating point numbers, so you need `toString(16)` to get them as hexadecimals, which is how 256-bit values such as +storage cells and their content are normally represented. + +#### Storage Information + +The function below provides a trace of all the storage operations and their parameters. This gives +a more complete picture of the program's interaction with storage. + +```javascript +tracer = function(tx) { + return debug.traceTransaction(tx, {tracer: + '{' + + 'retVal: [],' + + 'step: function(log,db) {' + + ' if(log.op.toNumber() == 0x54) ' + + ' this.retVal.push(log.getPC() + ": SLOAD " + ' + + ' log.stack.peek(0).toString(16));' + + ' if(log.op.toNumber() == 0x55) ' + + ' this.retVal.push(log.getPC() + ": SSTORE " +' + + ' log.stack.peek(0).toString(16) + " <- " +' + + ' log.stack.peek(1).toString(16));' + + '},' + + 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + + 'result: function(ctx,db) {return this.retVal}' + + '}' + }) // return debug.traceTransaction ... +} // tracer = function ... + +``` + +The output is similar to: + +```javascript +[ + "5921: SLOAD 0", + . + . + . + "2413: SSTORE 3f0af0a7a3ed17f5ba6a93e0a2a05e766ed67bf82195d2dd15feead3749a575d <- fb8629ad13d9a12456", + "2420: SLOAD cc39b177dd3a7f50d4c09527584048378a692aed24d31d2eabeddb7f3c041870", + "2475: SSTORE cc39b177dd3a7f50d4c09527584048378a692aed24d31d2eabeddb7f3c041870 <- 358c3de691bd19", + "6094: SSTORE 0 <- 1" +] +``` + +#### Operation Results + +One piece of information missing from the function above is the result on an `SLOAD` operation. The +state we get inside `log` is the state prior to the execution of the opcode, so that value is not +known yet. For more operations we can figure it out for ourselves, but we don't have access to the +storage, so here we can't. + +The solution is to have a flag, `afterSload`, which is only true in the opcode right after an +`SLOAD`, when we can see the result at the top of the stack. + +```javascript +tracer = function(tx) { + return debug.traceTransaction(tx, {tracer: + '{' + + 'retVal: [],' + + 'afterSload: false,' + + 'step: function(log,db) {' + + ' if(this.afterSload) {' + + ' this.retVal.push(" Result: " + ' + + ' log.stack.peek(0).toString(16)); ' + + ' this.afterSload = false; ' + + ' } ' + + ' if(log.op.toNumber() == 0x54) {' + + ' this.retVal.push(log.getPC() + ": SLOAD " + ' + + ' log.stack.peek(0).toString(16));' + + ' this.afterSload = true; ' + + ' } ' + + ' if(log.op.toNumber() == 0x55) ' + + ' this.retVal.push(log.getPC() + ": SSTORE " +' + + ' log.stack.peek(0).toString(16) + " <- " +' + + ' log.stack.peek(1).toString(16));' + + '},' + + 'fault: function(log,db) {this.retVal.push("FAULT: " + JSON.stringify(log))},' + + 'result: function(ctx,db) {return this.retVal}' + + '}' + }) // return debug.traceTransaction ... +} // tracer = function ... +``` + +The output now contains the result in the line that follows the `SLOAD`. + +```javascript +[ + "5921: SLOAD 0", + " Result: 1", + . + . + . + "2413: SSTORE 3f0af0a7a3ed17f5ba6a93e0a2a05e766ed67bf82195d2dd15feead3749a575d <- fb8629ad13d9a12456", + "2420: SLOAD cc39b177dd3a7f50d4c09527584048378a692aed24d31d2eabeddb7f3c041870", + " Result: 0", + "2475: SSTORE cc39b177dd3a7f50d4c09527584048378a692aed24d31d2eabeddb7f3c041870 <- 358c3de691bd19", + "6094: SSTORE 0 <- 1" +] +``` + +### Dealing With Calls Between Contracts + +So the storage has been treated as if there are only 2256 cells. However, that is not true. +Contracts can call other contracts, and then the storage involved is the storage of the other contract. +We can see the address of the current contract in `log.contract.getAddress()`. This value is the execution +context - the contract whose storage we are using - even when code from another contract is executed (by using +[`CALLCODE` or `DELEGATECALL`][solidity-delcall]). + +However, `log.contract.getAddress()` returns an array of bytes. To convert this to the familiar hexadecimal +representation of Ethereum addresses, `this.byteHex()` and `array2Hex()` can be used. + +```javascript +tracer = function(tx) { + return debug.traceTransaction(tx, {tracer: + '{' + + 'retVal: [],' + + 'afterSload: false,' + + 'callStack: [],' + + + 'byte2Hex: function(byte) {' + + ' if (byte < 0x10) ' + + ' return "0" + byte.toString(16); ' + + ' return byte.toString(16); ' + + '},' + + + 'array2Hex: function(arr) {' + + ' var retVal = ""; ' + + ' for (var i=0; i 0 { + t.env.Cancel() + return + } + + name := op.String() + if _, ok := t.counts[name]; !ok { + t.counts[name] = 0 + } + t.counts[name]++ +} + +// CaptureEnter is called when EVM enters a new scope (via call, create or selfdestruct). +func (t *opcounter) CaptureEnter(op vm.OpCode, from common.Address, to common.Address, input []byte, gas uint64, value *big.Int) {} + +// CaptureExit is called when EVM exits a scope, even if the scope didn't +// execute any code. +func (t *opcounter) CaptureExit(output []byte, gasUsed uint64, err error) {} + +// CaptureFault implements the EVMLogger interface to trace an execution fault. +func (t *opcounter) CaptureFault(pc uint64, op vm.OpCode, gas, cost uint64, scope *vm.ScopeContext, depth int, err error) {} + +// CaptureEnd is called after the call finishes to finalize the tracing. +func (t *opcounter) CaptureEnd(output []byte, gasUsed uint64, _ time.Duration, err error) {} + +func (*opcounter) CaptureTxStart(gasLimit uint64) {} + +func (*opcounter) CaptureTxEnd(restGas uint64) {} + +// GetResult returns the json-encoded nested list of call traces, and any +// error arising from the encoding or forceful termination (via `Stop`). +func (t *opcounter) GetResult() (json.RawMessage, error) { + res, err := json.Marshal(t.counts) + if err != nil { + return nil, err + } + return res, t.reason +} + +// Stop terminates execution of the tracer at the first opportune moment. +func (t *opcounter) Stop(err error) { + t.reason = err + atomic.StoreUint32(&t.interrupt, 1) +} +``` + +As can be seen every method of the [EVMLogger interface](https://pkg.go.dev/github.com/ethereum/go-ethereum/core/vm#EVMLogger) needs to be implemented (even if empty). Key parts to notice are the `init()` function which registers the tracer in Geth, the `CaptureState` hook where the opcode counts are incremented and `GetResult` where the result is serialized and delivered. To test this out the source is first compiled with `make geth`. Then in the console it can be invoked through the usual API methods by passing in the name it was registered under: + +```console +> debug.traceTransaction('0x7ae446a7897c056023a8104d254237a8d97783a92900a7b0f7db668a9432f384', { tracer: 'opcounter' }) +{ + ADD: 4, + AND: 3, + CALLDATALOAD: 2, + ... +} +``` + +[solidity-delcall]:https://docs.soliditylang.org/en/v0.8.14/introduction-to-smart-contracts.html#delegatecall-callcode-and-libraries +[debug-docs]: /docs/rpc/ns-debug diff --git a/content/docs/developers/dapp-developer/mobile/mobile-accounts.md b/content/docs/developers/dapp-developer/mobile/mobile-accounts.md new file mode 100644 index 0000000000..9d4bd39219 --- /dev/null +++ b/content/docs/developers/dapp-developer/mobile/mobile-accounts.md @@ -0,0 +1,323 @@ +--- +title: Mobile Account Management +sort_key: G +--- + +To provide Ethereum integration for your mobile applications, the very first thing you +should be interested in doing is account management. + +Although all current leading Ethereum implementations provide account management built in, +it is ill advised to keep accounts in any location that is shared between multiple +applications and/or multiple people. The same way you do not entrust your ISP (who is +after all your gateway into the internet) with your login credentials; you should not +entrust an Ethereum node (who is your gateway into the Ethereum network) with your +credentials either. + +The proper way to handle user accounts in your mobile applications is to do client side +account management, everything self-contained within your own application. This way you +can ensure as fine grained (or as coarse) access permissions to the sensitive data as +deemed necessary, without relying on any third party application's functionality and/or +vulnerabilities. + +To support this, `go-ethereum` provides a simple, yet thorough accounts library that gives +you all the tools to do properly secured account management via encrypted keystores and +passphrase protected accounts. You can leverage all the security of the `go-ethereum` +crypto implementation while at the same time running everything in your own application. + +## Encrypted keystores + +Although handling your users' accounts locally on their own mobile device does provide +certain security guarantees, access keys to Ethereum accounts should never lay around in +clear-text form. As such, we provide an encrypted keystore that provides the proper +security guarantees for you without requiring a thorough understanding from your part of +the associated cryptographic primitives. + +The important thing to know when using the encrypted keystore is that the cryptographic +primitives used within can operate either in *standard* or *light* mode. The former +provides a higher level of security at the cost of increased computational burden and +resource consumption: + + * *standard* needs 256MB memory and 1 second processing on a modern CPU to access a key + * *light* needs 4MB memory and 100 millisecond processing on a modern CPU to access a key + +As such, *light* is more suitable for mobile applications, but you should be aware of the +trade-offs nonetheless. + +*For those interested in the cryptographic and/or implementation details, the key-store +uses the `secp256k1` elliptic curve as defined in the [Standards for Efficient +Cryptography](sec2), implemented by the [`libsecp256k`][secp256k1] library and wrapped by +[`github.com/ethereum/go-ethereum/accounts`][accounts-go]. Accounts are stored on disk in +the [Web3 Secret Storage][secstore] format.* + +### Keystores on Android (Java) + +The encrypted keystore on Android is implemented by the `KeyStore` class from the +`org.ethereum.geth` package. The configuration constants (for the *standard* or *light* +security modes described above) are located in the `Geth` abstract class, similarly from +the `org.ethereum.geth` package. Hence to do client side account management on Android, +you'll need to import two classes into your Java code: + +```java +import org.ethereum.geth.Geth; +import org.ethereum.geth.KeyStore; +``` + +Afterwards you can create a new encrypted keystore via: + +```java +KeyStore ks = new KeyStore("/path/to/keystore", Geth.LightScryptN, Geth.LightScryptP); +``` + +The path to the keystore folder needs to be a location that is writable by the local +mobile application but non-readable for other installed applications (for security reasons +obviously), so we'd recommend placing it inside your app's data directory. If you are +creating the `KeyStore` from within a class extending an Android object, you will most +probably have access to the `Context.getFilesDir()` method via `this.getFilesDir()`, so +you could set the keystore path to `this.getFilesDir() + "/keystore"`. + +The last two arguments of the `KeyStore` constructor are the crypto parameters defining +how resource-intensive the keystore encryption should be. You can choose between +`Geth.StandardScryptN, Geth.StandardScryptP`, `Geth.LightScryptN, Geth.LightScryptP` or +specify your own numbers (please make sure you understand the underlying cryptography for +this). We recommend using the *light* version. + +### Keystores on iOS (Swift 3) + +The encrypted keystore on iOS is implemented by the `GethKeyStore` class from the `Geth` +framework. The configuration constants (for the *standard* or *light* security modes +described above) are located in the same namespace as global variables. Hence to do client +side account management on iOS, you'll need to import the framework into your Swift code: + +```swift +import Geth +``` + +Afterwards you can create a new encrypted account manager via: + +```swift +let ks = GethNewKeyStore("/path/to/keystore", GethLightScryptN, GethLightScryptP); +``` + +The path to the keystore folder needs to be a location that is writable by the local +mobile application but non-readable for other installed applications (for security reasons +obviously), so we'd recommend placing it inside your app's document directory. You should +be able to retrieve the document directory via `let datadir = +NSSearchPathForDirectoriesInDomains(.documentDirectory, .userDomainMask, true)[0]`, so you +could set the keystore path to `datadir + "/keystore"`. + +The last two arguments of the `GethNewKeyStore` factory method are the crypto parameters +defining how resource-intensive the keystore encryption should be. You can choose between +`GethStandardScryptN, GethStandardScryptP`, `GethLightScryptN, GethLightScryptP` or +specify your own numbers (please make sure you understand the underlying cryptography for +this). We recommend using the *light* version. + +## Account lifecycle + +Having created an encrypted keystore for your Ethereum accounts, you can use this for the +entire account lifecycle requirements of your mobile application. This includes the basic +functionality of creating new accounts and deleting existing ones; as well as the more +advanced functionality of updating access credentials, exporting existing accounts, and +importing them on another device. + +Although the keystore defines the encryption strength it uses to store your accounts, +there is no global master password that can grant access to all of them. Rather each +account is maintained individually, and stored on disk in its [encrypted format][secstore] +individually, ensuring a much cleaner and stricter separation of credentials. + +This individuality however means that any operation requiring access to an account will +need to provide the necessary authentication credentials for that particular account in +the form of a passphrase: + + * When creating a new account, the caller must supply a passphrase to encrypt the account + with. This passphrase will be required for any subsequent access, the lack of which + will forever forfeit using the newly created account. + * When deleting an existing account, the caller must supply a passphrase to verify + ownership of the account. This isn't cryptographically necessary, rather a protective + measure against accidental loss of accounts. + * When updating an existing account, the caller must supply both current and new + passphrases. After completing the operation, the account will not be accessible via the + old passphrase any more. + * When exporting an existing account, the caller must supply both the current passphrase + to decrypt the account, as well as an export passphrase to re-encrypt it with before + returning the key-file to the user. This is required to allow moving accounts between + devices without sharing original credentials. + * When importing a new account, the caller must supply both the encryption passphrase of + the key-file being imported, as well as a new passhprase with which to store the + account. This is required to allow storing account with different credentials than used + for moving them around. + +*Please note, there is no recovery mechanisms for losing the passphrases. The +cryptographic properties of the encrypted keystore (if using the provided parameters) +guarantee that account credentials cannot be brute forced in any meaningful time.* + +### Accounts on Android (Java) + +An Ethereum account on Android is implemented by the `Account` class from the +`org.ethereum.geth` package. Assuming we already have an instance of a `KeyStore` called +`ks` from the previous section, we can easily execute all of the described lifecycle +operations with a handful of function calls. + +```java +// Create a new account with the specified encryption passphrase. +Account newAcc = ksm.newAccount("Creation password"); + +// Export the newly created account with a different passphrase. The returned +// data from this method invocation is a JSON encoded, encrypted key-file. +byte[] jsonAcc = ks.exportKey(newAcc, "Creation password", "Export password"); + +// Update the passphrase on the account created above inside the local keystore. +ks.updateAccount(newAcc, "Creation password", "Update password"); + +// Delete the account updated above from the local keystore. +ks.deleteAccount(newAcc, "Update password"); + +// Import back the account we've exported (and then deleted) above with yet +// again a fresh passphrase. +Account impAcc = ks.importKey(jsonAcc, "Export password", "Import password"); +``` + +*Although instances of `Account` can be used to access various information about specific +Ethereum accounts, they do not contain any sensitive data (such as passphrases or private +keys), rather act solely as identifiers for client code and the keystore.* + +### Accounts on iOS (Swift 3) + +An Ethereum account on iOS is implemented by the `GethAccount` class from the `Geth` +framework. Assuming we already have an instance of a `GethKeyStore` called `ks` from the +previous section, we can easily execute all of the described lifecycle operations with a +handful of function calls. + +```swift +// Create a new account with the specified encryption passphrase. +let newAcc = try! ks?.newAccount("Creation password") + +// Export the newly created account with a different passphrase. The returned +// data from this method invocation is a JSON encoded, encrypted key-file. +let jsonKey = try! ks?.exportKey(newAcc!, passphrase: "Creation password", newPassphrase: "Export password") + +// Update the passphrase on the account created above inside the local keystore. +try! ks?.update(newAcc, passphrase: "Creation password", newPassphrase: "Update password") + +// Delete the account updated above from the local keystore. +try! ks?.delete(newAcc, passphrase: "Update password") + +// Import back the account we've exported (and then deleted) above with yet +// again a fresh passphrase. +let impAcc = try! ks?.importKey(jsonKey, passphrase: "Export password", newPassphrase: "Import password") +``` + +*Although instances of `GethAccount` can be used to access various information about +specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or +private keys), rather act solely as identifiers for client code and the keystore.* + +## Signing authorization + +As mentioned above, account objects do not hold the sensitive private keys of the +associated Ethereum accounts, but are merely placeholders to identify the cryptographic +keys with. All operations that require authorization (e.g. transaction signing) are +performed by the account manager after granting it access to the private keys. + +There are a few different ways one can authorize the account manager to execute signing +operations, each having its advantages and drawbacks. Since the different methods have +wildly different security guarantees, it is essential to be clear on how each works: + + * **Single authorization**: The simplest way to sign a transaction via the keystore is to + provide the passphrase of the account every time something needs to be signed, which + will ephemerally decrypt the private key, execute the signing operation and immediately + throw away the decrypted key. The drawbacks are that the passphrase needs to be queried + from the user every time, which can become annoying if done frequently; or the + application needs to keep the passphrase in memory, which can have security + consequences if not done properly; and depending on the keystore's configured strength, + constantly decrypting keys can result in non-negligible resource requirements. + * **Multiple authorizations**: A more complex way of signing transactions via the + keystore is to unlock the account via its passphrase once, and allow the account + manager to cache the decrypted private key, enabling all subsequent signing requests to + complete without the passphrase. The lifetime of the cached private key may be managed + manually (by explicitly locking the account back up) or automatically (by providing a + timeout during unlock). This mechanism is useful for scenarios where the user may need + to sign many transactions or the application would need to do so without requiring user + input. The crucial aspect to remember is that **anyone with access to the account + manager can sign transactions while a particular account is unlocked** (e.g. device + left unattended; application running untrusted code). + +*Note, creating transactions is out of scope here, so the remainder of this section will +assume we already have a transaction to sign, and will focus only on creating an +authorized version of it. Creating an actually meaningful transaction will be covered +later.* + +### Signing on Android (Java) + +Assuming we already have an instance of a `KeyStore` called `ks` from the previous +sections, we can create a new account to sign transactions with via it's already +demonstrated `newAccount` method; and to avoid going into transaction creation for now, we +can hard-code a random transaction to sign instead. + +```java +// Create a new account to sign transactions with +Account signer = ks.newAccount("Signer password"); +Transaction tx = new Transaction( + 1, new Address("0x0000000000000000000000000000000000000000"), + new BigInt(0), new BigInt(0), new BigInt(1), null); // Random empty transaction +BigInt chain = new BigInt(1); // Chain identifier of the main net +``` + +With the boilerplate out of the way, we can now sign transaction using the authorization +mechanisms described above: + +```java +// Sign a transaction with a single authorization +Transaction signed = ks.signTxPassphrase(signer, "Signer password", tx, chain); + +// Sign a transaction with multiple manually cancelled authorizations +ks.unlock(signer, "Signer password"); +signed = ks.signTx(signer, tx, chain); +ks.lock(signer.getAddress()); + +// Sign a transaction with multiple automatically cancelled authorizations +ks.timedUnlock(signer, "Signer password", 1000000000); +signed = ks.signTx(signer, tx, chain); +``` + +### Signing on iOS (Swift 3) + +Assuming we already have an instance of a `GethKeyStore` called `ks` from the previous +sections, we can create a new account to sign transactions with via it's already +demonstrated `newAccount` method; and to avoid going into transaction creation for now, we +can hard-code a random transaction to sign instead. + +```swift +// Create a new account to sign transactions with +var error: NSError? +let signer = try! ks?.newAccount("Signer password") + +let to = GethNewAddressFromHex("0x0000000000000000000000000000000000000000", &error) +let tx = GethNewTransaction(1, to, GethNewBigInt(0), GethNewBigInt(0), GethNewBigInt(0), nil) // Random empty transaction +let chain = GethNewBigInt(1) // Chain identifier of the main net +``` + +*Note, although Swift usually rewrites `NSError` returns to throws, this particular +instance seems to have been missed for some reason (possibly due to it being a +constructor). It will be fixed in a later version of the iOS bindings when the appropriate +fixed are implemented upstream in the `gomobile` project.* + +With the boilerplate out of the way, we can now sign transaction using the authorization +methods described above: + +```swift +// Sign a transaction with a single authorization +var signed = try! ks?.signTxPassphrase(signer, passphrase: "Signer password", tx: tx, chainID: chain) + +// Sign a transaction with multiple manually cancelled authorizations +try! ks?.unlock(signer, passphrase: "Signer password") +signed = try! ks?.signTx(signer, tx: tx, chainID: chain) +try! ks?.lock(signer?.getAddress()) + +// Sign a transaction with multiple automatically cancelled authorizations +try! ks?.timedUnlock(signer, passphrase: "Signer password", timeout: 1000000000) +signed = try! ks?.signTx(signer, tx: tx, chainID: chain) +``` + +[sec2]: https://www.secg.org/sec2-v2.pdf +[accounts-go]: https://godoc.org/github.com/ethereum/go-ethereum/accounts +[secp256k1]: https://github.com/bitcoin-core/secp256k1 +[secstore]: https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition diff --git a/content/docs/developers/dapp-developer/mobile/mobile.md b/content/docs/developers/dapp-developer/mobile/mobile.md new file mode 100644 index 0000000000..efcc107451 --- /dev/null +++ b/content/docs/developers/dapp-developer/mobile/mobile.md @@ -0,0 +1,180 @@ +--- +title: Mobile API +sort_key: F +--- + +The Ethereum blockchain along with its two extension protocols Whisper and Swarm was +originally conceptualized to become the supporting pillar of web3, providing the +consensus, messaging and storage backbone for a new generation of distributed (actually, +decentralized) applications called DApps. + +The first incarnation towards this dream of web3 was a command line client providing an +RPC interface into the peer-to-peer protocols. The client was soon enough extended with a +web-browser-like graphical user interface, permitting developers to write DApps based on +the tried and proven HTML/CSS/JS technologies. + +As many DApps have more complex requirements than what a browser environment can handle, +it became apparent that providing programmatic access to the web3 pillars would open the +door towards a new class of applications. As such, the second incarnation of the web +dream is to open up all our technologies for other projects as reusable components. + +Starting with the 1.5 release family of `go-ethereum`, we transitioned away from providing +only a full blown Ethereum client and started shipping official Go packages that could be +embedded into third party desktop and server applications. It took only a small leap from +here to begin porting our code to mobile platforms. + +## Quick overview + +Similarly to our reusable Go libraries, the mobile wrappers also focus on four main usage +areas: + +- Simplified client side account management +- Remote node interfacing via different transports +- Contract interactions through auto-generated bindings +- In-process Ethereum, Whisper and Swarm peer-to-peer node + +You can watch a quick overview about these in Peter's (@karalabe) talk titled "Import +Geth: Ethereum from Go and beyond", presented at the Ethereum Devcon2 developer conference +in September, 2016 (Shanghai). Slides are [available +here](https://ethereum.karalabe.com/talks/2016-devcon.html). + +[![Peter's Devcon2 talk](https://img.youtube.com/vi/R0Ia1U9Gxjg/0.jpg)](https://www.youtube.com/watch?v=R0Ia1U9Gxjg) + +## Library bundles + +The `go-ethereum` mobile library is distributed either as an Android `.aar` archive +(containing binaries for `arm-7`, `arm64`, `x86` and `x64`); or as an iOS XCode framework +(containing binaries for `arm-7`, `arm64` and `x86`). We do not provide library bundles +for Windows phone the moment. + +### Android archive + +The simplest way to use `go-ethereum` in your Android project is through a Maven +dependency. We provide bundles of all our stable releases (starting from v1.5.0) through +Maven Central, and also provide the latest develop bundle through the Sonatype OSS +repository. + +#### Stable dependency (Maven Central) + +To add an Android dependency to the **stable** library release of `go-ethereum`, you'll +need to ensure that the Maven Central repository is enabled in your Android project, and +that the `go-ethereum` code is listed as a required dependency of your application. You +can do both of these by editing the `build.gradle` script in your Android app's folder: + +```gradle +repositories { + mavenCentral() +} + +dependencies { + // All your previous dependencies + compile 'org.ethereum:geth:1.5.2' // Change the version to the latest release +} +``` + +#### Develop dependency (Sonatype) + +To add an Android dependency to the current version of `go-ethereum`, you'll need to +ensure that the Sonatype snapshot repository is enabled in your Android project, and that +the `go-ethereum` code is listed as a required `SNAPSHOT` dependency of your application. +You can do both of these by editing the `build.gradle` script in your Android app's +folder: + +```gradle +repositories { + maven { + url "https://oss.sonatype.org/content/groups/public" + } +} + +dependencies { + // All your previous dependencies + compile 'org.ethereum:geth:1.5.3-SNAPSHOT' // Change the version to the latest release +} +``` + +#### Custom dependency + +If you prefer not to depend on Maven Central or Sonatype; or would like to access an older +develop build not available any more as an online dependency, you can download any bundle +directly from [our website](https://geth.ethereum.org/downloads/) and insert it into your +project in Android Studio via `File -> New -> New module... -> Import .JAR/.AAR Package`. + +You will also need to configure `gradle` to link the mobile library bundle to your +application. This can be done by adding a new entry to the `dependencies` section of your +`build.gradle` script, pointing it to the module you just added (named `geth` by default). + +```gradle +dependencies { + // All your previous dependencies + compile project(':geth') +} +``` + +#### Manual builds + +Lastly, if you would like to make modifications to the `go-ethereum` mobile code and/or +build it yourself locally instead of downloading a pre-built bundle, you can do so using a +`make` command. This will create an Android archive called `geth.aar` in the `build/bin` +folder that you can import into your Android Studio as described above. + +```bash +$ make android +[...] +Done building. +Import "build/bin/geth.aar" to use the library. +``` + +### iOS framework + +The simplest way to use `go-ethereum` in your iOS project is through a +[CocoaPods](https://cocoapods.org/) dependency. We provide bundles of all our stable +releases (starting from v1.5.3) and also latest develop versions. + +#### Automatic dependency + +To add an iOS dependency to the current stable or latest develop version of `go-ethereum`, +you'll need to ensure that your iOS XCode project is configured to use CocoaPods. +Detailing that is out of scope in this document, but you can find a guide in the upstream +[Using CocoaPods](https://guides.cocoapods.org/using/using-cocoapods.html) page. +Afterwards you can edit your `Podfile` to list `go-ethereum` as a dependency: + +```ruby +target 'MyApp' do + # All your previous dependencies + pod 'Geth', '1.5.4' # Change the version to the latest release +end +``` + +Alternatively, if you'd like to use the latest develop version, replace the package +version `1.5.4` with `~> 1.5.5-unstable` to switch to pre-releases and to always pull in +the latest bundle from a particular release family. + +#### Custom dependency + +If you prefer not to depend on CocoaPods; or would like to access an older develop build +not available any more as an online dependency, you can download any bundle directly from +[our website](https://geth.ethereum.org/downloads/) and insert it into your project in +XCode via `Project Settings -> Build Phases -> Link Binary With Libraries`. + +Do not forget to extract the framework from the compressed `.tar.gz` archive. You can do +that either using a GUI tool or from the command line via (replace the archive with your +downloaded file): + +``` +tar -zxvf geth-ios-all-1.5.3-unstable-e05d35e6.tar.gz +``` + +#### Manual builds + +Lastly, if you would like to make modifications to the `go-ethereum` mobile code and/or +build it yourself locally instead of downloading a pre-built bundle, you can do so using a +`make` command. This will create an iOS XCode framework called `Geth.framework` in the +`build/bin` folder that you can import into XCode as described above. + +```bash +$ make ios +[...] +Done building. +Import "build/bin/Geth.framework" to use the library. +``` diff --git a/content/docs/developers/dapp-developer/native-accounts.md b/content/docs/developers/dapp-developer/native-accounts.md new file mode 100644 index 0000000000..867a438018 --- /dev/null +++ b/content/docs/developers/dapp-developer/native-accounts.md @@ -0,0 +1,223 @@ +--- +title: Go Account Management +sort_key: D +--- + +Geth provides a simple, yet thorough accounts package that includes all the tools developers +need to leverage all the security of Geth's crypto implementation in a Go native application. +The account management is done client side with all sensitive data held inside the application. +This gives the user control over access permissions without relying on any third party. + +**Note Geth's built-in account management is convenient and straightforward to use, but +best practise is to use the external tool *Clef* for key management.** + +{:toc} + +- this will be removed by the toc + +## Encrypted keystores + +Access keys to Ethereum accounts should never be stored in plain-text. Instead, they should be +stored encrypted so that even if the mobile device is accessed by a malicious third party the +keys are still hidden under an additional layer of security. Geth provides a keystore that enables +developers to store keys securely. The Geth keystore uses [Scrypt][scrypt-docs] to store keys that are encoded +using the [`secp256k1`][secp256k1] elliptic curve. Accounts are stored on disk in the +[Web3 Secret Storage][wss] format. Developers should be aware of these implementation details +but are not required to deeply understand the cryptographic primitives in order to use the keystore. + +One thing that should be understood, though, is that the cryptographic primitives underpinning the +keystore can operate in light or standard mode. Light mode is computationally cheaper, while standard +mode has extra security. Light mode is appropriate for mobile devices, but developers should be +aware that there is a security trade-off. + +* standard needs 256MB memory and 1 second processing on a modern CPU to access a key +* light needs 4MB memory and 100 millisecond processing on a modern CPU to access a key + + +The encrypted keystore is implemented by the [`accounts.Manager`][accounts-manager] struct +from the [`accounts`][accounts-pkg] package, which also contains the configuration constants for the +*standard* or *light* security modes described above. Hence client side account management +simply requires importing the `accounts` package into the application code. + +```go +import "github.com/ethereum/go-ethereum/accounts" +import "github.com/ethereum/go-ethereum/accounts/keystore" +import "github.com/ethereum/go-ethereum/common" +``` +Afterwards a new encrypted account manager can be created via: + +```go +ks := keystore.NewKeyStore("/path/to/keystore", keystore.StandardScryptN, keystore.StandardScryptP) +am := accounts.NewManager(&accounts.Config{InsecureUnlockAllowed: false}, ks) +``` + +The path to the keystore folder needs to be a location that is writable by the local user +but non-readable for other system users, such as inside the user's home directory. + +The last two arguments of [`keystore.NewKeyStore`][keystore] are the crypto parameters defining +how resource-intensive the keystore encryption should be. The options are +[`accounts.StandardScryptN, accounts.StandardScryptP`, `accounts.LightScryptN, +accounts.LightScryptP`][pkg-constants] or custom values (requiring understanding of the underlying +cryptography). The *standard* version is recommended. + + +## Account lifecycle + +Once an encrypted keystore for Ethereum accounts exists it, it can be used to manage accounts for the +entire account lifecycle requirements of a Go native application. This includes the basic functionality +of creating new accounts and deleting existing ones as well as updating access credentials, +exporting existing accounts, and importing them on other devices. + +Although the keystore defines the encryption strength it uses to store accounts, there is no global master +password that can grant access to all of them. Rather each account is maintained individually, and stored on +disk in its [encrypted format][wss] individually, ensuring a much cleaner and stricter separation of +credentials. + +This individuality means that any operation requiring access to an account will need to provide the +necessary authentication credentials for that particular account in the form of a passphrase: + + * When creating a new account, the caller must supply a passphrase to encrypt the account + with. This passphrase will be required for any subsequent access, the lack of which + will forever forfeit using the newly created account. + + * When deleting an existing account, the caller must supply a passphrase to verify + ownership of the account. This isn't cryptographically necessary, rather a protective + measure against accidental loss of accounts. + + * When updating an existing account, the caller must supply both current and new + passphrases. After completing the operation, the account will not be accessible via the + old passphrase any more. + + * When exporting an existing account, the caller must supply both the current passphrase + to decrypt the account, as well as an export passphrase to re-encrypt it with before + returning the key-file to the user. This is required to allow moving accounts between + machines and applications without sharing original credentials. + + * When importing a new account, the caller must supply both the encryption passphrase of + the key-file being imported, as well as a new passhprase with which to store the + account. This is required to allow storing account with different credentials than used + for moving them around. + +***Please note, there are no recovery mechanisms for lost passphrases. The +cryptographic properties of the encrypted keystore (using the provided parameters) +guarantee that account credentials cannot be brute forced in any meaningful time.*** + +An Ethereum account is implemented by the [`accounts.Account`][accounts-account] struct from +the Geth [accounts][accounts-pkg] package. Assuming an instance of an +[`accounts.Manager`][accounts-manager] called `am` exists, all of the described lifecycle +operations can be executed with a handful of function calls (error handling omitted). + +```go +// Create a new account with the specified encryption passphrase. +newAcc, _ := ks.NewAccount("Creation password") +fmt.Println(newAcc) + +// Export the newly created account with a different passphrase. The returned +// data from this method invocation is a JSON encoded, encrypted key-file. +jsonAcc, _ := ks.Export(newAcc, "Creation password", "Export password") + +// Update the passphrase on the account created above inside the local keystore. +_ = ks.Update(newAcc, "Creation password", "Update password") + +// Delete the account updated above from the local keystore. +_ = ks.Delete(newAcc, "Update password") + +// Import back the account we've exported (and then deleted) above with yet +// again a fresh passphrase. +impAcc, _ := ks.Import(jsonAcc, "Export password", "Import password") +``` + +*Although instances of [`accounts.Account`][accounts-account] can be used to access various information about +specific Ethereum accounts, they do not contain any sensitive data (such as passphrases or private keys), +rather they act solely as identifiers for client code and the keystore.* + +## Signing authorization + +Account objects do not hold the sensitive private keys of the associated Ethereum accounts. +Account objects are placeholders that identify the cryptographic keys. All operations that +require authorization (e.g. transaction signing) are performed by the account manager after +granting it access to the private keys. + +There are a few different ways to authorize the account manager to execute signing +operations, each having its advantages and drawbacks. Since the different methods have +wildly different security guarantees, it is essential to be clear on how each works: + +* **Single authorization**: The simplest way to sign a transaction via the account + manager is to provide the passphrase of the account every time something needs to be + signed, which will ephemerally decrypt the private key, execute the signing operation + and immediately throw away the decrypted key. The drawbacks are that the passphrase + needs to be queried from the user every time, which can become annoying if done + frequently or the application needs to keep the passphrase in memory, which can have + security consequences if not done properly. Depending on the keystore's configured + strength, constantly decrypting keys can result in non-negligible resource + requirements. + +* **Multiple authorizations**: A more complex way of signing transactions via the account + manager is to unlock the account via its passphrase once, and allow the account manager + to cache the decrypted private key, enabling all subsequent signing requests to + complete without the passphrase. The lifetime of the cached private key may be managed + manually (by explicitly locking the account back up) or automatically (by providing a + timeout during unlock). This mechanism is useful for scenarios where the user may need + to sign many transactions or the application would need to do so without requiring user + input. The crucial aspect to remember is that **anyone with access to the account + manager can sign transactions while a particular account is unlocked** (e.g. + application running untrusted code). + + +Assuming an instance of an [`accounts.Manager`][accounts-manager] called `am` exists, a new +account can be created to sign transactions using [`NewAccount`][new-account]. Creating transactions +is out of scope for this page so instead a random [`common.Hash`][common-hash] will be signed instead. +For information on creating transactions in Go native applications see the [Go API page](/docs/dapp/native). + +```go +// Create a new account to sign transactions with +signer, _ := ks.NewAccount("Signer password") +txHash := common.HexToHash("0x0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef") +``` + +With the boilerplate out of the way, the transaction can be signed using the authorization +mechanisms described above: + +```go +// Sign a transaction with a single authorization +signature, _ := ks.SignHashWithPassphrase(signer, "Signer password", txHash.Bytes()) + +// Sign a transaction with multiple manually cancelled authorizations +_ = ks.Unlock(signer, "Signer password") +signature, _ = ks.SignHash(signer, txHash.Bytes()) +_ = ks.Lock(signer.Address) + +// Sign a transaction with multiple automatically cancelled authorizations +_ = ks.TimedUnlock(signer, "Signer password", time.Second) +signature, _ = ks.SignHash(signer, txHash.Bytes()) +``` + +Note that [`SignWithPassphrase`][sign-w-phrase] takes an [`accounts.Account`][accounts-account] as the +signer, whereas [`Sign`][accounts-sign] takes only a [`common.Address`][common-address]. The reason +for this is that an [`accounts.Account`][accounts-account] object may also contain a custom key-path, allowing +[`SignWithPassphrase`][sign-w-phrase] to sign using accounts outside of the keystore; however +[`Sign`][accounts-sign] relies on accounts already unlocked within the keystore, so it cannot specify custom paths. + + +## Summary + +Account management is a fundamental pillar of Ethereum development. Geth's Go API provides the tools required +to integrate best-practise account security into Go native applications using a simple set of Go functions. + + +[accounts-sign]: (https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.Sign) +[common-address]: https://godoc.org/github.com/ethereum/go-ethereum/common#Address +[accounts-sign]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.Sign +[sign-w-phrase]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.SignWithPassphrase +[secp256k1]: https://www.secg.org/sec2-v2.pdf +[libsecp256k1]: https://github.com/bitcoin-core/secp256k1 +[wss]:https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition +[go-accounts]:https://godoc.org/github.com/ethereum/go-ethereum/accounts +[accounts-manager]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager +[accounts-pkg]: https://godoc.org/github.com/ethereum/go-ethereum/accounts +[keystore]: https://godoc.org/github.com/ethereum/go-ethereum/accounts/keystore#NewKeyStore +[pkg-constants]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#pkg-constants +[accounts-account]:https://godoc.org/github.com/ethereum/go-ethereum/accounts#Account +[new-account]: https://godoc.org/github.com/ethereum/go-ethereum/accounts#Manager.NewAccount +[common-hash]: https://godoc.org/github.com/ethereum/go-ethereum/common#Hash +[scrypt-docs]: https://pkg.go.dev/golang.org/x/crypto/scrypt diff --git a/content/docs/developers/dapp-developer/native-bindings.md b/content/docs/developers/dapp-developer/native-bindings.md new file mode 100644 index 0000000000..248bd12e01 --- /dev/null +++ b/content/docs/developers/dapp-developer/native-bindings.md @@ -0,0 +1,617 @@ +--- +title: Go Contract Bindings +sort_key: E +--- + +This page introduces the concept of server-side native dapps. Geth provides the tools required +to generate [Go][go-link] language bindings to any Ethereum contract that is compile-time type safe, +highly performant and can be generated completely automatically from a compiled contract. + +Interacting with a contract on the Ethereum blockchain from Go is already possible via the +RPC interfaces exposed by Ethereum clients. However, writing the boilerplate code that +translates Go language constructs into RPC calls and back is time consuming and brittle - +implementation bugs can only be detected during runtime and it's almost impossible to evolve +a contract as even a tiny change in Solidity is awkward to port over to Go. Therefore, +Geth provides tools for easily converting contract code into Go code that can be used directly +in Go applications. + +This page provides an introduction to generating Go contract bindings and using them in a simple +Go application. + +{:toc} + +- this will be removed by the toc + +## Prerequisites + +This page is fairly beginner-friendly and designed for people starting out with +writing Go native dapps. The core concepts will be introduced gradually as a developer +would encounter them. However, some basic familiarity with [Ethereum](https://ethereum.org), +[Solidity](https://docs.soliditylang.org/en/v0.8.15/) and [Go](https://go.dev/) is +assumed. + + +## What is an ABI? + +Ethereum smart contracts have a schema that defines its functions and return types in the form +of a JSON file. This JSON file is known as an *Application Binary Interface*, or ABI. The ABI +acts as a specification for precisely how to encode data sent to a contract and how to +decode the data the contract sends back. The ABI is the only essential piece of information required to +generate Go bindings. Go developers can then use the bindings to interact with the contract +from their Go application without having to deal directly with data encoding and decoding. +An ABI is generated when a contract is compiled. + +## Abigen: Go binding generator + +Geth includes a source code generator called `abigen` that can convert Ethereum ABI definitions +into easy to use, type-safe Go packages. With a valid Go development environment +set up and the go-ethereum repository checked out correctly, `abigen` can be built as follows: + +``` +$ cd $GOPATH/src/github.com/ethereum/go-ethereum +$ go build ./cmd/abigen +``` + +### Generating the bindings + +To demonstrate the binding generator a contract is required. The contract `Storage.sol` implements two +very simple functions: `store` updates a user-defined `uint256` to the contract's storage, and `retrieve` +displays the value stored in the contract to the user. The Solidity code is as follows: + +```solidity +// SPDX-License-Identifier: GPL-3.0 + +pragma solidity >0.7.0 < 0.9.0; +/** +* @title Storage +* @dev store or retrieve variable value +*/ + +contract Storage { + + uint256 value; + + function store(uint256 number) public{ + value = number; + } + + function retrieve() public view returns (uint256){ + return value; + } +} +``` + +This contract can be pasted into a text file and saved as `Storage.sol`. + +The following code snippet shows how an ABI can be generated for `Storage.sol` +using the Solidity compiler `solc`. + +```shell +solc --abi Storage.sol -o build +``` + +The ABI can also be generated in other ways such as using the `compile` commands in development +frameworks such as [Truffle][truffle-link], [Hardhat][hardhat-link] and [Brownie][brownie-link] +or in the online IDE [Remix][remix-link]. ABIs for existing +verified contracts can be downloaded from [Etherscan](etherscan.io). + + +The ABI for `Storage.sol` (`Storage.abi`) looks as follows: + +```json +[{"inputs":[],"name":"retrieve","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"number","type":"uint256"}],"name":"store","outputs":[],"stateMutability":"nonpayable","type":"function"}] +``` + +The contract binding can then be generated by passing the ABI to `abigen` as follows: + +``` +$ abigen --abi Storage.abi --pkg main --type Storage --out Storage.go +``` + +Where the flags are: + + * `--abi`: Mandatory path to the contract ABI to bind to + * `--pkg`: Mandatory Go package name to place the Go code into + * `--type`: Optional Go type name to assign to the binding struct + * `--out`: Optional output path for the generated Go source file (not set = stdout) + +This will generate a type-safe Go binding for the Storage contract. The generated code will +look something like the snippet below, the full version of which can be viewed +[here](https://gist.github.com/jmcook1186/a78e59d203bb54b06e1b81f2cda79d93). + +```go +// Code generated - DO NOT EDIT. +// This file is a generated binding and any manual changes will be lost. + +package main + +import ( + "errors" + "math/big" + "strings" + + ethereum "github.com/ethereum/go-ethereum" + "github.com/ethereum/go-ethereum/accounts/abi" + "github.com/ethereum/go-ethereum/accounts/abi/bind" + "github.com/ethereum/go-ethereum/common" + "github.com/ethereum/go-ethereum/core/types" + "github.com/ethereum/go-ethereum/event" +) + +// Reference imports to suppress errors if they are not otherwise used. +var ( + _ = errors.New + _ = big.NewInt + _ = strings.NewReader + _ = ethereum.NotFound + _ = bind.Bind + _ = common.Big1 + _ = types.BloomLookup + _ = event.NewSubscription +) + +// StorageMetaData contains all meta data concerning the Storage contract. +var StorageMetaData = &bind.MetaData{ + ABI: "[{\"inputs\":[],\"name\":\"retrieve\",\"outputs\":[{\"internalType\":\"uint256\",\"name\":\"\",\"type\":\"uint256\"}],\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"internalType\":\"uint256\",\"name\":\"number\",\"type\":\"uint256\"}],\"name\":\"store\",\"outputs\":[],\"stateMutability\":\"nonpayable\",\"type\":\"function\"}]", +} + +// StorageABI is the input ABI used to generate the binding from. +// Deprecated: Use StorageMetaData.ABI instead. +var StorageABI = StorageMetaData.ABI + +// Storage is an auto generated Go binding around an Ethereum contract. +type Storage struct { + StorageCaller // Read-only binding to the contract + StorageTransactor // Write-only binding to the contract + StorageFilterer // Log filterer for contract events +} +... + +``` + +`Storage.go` contains all the bindings required to interact with `Storage.sol` from a Go application. +However, this isn't very useful unless the contract is actually deployed on Ethereum or one of +Ethereum's testnets. The following sections will demonstrate how to deploy the contract to +an Ethereum testnet and interact with it using the Go bindings. + +### Deploying contracts to Ethereum + +In the previous section, the contract ABI was sufficient for generating the contract bindings from its ABI. +However, deploying the contract requires some additional information in the form of the compiled +bytecode. + +The bytecode is obtained by running the compiler again but this passing the `--bin` flag, e.g. + +```shell +solc --bin Storage.sol -o Storage.bin +``` + +Then `abigen` can be run again, this time passing `Storage.bin`: + + +``` +$ abigen --abi Storage.abi --pkg main --type Storage --out Storage.go --bin Storage.bin +``` + +This will generate something similar to the bindings generated in the previous section. However, +an additional `DeployStorage` function has been injected: + +```go +// DeployStorage deploys a new Ethereum contract, binding an instance of Storage to it. +func DeployStorage(auth *bind.TransactOpts, backend bind.ContractBackend) (common.Address, *types.Transaction, *Storage, error) { + parsed, err := StorageMetaData.GetAbi() + if err != nil { + return common.Address{}, nil, nil, err + } + if parsed == nil { + return common.Address{}, nil, nil, errors.New("GetABI returned nil") + } + + address, tx, contract, err := bind.DeployContract(auth, *parsed, common.FromHex(StorageBin), backend) + if err != nil { + return common.Address{}, nil, nil, err + } + return address, tx, &Storage{StorageCaller: StorageCaller{contract: contract}, StorageTransactor: StorageTransactor{contract: contract}, StorageFilterer: StorageFilterer{contract: contract}}, nil +} +``` +View the full file [here](https://gist.github.com/jmcook1186/91124cfcbc7f22dcd3bb4f148d2868a8). + +The new `DeployStorage()` function can be used to deploy the contract to an Ethereum testnet from a Go application. To do this +requires incorporating the bindings into a Go application that also handles account management, authorization and Ethereum backend +to deploy the contract through. Specifically, this requires: + +1. A running Geth node connected to an Ethereum testnet (recommended Goerli) +2. An account in the keystore prefunded with enough ETH to cover gas costs for deploying and interacting with the contract + +Assuming these prerequisites exist, a new `ethclient` can be instantiated with the local Geth node's ipc file, providing +access to the testnet from the Go application. The key can be instantiated as a variable in the application by copying the +JSON object from the keyfile in the keystore. + +Putting it all together would result in: + +```go +package main + +import ( + "fmt" + "log" + "math/big" + "strings" + "time" + + "github.com/ethereum/go-ethereum/accounts/abi/bind" + "github.com/ethereum/go-ethereum/ethclient" + +) + +const key = `<>` + +func main() { + // Create an IPC based RPC connection to a remote node and an authorized transactor + conn, err := rpc.NewIPCClient("/home/go-ethereum/goerli/geth.ipc") + if err != nil { + log.Fatalf("Failed to connect to the Ethereum client: %v", err) + } + auth, err := bind.NewTransactor(strings.NewReader(key), "<>") + if err != nil { + log.Fatalf("Failed to create authorized transactor: %v", err) + } + // Deploy the contract passing the newly created `auth` and `conn` vars + address, tx, instance, err := DeployStorage(auth, conn), new(big.Int), "Storage contract in Go!", 0, "Go!") + if err != nil { + log.Fatalf("Failed to deploy new storage contract: %v", err) + } + fmt.Printf("Contract pending deploy: 0x%x\n", address) + fmt.Printf("Transaction waiting to be mined: 0x%x\n\n", tx.Hash()) + + time.Sleep(250 * time.Millisecond) // Allow it to be processed by the local node :P + + // function call on `instance`. Retrieves pending name + name, err := instance.Name(&bind.CallOpts{Pending: true}) + if err != nil { + log.Fatalf("Failed to retrieve pending name: %v", err) + } + fmt.Println("Pending name:", name) +} +``` + +Running this code requests the creation of a brand new `Storage` contract on the Goerli blockchain. +The contract functions can be called while the contract is waiting to be mined. + +``` +Contract pending deploy: 0x46506d900559ad005feb4645dcbb2dbbf65e19cc +Transaction waiting to be mined: 0x6a81231874edd2461879b7280ddde1a857162a744e3658ca7ec276984802183b + +Pending name: Storage contract in Go! +``` + +Once mined, the contract exists permanently at its deployment address and can now be interacted with +from other applications without ever needing to be redeployed. + +Note that `DeployStorage` returns four variables: + +- `address`: the deployment address of the contract + +- `tx`: the transaction hash that can be queried using Geth or a service like [Etherscan](etherscan.io) + +- `instance`: an instance of the deployed contract whose functions can be called in the Go application + +- `err`: a variable that handles errors in case of a deployment failure + + +### Accessing an Ethereum contract + +To interact with a contract already deployed on the blockchain, the deployment `address` is required and +a `backend` through which to access Ethereum must be defined. The binding generator provides an RPC +backend out-of-the-box that can be used to attach to an existing Ethereum node via IPC, HTTP or WebSockets. + +As in the previous section, a Geth node running on an Ethereum testnet (recommend Goerli) and an account +with some test ETH to cover gas is required. The `Storage.sol` deployment address is also needed. + +Again, an instance of `ethclient` can be created, passing the path to Geth's ipc file. In the example +below this backend is assigned to the variable `conn`. + +```go +// Create an IPC based RPC connection to a remote node +// NOTE update the path to the ipc file! +conn, err := ethclient.Dial("/home/go-ethereum/goerli/geth.ipc") +if err != nil { + log.Fatalf("Failed to connect to the Ethereum client: %v", err) +} +``` + +The functions available for interacting with the `Storage` contract are defined in `Storage.go`. To create +a new instance of the contract in a Go application, the `NewStorage()` function can be used. The function +is defined in `Storage.go` as follows: + +```go +// NewStorage creates a new instance of Storage, bound to a specific deployed contract. +func NewStorage(address common.Address, backend bind.ContractBackend) (*Storage, error) { + contract, err := bindStorage(address, backend, backend, backend) + if err != nil { + return nil, err + } + return &Storage{StorageCaller: StorageCaller{contract: contract}, StorageTransactor: StorageTransactor{contract: contract}, StorageFilterer: StorageFilterer{contract: contract}}, nil +} +``` + +`NewStorage()` takes two arguments: the deployment address and a backend (`conn`) and returns +an instance of the deployed contract. In the example below, the instance is assigned to `store`. + + +```go +package main + +import ( + "fmt" + "log" + + "github.com/ethereum/go-ethereum/common" + "github.com/ethereum/go-ethereum/ethclient" +) + +func main() { + // Create an IPC based RPC connection to a remote node + // NOTE update the path to the ipc file! + conn, err := ethclient.Dial("/home/go-ethereum/goerli/geth.ipc") + if err != nil { + log.Fatalf("Failed to connect to the Ethereum client: %v", err) + } + // Instantiate the contract and display its name + // NOTE update the deployment address! + store, err := NewStorage(common.HexToAddress("0x21e6fc92f93c8a1bb41e2be64b4e1f88a54d3576"), conn) + if err != nil { + log.Fatalf("Failed to instantiate Storage contract: %v", err) + } + +``` + +The contract instance is then available to interact with in the Go application. To read a value from +the blockchain, for example the `value` stored in the contract, the contract's `Retrieve()` function +can be called. Again, the function is defined in `Storage.go` as follows: + +```go +// Retrieve is a free data retrieval call binding the contract method 0x2e64cec1. +// +// Solidity: function retrieve() view returns(uint256) +func (_Storage *StorageCaller) Retrieve(opts *bind.CallOpts) (*big.Int, error) { + var out []interface{} + err := _Storage.contract.Call(opts, &out, "retrieve") + + if err != nil { + return *new(*big.Int), err + } + + out0 := *abi.ConvertType(out[0], new(*big.Int)).(**big.Int) + + return out0, err + +} +``` + +Note that the `Retrieve()` function requires a parameter to be passed, even though the +original Solidity contract didn't require any at all none. The parameter required is +a `*bind.CallOpts` type, which can be used to fine tune the call. If no adjustments to the +call are required, pass `nil`. Adjustments to the call include: + +* `Pending`: Whether to access pending contract state or the current stable one +* `GasLimit`: Place a limit on the computing resources the call might consume + +So to call the `Retrieve()` function in the Go application: + +```go +value, err := store.Retrieve(nil) +if err != nil { + log.Fatalf("Failed to retrieve value: %v", err) +} +fmt.Println("Value: ", value) +} +``` + +The output will be something like: + +```terminal +Value: 56 +``` + +### Transacting with an Ethereum contract + +Invoking a method that changes contract state (i.e. transacting) is a bit more involved, +as a live transaction needs to be authorized and broadcast into the network. **Go bindings +require local signing of transactions and do not delegate this to a remote node.** This is +to keep accounts private within dapps, and not shared (by default) between them. + +Thus to allow transacting with a contract, your code needs to implement a method that +given an input transaction, signs it and returns an authorized output transaction. Since +most users have their keys in the [Web3 Secret Storage][web3-ss-link] format, the `bind` +package contains a small utility method (`bind.NewTransactor(keyjson, passphrase)`) that can +create an authorized transactor from a key file and associated password, without the user +needing to implement key signing themselves. + +Changing the previous code snippet to update the value stored in the contract: + +```go +package main + +import ( + "fmt" + "log" + "math/big" + "strings" + + "github.com/ethereum/go-ethereum/accounts/abi/bind" + "github.com/ethereum/go-ethereum/common" + "github.com/ethereum/go-ethereum/ethclient" +) + +const key = `json object from keystore` + +func main() { + // Create an IPC based RPC connection to a remote node and instantiate a contract binding + conn, err := ethclient.Dial("/home/go-ethereum/goerli/geth.ipc") + if err != nil { + log.Fatalf("Failed to connect to the Ethereum client: %v", err) + } + store, err := NewStorage(common.HexToAddress("0x21e6fc92f93c8a1bb41e2be64b4e1f88a54d3576"), conn) + if err != nil { + log.Fatalf("Failed to instantiate a Storage contract: %v", err) + } + // Create an authorized transactor and call the store function + auth, err := bind.NewStorageTransactor(strings.NewReader(key), "strong_password") + if err != nil { + log.Fatalf("Failed to create authorized transactor: %v", err) + } + // Call the store() function + tx, err := store.Store(auth, big.NewInt(420)) + if err != nil { + log.Fatalf("Failed to update value: %v", err) + } + fmt.Printf("Update pending: 0x%x\n", tx.Hash()) +} +``` + +And the output: + +```terminal +Update pending: 0x4f4aaeb29ed48e88dd653a81f0b05d4df64a86c99d4e83b5bfeb0f0006b0e55b +``` + +Similar to the method invocations in the previous section which only read contract state, +transacting methods also require a mandatory first parameter, a `*bind.TransactOpts` type, +which authorizes the transaction and potentially fine tunes it: + +* `From`: Address of the account to invoke the method with (mandatory) +* `Signer`: Method to sign a transaction locally before broadcasting it (mandatory) +* `Nonce`: Account nonce to use for the transaction ordering (optional) +* `GasLimit`: Place a limit on the computing resources the call might consume (optional) +* `GasPrice`: Explicitly set the gas price to run the transaction with (optional) +* `Value`: Any funds to transfer along with the method call (optional) + +The two mandatory fields are automatically set by the `bind` package if the auth options are +constructed using `bind.NewTransactor`. The nonce and gas related fields are automatically +derived by the binding if they are not set. Unset values are assumed to be zero. + + +### Pre-configured contract sessions + +Reading and state modifying contract-calls require a mandatory first parameter which can +authorize and fine tune some of the internal parameters. However, most of the time the +same accounts and parameters will be used to issue many transactions, so constructing +the call/transact options individually quickly becomes unwieldy. + +To avoid this, the generator also creates specialized wrappers that can be pre-configured with +tuning and authorization parameters, allowing all the Solidity defined methods to be invoked +without needing an extra parameter. + +These are named similarly to the original contract type name but suffixed with `Sessions`: + +```go +// Wrap the Storage contract instance into a session +session := &StorageSession{ + Contract: store, + CallOpts: bind.CallOpts{ + Pending: true, + }, + TransactOpts: bind.TransactOpts{ + From: auth.From, + Signer: auth.Signer, + GasLimit: big.NewInt(3141592), + }, +} +// Call the previous methods without the option parameters +session.Store(big.NewInt(69)) +``` + +## Bind Solidity directly + +In the past, abigen allowed compilation and binding of a Solidity source file directly to a Go package in a single step. +This feature has been discontinued from [v1.10.18](https://github.com/ethereum/go-ethereum/releases/tag/v1.10.18) +onwards due to maintenance synchronization challenges with the compiler in Geth. + +The compilation and binding steps can be joined together into a pipeline, for example: +``` +solc Storage.sol --combined-json abi,bin | abigen --pkg main --type storage --out Storage.go --combined-json - +``` + +### Project integration (`go generate`) + +The `abigen` command was made in such a way as to integrate easily into existing +Go toolchains: instead of having to remember the exact command needed to bind an Ethereum +contract into a Go project, `go generate` can handle all the fine details. + +Place the binding generation command into a Go source file before the package definition: + +``` +//go:generate abigen --sol Storage.sol --pkg main --out Storage.go +``` + +After which whenever the Solidity contract is modified, instead of needing to remember and +run the above command, we can simply call `go generate` on the package (or even the entire +source tree via `go generate ./...`), and it will correctly generate the new bindings for us. + + +## Blockchain simulator + +Being able to deploy and access deployed Ethereum contracts from native Go code is a powerful +feature. However, using public testnets as a backend does not lend itself well to +*automated unit testing*. Therefore, Geth also implements a *simulated blockchain* +that can be set as a backend to native contracts the same way as a live RPC backend, using the +command `backends.NewSimulatedBackend(genesisAccounts)`. The code snippet below shows how this +can be used as a backend in a Go applicatioon. + +```go +package main + +import ( + "fmt" + "log" + "math/big" + + "github.com/ethereum/go-ethereum/accounts/abi/bind" + "github.com/ethereum/go-ethereum/accounts/abi/bind/backends" + "github.com/ethereum/go-ethereum/core" + "github.com/ethereum/go-ethereum/crypto" +) + +func main() { + // Generate a new random account and a funded simulator + key, _ := crypto.GenerateKey() + auth := bind.NewKeyedTransactor(key) + + sim := backends.NewSimulatedBackend(core.GenesisAccount{Address: auth.From, Balance: big.NewInt(10000000000)}) + + // instantiate contract + store, err := NewStorage(common.HexToAddress("0x21e6fc92f93c8a1bb41e2be64b4e1f88a54d3576"), sim) + if err != nil { + log.Fatalf("Failed to instantiate a Storage contract: %v", err) + } + // Create an authorized transactor and call the store function + auth, err := bind.NewStorageTransactor(strings.NewReader(key), "strong_password") + if err != nil { + log.Fatalf("Failed to create authorized transactor: %v", err) + } + // Call the store() function + tx, err := store.Store(auth, big.NewInt(420)) + if err != nil { + log.Fatalf("Failed to update value: %v", err) + } + fmt.Printf("Update pending: 0x%x\n", tx.Hash()) +} +``` + +Note, that it is not necessary to wait for a local private chain miner, or testnet miner to +integrate the currently pending transactions. To mine the next block, simply `Commit()` the simulator. + + +## Summary + +To make interacting with Ethereum contracts easier for Go developers, Geth provides tools that generate +contract bindings automatically. This makes contract functions available in Go native applications. + + +[go-link]:https://github.com/golang/go/wiki#getting-started-with-go +[truffle-link]:https://trufflesuite.com/docs/truffle/ +[hardhat-link]:https://hardhat.org/ +[brownie-link]:https://eth-brownie.readthedocs.io/en/stable/ +[remix-link]:https://remix.ethereum.org/ +[web3-ss-link]:https://github.com/ethereum/wiki/wiki/Web3-Secret-Storage-Definition \ No newline at end of file diff --git a/content/docs/developers/dapp-developer/native.md b/content/docs/developers/dapp-developer/native.md new file mode 100644 index 0000000000..34d9816d97 --- /dev/null +++ b/content/docs/developers/dapp-developer/native.md @@ -0,0 +1,249 @@ +--- +title: Go API +sort_key: C +--- + +Ethereum was originally conceptualized to be the base layer for [Web3][web3-link], providing +the backbone for a new generation of decentralized, permissionless and censorship resistant +applications called [dapps][dapp-link]. The first step towards this vision was the development +of clients providing an RPC interface into the peer-to-peer protocols. This allowed users to +transact between accounts and interact with smart contracts using command line tools. +Geth was one of the original clients to provide this type of gateway to the Ethereum network. + +Before long, web-browser-like graphical interfaces (e.g. Mist) were created to extend clients, and +client functions were built into websites built using the time-tested HTML/CSS/JS stack. +However, to support the most diverse, complex dapps, developers require programmatic access to client +functions through an API. This opens up client technologies as re-usable, composable units that +can be applied in creative ways by a global community of developers. + +To support this, Geth ships official Go packages that can be embedded into third party +desktop and server applications. There is also a [mobile API](/docs/dapp/mobile) that can be +used to embed Geth into mobile applications. + +This page provides a high-level overview of the Go API. + +*Note, this guide will assume some familiarity with Go development. It does not cover general topics +about Go project layouts, import paths or any other standard methodologies. If you are new to Go, +consider reading [Getting Started with Go][go-guide] first.* + +## Overview + +Geth's reusable Go libraries focus on three main usage areas: + +- Simplified client side account management +- Remote node interfacing via different transports +- Contract interactions through auto-generated bindings + +The libraries are updated synchronously with the Geth Github repository. +The Go libraries can be viewed in full at [Go Packages][go-pkg-link]. + +Péter Szilágyi (@karalabe) gave a high level overview of the Go libraries in +a talk at DevCon2 in Shanghai in 2016. The slides are still a useful resource +([available here][peter-slides]) and the talk itself can be viewed by clicking +the image below (it is also archived on [IPFS][ipfs-link]). + +[![Peter's Devcon2 talk](/static/images/devcon2_labelled.webp)](https://www.youtube.com/watch?v=R0Ia1U9Gxjg) + +## Go packages + +The `go-ethereum` library is distributed as a collection of standard Go packages straight from go-ethereum's +GitHub repository. The packages can be used directly via the official Go toolkit, without needing any +third party tools. + +The canonical import path for Geth is `github.com/ethereum/go-ethereum`, with all packages residing +underneath. Although there are [lots of them][go-ethereum-dir] most developers will only care about +a limited subset. + +All the Geth packages can be downloaded using: + +``` +$ go get -d github.com/ethereum/go-ethereum/... +``` + +More Go API support for dapp developers can be found on the [Go Contract Bindings](/docs/dapp/native-bindings) +and [Go Account Management](/docs/dapp/native-accounts) pages. + + +## Tutorial + +This section includes some basic usage examples for the `ethclient` and `gethclient` packages available as +part of the Go API. The `ethclient` package provides a client that implements the full Ethereum JSON-RPC API, +whereas `gethclient` offers the Geth-specific API. + +### Instantiating a client + +The client is an instance of the `Client` struct which has associated functions that wrap requests to the Ethereum +or Geth RPC API endpoints. + +A client is instantiated by passing a raw url or path to an ipc file to the client's `Dial` function. In the following +code snippet the path to the ipc file for a local Geth node is provided to `ethclient.Dial()`. + +```go +// create instance of ethclient and assign to cl +cl, err := ethclient.Dial("/tmp/geth.ipc") +if err != nil { + panic(err) +} +_ = cl +``` + +### Interacting with the client + +The client can now be used to handle requests to the Geth node using the full JSON-RPC API. For example, the function +`BlockNumer()` wraps a call to the `eth_blockNumber` endpoint. The function `SendTransaction` wraps a call to +`eth_sendTransaction`. The full list of client methods can be found [here][ethclient-pkg]. + +Frequently, the functions take an instance of the `Context` type as their leading argument. This defines context about requests sent from the application such as deadlines, cancellation signals etc. More information on this can +be found in the [Go documentation](https://pkg.go.dev/golang.org/x/net/context). An empty context instance can be +created using `Context.Background()`. + +### Querying client for data + +A simple starting point is to fetch the chain ID from the client. This e.g. is needed when signing a transaction as is to be seen in the next section. + +```go +chainid, err := cl.ChainID(context.Background()) +if err != nil { + return err +} +``` + +Unlike `ChainID`, many functions require arguments other than context. The Go API takes in and returns high-level types which are used in Geth internals as well to simplify programming and remove the need for knowing how data needs to be formatted exactly as per the JSON-RPC API spec. For example to find out the nonce for an account at a given block the address needs to be provided as a `common.Address` type and the block number as a `*big.Int`: + +```go +addr := common.HexToAddress("0xb02A2EdA1b317FBd16760128836B0Ac59B560e9D") +nonce, err := cl.NonceAt(context.Background(), addr, big.NewInt(14000000)) +``` + +### Querying past events + +Contracts emit events during execution which can be queried from the client. The parameters for the event one is interested in have to be filled out in the `ethereum.FilterQuery` object. This includes which event topics are of interested, from which contracts and during which range of blocks. The example below queries `Transfer` events of all ERC-20 tokens for the last 10 blocks: + +```go +blockNum, err := cl.BlockNumber(context.Background()) +if err != nil { + return err +} +q := ethereum.FilterQuery{ + FromBlock: new(big.Int).Sub(blockNum, big.NewInt(10)), + ToBlock: blockNum, + Topics: [][]common.Hash{common.HexToHash("0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef")}, +} +logs, err := cl.FilterLogs(context.Background(), q) +if err != nil { + return err +} +``` + +### Sending a transaction + +Sending a transaction is achieved using the `SendTransaction()` function. `SendTransaction` takes an instance of +`context.Context` as its leading argument and a signed transaction as its second argument. The signed transaction +must be generated in advance. Building the signed transaction is a multi-stage +process that requires first generating a key pair if none exists already, retrieving some chain data and defining sender and recipient +addresses. Then these data can be collected into a transaction object and signed. The resulting signed transaction +can then be passed to `SendTransaction`. + +The example below assumes the following key pair has already been generated: + +```go +// SK and ADDR are the secret key and sender address +SK = "0xaf5ead4413ff4b78bc94191a2926ae9ccbec86ce099d65aaf469e9eb1a0fa87f" +ADDR = "0x6177843db3138ae69679A54b95cf345ED759450d" +``` + +The secret key and address can be used to send a transaction. In the example below 1 ETH is sent from the +address `ADDR` to an arbitrary recipient. + +```go +import ( + "context" + "math/big" + + "github.com/ethereum/go-ethereum/common" + "github.com/ethereum/go-ethereum/core/types" + "github.com/ethereum/go-ethereum/crypto" + "github.com/ethereum/go-ethereum/ethclient" + "github.com/ethereum/go-ethereum/params" +) + +// sendTransaction sends a transaction with 1 ETH to a specified address. +func sendTransaction(cl *ethclient.Client) error { + var ( + sk = crypto.ToECDSAUnsafe(common.FromHex(SK)) + to = common.HexToAddress("0xb02A2EdA1b317FBd16760128836B0Ac59B560e9D") + value = new(big.Int).Mul(big.NewInt(1), big.NewInt(params.Ether)) + sender = common.HexToAddress(ADDR) + gasLimit = uint64(21000) + ) + // Retrieve the chainid (needed for signer) + chainid, err := cl.ChainID(context.Background()) + if err != nil { + return err + } + // Retrieve the pending nonce + nonce, err := cl.PendingNonceAt(context.Background(), sender) + if err != nil { + return err + } + // Get suggested gas price + tipCap, _ := cl.SuggestGasTipCap(context.Background()) + feeCap, _ := cl.SuggestGasPrice(context.Background()) + // Create a new transaction + tx := types.NewTx( + &types.DynamicFeeTx{ + ChainID: chainid, + Nonce: nonce, + GasTipCap: tipCap, + GasFeeCap: feeCap, + Gas: gasLimit, + To: &to, + Value: value, + Data: nil, + }) + // Sign the transaction using our keys + signedTx, _ := types.SignTx(tx, types.NewLondonSigner(chainid), sk) + // Send the transaction to our node + return cl.SendTransaction(context.Background(), signedTx) +} +``` + +### gethclient + +An instance of `gethclient` can be used in exactly the same way as `ethclient`. However, `gethclient` +includes Geth-specific API methods. These additional methods are: + +```shell +CallContract() +CreatAccessList() +GCStats() +GetNodeInfo() +GetProof() +MemStats() +SetHead() +SubscribePendingTransactions() +``` +*Note that both `ethclient` and `gethclient` have a `CallContract()` function - the difference is that +the `gethclient` version includes an `overrides` argument.* + +Details relating to these endpoints can be found at [pkg.go.dev][go-api-docs] or the Geth [Github][ethclient-link]. +The code snippets in this tutorial were adapted from a more more in-depth set of examples available on +[Github][web3go-link]. + + +## Summary + +There are a wide variety of Go APIs available for dapp developers that abstract away the complexity of interacting with Ethereum +using a set of composable, reusable functions provided by Geth. + +[go-guide]: https://github.com/golang/go/wiki#getting-started-with-go +[peter-slides]: https://ethereum.karalabe.com/talks/2016-devcon.html +[go-ethereum-dir]: https://pkg.go.dev/github.com/ethereum/go-ethereum/#section-directories +[ethclient-pkg]:https://pkg.go.dev/github.com/ethereum/go-ethereum/ethclient#Client +[go-pkg-link]: https://pkg.go.dev/github.com/ethereum/go-ethereum#section-directories +[ipfs-link]: https://ipfs.io/ipfs/QmQRuKPKWWJAamrMqAp9rytX6Q4NvcXUKkhvu3kuREKqXR +[dapp-link]: https://ethereum.org/en/glossary/#dapp +[web3-link]: https://ethereum.org/en/web3/ +[ethclient-link]: https://github.com/ethereum/go-ethereum/tree/master/ethclient +[go-api-docs]:https://pkg.go.dev/github.com/ethereum/go-ethereum@v1.10.19/ethclient/gethclient +[web3go-link]:https://github.com/MariusVanDerWijden/web3go diff --git a/content/docs/developers/dapp-developer/tracing.md b/content/docs/developers/dapp-developer/tracing.md new file mode 100644 index 0000000000..74dca40f83 --- /dev/null +++ b/content/docs/developers/dapp-developer/tracing.md @@ -0,0 +1,232 @@ +--- +title: EVM Tracing +sort_key: A +--- + +There are two different types of [transactions][transactions] +in Ethereum: simple value transfers and contract executions. A value transfer just +moves Ether from one account to another. If however the recipient of a transaction is +a contract account with associated [EVM][evm] (Ethereum Virtual Machine) bytecode - beside +transferring any Ether - the code will also be executed as part of the transaction. + +Having code associated with Ethereum accounts permits transactions to do arbitrarily +complex data storage and enables them to act on the previously stored data by further +transacting internally with outside accounts and contracts. This creates an interlinked +ecosystem of contracts, where a single transaction can interact with tens or hundreds of +accounts. + +The downside of contract execution is that it is very hard to say what a transaction +actually did. A transaction receipt does contain a status code to check whether execution +succeeded or not, but there is no way to see what data was modified, nor what external +contracts where invoked. Geth resolves this by re-running transactions locally and collecting +data about precisely what was executed by the EVM. This is known as "tracing" the transaction. + + +* TOC +{:toc} + + +## Tracing prerequisites + +In its simplest form, tracing a transaction entails requesting the Ethereum node to +reexecute the desired transaction with varying degrees of data collection and have it +return the aggregated summary for post processing. Reexecuting a transaction however has a +few prerequisites to be met. + +In order for an Ethereum node to reexecute a transaction, all historical state accessed +by the transaction must be available. This includes: + +* Balance, nonce, bytecode and storage of both the recipient as well as all internally invoked contracts. +* Block metadata referenced during execution of both the outer as well as all internally created transactions. +* Intermediate state generated by all preceding transactions contained in the same block as the one being traced. + +This means there are limits on the transactions that can be traced imposed by the synchronization and +pruning configuration of a node. + +* An **archive** node retains **all historical data** back to genesis. It can therefore +trace arbitrary transactions at any point in the history of the chain. Tracing a single +transaction requires reexecuting all preceding transactions in the same block. + +* A **full synced** node retains the most recent 128 blocks in memory, so transactions in +that range are always accessible. Full nodes also store occasional checkpoints back to genesis +that can be used to rebuild the state at any point on-the-fly. This means older transactions +can be traced but if there is a large distance between the requested transaction and the most +recent checkpoint rebuilding the state can take a long time. Tracing a single +transaction requires reexecuting all preceding transactions in the same block +**and** all preceding blocks until the previous stored snapshot. + +* A **snap synced** node holds the most recent 128 blocks in memory, so transactions in that +range are always accessible. However, snap-sync only starts processing from a relatively recent +block (as opposed to genesis for a full node). Between the initial sync block and the 128 most +recent blocks, the node stores occasional checkpoints that can be used to rebuild the state on-the-fly. +This means transactions can be traced back as far as the block that was used for the initial sync. +Tracing a single transaction requires reexecuting all preceding transactions in the same block, +**and** all preceding blocks until the previous stored snapshot. + +* A **light synced** node retrieving data **on demand** can in theory trace transactions +for which all required historical state is readily available in the network. This is because the data +required to generate the trace is requested from an les-serving full node. In practice, data +availability **cannot** be reasonably assumed. + +*There are exceptions to the above rules when running batch traces of entire blocks or +chain segments. Those will be detailed later.* + +## Basic traces + +The simplest type of transaction trace that Geth can generate are raw EVM opcode +traces. For every VM instruction the transaction executes, a structured log entry is +emitted, containing all contextual metadata deemed useful. This includes the *program +counter*, *opcode name*, *opcode cost*, *remaining gas*, *execution depth* and any +*occurred error*. The structured logs can optionally also contain the content of the +*execution stack*, *execution memory* and *contract storage*. + +The entire output of a raw EVM opcode trace is a JSON object having a few metadata +fields: *consumed gas*, *failure status*, *return value*; and a list of *opcode entries*: + +```json +{ + "gas": 25523, + "failed": false, + "returnValue": "", + "structLogs": [] +} +``` + +An example log for a single opcode entry has the following format: + +```json +{ + "pc": 48, + "op": "DIV", + "gasCost": 5, + "gas": 64532, + "depth": 1, + "error": null, + "stack": [ + "00000000000000000000000000000000000000000000000000000000ffffffff", + "0000000100000000000000000000000000000000000000000000000000000000", + "2df07fbaabbe40e3244445af30759352e348ec8bebd4dd75467a9f29ec55d98d" + ], + "memory": [ + "0000000000000000000000000000000000000000000000000000000000000000", + "0000000000000000000000000000000000000000000000000000000000000000", + "0000000000000000000000000000000000000000000000000000000000000060" + ], + "storage": { + } +} +``` + +### Generating basic traces + +To generate a raw EVM opcode trace, Geth provides a few [RPC API endpoints](/docs/rpc/ns-debug). +The most commonly used is [`debug_traceTransaction`](/docs/rpc/ns-debug#debug_tracetransaction). + +In its simplest form, `traceTransaction` accepts a transaction hash as its only argument. It then +traces the transaction, aggregates all the generated data and returns it as a **large** +JSON object. A sample invocation from the Geth console would be: + +```js +debug.traceTransaction("0xfc9359e49278b7ba99f59edac0e3de49956e46e530a53c15aa71226b7aa92c6f") +``` + +The same call can also be invoked from outside the node too via HTTP RPC (e.g. using Curl). In this +case, the HTTP endpoint must be enabled in Geth using the `--http` command and the `debug` API +namespace must be exposed using `--http.api=debug`. + +``` +$ curl -H "Content-Type: application/json" -d '{"id": 1, "method": "debug_traceTransaction", "params": ["0xfc9359e49278b7ba99f59edac0e3de49956e46e530a53c15aa71226b7aa92c6f"]}' localhost:8545 +``` + +To follow along with this tutorial, transaction hashes can be found from a local Geth node (e.g. by +attaching a [Javascript console](/docs/interface/javascript-console) and running `eth.getBlock('latest')` +then passing a transaction hash from the returned block to `debug.traceTransaction()`) or from a block +explorer (for [Mainnet](https://etherscan.io/) or a [testnet](https://goerli.etherscan.io/)). + +It is also possible to configure the trace by passing Boolean (true/false) values for four parameters +that tweak the verbosity of the trace. By default, the *EVM memory* and *Return data* are not reported +but the *EVM stack* and *EVM storage* are. To report the maximum amount of data: + +```shell +enableMemory: true +disableStack: false +disableStorage: false +enableReturnData: true +``` + +An example call, made in the Geth Javascript console, configured to report the maximum amount of data +looks as follows: + +```js +debug.traceTransaction("0xfc9359e49278b7ba99f59edac0e3de49956e46e530a53c15aa71226b7aa92c6f",{enableMemory: true, disableStack: false, disableStorage: false, enableReturnData: true}) +``` + +Running the above operation on the Rinkeby network (with a node retaining enough history) +will result in this [trace dump](https://gist.github.com/karalabe/c91f95ac57f5e57f8b950ec65ecc697f). + +Alternatively, disabling *EVM Stack*, *EVM Memory*, *Storage* and *Return data* (as demonstrated in the Curl request below) +results in the following, much shorter, [trace dump](https://gist.github.com/karalabe/d74a7cb33a70f2af75e7824fc772c5b4). + +``` +$ curl -H "Content-Type: application/json" -d '{"id": 1, "method": "debug_traceTransaction", "params": ["0xfc9359e49278b7ba99f59edac0e3de49956e46e530a53c15aa71226b7aa92c6f", {"disableStack": true, "disableStorage": true}]}' localhost:8545 +``` + +### Limits of basic traces + +Although the raw opcode traces generated above are useful, having an individual log entry for every single +opcode is too low level for most use cases, and will require developers to create additional tools to +post-process the traces. Additionally, a full opcode trace can easily go into the hundreds of +megabytes, making them very resource intensive to get out of the node and process externally. + +To avoid those issues, Geth supports running custom JavaScript tracers *within* the Ethereum node, +which have full access to the EVM stack, memory and contract storage. This means developers only have to +gather the data they actually need, and do any processing at the source. + +## Pruning + +Geth does in-memory state-pruning by default, discarding state entries that it deems +no longer necessary to maintain. This is configured via the `--gcmode` command. An error +message alerting the user that the necessary state is not available is common in EVM tracing on +anything other than an archive node. + +```sh +Error: required historical state unavailable (reexec=128) + at web3.js:6365:37(47) + at send (web3,js:5099:62(35)) + at :1:23(13) +``` + +The pruning behaviour, and consequently the state availability and tracing capability of +a node depends on its sync and pruning configuration. The 'oldest' block after which +state is immediately available, and before which state is not immediately available, +is known as the "pivot block". There are then several possible cases for a trace request +on a Geth node. + +For tracing a transaction in block `B` where the pivot block is `P` can regenerate the desired +state by replaying blocks from the last : + +1. a fast-sync'd node can regenerate the desired state by replaying blocks from the most recent +checkpoint between `P` and `B` as long as `P` < `B`. If `P` > `B` there is no available checkpoint +and the state cannot be regenerated without replying the chain from genesis. + +2. a fully sync'd node can regenerate the desired state by replaying blocks from the last available +full state before `B`. A fully sync'd node re-executes all blocks from genesis, so checkpoints are available +across the entire history of the chain. However, database pruning discards older data, moving `P` to a more +recent position in the chain. If `P` > `B` there is no available checkpoint and the state cannot be +regenerated without replaying the chain from genesis. + +3. A fully-sync'd node without pruning (i.e. an archive node configured with `--gcmode=archive`) +does not need to replay anything, it can immediately load up any state and serve the request for any `B`. + +The time taken to regenerate a specific state increases with the distance between `P` and `B`. If the distance +between `P` and `B` is large, the regeneration time can be substantial. + +## Summary + +This page covered the concept of EVM tracing and how to generate traces with the default opcode-based tracers using RPC. +More advanced usage is possible, including using other built-in tracers as well as writing [custom tracing](/docs/dapp/custom-tracer) code in Javascript +and Go. The API as well as the JS tracing hooks are defined in [the reference](/docs/rpc/ns-debug#debug_traceTransaction). + + +[transactions]: https://ethereum.org/en/developers/docs/transactions +[evm]: https://ethereum.org/en/developers/docs/evm diff --git a/content/docs/developers/geth-developer/Code-Review-Guidelines.md b/content/docs/developers/geth-developer/Code-Review-Guidelines.md new file mode 100644 index 0000000000..cfe6ae85d3 --- /dev/null +++ b/content/docs/developers/geth-developer/Code-Review-Guidelines.md @@ -0,0 +1,103 @@ +--- +title: Code Review Guidelines +sort_key: B +--- + +The only way to get code into go-ethereum is to send a pull request. Those pull requests +need to be reviewed by someone. This document is a guide that explains our expectations +around PRs for both authors and reviewers. + +## Terminology + +* The **author** of a pull request is the entity who wrote the diff and submitted it to + GitHub. +* The **team** consists of people with commit rights on the go-ethereum repository. +* The **reviewer** is the person assigned to review the diff. The reviewer must be a team + member. +* The **code owner** is the person responsible for the subsystem being modified by the PR. + +## The Process + +The first decision to make for any PR is whether it's worth including at all. This +decision lies primarily with the code owner, but may be negotiated with team members. + +To make the decision we must understand what the PR is about. If there isn't enough +description content or the diff is too large, request an explanation. Anyone can do this +part. + +We expect that reviewers check the style and functionality of the PR, providing comments +to the author using the GitHub review system. Reviewers should follow up with the PR until +it is in good shape, then **approve** the PR. Approved PRs can be merged by any code owner. + +When communicating with authors, be polite and respectful. + +### Code Style + +We expect `gofmt`ed code. For contributions of significant size, we expect authors to +understand and use the guidelines in [Effective Go][effgo]. Authors should avoid common +mistakes explained in the [Go Code Review Comments][revcomment] page. + +### Functional Checks + +For PRs that fix an issue, reviewers should try reproduce the issue and verify that the +pull request actually fixes it. Authors can help with this by including a unit test that +fails without (and passes with) the change. + +For PRs adding new features, reviewers should attempt to use the feature and comment on +how it feels to use it. Example: if a PR adds a new command line flag, use the program +with the flag and comment on whether the flag feels useful. + +We expect appropriate unit test coverage. Reviewers should verify that new code is covered +by unit tests. + +### CI + +Code submitted must pass all unit tests and static analysis ("lint") checks. We use Travis +CI to test code on Linux, macOS and AppVeyor to test code on Microsoft Windows. + +For failing CI builds, the issue may not be related to the PR itself. Such failures are +usually related to flakey tests. These failures can be ignored (authors don't need to fix +unrelated issues), but please file a GH issue so the test gets fixed eventually. + +### Commit Messages + +Commit messages on the master branch should follow the rule below. PR authors are not +required to use any particular style because the message can be modified at merge time. +Enforcing commit message style is the responsibility of the person merging the PR. + +The commit message style we use is similar to the style used by the Go project: + +The first line of the change description is conventionally a one-line summary of the +change, prefixed by the primary affected Go package. It should complete the sentence "This +change modifies go-ethereum to _____." The rest of the description elaborates and should +provide context for the change and explain what it does. + +Template: + +```text +package/path: change XYZ + +Longer explanation of the change in the commit. You can use +multiple sentences here. It's usually best to include content +from the PR description in the final commit message. + +issue notices, e.g. "Fixes #42353". +``` + +### Special Situations And How To Deal With Them + +As a reviewer, you may find yourself in one of the sitations below. Here's how to deal +with those: + +* The author doesn't follow up: ping them after a while (i.e. after a few days). If there + is no further response, close the PR or complete the work yourself. + +* Author insists on including refactoring changes alongside bug fix: We can tolerate small + refactorings alongside any change. If you feel lost in the diff, ask the author to + submit the refactoring as an independent PR, or at least as an independent commit in the + same PR. + +* Author keeps rejecting your feedback: reviewers have authority to reject any change for technical reasons. If you're unsure, ask the team for a second opinion. You may close the PR if no consensus can be reached. + +[effgo]: https://golang.org/doc/effective_go.html +[revcomment]: https://github.com/golang/go/wiki/CodeReviewComments diff --git a/content/docs/developers/geth-developer/Private-Network.md b/content/docs/developers/geth-developer/Private-Network.md new file mode 100644 index 0000000000..e54dabcdac --- /dev/null +++ b/content/docs/developers/geth-developer/Private-Network.md @@ -0,0 +1,481 @@ +--- +title: Private Networks +sort_key: D +--- + +This guide explains how to set up a private network of multiple Geth nodes. An Ethereum network is private if the nodes are not connected to the main network. In this context private only means reserved or isolated, rather than protected or secure. A fully controlled, private Ethereum network is useful as a backend for core developers working on issues relating to networking/blockchain syncing etc. Private networks are also useful for Dapp developers testing multi-block and multi-user scenarios. + +## Prerequisites + +To follow the tutorial on this page it is necessary to have a working Geth installation (instructions [here](/docs/install-and-build/installing-geth)). It is also helpful to understand Geth fundamentals (see [Getting Started](/docs/getting-started)). + + +## Private Networks + +A private network is composed of multiple Ethereum nodes that can only connect to each other. In order to run multiple nodes locally, each one requires a separate data directory (`--datadir`). The nodes must also know about each other and be able to exchange information, share an initial state and a common consensus algorithm. The remainder of this page will explain how to configure Geth so that these basic requirements are met, enabling a private network to be started. + + +### Choosing A Network ID + +Ethereum Mainnet has Network ID = 1. There are also many other networks that Geth can connect to by providing alternative Chain IDs, some are testnets and others are alternative networks built from forks of the Geth source code. Providing a network ID that is not already being used by an existing network or testnet means the nodes using that network ID can only connect to each other, creating a private network. A list of current network IDs is available at [Chainlist.org](https://chainlist.org/). The network ID is controlled using the `networkid` flag, e.g. + +```shell +geth --networkid 12345 +``` + + +### Choosing A Consensus Algorithm + +While the main network uses proof-of-work (PoW) to secure the blockchain, Geth also supports the the 'Clique' proof-of-authority (PoA) consensus algorithm as an alternative for private networks. Clique is strongly recommended for private testnets because PoA is far less resource-intensive than PoW. Clique is currently used as the consensus algorithm in public testnets such as [Rinkeby](https://www.rinkeby.io) and [Görli](https://goerli.net). The key differences between the consensus algorithms available in Geth are: + +#### Ethash + +Geth's PoW algorithm, [Ethhash](https://ethereum.org/en/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash), is a system that allows open participation by anyone willing to dedicate resources to mining. While this is a critical property for a public network, the overall security of the blockchain strictly depends on the total amount of resources used to secure it. As such, PoW is a poor choice for private networks with few miners. The Ethash mining 'difficulty' is adjusted automatically so that new blocks are created approximately 12 seconds apart. As more mining resources are deployed on the network, creating a new block becomes harder so that the average block time matches the target block time. + +#### Clique + +Clique consensus is a PoA system where new blocks can be created by authorized 'signers' only. The clique consenus protocol is specified in [EIP-225][clique-eip]. The initial set of authorized signers is configured in the genesis block. Signers can be authorized and de-authorized using a voting mechanism, thus allowing the set of signers to change while the blockchain operates. Clique can be configured to target any block time (within reasonable limits) since it isn't tied to the difficulty adjustment. + + +[clique-eip]: https://eips.ethereum.org/EIPS/eip-225 + + +### Creating The Genesis Block + +Every blockchain starts with a genesis block. When Geth is run with default settings for the first time, it commits the Mainnet genesis to the database. For a private network, it is generally preferable to use a different genesis block. The genesis block is configured using a _genesis.json_ file whose path must be provided to Geth on start-up. When creating a genesis block, a few initial parameters for the private blockchain must be defined: + +- Ethereum platform features enabled at launch (`config`). Enabling and disabling features once the blockchain is running requires scheduling a [hard fork](https://ethereum.org/en/glossary/#hard-fork). + +- Initial block gas limit (`gasLimit`). This impacts how much EVM computation can happen within a single block. Mirroring the main Ethereum network is generally a [good choice][gaslimit-chart]. The block gas limit can be adjusted after launch using the `--miner.gastarget` command-line flag. + +- Initial allocation of ether (`alloc`). This determines how much ether is available to the addresses listed in the genesis block. Additional ether can be created through mining as the chain progresses. + + +#### Clique Example + +Below is an example of a `genesis.json` file for a PoA network. The `config` section ensures that all known protocol changes are available and configures the 'clique' engine to be used for consensus. Note that the initial signer set must be configured through the `extradata` field. This field is required for Clique to work. + +The signer account keys can be generated using the [geth account](./managing-your-accounts) command (this command can be run multiple times to create more than one signer key). + +```shell +geth account new --datadir data +``` + +The Ethereum address printed by this command should be recorded. To encode the signer addresses in `extradata`, concatenate 32 zero bytes, all signer addresses and 65 further zero bytes. The result of this concatenation is then used as the value accompanying the `extradata` key in `genesis.json`. In the example below, `extradata` contains a single initial signer address, `0x7df9a875a174b3bc565e6424a0050ebc1b2d1d82`. + +The `period` configuration option sets the target block time of the chain. + +```json +{ + "config": { + "chainId": 12345, + "homesteadBlock": 0, + "eip150Block": 0, + "eip155Block": 0, + "eip158Block": 0, + "byzantiumBlock": 0, + "constantinopleBlock": 0, + "petersburgBlock": 0, + "istanbulBlock": 0, + "berlinBlock": 0, + "clique": { + "period": 5, + "epoch": 30000 + } + }, + "difficulty": "1", + "gasLimit": "8000000", + "extradata": "0x00000000000000000000000000000000000000000000000000000000000000007df9a875a174b3bc565e6424a0050ebc1b2d1d820000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "alloc": { + "7df9a875a174b3bc565e6424a0050ebc1b2d1d82": { "balance": "300000" }, + "f41c74c9ae680c1aa78f42e5647a62f353b7bdde": { "balance": "400000" } + } +} +``` + +#### Ethash Example + +Since Ethash is the default consensus algorithm, no additional parameters need to be configured in order to use it. The initial mining difficulty is influenced using the `difficulty` parameter, but note that the difficulty adjustment algorithm will quickly adapt to the amount of mining resources deployed on the chain. + +```json +{ + "config": { + "chainId": 12345, + "homesteadBlock": 0, + "eip150Block": 0, + "eip155Block": 0, + "eip158Block": 0, + "byzantiumBlock": 0, + "constantinopleBlock": 0, + "petersburgBlock": 0, + "istanbulBlock": 0, + "berlinBlock": 0, + "ethash": {} + }, + "difficulty": "1", + "gasLimit": "8000000", + "alloc": { + "7df9a875a174b3bc565e6424a0050ebc1b2d1d82": { "balance": "300000" }, + "f41c74c9ae680c1aa78f42e5647a62f353b7bdde": { "balance": "400000" } + } +} +``` + +### Initializing the Geth Database + +To create a blockchain node that uses this genesis block, first use `geth init` to import and sets the canonical genesis block for the new chain. This requires the path to `genesis.json` to be passed as an argument. + +```shell +geth init --datadir data genesis.json +``` + +When Geth is started using `--datadir data` the genesis block defined in `genesis.json` will be used. For example: + + +```shell +geth --datadir data --networkid 12345 +``` + +### Scheduling Hard Forks + +As Ethereum protocol development progresses, new features become available. To enable these features on an existing private network, a hard fork must be scheduled. To do this, a future block number must be chosen which determines precisely when the hard fork will activate. Continuing the `genesis.json` example above and assuming the current block number is 35421, a hard fork might be scheduled for block 40000. This hard fork might upgrade the network to conform to the 'London' specs. First, all the Geth instances on the private network must be recent enough to support the specific hard fork. If so, `genesis.json` can be updated so that the `londonBlock` key gets the value 40000. The Geth instances are then shut down and `geth init` is run to update their configuration. When the nodes are restarted they will pick up where they left off and run normally until block 40000, at which point they will automatically upgrade. + +The modification to `genesis.json` is as follows: + +```json +{ + "config": { + + "londonBlock": 40000, + + }, + +} +``` + +The upgrade command is: + +```shell +geth init --datadir data genesis.json +``` + + +### Setting Up Networking + +With the node configured and initialized, the next step is to set up a peer-to-peer network. This requires a bootstrap node. The bootstrap node is a normal node that is designated to be the entry point that other nodes use to join the network. Any node can be chosen to be the bootstrap node. + +To configure a bootstrap node, the IP address of the machine the bootstrap node will run on must be known. The bootsrap node needs to know its own IP address so that it can broadcast it to other nodes. On a local machine this can be found using tools such as `ifconfig` and on cloud instances such as Amazon EC2 the IP address of the virtual machine can be found in the management console. Any firewalls must allow UDP and TCP traffic on port 30303. + +The bootstrap node IP is set using the `--nat` flag (the command below contains an example address - replace it with the correct one). + +```shell +geth --datadir data --networkid 15 --nat extip:172.16.254.4 +``` + +The 'node record' of the bootnode can be extracted using the JS console: + +```shell +geth attach data/geth.ipc --exec admin.nodeInfo.enr +``` + +This command should print a base64 string such as the following example. Other nodes will use the information contained in the bootstrap node record to connect to the peer-to-peer network. + +```text +"enr:-Je4QEiMeOxy_h0aweL2DtZmxnUMy-XPQcZllrMt_2V1lzynOwSx7GnjCf1k8BAsZD5dvHOBLuldzLYxpoD5UcqISiwDg2V0aMfGhGlQhqmAgmlkgnY0gmlwhKwQ_gSJc2VjcDI1NmsxoQKX_WLWgDKONsGvxtp9OeSIv2fRoGwu5vMtxfNGdut4cIN0Y3CCdl-DdWRwgnZf" +``` + +If the nodes are intended to connect across the Internet, the bootnode and all other nodes must have public IP addresses assigned, and both TCP and UDP traffic can pass their firewalls. If Internet connectivity is not required or all member nodes connect using well-known IPs, Geth should be set up to restrict peer-to-peer connectivity to an IP subnet. Doing so will further isolate the network and prevents cross-connecting with other blockchain networks in case the nodes are reachable from the Internet. Use the +`--netrestrict` flag to configure a whitelist of IP networks: + +```shell +geth --netrestrict 172.16.254.0/24 +``` + +With the above setting, Geth will only allow connections from the 172.16.254.0/24 subnet, and will not attempt to connect to other nodes outside of the set IP range. + +### Running Member Nodes + +Before running a member node, it must be initialized with the same genesis file as used for the bootstrap node. With the bootnode operational and externally reachable (`telnet ` will confirm that it is indeed reachable), more Geth nodes can be started and connected to them via the bootstrap node using the `--bootnodes` flag. The process is to start Geth on the same machine as the bootnode, with a separate data directory and listening port and the bootnode node record provided as an argument: + +For example, using data directory (example: `data2`) and listening port (example: `30305`): + +```shell +geth --datadir data2 --networkid 12345 --port 30305 --bootnodes +``` + +With the member node running, it is possible to check that it is connected to the bootstrap node or any other node in the network by attaching a console and running `admin.peers`. It may take up to a few seconds for the nodes to get connected. + +```shell +geth attach data2/geth.ipc --exec admin.peers +``` + +### Running A Signer (Clique) + +To set up Geth for signing blocks in Clique, a signer account must be available. The account must already be available as a keyfile in the keystore. To use it for signing blocks, it must be unlocked. The following command, for address `0x7df9a875a174b3bc565e6424a0050ebc1b2d1d82` will prompt for the account password, then start signing blocks: + +```shell +geth --unlock 0x7df9a875a174b3bc565e6424a0050ebc1b2d1d82 --mine +``` + +Mining can be further configured by changing the default gas limit blocks converge to (with `--miner.gastarget`) and the price transactions are accepted at (with `--miner.gasprice`). + +### Running A Miner (Ethash) + +For PoW in a simple private network, a single CPU miner instance is enough to create a stable stream of blocks at regular intervals. To start a Geth instance for mining, it can be run with all the usual flags plus the following to configure mining: + +```shell +geth --mine --miner.threads=1 --miner.etherbase=0xf41c74c9ae680c1aa78f42e5647a62f353b7bdde +``` + +This will start mining bocks and transactions on a single CPU thread, crediting all block rewards to the account specified by `--miner.etherbase`. + + +## End-to-end example {#end-to-end-example} + +This section will run through the commands for setting up a simple private network of two nodes. Both nodes will run on the local machine using the same genesis block and network ID. The data directories for each node will be named `node1` and `node2`. + +```shell +`mkdir node1 node2` +``` + +Each node will have an associated account that will receive some ether at launch. The following command creates an account for Node 1: + +```shell +geth --datadir node1 account new +``` + +This command returns a request for a password. Once a password has been provided the following information is returned to the terminal: + +```terminal +Your new account is locked with a password. Please give a password. Do not foget this password. +Password: +Repeat password: + +Your new key was generated + +Public address of the key: 0xC1B2c0dFD381e6aC08f34816172d6343Decbb12b +Path of the secret key file: node1/keystore/UTC--2022-05-13T14-25-49.229126160Z--c1b2c0dfd381e6ac08f34816172d6343decbb12b + +- You can share your public address with anyone. Others need it to interact with you. +- You must NEVER share the secret key with anyone! The key controls access to your funds! +- You must BACKUP your key file! Without the key, it's impossible to access account funds! +- You must remember your password! Without the password, it's impossible to decrypt the key! +``` + +The keyfile and account password should be backed up securely. These steps can then be repeated for Node 2. These commands create keyfiles that are stored in the `keystore` directory in `node1` and `node2` data directories. In order to unlock the accounts later the passwords for each account should be saved to a text file in each node's data directory. + +In each data directory save a copy of the following `genesis.json` to the top level project directory. The account addresses in the `alloc` field should be replaced with those created for each node in the previous step (without the leading `0x`). + + +```json +{ + "config": { + "chainId": 12345, + "homesteadBlock": 0, + "eip150Block": 0, + "eip155Block": 0, + "eip158Block": 0, + "byzantiumBlock": 0, + "constantinopleBlock": 0, + "petersburgBlock": 0, + "istanbulBlock": 0, + "muirGlacierBlock": 0, + "berlinBlock": 0, + "londonBlock": 0, + "arrowGlacierBlock": 0, + "grayGlacierBlock": 0, + "clique": { + "period": 5, + "epoch": 30000 + } + }, + "difficulty": "1", + "gasLimit": "800000000", + "extradata": "0x00000000000000000000000000000000000000000000000000000000000000007df9a875a174b3bc565e6424a0050ebc1b2d1d820000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000", + "alloc": { + "C1B2c0dFD381e6aC08f34816172d6343Decbb12b": { "balance": "500000" }, + "c94d95a5106270775351eecfe43f97e8e75e59e8": { "balance": "500000" } + } +} + +``` + +The nodes can now be set up using `geth init` as follows: + +```shell +geth init --datadir node1 genesis.json +``` + +This should be repeated for both nodes. The following will be returned to the terminal: + +```terminal +INFO [05-13|15:41:47.520] Maximum peer count ETH=50 LES=0 total=50 +INFO [05-13|15:41:47.520] Smartcard socket not found, disabling err="stat /run/pcscd/pcscd.comm: no such file or directory" +INFO [05-13|15:41:47.520] Set global gas cap cap=50,000,000 +INFO [05-13|15:41:47.520] Allocated cache and file handles database=/home/go-ethereum/node2/geth/chaindata cache=16.00MiB handles=16 +INFO [05-13|15:41:47.542] Writing custom genesis block +INFO [05-13|15:41:47.542] Persisted trie from memory database nodes=3 size=397.00B time="41.246µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B +INFO [05-13|15:41:47.543] Successfully wrote genesis state database=chaindata hash=c9a158..d415a0 +INFO [05-13|15:41:47.543] Allocated cache and file handles database=/home/go-ethereum/node2/geth/chaindata cache=16.00MiB handles=16 +INFO [05-13|15:41:47.556] Writing custom genesis block +INFO [05-13|15:41:47.557] Persisted trie from memory database nodes=3 size=397.00B time="81.801µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B +INFO [05-13|15:41:47.558] Successfully wrote genesis state database=chaindata hash=c9a158..d415a0 +``` + +The next step is to configure a bootnode. This can be any node, but for this tutorial the developer tool `bootnode` will be used to quickly and easily configure a dedicated bootnode. First the bootnode requires a key, which can be created with the following command, which will save a key to `boot.key`: + +```shell +bootnode -genkey boot.key +``` + +This key can then be used to generate a bootnode as follows: + +``` +bootnode -nodekey boot.key -addr :30305 +``` + +The choice of port passed to `-addr` is arbitrary, but public Ethereum networks use 30303, so this is best avoided. The `bootnode` command returns the following logs to the terminal, confirming that it is running: + +```terminal +enode://f7aba85ba369923bffd3438b4c8fde6b1f02b1c23ea0aac825ed7eac38e6230e5cadcf868e73b0e28710f4c9f685ca71a86a4911461637ae9ab2bd852939b77f@127.0.0.1:0?discport=30305 +Note: you're using cmd/bootnode, a developer tool. +We recommend using a regular node as bootstrap node for production deployments. +INFO [05-13|15:50:03.645] New local node record seq=1,652,453,403,645 id=a2d37f4a7d515b3a ip=nil udp=0 tcp=0 +``` + +The two nodes can now be started. Open separate terminals for each node, leaving the bootnode running in the original terminal. In each terminal, run the following command (replacing `node1` with `node2` where appropriate, and giving each node a different port ID. The account address and password file for node 1 must also be provided: + +```shell +./geth --datadir node1 --port 30306 --bootnodes enode://f7aba85ba369923bffd3438b4c8fde6b1f02b1c23ea0aac825ed7eac38e6230e5cadcf868e73b0e28710f4c9f685ca71a86a4911461637ae9ab2bd852939b77f@127.0.0.1:0?discport=30305 --networkid 123454321 --unlock 0xC1B2c0dFD381e6aC08f34816172d6343Decbb12b --password node1/password.txt +``` + +This will start the node using the bootnode as an entry point. Repeat the same command with the information appropriate to node 2. In each terminal, the following logs indicate success: + +```terminal +INFO [05-13|16:17:40.061] Maximum peer count ETH=50 LES=0 total=50 +INFO [05-13|16:17:40.061] Smartcard socket not found, disabling err="stat /run/pcscd/pcscd.comm: no such file or directory" +INFO [05-13|16:17:40.061] Set global gas cap cap=50,000,000 +INFO [05-13|16:17:40.061] Allocated trie memory caches clean=154.00MiB dirty=256.00MiB +INFO [05-13|16:17:40.061] Allocated cache and file handles database=/home/go-ethereum/node1/geth/chaindata cache=512.00MiB handles=524,288 +INFO [05-13|16:17:40.094] Opened ancient database database=/home/go-ethereum/node1/geth/chaindata/ancient readonly=false +INFO [05-13|16:17:40.095] Initialised chain configuration config="{ChainID: 123454321 Homestead: 0 DAO: nil DAOSupport: false EIP150: 0 EIP155: 0 EIP158: 0 Byzantium: 0 Constantinople: 0 Petersburg: 0 Istanbul: nil, Muir Glacier: nil, Berlin: nil, London: nil, Arrow Glacier: nil, MergeFork: nil, Terminal TD: nil, Engine: clique}" +INFO [05-13|16:17:40.096] Initialising Ethereum protocol network=123,454,321 dbversion=8 +INFO [05-13|16:17:40.098] Loaded most recent local header number=0 hash=c9a158..d415a0 td=1 age=53y1mo2w +INFO [05-13|16:17:40.098] Loaded most recent local full block number=0 hash=c9a158..d415a0 td=1 age=53y1mo2w +INFO [05-13|16:17:40.098] Loaded most recent local fast block number=0 hash=c9a158..d415a0 td=1 age=53y1mo2w +INFO [05-13|16:17:40.099] Loaded local transaction journal transactions=0 dropped=0 +INFO [05-13|16:17:40.100] Regenerated local transaction journal transactions=0 accounts=0 +INFO [05-13|16:17:40.100] Gasprice oracle is ignoring threshold set threshold=2 +WARN [05-13|16:17:40.100] Unclean shutdown detected booted=2022-05-13T16:16:46+0100 age=54s +INFO [05-13|16:17:40.100] Starting peer-to-peer node instance=Geth/v1.10.18-unstable-8d84a701-20220503/linux-amd64/go1.18.1 +INFO [05-13|16:17:40.130] New local node record seq=1,652,454,949,228 id=f1364e6d060c4625 ip=127.0.0.1 udp=30306 tcp=30306 +INFO [05-13|16:17:40.130] Started P2P networking self=enode://87606cd0b27c9c47ca33541d4b68cf553ae6765e22800f0df340e9788912b1e3d2759b3d1933b6f739c720701a56ce26f672823084420746d04c25fc7b8c6824@127.0.0.1:30306 +INFO [05-13|16:17:40.133] IPC endpoint opened url=/home/go-ethereum/node1/geth.ipc +INFO [05-13|16:17:40.785] Unlocked account address=0xC1B2c0dFD381e6aC08f34816172d6343Decbb12b +INFO [05-13|16:17:42.636] New local node record seq=1,652,454,949,229 id=f1364e6d060c4625 ip=82.11.59.221 udp=30306 tcp=30306 +INFO [05-13|16:17:43.309] Mapped network port proto=tcp extport=30306 intport=30306 interface="UPNP IGDv1-IP1" +INFO [05-13|16:17:43.822] Mapped network port proto=udp extport=30306 intport=30306 interface="UPNP IGDv1-IP1" +[05-13|16:17:50.150] Looking for peers peercount=0 tried=0 static=0 +INFO [05-13|16:18:00.164] Looking for peers peercount=0 tried=0 static=0 +``` + +In the first terminal that is currently running the logs resembling the following will be displayed, showing the discovery process in action: + +```terminal +INFO [05-13|15:50:03.645] New local node record seq=1,652,453,403,645 id=a2d37f4a7d515b3a ip=nil udp=0 tcp=0 +TRACE[05-13|16:15:49.228] PING/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:49.229] PONG/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:49.229] PING/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:49.230] PONG/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:49.730] FINDNODE/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:49.731] NEIGHBORS/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:50.231] FINDNODE/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:50.231] NEIGHBORS/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:50.561] FINDNODE/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:50.561] NEIGHBORS/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:50.731] FINDNODE/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:50.731] NEIGHBORS/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:51.231] FINDNODE/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:51.232] NEIGHBORS/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:52.591] FINDNODE/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:52.591] NEIGHBORS/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +TRACE[05-13|16:15:57.767] PING/v4 id=f1364e6d060c4625 addr=127.0.0.1:30306 err=nil +``` + +It is now possible to attach a Javascript console to either node to query the network properties: + + +```shell +geth attach node1/geth.ipc +``` + +Once the Javascript console is running, check that the node is connected to one other peer (node 2): + +```shell +net.peerCount +``` + +The details of this peer can also be queried and used to check that the peer really is Node 2: + +``` +admin.peers +``` + +This should return the following: + +```terminal +[{ + caps: ["eth/66", "snap/1"], + enode: "enode://6a4576fb12004aa13949dbf25de978102483a6521e6d5d87c5b7ccb1944bbf8995dc730303ae891732410b1dd2e684277e9292fc0a17372a789bb4e87bdf366b@127.0.0.1:30307", + id: "d300c59ba301abcb5f4a3866aab6f833857c3ddf2f0febb583410b1dc466f175", + name: "Geth/v1.10.18-unstable-8d84a701-20220503/linux-amd64/go1.18.1", + network: { + inbound: false, + localAddress: "127.0.0.1:56620", + remoteAddress: "127.0.0.1:30307", + static: false, + trusted: false + }, + protocols: { + eth: { + difficulty: 1, + head: "0xc9a158a687eff8a46128bd5b9aaf6b2f04f10f0683acbd7f031514db9ad415a0", + version: 66 + }, + snap: { + version: 1 + } + } +}] +``` + +The account associated with Node 1 was supposed to be funded with some ether at the chain genesis. This can be checked easily using `eth.getBalance()`: + +```shell +eth.getBalance(eth.accounts[0]) +``` + +This account can then be unlocked and some ether sent to Node 2, using the following commands: + + +```javascript +// unlock account +personal.unlock(eth.accounts[0]) + +// send some Wei +eth.sendTransaction({to: "0xc94d95a5106270775351eecfe43f97e8e75e59e8", from: eth.accounts[0], value: 25000}) + +//check the transaction was successful by querying Node 2's account balance +eth.getBalance("0xc94d95a5106270775351eecfe43f97e8e75e59e8") +``` + +The same steps can then be repeated to attach a console to Node 2. + + +## Summary + +This page explored the various options for configuring a local private network. A step by step guide showed how to set up and launch a private network, unlock the associated accounts, attach a console to check the network status and make some basic interactions. + + + +[gaslimit-chart]: https://etherscan.io/chart/gaslimit diff --git a/content/docs/developers/geth-developer/dev-mode.md b/content/docs/developers/geth-developer/dev-mode.md new file mode 100644 index 0000000000..472a0b946d --- /dev/null +++ b/content/docs/developers/geth-developer/dev-mode.md @@ -0,0 +1,353 @@ +--- +title: Developer mode +sort_key: B +--- + +It is often convenient for developers to work in an environment where changes to client or application software can be deployed and tested rapidly and without putting real-world users or assets at risk. For this purpose, Geth has a `--dev` flag that spins up Geth in "developer mode". This creates a single-node Ethereum test network with no connections to any external peers. It exists solely on the local machine. Starting Geth in developer mode does the following: + +- Initializes the data directory with a testing genesis block +- Sets max peers to 0 (meaning Geth does not search for peers) +- Turns off discovery by other nodes (meaning the node is invisible to other nodes) +- Sets the gas price to 0 (no cost to send transactions) +- Uses the Clique proof-of-authority consensus engine which allows blocks to be mined as-needed without excessive CPU and memory consumption +- Uses on-demand block generation, producing blocks when transactions are waiting to be mined + +This configuration enables developers to experiment with Geth's source code or develop new applications without having to sync to a pre-existing public network. Blocks are only mined when there are pending transactions. Developers can break things on this network without affecting other users. This page will demonstrate how to spin up a local Geth testnet and a simple smart contract will be deployed to it using the Remix online integrated development environment (IDE). + +## Prerequisites + +It is assumed that the user has a working Geth installation (see [installation guide](/docs/install-and-build/installing-geth)). +It would also be helpful to have basic knowledge of Geth and the Geth console. See [Getting Started](/docs/getting-started). +Some basic knowledge of [Solidity](https://docs.soliditylang.org/) and [smart contract deployment](https://ethereum.org/en/developers/tutorials/deploying-your-first-smart-contract/) would be useful. + +## Start Geth in Dev Mode + +Starting Geth in developer mode is as simple as providing the `--dev` flag. It is also possible to create a realistic block creation frequency by setting `--dev.period 13` instead of creating blocks only when transactions are pending. There are also additional configuration options required to follow this tutorial. + +First, `http` (or `ws`) must be enabled so that the Javascript console can be attached to the Geth node, and some namespaces must be specified so that certain functions can be executed from the Javascript console, specifically `eth`, `web3` and `personal`. Alternatively, Geth can be started with the `console` command. + +Finally, Remix will be used to deploy a smart contract to the node which requires information to be exchanged externally to Geth's own domain. To permit this, the `net` namespace must be enabled and the Remix URL must be provided to `--http.corsdomain`. The full command is as follows: + +```shell + +geth --dev --http --http.api eth,web3,personal,net --http.corsdomain "http://remix.ethereum.org" + +``` + +The terminal will display the following logs, confirming Geth has started successfully in developer mode: + +```terminal + + +INFO [05-09|10:49:02.951] Starting Geth in ephemeral dev mode... +INFO [05-09|10:49:02.952] Maximum peer count ETH=50 LES=0 total=50 +INFO [05-09|10:49:02.952] Smartcard socket not found, disabling err="stat /run/pcscd/pcscd.comm: no such file or directory" +INFO [05-09|10:49:02.953] Set global gas cap cap=50,000,000 +INFO [05-09|10:49:03.133] Using developer account address=0x7Aa16266Ba3d309e3cb278B452b1A6307E52Fb62 +INFO [05-09|10:49:03.196] Allocated trie memory caches clean=154.00MiB dirty=256.00MiB +INFO [05-09|10:49:03.285] Writing custom genesis block +INFO [05-09|10:49:03.286] Persisted trie from memory database nodes=13 size=1.90KiB time="180.524µs" gcnodes=0 gcsize=0.00B gctime=0s livenodes=1 livesize=0.00B +INFO [05-09|10:49:03.287] Initialised chain configuration config="{ ChainID: 1337 Homestead: 0 DAO: nil DAOSupport: false EIP150: 0 EIP155: 0 EIP158: 0 Byzantium: 0 Constantinople: 0 Petersburg: 0 Istanbul: 0, Muir Glacier: 0, Berlin: 0, London: 0, Arrow Glacier: nil, MergeFork: nil, Terminal TD: nil, Engine: clique}" +INFO [05-09|10:49:03.288] Initialising Ethereum protocol network=1337 dbversion= nil +INFO [05-09|10:49:03.289] Loaded most recent local header number=0 hash=c9c3de..579bb8 td=1 age=53y1mo1w +INFO [05-09|10:49:03.289] Loaded most recent local full block number=0 hash=c9c3de..579bb8 td=1 age=53y1mo1w +INFO [05-09|10:49:03.289] Loaded most recent local fast block number=0 hash=c9c3de..579bb8 td=1 age=53y1mo1w +WARN [05-09|10:49:03.289] Failed to load snapshot, regenerating err="missing or corrupted snapshot" +INFO [05-09|10:49:03.289] Rebuilding state snapshot +INFO [05-09|10:49:03.290] Resuming state snapshot generation root=ceb850..0662cb accounts=0 slots=0 storage=0.00B elapsed="778.089µs" +INFO [05-09|10:49:03.290] Regenerated local transaction journal transactions=0 accounts=0 +INFO [05-09|10:49:03.292] Gasprice oracle is ignoring threshold set threshold=2 +INFO [05-09|10:49:03.292] Generated state snapshot accounts=10 slots=0 storage=412.00B elapsed=2.418ms +WARN [05-09|10:49:03.292] Error reading unclean shutdown markers error="leveldb: not found" +INFO [05-09|10:49:03.292] Starting peer-to-peer node instance=Geth/v1.10.18-unstable-8d84a701-20220503/linux-amd64/go1.18.1 +WARN [05-09|10:49:03.292] P2P server will be useless, neither dialing nor listening +INFO [05-09|10:49:03.292] Stored checkpoint snapshot to disk number=0 hash=c9c3de..579bb8 +INFO [05-09|10:49:03.312] New local node record seq=1,652,089,743,311 id=bfedca74bea20733 ip=127.0.0.1 udp=0 tcp=0 +INFO [05-09|10:49:03.313] Started P2P networking self=enode://0544de6446dd5831daa5a391de8d0375d93ac602a95d6a182d499de31f22f75b6645c3f562932cac8328d51321b676c683471e2cf7b3c338bb6930faf6ead389@127.0.0.1:0 +INFO [05-09|10:49:03.314] IPC endpoint opened url=/tmp/geth.ipc +INFO [05-09|10:49:03.315] HTTP server started endpoint=127.0.0.1:8545 auth=false prefix= cors=http:remix.ethereum.org vhosts=localhost +INFO [05-09|10:49:03.315] Transaction pool price threshold updated price=0 +INFO [05-09|10:49:03.315] Updated mining threads threads=0 +INFO [05-09|10:49:03.315] Transaction pool price threshold updated price=1 +INFO [05-09|10:49:03.315] Etherbase automatically configured address=0x7Aa16266Ba3d309e3cb278B452b1A6307E52Fb62 +INFO [05-09|10:49:03.316] Commit new sealing work number=1 sealhash=2372a2..7fb8e7 uncles=0 txs=0 gas=0 fees=0 elapsed="202.366µs" +WARN [05-09|10:49:03.316] Block sealing failed err="sealing paused while waiting for transactions" +INFO [05-09|10:49:03.316] Commit new sealing work number=1 sealhash=2372a2..7fb8e7 uncles=0 txs=0 gas=0 fees=0 elapsed="540.054µs" + +``` + +This terminal must be left running throughout the entire tutorial. In a second terminal, attach a Javascript console: + + +```shell + +geth attach http://127.0.0.1:8545 + +``` + +The Javascript terminal will open with the following welcome message: + +```terminal + +Welcome to the Geth Javascript console! + +instance: Geth/v1.10.18-unstable-8d84a701-20220503/linux-amd64/go.1.18.1 +coinbase: 0x540dbaeb2390f2eb005f7a6dbf3436a0959197a9 +at block: 0 (Thu Jan 01 1970 01:00:00 GMT+0100 (BST)) + modules: eth:1.0 personal:1.0 rpc:1.0 web3:1.0 + +To exit, press ctrl-d or type exit +> + +``` + +In the [Getting Started](/docs/getting-started/) tutorial it was explained that using the external signing and account management tool, Clef, was best practise for generating and securing user accounts. However, for simplicity this tutorial will use Geth's built-in account management. First, the existing accounts can be displayed using `eth.accounts`: + +```shell + +eth.accounts + +``` + +An array containing a single address will be displayed in the terminal, despite no accounts having yet been explicitly created. This is the "coinbase" account. The coinbase address is the recipient of the total amount of ether created at the local network genesis. Querying the ether balance of the coinbase account will return a very large number. The coinbase account can be invoked as `eth.accounts[0]` or as `eth.coinbase`: + +```terminal + +> eth.coinbase==eth.accounts[0] +true + +``` + +The following command can be used to query the balance. The return value is in units of Wei, which is divided by 118 to give units of ether. This can be done explicitly or by calling the `web3.FromWei()` function: + +```shell + +eth.getBalance(eth.coinbase)/1e18 + +// or + +web3.fromWei(eth.getBalance(eth.coinbase)) + +``` + +Using `web3.fromWei()` is less error prone because the correct multiplier is built in. These commands both return the following: + +```terminal + +1.157920892373162e+59 + +``` + +A new account can be created and some of the ether from the coinbase transferred across to it. A new account is generated using the `newAccount` function in the `personal` namespace: + +```shell + +personal.newAccount() + +``` + +The terminal will display a request for a password, twice. Once provided, a new account will be created and its address printed to the terminal. The account creation is also logged in the Geth terminal, including the location of the keyfile in the keystore. It is a good idea to back up the password somewhere at this point. If this were an account on a live network, intended to own assets of real-world value, it would be critical to back up the account password and the keystore in a secure manner. + +To reconfirm the account creation, running `eth.accounts` in the Javascript console should display an array containing two account addresses, one being the coinbase and the other being the newly generated address. The following command transfers 50 ETH from the coinbase to the new account: + +```shell + +eth.sendTransaction({from: eth.coinbase, to: eth.accounts[1], value: web3.toWei(50, "ether")}) + +``` + +A transaction hash will be returned to the console. This transaction hash will also be displayed in the logs in the Geth console, followed by logs confirming that a new block was mined (remember in the local development network blocks are mined when transactions are pending). The transaction details can be displayed in the Javascript console by passing the transaction hash to `eth.getTransaction()`: + +```shell + +eth.getTransaction("0x62044d2cab405388891ee6d53747817f34c0f00341cde548c0ce9834e9718f27") + +``` + +The transaction details are displayed as follows: + +```terminal + +{ + accessList: [], + blockHash: "0xdef68762539ebfb247e31d749acc26ab5df3163aabf9d450b6001c200d17da8a", + blockNumber: 1, + chainId: "0x539", + from: "0x540dbaeb2390f2eb005f7a6dbf3436a0959197a9", + gas: 21000, + gasPrice: 875000001, + hash: "0x2326887390dc04483d435a6303dc05bd2648086eab15f24d7dcdf8c26e8af4b8", + input: "0x", + maxFeePerGas: 2000000001, + maxPriorityFeePerGas: 1, + nonce: 0, + r: "0x3f7b54f095b837ec13480eab5ac7de082465fc79f43b813cca051394dd028d5d", + s: "0x167ef271ae8175239dccdd970db85e06a044d5039252d6232d0954d803bb4e3e", + to: "0x43e3a14fb8c68caa7eea95a02693759de4513950", + transactionIndex: 0, + type: "0x2", + v: "0x0", + value: 50000000000000000000 +} + + +``` + +Now that the user account is funded with ether, a contract can be created ready to deploy to the Geth node. + + +## A simple smart contract + +This tutorial will make use of a classic example smart contract, `Storage.sol`. This contract exposes two public functions, one to add a value to the contract storage and one to view the stored value. The contract, written in Solidity, is provided below: + + +```Solidity + +pragma solidity >=0.7.0; + +contract Storage{ + + + uint256 number; + + function store(uint256 num) public{ + + number = num; + } + + function retrieve() public view returns (uint256){ + return number; + + } +} + +``` + +Solidity is a high-level language that makes code executable by the Ethereum virtual machine (EVM) readable to humans. This means that there is an intermediate step between writing code in Solidity and deploying it to Ethereum. This step is called "compilation" and it converts human-readable code into EVM-executable byte-code. This byte-code is then included in a transaction sent from the Geth node during contract deployment. This can all be done directly from the Geth Javascript console; however this tutorial uses an online IDE called Remix to handle the compilation and deployment of the contract to the local Geth node. + + + +## Compile and deploy using Remix + +In a web browser, open . This opens an online smart contract development environment. On the left-hand side of the screen there is a side-bar menu that toggles between several toolboxes that are displayed in a vertical panel. On the right hand side of the screen there is an editor and a terminal. This layout is similar to the default layout of many other IDEs such as [VSCode](https://code.visualstudio.com/). The contract defined in the previous section, `Storage.sol` is already available in the `Contracts` directory in Remix. It can be opened and reviewed in the editor. + +![Remix](/static/images/remix.png) + + +The Solidity logo is present as an icon in the Remix side-bar. Clicking this icon opens the Solidity compiler wizard. This can be used to compile `Storage.sol` ready. With `Solidity.sol` open in the editor window, simply click the `Compile 1_Storage.sol` button. A green tick will appear next to the Solidity icon to confirm that the contract has compiled successfully. This means the contract bytecode is available. + +![Remix-compiler](/static/images/remix-compiler.png) + +Below the Solidity icon is a fourth icon that includes the Ethereum logo. Clicking this opens the Deploy menu. In this menu, Remix can be configured to connect to the local Geth node. In the drop-down menu labelled `ENVIRONMENT`, select `Injected Web3`. This will open an information pop-up with instructions for configuring Geth - these can be ignored as they were completed earlier in this tutorial. However, at the bottom of this pop-up is a box labelled `Web3 Provider Endpoint`. This should be set to Geth's 8545 port on `localhost` (`127.0.0.1:8545`). Click OK. The `ACCOUNT` field should automatically populate with the address of the account created earlier using the Geth Javascript console. + + +![Remix-deploy](/static/images/remix-deploy.png) + + +To deploy `Storage.sol`, click `DEPLOY`. + +The following logs in the Geth terminal confirm that the contract was successfully deployed. + + +```terminal + +INFO [05-09|12:27:09.680] Setting new local account address=0x7Aa16266Ba3d309e3cb278B452b1A6307E52Fb62 +INFO [05-09|12:27:09.680] Submitted contract creation hash=0xbf2d2d1c393a882ffb6c90e6d1713906fd799651ae683237223b897d4781c4f2 from=0x7Aa16266Ba3d309e3cb278B452b1A6307E52Fb62 nonce=1 contract=0x4aA11DdfD817dD70e9FF2A2bf9c0306e8EC450d3 value=0 +INFO [05-09|12:27:09.681] Commit new sealing work number=2 sealhash=845a53..f22818 uncles=0 txs=1 gas=125,677 fees=0.0003141925 elapsed="335.991µs" +INFO [05-09|12:27:09.681] Successfully sealed new block number=2 sealhash=845a53..f22818 hash=e927bc..f2c8ed elapsed="703.415µs" +INFO [05-09|12:27:09.681] 🔨 mined potential block number=2 hash=e927bc..f2c8ed + +``` + +## Interact with contract using Remix + +The contract is now deployed on a local testnet version of the Etheruem blockchain. This means there is a contract address that contains executable bytecode that can be invoked by sending transactions with instructions, also in bytecode, to that address. Again, this can all be achieved by constructing transactions directly in the Geth console or even by making external http requests using tools such as Curl. Here, Remix is used to retrieve the value, then the same action is taken using the Javascript console. + +After deploying the contract in Remix, the `Deployed Contracts` tab in the sidebar automatically populates with the public functions exposed by `Storage.sol`. To send a value to the contract storage, type a number in the field adjacent to the `store` button, then click the button. + +![Remix-func](/static/images/remix-func.png) + +In the Geth terminal, the following logs confirm that the transaction was successful (the actual values will vary from the example below): + +```terminal + +INFO [05-09|13:41:58.644] Submitted transaction hash=0xfa3cd8df6841c5d3706d3bacfb881d2b985d0b55bdba440f1fdafa4ed5b5cc31 from=0x7Aa16266Ba3d309e3cb278B452b1A6307E52Fb62 nonce=2 recipient=0x4aA11DdfD817dD70e9FF2A2bf9c0306e8EC450d3 value=0 +INFO [05-09|13:41:58.644] Commit new sealing work number=3 sealhash=5442e3..f49739 uncles=0 txs=1 gas=43724 fees=0.00010931 elapsed="334.446µs" +INFO [05-09|13:41:58.645] Successfully sealed new block number=3 sealhash=5442e3..f49739 hash=c076c8..eeee77 elapsed="581.374µs" +INFO [05-09|13:41:58.645] 🔨 mined potential block number=3 hash=c076c8..eeee77 + +``` + +The transaction hash can be used to retrieve the transaction details using the Geth Javascript console, which will return the following information: + +```terminal + +{ + accessList: [], + blockHash: "0xc076c88200618f4cbbfb4fe7c3eb8d93566724755acc6c4e9a355cc090eeee77", + blockNumber: 3, + chainId: "0x539", + from: "0x7aa16266ba3d309e3cb278b452b1a6307e52fb62", + gas: 43724, + gasPrice: 3172359839, + hash: "0xfa3cd8df6841c5d3706d3bacfb881d2b985d0b55bdba440f1fdafa4ed5b5cc31", + input: "0x6057361d0000000000000000000000000000000000000000000000000000000000000038", + maxFeePerGas: 4032048134, + maxPriorityFeePerGas: 2500000000, + nonce: 2, + r: "0x859b88062715c5d66b9a188886ad51b68a1e4938d5932ce2dac874c104d2b26", + s: "0x61ef6bc454d5e6a76c414f133aeb6321197a61e263a3e270a16bd4a65d94da55", + to: "0x4aa11ddfd817dd70e9ff2a2bf9c0306e8ec450d3", + transactionIndex: 0, + type: "0x2", + v: "0x1", + value: 0 +} + +``` + +The `from` address is the account that sent the transaction, the `to` address is the deployment address of the contract. The value entered into Remix is now in storage at that contract address. This can be retrieved using Remix by calling the `retrieve` function - to do this simply click the `retrieve` button. Alternatively, it can be retrieved using `web3.getStorageAt` using the Geth Javascript console. The following command returns the value in the contract storage (replace the given address with the correct one displayed in the Geth logs). + +```shell + +web3.eth.getStorageAt("0x407d73d8a49eeb85d32cf465507dd71d507100c1", 0) + +``` + +This returns a value that looks like the following: + +```terminal + +"0x000000000000000000000000000000000000000000000000000000000000000038" + +``` + + +The returned value is a left-padded hexadecimal value. For example, the return value `0x000000000000000000000000000000000000000000000000000000000000000038` corresponds to a value of `56` entered as a uint256 to Remix. After converting from hexadecimal string to decimal number the returned value should be equal to that provided to Remix in the previous step. + +## Reusing --datadir + +This tutorial used an ephemeral blockchain that is completely destroyed and started afresh during each dev-mode session. However, it is also possible to create persistent blockchain and account data that can be reused across multiple sessions. This is done by providing the `--datadir` flag and a directory name when starting Geth in dev-mode. + +```shell + +geth --datadir dev-chain --dev --http --http.api personal,web3,eth,net --http.corsdomain "remix.ethereum.org" + +``` + +## Re-using accounts + +Geth will fail to start in dev-mode if keys have been manually created or imported into the keystore in the `--datadir` directory. This is because the account cannot be automatically unlocked. To resolve this issue, the password defined when the account was created can be saved to a text file and its path passed to the `--password` flag on starting Geth, for example if `password.txt` is saved in the top-level `go-ethereum` directory: + +```shell + +geth --datadir dev-chain --dev --http --http.api personal,web3,eth,net --http.corsdomain "remix.ethereum.org" --password password.txt + +``` +**Note** that this is an edge-case that applies when both the `--datadir` and `--dev` flags are used and a key has been manually created or imported into the keystore. + + + +## Summary + +This tutorial has demonstrated how to spin up a local developer network using Geth. Having started this development network, a simple contract was deployed to the developer network. Then, Remix was connected to the local Geth node and used to deploy and interact with a contract. Remix was used to add a value to the contract storage and then the value was retrieved using Remix and also using the lower level commands in the Javascript console. diff --git a/content/docs/developers/geth-developer/devguide.md b/content/docs/developers/geth-developer/devguide.md new file mode 100644 index 0000000000..171016a486 --- /dev/null +++ b/content/docs/developers/geth-developer/devguide.md @@ -0,0 +1,122 @@ +--- +title: Developer Guide +sort_key: A +--- + +**NOTE: These instructions are for people who want to contribute Go source code changes. +If you just want to run ethereum, use the regular [Installation Instructions][install-guide].** + +This document is the entry point for developers of the Go implementation of Ethereum. +Developers here refer to the hands-on: who are interested in build, develop, debug, submit +a bug report or pull request or contribute code to go-ethereum. + +## Contributing + +Thank you for considering to help out with the source code! We welcome contributions from +anyone on the internet, and are grateful for even the smallest of fixes! + +GitHub is used to track issues and contribute code, suggestions, feature requests or +documentation. + +If you'd like to contribute to go-ethereum, please fork, fix, commit and send a pull +request (PR) for the maintainers to review and merge into the main code base. If you wish +to submit more complex changes though, please check up with the core devs in the +go-ethereum [Discord Server][discord]. to ensure those changes are in line with the +general philosophy of the project and/or get some early feedback. This can reduce your +effort as well as speeding up our review and merge procedures. + +PRs need to be based on and opened against the `master` branch (unless by explicit +agreement, you contribute to a complex feature branch). + +Your PR will be reviewed according to the [Code Review guidelines][code-review]. + +We encourage a PR early approach, meaning you create the PR the earliest even without the +fix/feature. This will let core devs and other volunteers know you picked up an issue. +These early PRs should indicate 'in progress' status. + +## Building and Testing + +We assume that you have Go installed. Please use Go version 1.13 or later. We use the go +toolchain for development, which you can get from the [Go downloads page][go-install]. + +go-ethereum is a Go module, and uses the [Go modules system][go-modules] to manage +dependencies. Using `GOPATH` is not required to build go-ethereum. + +### Building Executables + +Switch to the go-ethereum repository root directory. + +You can build all code using the go tool, placing the resulting binary in `$GOPATH/bin`. + +```text +go install -v ./... +``` + +go-ethereum exectuables can be built individually. To build just geth, use: + +```text +go install -v ./cmd/geth +``` + +If you want to compile geth for an architecture that differs from your host, please +consult our [cross compilation guide][cross-compile]. + +### Testing + +Testing a package: + +``` +go test -v ./eth +``` + +Running an individual test: + +``` +go test -v ./eth -run TestMethod +``` + +**Note**: here all tests with prefix _TestMethod_ will be run, so if you got TestMethod, +TestMethod1, then both tests will run. + +Running benchmarks, eg.: + +``` +go test -v -bench . -run BenchmarkJoin +``` + +For more information, see the [go test flags][testflag] documentation. + +### Getting Stack Traces + +If `geth` is started with the `--pprof` option, a debugging HTTP server is made available +on port 6060. You can bring up to see the heap, +running routines etc. By clicking "full goroutine stack dump" you can generate a trace +that is useful for debugging. + +Note that if you run multiple instances of `geth`, this port will only work for the first +instance that was launched. If you want to generate stacktraces for these other instances, +you need to start them up choosing an alternative pprof port. Make sure you are +redirecting stderr to a logfile. + +``` +geth -port=30300 -verbosity 5 --pprof --pprof.port 6060 2>> /tmp/00.glog +geth -port=30301 -verbosity 5 --pprof --pprof.port 6061 2>> /tmp/01.glog +geth -port=30302 -verbosity 5 --pprof --pprof.port 6062 2>> /tmp/02.glog +``` + +Alternatively if you want to kill the clients (in case they hang or stalled syncing, etc) +and have the stacktrace too, you can use the `-QUIT` signal with `kill`: + +``` +killall -QUIT geth +``` + +This will dump stack traces for each instance to their respective log file. + +[install-guide]: ../install-and-build/installing-geth +[code-review]: ../developers/code-review-guidelines +[cross-compile]: ../install-and-build/cross-compile +[go-modules]: https://github.com/golang/go/wiki/Modules +[discord]: https://discord.gg/invite/nthXNEv +[go-install]: https://golang.org/doc/install +[testflag]: https://golang.org/cmd/go/#hdr-Testing_flags diff --git a/content/docs/developers/geth-developer/dns-discovery-setup.md b/content/docs/developers/geth-developer/dns-discovery-setup.md new file mode 100644 index 0000000000..715838eea8 --- /dev/null +++ b/content/docs/developers/geth-developer/dns-discovery-setup.md @@ -0,0 +1,125 @@ +--- +title: DNS Discovery Setup Guide +sort_key: C +--- + +This document explains how to set up an [EIP 1459][dns-eip] node list using the devp2p +developer tool. The focus of this guide is creating a public list for the Ethereum mainnet +and public testnets, but you may also find this helpful if you want to set up DNS-based +discovery for a private network. + +DNS-based node lists can serve as a fallback option when connectivity to the discovery DHT +is unavailable. In this guide, we'll create node lists by crawling the discovery DHT, then +publishing the resulting node sets under chosen DNS names. + +### Installing the devp2p command + +cmd/devp2p is a developer utility and is not included in the Geth distribution. You can +install this command using `go get`: + +```shell +go get github.com/ethereum/go-ethereum/cmd/devp2p +``` + +To create a signing key, you might also need the `ethkey` utility. + +```shell +go get github.com/ethereum/go-ethereum/cmd/ethkey +``` + +### Crawling the v4 DHT + +Our first step is to compile a list of all reachable nodes. The DHT crawler in cmd/devp2p +is a batch process which runs for a set amount of time. You should should schedule this command +to run at a regular interval. To create a node list, run + +```shell +devp2p discv4 crawl -timeout 30m all-nodes.json +``` + +This walks the DHT and stores the set of all found nodes in the `all-nodes.json` file. +Subsequent runs of the same command will revalidate previously discovered node records, +add newly-found nodes to the set, and remove nodes which are no longer alive. The quality +of the node set improves with each run because the number of revalidations is tracked +alongside each node in the set. + +### Creating sub-lists through filtering + +Once `all-nodes.json` has been created and the set contains a sizeable number of nodes, +useful sub-sets of nodes can be extracted using the `devp2p nodeset filter` command. This +command takes a node set file as argument and applies filters given as command-line flags. + +To create a filtered node set, first create a new directory to hold the output set. You +can use any directory name, though it's good practice to use the DNS domain name as the +name of this directory. + +```shell +mkdir mainnet.nodes.example.org +``` + +Then, to create the output set containing Ethereum mainnet nodes only, run + +```shell +devp2p nodeset filter all-nodes.json -eth-network mainnet > mainnet.nodes.example.org/nodes.json +``` + +The following filter flags are available: + +* `-eth-network ( mainnet | ropsten | rinkeby | goerli )` selects an Ethereum network. +* `-les-server` selects LES server nodes. +* `-ip ` restricts nodes to the given IP range. +* `-min-age ` restricts the result to nodes which have been live for the + given duration. + +### Creating DNS trees + +To turn a node list into a DNS node tree, the list needs to be signed. To do this, you +need a key pair. To create the key file in the correct format, you can use the cmd/ethkey +utility. Please choose a good password to encrypt the key on disk. + +```shell +ethkey generate dnskey.json +``` + +Now use `devp2p dns sign` to update the signature of the node list. If your list's +directory name differs from the name you want to publish it at, please specify the DNS +name the using the `-domain` flag. This command will prompt for the key file password and +update the tree signature. + +```shell +devp2p dns sign mainnet.nodes.example.org dnskey.json +``` + +The resulting DNS tree metadata is stored in the +`mainnet.nodes.example.org/enrtree-info.json` file. + +### Publishing DNS trees + +Now that the tree is signed, it can be published to a DNS provider. cmd/devp2p currently +supports publishing to CloudFlare DNS and Amazon Route53. You can also export TXT records +as a JSON file and publish them yourself. + +To publish to CloudFlare, first create an API token in the management console. cmd/devp2p +expects the API token in the `CLOUDFLARE_API_TOKEN` environment variable. Now use the +following command to upload DNS TXT records via the CloudFlare API: + +```shell +devp2p dns to-cloudflare mainnet.nodes.example.org +``` + +Note that this command uses the domain name specified during signing. Any existing records +below this name will be erased by cmd/devp2p. + +### Using DNS trees with Geth + +Once your tree is available through a DNS name, you can tell geth to use it with the +`--discovery.dns` command line flag. Node trees are referenced using the `enrtree://` URL +scheme. You can find the URL of your tree in the `enrtree-info.json` file created by +`devp2p dns sign`. Just pass the URL as an argument to the flag in order to make use of +the published tree. + +```shell +geth --discovery.dns "enrtree://AMBMWDM3J6UY3M32TMMROUNLX6Y3YTLVC3DC6HN2AVG5NHNSAXDW6@mainnet.nodes.example.org" +``` + +[dns-eip]: https://eips.ethereum.org/EIPS/eip-1459 diff --git a/content/docs/developers/geth-developer/issue-handling-workflow.md b/content/docs/developers/geth-developer/issue-handling-workflow.md new file mode 100644 index 0000000000..9fb2bdc180 --- /dev/null +++ b/content/docs/developers/geth-developer/issue-handling-workflow.md @@ -0,0 +1,57 @@ +--- +title: Issue Handling Workflow +sort_key: B +--- + +### (Draft proposal) + +Keep the number of open issues under 820 + +Keep the ratio of open issues per all issues under 13% + +Have 50 issues labelled [help wanted](https://github.com/ethereum/go-ethereum/labels/help%20wanted) and 50 [good first issue](https://github.com/ethereum/go-ethereum/labels/good%20first%20issue). + +Use structured labels of the form `: