From fa4e18c53d06a661aa542fc5b9482956b637bf6c Mon Sep 17 00:00:00 2001
From: gvensan <4477169+gvensan@users.noreply.github.com>
Date: Fri, 20 Dec 2024 19:17:53 +0530
Subject: [PATCH] Added missing md file and fixed image path
---
markdown/blog/streamlining-eda-design.md | 159 ++++++++++++++++++
...omain-app-event-schema-circle-diagram.webp | Bin
.../asyncapi-scst-table.webp | Bin
...lenges-designing-event-driven-systems.webp | Bin
.../ep-asynapi-table.webp | Bin
...tal-asyncapi-post_coffee-shop-example.webp | Bin
...-portal-asyncapi-post_pic-02-1536x994.webp | Bin
...-portal-asyncapi-post_pic-03-1600x811.webp | Bin
.../event-portal-asyncapi-post_pic-08.webp | Bin
.../giri-eda-post-screenshot.webp | Bin
.../streamlining-eda-design-banner.webp | Bin 0 -> 21448 bytes
11 files changed, 159 insertions(+)
create mode 100644 markdown/blog/streamlining-eda-design.md
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/app-domain-app-event-schema-circle-diagram.webp (100%)
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/asyncapi-scst-table.webp (100%)
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/common-challenges-designing-event-driven-systems.webp (100%)
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/ep-asynapi-table.webp (100%)
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/event-portal-asyncapi-post_coffee-shop-example.webp (100%)
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/event-portal-asyncapi-post_pic-02-1536x994.webp (100%)
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/event-portal-asyncapi-post_pic-03-1600x811.webp (100%)
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/event-portal-asyncapi-post_pic-08.webp (100%)
rename public/img/posts/{streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal => streamlining-eda-design}/giri-eda-post-screenshot.webp (100%)
create mode 100644 public/img/posts/streamlining-eda-design/streamlining-eda-design-banner.webp
diff --git a/markdown/blog/streamlining-eda-design.md b/markdown/blog/streamlining-eda-design.md
new file mode 100644
index 000000000000..7e583740b5b4
--- /dev/null
+++ b/markdown/blog/streamlining-eda-design.md
@@ -0,0 +1,159 @@
+---
+title: Streamlining EDA Design with AsyncAPI Code Generation and PubSub+ Event Portal
+date: 2024-12-17T18:14:40.065Z
+type: Engineering
+canonical: https://solace.com/blog/streamlining-eda-design-asyncapi-code-gen-event-portal
+tags:
+ - Event Portal
+ - EDA
+ - SCSt
+ - Event-driven API
+cover: /img/posts/streamlining-eda-design/streamlining-eda-design-banner.webp
+authors:
+ - name: Giri Venkatesan
+ photo: /img/avatars/gvensan.webp
+ link: https://linkedin.com/in/girivenkatesan
+ byline: AsyncAPI Ambassador
+excerpt: The combination of AsyncAPI, PubSub+ Event Portal, and Spring Cloud Stream provides a streamlined yet powerful approach to designing, developing, and managing event-driven systems.
+---
+
+As developers strive for ‘designed with precision and tested to perfection’ to ensure reliability, efficiency, and improved user experience, it’s important to recognize the complexities and challenges of real-world applications. This ongoing effort for improvement is particularly true and complex in the context of event-driven systems.
+
+Building event-driven systems presents several unique challenges compared to traditional request-response systems, with code generation being the first step.
+
+![](/img/posts/streamlining-eda-design/common-challenges-designing-event-driven-systems.webp)
+
+
+The first three challenges are inherent to the system’s nature and behavior. [Solace PubSub+ Event Broker](https://solace.com/products/event-broker/) provides robust capabilities to address these challenges.
+
+* **Complexity of Asynchronous Interactions:** Issues related to concurrent processing, error handling and the unpredictability around ordered processing.
+* **Event Handling:** In decoupled, asynchronous systems, event loss or duplication is a risk. Without a robust event broker in the mix, managing this is hard. Evolving schemas and versions add complexity. Rigorous testing is key to ensuring consistent event-driven interactions.
+* **Observable Outcomes:** Asynchronous interactions can lead to non-deterministic outcomes, making verifications challenging. Unlike synchronous systems, event-driven interactions lack immediate feedback, complicating real-time verification of correctness. Additionally, managing state becomes more complex, as the system’s state change unpredictably based on the sequence and timing of events further complicating the verification process.
+
+This is only half the battle, however. The other half involves having systems that support designing the EDA that can be tested. [Solace PubSub+ Event Portal](https://solace.com/products/portal/) helps you design the building blocks of your event-driven system, aligned with the capabilities of Event Broker. By fully embracing the AsyncAPI standards, Event Portal offers a comprehensive way to design, document and discover event-driven services.
+
+* **Standardization:** Standardization is crucial for documenting and testing system-wide interactions in event-driven systems. Without it, testing can become significantly more complex and resource intensive.
+* **Integration and Performance Testing:** Testing integration, scalability, and performance in event-driven systems is challenging due to loose coupling, asynchronous communications, and variable latency. Comprehensive testing scenarios, supported by standardized tools and frameworks, are essential for reliable end-to-end testing.
+
+This synergy between Event Portal and AsyncAPI not only helps address the initial challenges, but facilitates code generation and testing, significantly enhancing design, development, documentation, and testing processes aligned with your SDLC.
+
+## The Emergence of Event Portals
+An event portal lets IT organizations more effectively create, share, and manage event streams and event-driven APIs and applications as part of event-driven architecture.
+
+> An event portal, like an API user portal, provides a place for event publishers and event consumers (aka sinks) to connect and collaborate on event usage policy and subscription to event streams.
+David Mooter, Forrester Research, “Use EDA In Your Quest for Modern Applications”, Apr 9, 2021
+
+In context of EDA, event portals serve three primary audiences within enterprise IT organizations:
+
+* **Architects** use event portals to define, discuss and review events, data definitions and application relationships.
+* **Developers** use event portals to discover, understand and reuse events across applications, lines of business and between external organizations more easily.
+* **Data scientists** use event portals to better understand event-driven data and discover new insights by combining events.
+
+Solace pioneered the event portal space with the introduction of PubSub+ Event Portal, which lets you design and organize the building blocks of your event-driven system as manageable design artifacts.
+
+PubSub+ Event Portal lets you give developers [self-service](https://solace.com/products/portal/self-service-access/) access to event streams and easily configure event brokers within guardrails set by your middleware/integration teams offering faster development, strong governance and better efficiency.
+
+![](/img/posts/streamlining-eda-design/app-domain-app-event-schema-circle-diagram.webp)
+
+
+An **Application** represents a client interacting with an event broker by consuming, producing, or processing events. It encapsulates the contract details through event, schema, and topic definitions. The Application is a real-world service or task that must be converted into a runnable component for asynchronous interactions within the enterprise.
+
+![](/img/posts/streamlining-eda-design/event-portal-asyncapi-post_pic-02-1536x994.webp)
+
+Designing your event flows using Event Portal is the important first step on your journey, but once you have the application’s interface “contract ready,” code generation is the next step towards implementing EDA for real-world use cases.
+
+## AsyncAPI Specification
+AsyncAPI defines and documents event-driven APIs, much like how OpenAPI serves RESTful APIs. AsyncAPI provides a standard way to define the contract between the producer and consumer of an event-driven system. This contract can be used to generate code, documentation, and tests, ensuring that the system behaves as expected.
+
+With AsyncAPI specification, you have a well-structured document defining the asynchronous communication patterns, message formats, and EDA for your system. However, it doesn’t inherently offer tools for managing, deploying, or maintaining those APIs over time. To operationalize your AsyncAPI definitions. Enables efficient event discovery and governance, handles version management, mapping the specification to runtime environments and facilitates a better CI/CD pipeline ensuring your EDA can scale, evolve and perform reliably in production.
+
+The first step is to obtain an AsyncAPI document that defines the application you want to develop. You can generate the AsyncAPI document from an application directly from Event Portal.
+
+![](/img/posts/streamlining-eda-design/event-portal-asyncapi-post_pic-03-1600x811.webp)
+
+To bridge the gap between AsyncAPI specifications and practical implementation, it is essential to understand how AsyncAPI elements map to application components in PubSub+ Event Portal. Here’s how various AsyncAPI elements—such as channels, messages, and schemas—equate to counterparts in Event Portal.
+
+
+
+
+## AsyncAPI Code Generation
+The AsyncAPI Generator tool is your best friend for generating code or frameworks, with rich sets of binders for all popular programming languages. You can find the full list of official generator templates in the [asyncapi/generator](https://github.com/asyncapi/generator) repository.
+
+## Java Spring Cloud Stream
+The Java Spring Cloud Stream generator template, contributed by Solace, can generate scaffolding code from an AsyncAPI specification that can be built upon to get the asynchronous, publish-subscribe interaction with your brokers including Solace, Kafka and RabbitMQ.
+
+Java Spring Cloud Stream is well suited for EDA and a popular choice for implementing event-driven microservices, and works effectively with AsyncAPI for several reasons:
+
+* **Abstraction Over Messaging Middleware:** Spring Cloud Stream abstracts messaging systems like Kafka and RabbitMQ, enabling developers to focus on business logic rather than middleware complexities, which is especially useful in event-driven systems with multiple messaging systems.
+* **Binder Abstraction:** The binder abstraction in Spring Cloud Stream simplifies the integration with different messaging systems. Developers can switch between messaging platforms with minimal code changes by using binders.
+* **Integration with Spring Ecosystem:** Spring Cloud Stream integrates seamlessly with Spring Boot, Spring Integration, and Spring Security, leveraging configuration management, dependency injection, and security features across the Spring ecosystem.
+* **Event-Driven Programming Model:** Spring Cloud Stream promotes an event-driven programming model with annotations that make it easy to develop, test, and maintain event-driven applications.
+* **Configuration and Dependency Management:** Spring Boot’s auto-configuration and dependency management minimize boilerplate code and configuration overhead, simplifying event-driven microservice setup and aligning with AsyncAPI’s structured approach.
+* **Community and Ecosystem:** Spring Cloud Stream benefits from the extensive Spring community and ecosystem, providing access to a wealth of resources, tutorials, and support.
+* **Alignment with AsyncAPI:** Spring Cloud Stream’s configuration-oriented approach aligns well with AsyncAPI’s contract-first design, allowing direct mapping of AsyncAPI specifications to ensure adherence to defined event-driven contracts.
+
+
+
+
+## An Example: Coffee Shop
+I’ll give an example of the Coffee Shop domain shown in this diagram, focusing on two applications:
+
+* **Order Management System:** The heart of Coffee Shop domain that serves received requests with an orderId, and continuously updates the order progress as updated by other applications such as Kitchen Floor, Inventory, and others.
+* **Barista Station:** The Barista station that monitors the order progress and updates order progress status including ready for pickup status.
+
+
+
+I’ll walk through the process of building these applications and demonstrate the design-to-code using AsyncAPI document and spring-cloud-stream binder for code generation.
+
+1. Download AsyncAPI document of the Order Management application and generate spring-cloud-stream application using asyncapi-generator utility
+
+
+
+```
+asyncapi-generator
+ -p binder=solace
+ -p artifactId=CoffeeShop
+ -p groupId=com.coffeeshop
+ -p javaPackage=com.coffeeshop.ordermanagement
+ -p actuator=true "Order Management-0.1.0.json"
+ @asyncapi/java-spring-cloud-stream-template
+ -o "Order Management"
+```
+
+2. Download AsyncAPI document of the Barista Station application and generate spring-cloud-stream application using asyncapi-generator utility
+
+
+
+
+```
+asyncapi-generator
+ -p binder=solace
+ -p artifactId=CoffeeShop
+ -p groupId=com.coffeeshop
+ -p javaPackage=com.coffeeshop.baristastation
+ -p actuator=true "Barista Station-0.1.0.json"
+ @asyncapi/java-spring-cloud-stream-template
+ -o "Barista Station"
+```
+
+The Spring Cloud Stream microservice generated using this template will be a ready to run Spring Boot app. By default, the microservice will contain a java class, ```Application.java```, which includes methods to publish or subscribe events as defined in the AsyncAPI document. These generated methods include *Supplier*, *Consumer* and *Function* functional interfaces from the [```java.util.function```](https://docs.oracle.com/javase/8/docs/api/java/util/function/package-summary.html) package. These methods will be pre-configured to publish to and consume from the channels as defined in the AsyncAPI. This configuration is in the ```spring.cloud.stream``` section of the generated ```application.yml``` file.
+
+With the addition of appropriate business logic on these Spring applications, we should see a new order placed by the Order Management System receives Order Completed event asynchronously when it is completed.
+
+A completed code of the referred sample applications is at [https://github.com/gvensan/ep-coffeeshop-design-to-code](https://github.com/gvensan/ep-coffeeshop-design-to-code)
+
+## Conclusion
+The combination of AsyncAPI, PubSub+ Event Portal, and Spring Cloud Stream offers a simple yet powerful means for designing, developing, and managing event-driven systems.
+
+I’d like to wrap things up with a few recommendations:
+
+1. **Adopt AsyncAPI:** Embrace AsyncAPI for its robust specifications and structured approach to defining event-driven services. This ensures clarity and consistency across the development lifecycle.
+2. **Utilize PubSub+ Event Portal:** Leverage the design and management capabilities of Event Portal to create, document, and export your EDA applications as AsyncAPI documents. This facilitates a seamless transition from design to implementation.
+3. **Employ Code Generators:** Use AsyncAPI code generators to automate the creation of boilerplate code for frameworks like Spring Cloud Stream. This approach not only accelerates development and ensures alignment with the defined specifications but also significantly boosts developer productivity by reducing manual coding effort. Additionally, it minimizes errors in transcription by generating accurate, consistent code based on the specifications, leading to fewer bugs and a smoother development process.
+4. **Integrate with Spring Cloud Stream:** Implement your event-driven services using Spring Cloud Stream to benefit from its abstraction over messaging systems, ease of configuration, and integration with the Spring ecosystem.
+
+By following these recommendations, you can harness the full potential of AsyncAPI, PubSub+ Event Portal, and Spring Cloud Stream, leading to more efficient, reliable, and scalable event-driven architectures.
+
+---
+
+Originally published at [https://solace.com/blog/streamlining-eda-design-asyncapi-code-gen-event-portal](https://solace.com/blog/streamlining-eda-design-asyncapi-code-gen-event-portal)
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/app-domain-app-event-schema-circle-diagram.webp b/public/img/posts/streamlining-eda-design/app-domain-app-event-schema-circle-diagram.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/app-domain-app-event-schema-circle-diagram.webp
rename to public/img/posts/streamlining-eda-design/app-domain-app-event-schema-circle-diagram.webp
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/asyncapi-scst-table.webp b/public/img/posts/streamlining-eda-design/asyncapi-scst-table.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/asyncapi-scst-table.webp
rename to public/img/posts/streamlining-eda-design/asyncapi-scst-table.webp
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/common-challenges-designing-event-driven-systems.webp b/public/img/posts/streamlining-eda-design/common-challenges-designing-event-driven-systems.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/common-challenges-designing-event-driven-systems.webp
rename to public/img/posts/streamlining-eda-design/common-challenges-designing-event-driven-systems.webp
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/ep-asynapi-table.webp b/public/img/posts/streamlining-eda-design/ep-asynapi-table.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/ep-asynapi-table.webp
rename to public/img/posts/streamlining-eda-design/ep-asynapi-table.webp
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/event-portal-asyncapi-post_coffee-shop-example.webp b/public/img/posts/streamlining-eda-design/event-portal-asyncapi-post_coffee-shop-example.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/event-portal-asyncapi-post_coffee-shop-example.webp
rename to public/img/posts/streamlining-eda-design/event-portal-asyncapi-post_coffee-shop-example.webp
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/event-portal-asyncapi-post_pic-02-1536x994.webp b/public/img/posts/streamlining-eda-design/event-portal-asyncapi-post_pic-02-1536x994.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/event-portal-asyncapi-post_pic-02-1536x994.webp
rename to public/img/posts/streamlining-eda-design/event-portal-asyncapi-post_pic-02-1536x994.webp
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/event-portal-asyncapi-post_pic-03-1600x811.webp b/public/img/posts/streamlining-eda-design/event-portal-asyncapi-post_pic-03-1600x811.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/event-portal-asyncapi-post_pic-03-1600x811.webp
rename to public/img/posts/streamlining-eda-design/event-portal-asyncapi-post_pic-03-1600x811.webp
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/event-portal-asyncapi-post_pic-08.webp b/public/img/posts/streamlining-eda-design/event-portal-asyncapi-post_pic-08.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/event-portal-asyncapi-post_pic-08.webp
rename to public/img/posts/streamlining-eda-design/event-portal-asyncapi-post_pic-08.webp
diff --git a/public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/giri-eda-post-screenshot.webp b/public/img/posts/streamlining-eda-design/giri-eda-post-screenshot.webp
similarity index 100%
rename from public/img/posts/streamlining-eda-design-with-asyncapi-code-generation-and-pubsub-event-portal/giri-eda-post-screenshot.webp
rename to public/img/posts/streamlining-eda-design/giri-eda-post-screenshot.webp
diff --git a/public/img/posts/streamlining-eda-design/streamlining-eda-design-banner.webp b/public/img/posts/streamlining-eda-design/streamlining-eda-design-banner.webp
new file mode 100644
index 0000000000000000000000000000000000000000..ca4b39ab90510a9845f8c57916436b95561e27ce
GIT binary patch
literal 21448
zcmV)qK$^c&Nk&G%Qvd*0MM6+kP&gp8Qvd)Eq5+)&D!>CA0zQ#QpG&2rBO#+x34pK?
z31x2l1ol6cTnzl%_%x9eqqm%m>zhZpcg=95MxT2+VflaM`dWP3N)P9HQym`VKfCuS
z^H2R>tIz7c=ly~|vj1T7<^4(byZfQ)Bl;Km&)TndkNKaozWsl$elvUqe^UPe|Esb$
z_k-9^`M3I?PG8(#hX3l{@&9psqd))u$=5>i|M(y7f3V(b|7QO~{u}&%`LFN(u=!H<
zpS7Rhd9rp7n!n3_>VD7sC+;7{kL17GeoX&|^nc~Y`Tn54mVZJ2U-`A^3$#c8{%if$
z{{Q(u$=`?nssF|PFV*k0Kli=Bzn=ed|C#J}{O=9_$$#1Q1O9dXQ})BzkN*EQA6ftK
z_ZI$%{wve3*pKgD|NsC04FfsZpF!_hIxk}gWSsC;&`2e=xpTXel`Qs0b
z@H08vrz@9ypjJ5C8_)pTem@Ujj{xom!EX10v?yfgN}kPcN1rkbS`CC
z^vk86QNz|WB6s#1hBbwRbU>n?2_0XX@9l`|Lchgp_biO%S@nj3oBX)-jo1Veth+Z&
zYqBk(t&woeb9@y5$mOvZ&%+Oq(y3I~8Y4JV{I0%gp;>B^sA?a3Jn57SXl6J@Sw$uu
zfgmy$O>~dWbc4W4Ks36qmyek8H(`=-D5Cirs+__D@-v}};podsu-EbAv6YPRQQ
z5X5*7(Le0E%4*iqB^^5|Fvq(}i)v7Gxy>@i1u|{!3lR-qcwI0+4>P4q8|8XhW<8_V
zQ0MB+*b&7zyy^RZ{H~6lzRPNR3v&SHyLH>x9y_zxMVB@u7v93By4FZHKDUQ`jedn}
zI-7u_i>!u)!^mi+Wc&CMlLPB4EjG&l3J-2=pK{nar@vLG3p1Jf20GYgX8jX#_+MZ53;AlCcc}4AzjMiXVn7#R6=XxdGjwk7{iKMUgg6#
zJ5qEX47^5!Wo85RI=@3jq7^9l^cb+2YlVLdsB5;2JdAAumT>*)R7@K6O@NDY<+Lku
zSNktkLe~r{7tLH1E-%#R_Z%n2jNK*{sng)F^voIHfol%W70LrjYnj$56{Rwey1g-=
z<7CZ6a&Kn79ck&+gcc`U%D4x2MyZQPsT!Nqfio1|!Pj;p#_!=k5NdOCgJ{X~5JQ2d(xHBFBY0;NKb$UpR(O5za*%da5&>WxxmP1kV4y
z2`{ubuW*857*?vX$H^?|P%wP*`Zc0_PniUy@P`pJDV-r*(cmK7z&ex8(qywmnFt8C
zFb_B0_DB3lW8lgV-bNLyVYTD0bIY@L1UOAlKpnF4ML;S=h$x8l*~=q7g_xIp
z+ux`MirT=h%Sju(Nav0fzts%171$+JD)3BP6DJU?#(->SUsn8FzXD$-SRYVAj6u_*
zX>QppEXyGE?sT&cEmBpUAz2ypF0m)EJ#;ug6)M}J;nCs(EzAJ?)%=~@F4@4a?0K4A
z!fyiWlau~&eJ`Xp&5Bw2kZWJz7H8*$g9DIQnIIN;{*AM2zK6edspx)SK{i!?hjT8E
zD7ka8J(C|!GUl^)1Y4FKJ|$S%d6doE5pG}}3D86c00`^x33L?#J+d?C
zVeR0+w=fR@7Zi8WCM@AL86Jj}Qz2QN~8ETec59hx5m}e#0?I@hM)HPij!BF(Iu=BmkHp4c-pDjlaO(V!Y*cWq1K!p+FH>6WeEl)gWm+b
zYX~FZwZki?K%gUNaMAaS0*^gbDsTrvB}1INa&I;01<P}qrEh#cf^b9+$EC*O(HZg6$IYjIm+g>h?ExiS6N~qDTbQYhENN=$eIm)!
zohq7$a00S91!C#ZD{f5w9#I;Q_WEh`}?q3&(E`h3}m)Ht*PiFRqp8
z$ZK*`grV*Sn+P@QYFY&sTkIOAY=iaCkcSz#+n%Enec
zg$xYO)<=@R&r`pLVWVjKmZxt~3D|8{Sk(xZ_||2?6~CAr39)|vtbx$o2n>PrhW8DRKH8aJ{}=Scy(a1m(2o@`ekP*G_O8g
zhB`Yem^iO`%QMWj`nQpfa*ZquGVJ)-3K%vzke3*vKe<)>Z7zV^@1(aJt(8I#05!_6
z@`Edt&}d1pVDY!lAYi6zV?y5JL$L!C6Tf^^5$tViK!HdOlUObbSMxqRo4$pAN4TFa
zzpne)8TrOLkt-=<)CPSLvRFIlB-oxhpOHmHOchx5SbI7dMs!|J3d`holqb=C1ZxF9
z?)TSkK=9!fsT)}&$29p(S*!BA6eoS($hDNdfkLi+C_3nB?M@jR#9HIXy)Q0sK+w;I
z3P24&3c9cNf9AhppYQbW1HeVOfOrVEFb^Y@&GVu|OE9^`~s)UeI$j|UouK*`$Bneu}cebTL+kKwn-J@7D5-Q;#Y;D~)ICbao
znQmIxw72M1z&qmtpDKWZTcBK=I7TI<={>D?am=NLX$cZ-Xx#@=|Cz$=htx9*1d*1x
z$h@_?3&dL?1;4P)OuMvQgUVrD`RTjyxl_PoVM|n`Rg^^Of%}DlRqYN@G1qrb5x+dm
zUJEUn*u>nyYE+9Joh}nT9c;mKMMntsX0*UO1Y30mCg8p1!_7_f?pEw)#m>9isO7u|
z#*Q48`k?2WJb_1~AFora04d$r}(p)E_*1L`ebpp3DqM2094;!egPhu2fu5(ZDuwAqw
zeDNmIJ%PJ+W$A-d&QYQ2ZiIDig_Id*(&S?CTxuRBT~7dRr^48w@Ckb(Vmbj&JR5u%
zd@RRFmFq6S40f@H1c*X>mBdVJ!1JJfb)?iUeh;;rp%h_4g=A{xfUY^vVb|S+H(hZ}oY{sGXkw6WmKBB}FH
zDJu)(3cZE3jRr38|xf
zwvIKov*fY&Nhht?>$ROIBdg`jl#o
zfq(VrR+0Y_I!wR+>>@Fj^KiPNEu!}cmRn`?rRcyYht_4Jcdwc~?9FRBL%^5vSx}0~
zg4w-O|Lne3Fn{A<9&gr#WM|OcG~@us>mFOkk%oq%~n9^{
zUV3U|QJ{1b)bl3kMf}dMZ-vy@4iWLFA}@v#wpnH-QlT&QOxiF000002Ea0P4FRwu
zPC5hfPF#61JvQR*2i}S|GL5x^UclN6Pd
zW<{Ly2I5h2y*Xr8+y#NBhh@c2nJS8l+PE?0qJo
zA#w(0A5xA1Hr{=>7tFY{w-mjV5h>1izyKu_c9b;jL08fB@^|c*q`V1A{bi{LOS9N^
zs9`+^vbawT<_@~y^L&No)7vSZa~L$SF(nqAdxfLN_zitSBU|@wkoPSP@~pO!@~fW5
zl|=JOnq5uY_n`WH@I|N>?%&JJUTa)eA-oWE+I3TS981oR!a)rG=EV8LalQ^l+N+hT
zv=Csg@XYP{XPol&MsWT{J|j5RTP3Y82z(oiid>IbaqInp+zL|cWzg+_w-RZaZ}@M(
za_d-bns$SCSY7)Zg0tT9C)(VOUiQ;r1zK-$WuFE|)Z>_)HE9iKQExetukn?jJ}l#T
z$y^3JKdf^(L@vAg5>8ITuUU63=408y;Utui@40KncYGaG4BT5{$>%y9JlL@EDa-uk
zD7Le2!?mF_^|f$*aFBW|%BO^FVTk6bI(cbk^Z4=w+|%s#JAm84`z`WtOrmi3C_dN{
zOXkP*rYoxiLPeIxhm(49n%CcF*~^UVcyiv!Bw>5e(lZ}12dW5AQYORP8W!b%%c&b|
zK0$PcM>dl5+AGQ!3r)vV3ecdGNSydY!P}oThEc!C3!5=^^QmOD(dYj2zj;=x&p#T~
zRKKwI{3)eUXUXPBsSAM!A|9ft{BYxFvz-Wqe}K0O!yM_@R|ps4&OT*Z#j>
z)f2$F!^EHD3X1ku9%0rY@)~2emKz6J_X|q)oj+8gcSYP(pAxt^1riu3n0*
zEPHOjC~x`&!j$(IPb8@M1jR;NPKBzPjP1bfF6H{rI~{$UOGd`Rmatnq1OKB1eNnXCPsZc_jibZNh$-K
zEBYsw>L>LdrGE$Qk;UXNk*IKIksd5E*~36073aT>g!6d#-eXTHsqpWS>g7WhbwEi->_R1mYU)q*V_@<-ld3h_V--}bq>w$szd>ssi
zwf#{@sJo@S=1PKkeOA(NXy#9*msi4`fuI|=;`R436&c-eJ*|l#R;%WRi`SB#m*iv)>8>WwTG51hnG4p(3bobc|J5FN(LmvK
z&KL8V=-|JePNj5N?X~!VfmoB)sJE^L9NG@ti*`as*0#Fyt?H?FT0H04oU{+@;h4
zQbTksyH}Osyjem}oQZPID1Pc2CM_&3d3_@r4=N(nLcQ*7YD&h_@a%@iZA-u6>m}>g
zL%L_)H#!*+3~ilr=dK;gDXP?V>7jw>DY40c{NKTw($teiPPm(?;eG3K)k15_s!~s~
z;mqL06)jfGU_SpABKAKNucz-5`Wqdc~|-
zfAa$NhJ9a}>ooK&tEkN7pnzVD3BJ>n3}19;!KO#!2w{4O6fW@~jj);n3IM@%UiP3J
zg_0)8&fNXIm`T!2dGd2((Jht`>3I^F)_i{p&new(!W4vrbv
z@_10+Za2L3L%Cb>5%3USmoqz~7CXsneJzGzbi5P;bXlxLeOa5;1R6vkS09jcP|~a76<5BO+HROd
ze|-1=JWS_O47$cba`d!J!I~zea$ZP>BgPpgg?A62;@2u-4BoxfnZoi_g*lsFwy^
z`Xry>4_()A;ZUKBb6WN6Lo3KH7q}?ka`Tn!$R`X>=Z+_@!?Nzt=Hc?%+b6;!gu;mr(Hy?ND~ykenfxdt}1<%%=M=8X;(%
zJx!xhx62G6&8Kf}kC;tslt>vS?0&TQfhUjAlYIvY^so|Z=`6_%dd}J#`)GO%@w+GR
z;}I?Q-P(7Ml5a555YP2@O<~%3HzJgH7RVzJBFuQ-xEd$ZGF^Cu`Eq|Jk10EPOZoQ-
zN&mXv37-CJ;=IYlk|QY
zcs{<;GP!72w`yHj7KHLS`N#&X5uKJgjEn(E)~LT|V-IonP|cuepqenl{=cle>n_$7
zhPew8uF8u_bjP0{g6`+d!Z(Op5}UvIoEJpb_eoF6BHY}Bpr467^)PZI0*w!qSW;|7
zI)FoF2h!F_=7$0j9RgK19{|&-YLcU0&LqH?mMXgwLjw#F2?~Eu=^pH>lRJL)qYf?87ec?^v&q!p7FLi{Z^j2$eT~)mTY;ElOx!
zlnrMqx$gX{-R%_r^;+>5Cp9NE&)8fJ4F&R{5THQnJ^w5`VLj~&c2riViZ;*007Mex
z*oajiFTVXk)iYZ?Z25D3h-JyZffm~^Wk#AlDxU7cg*>5!u8&=0UiQozIk&;ztH_
z4?nEvqonO1%hur5@J3>jcReDm_4q6uW_$@hoFovin9QNQ{1WzOYblZIJ36nzNI0n6
z@}GAsM3W6f0NY1E$`<5{%7jNZvOM)Yz|?pR@7is|L&_}!CCxqAM;I^y9($;P)NnwD
z0q~H3s4NeOwbZ-O-cJ0KnW_{!eHlHGU~8v{Bs>POom{~9B6byVt2!{8nB#AjRtJ^$
zOP6>d6KDVc0jNL#01B^N=(9T;wqjC#bSoZ+)8H=uj?OR^9NX@p;fZNy(0W(2D_hP>TJl`H6!@=5_`s)X(blc{xoGG4KLn#X{6=*e_KS`Bb-&$
z88-x&?auvomc~5nUkTvB&5}&!ljAG;z0z|zHRsM18GdNwaZP?VyhOs|Dml{Sj5yW2t4`QC#F#FQuG+$*-?dn^T@sZ8&W0(%cFSrh
zm_FjVruH!05-35ccUxZ)Uf^>10|DLzZ=79FHYCJunZd6%q
zUnXALRG;s&4Jq3)QN{s!U%#DFy{~=(G~bdGnDk`x(8Q`i-k2@c@nMkHx)?m<+KfNh
zg9~f5S?K7NiYh-y}t;kuHTabwTDp
zON#gzOQTpnj*a_bTr#2fGKt6L;5iKz<2POBTc2S
z)vhCYhqW6|RNDi(-7BPxo%AmFLR|+;!dT>J~}2^#+q=4GPOV
zRhw`zUY4hcFw#w~fjt&J%M#^%xh(P}o|0dcIu5Y>LIxCaUReUa%--)1ope+Q?aRzY
zddI7cU+$T(i44MDFo06<`k8PR&^4xmeki>Le)_>57@VyREZ8^%4T1UaoAbVX?}gSb
zDINzFEzWf3L%?WhCqORmWd@Z**T1%zybt{)N`5>Xn1w6p+3^TN^pbCNv&iV~zJuv7
zI-}D)U6TXJcJXPseU};Dc^SDqxyRE^^HNn9X`3yx)p{gk3VtH>9}x$0Kx{#S5UxjS)Q=K_kh38edp6WRG+54qLbvqJ
z?B?j;b*ogdvEZ&Exa(&Q&xTz1NpZvjB(^E4a0zVSVs}3Tohf}6DfTWs;wTYH`tbJ_
z9ICO}kF-QrqfLW=7lM(IBq@KD*6B@ZutQaOet1;ApY`je7Ubm%8s-&QboI_Uy>Q*J
z_iDnF3x+(QV$oZRS8_%Fcr4;~|8j253+t%s8<0`I>)gWjgrQF~y;XQQLVZWeNfd#b
z(K+2KQg(6~WQ^s9_j;RC93}q^ao0Lnrr1bpyh1!kJr?{t^oGP34(~p|o-|F9m|#WoOa9rdN^9C$I4JbNvSc
zJ75-($%dcbBEVlf;9n|*#O>SVe-$qQajpkjX(TeBWOe1&@0=?nw&<5d@sS1COs(ys
znJt>c3Iunqu#;&buFnwJe1y_MzGj+zF(6<%(jl_vKE@NmtkDAxpE|0kd?@z}n&*`#
z@XrYPxA+_8q!ux&!FpcOa=|U^qp-Q}ZVF9|_LWQgT?6Da>8`)yy;!VdPYl)_cYRz)
zC)rYZpU6I`iw3f6mnM15Pg7OUF0bqvT)O0;cn9~aeW=ymkh#=G&D>0MQ(c~*2SYNW
zL2$sQK2x7%=;a1de9?w@FWZD6*mGSRTU1Pq#KsRl;f5788#DBq@~JOf%M!)rxHSbf
z{em>KU|X0kS5gN`kIur`)Qe3I#??-vxD~Y!A}y55kQi=K{l>xB#A_9J&VwhPCE28o
zklsbAcq#Kh11Wwk_q$rlmq?7MspPtQpSIxYYJ9$Kr8%$ZS)J1^Ji
zML#pk&%7It)qvHv;1&SYuWYfdkS5}6oOSp261UQP*yLLEQkMu=sG
zz)x+^P-9-vx10)Ed~5@c_9)$h+M&BrxLc;MhH5#-HZ&=DUrXpdj69CI7uMLd+%)G~
z$!H5=;8drP*eZqQ0|H;`N#6SSc|7Z!aIGUP=iA_u`Tx^H)6gCM(%;z<_#TYNJn{=s
z@kbpqd%X-5zwoZRa$iXm36HMP`4cW5eh4lwIM2%aiyjbtaEHduee-)Yh5rJmOcF0i
z5cLd)>M{>vvGE@pRz|fhP@e`V7ST@VuarHW(Tza`M>0>Y!OHBgI{z<0G|iA68!P-q31<{y4-L29KZ3wXN!2iy$|hA
zPOk*@XI`p-9o0}uRBB5qun!^8Wqu~yfk%wmSn}ha3)tizb_`k3n
zYYH2se)_kf3}IiE7~;r$Lm_V7R7&%Yy-KXhblT6d)7l(PQ}(fI=7x_M5iSV-2Jg;_
zE`$L>L*!B5b*1jNb?1Hy5f7j>SM8FLEsu&~wEZi2Gj-|VPdx7c-&yMQMHoYF?XJu-
z4yu5z8C`4H-d#-7Q5Kc>i-WV|(I<2_BqpB$d?U4lP=Vc|6u}bwT0(Zs?Vt?gJvj=5
z6RX`;AB#5&)`jQ@_Q2k{TrIU+JOfC(-V~)ja)OC7jn~=7O20`yb+qZ3og>6Z>lmJZ
z^#L}1*j$`x@YxSZZqtyA6rh%PGF=HzJ085UI6^JN^qwlH{BlvjoVLeAOe)}j*h-q>
zK0?@k#bmYqBT9#sx-1SEG9S92P6MvIpJ>mhoSTnO5GDkOC<9sM*bSZYdZ(B?Ex4)@
zZrA~Pxet*uAKx6pg`Z554>?uv&GMkSKLRc03-d&L-@iK$Z;0jIfu00001FUFQG3EUKNwJ$1`!{r#REte=}!@%rjw%#@f
zJrq~wKMlxXE6QpdUvD>V0L3zT=*9e4WY54Ar*c#oftE~OT6fi{?LAlAjM}SJt80Rh
z(qc$8B|_#MH}+3+Vp;EKPPI$Q0Zsr@Plu(oaV&A^80+n!v;HLQxYI|GT~lzYUv$J3rk(A3}Xx+q+4
zVzMdJ+JoI>LZVS+MYkAVHtzX4T?&K(PW=pzeNyL0H$?QzHRGC#!cM!ZLxWf{s()Ly
zp|pnuXGIKSr^<2gNlFxyIa-)`D>voLiuY!ZY@WRv;L0J54E0PM#*=X=8PyX+{Oz-m
zFaQA!{f@flu3+H2t;0XT8tCoC>a`%U6w@J+lkzbHoF-wW)t_?+sX38iI5?ujG(Z11
zK;4|(r(+L^Jutrv)YaP!q`grH=lM7Ww>5!7W)_8&
zjAca<-PXBZe5)g_=8S6{=2?fzXP}qt?TCv*z(-Q{w1tdYROIG*Tw+zmuq`1L21d@P
zcs#;tzizxm?&!<(j+mmEB$-aO^Aqf#d0iUc$|fNNt~^Y-#Dbl!v>8Zj|9?teml77-
zzzhc&E6$BuY<_IH{bDqTvel@BQ+*3h^W1@h6;qBhdNF3La3>&XGf#mghClcZ1(juv
zTpuPZ#qDsrN7(O`x20g%x#sUx^MK<;7YqIh(+_G+g)cQ+mTsl*z1d@Te?T8FD{nnL
z1JiElr$FWZ&rHuyTSr9ZW`p^E7B>7+>}$llLpLYKY{5n;Lx|TIbWG>)WDmXO&3&bS
zuSA^vAEC`4?XZZ~lR3nNQBTg1y;JPQ-|YX|SjuB>9T5LKV{{?M9I)AT%>P>3nyX=M
z6;lTWFBjg^6ac{-?O&^(FxJZGuZOv5XNe6#15t2lnKW1$Jzy-~27C}I)D7KK_km6S
z73&pzm#&42xV;xm1#$i^Z3@Bl_9WJcCS`FS$i(p_aCE(siEnsMSym2q)%`LdQfZdYB)})J(=3Juh
z+oY5i77Tv$3n*#4Z4kNbP1rOw?f4Ja=qUScmPuu3==<)QB4AyphmwXp^a^qI0Tr#6
za{yA%7{B#CmwWY`E*wH@d@BTmuwf%C_3N1EjVibYWc4wLN!0n&>JlMGls(p)>xuym3%EsIzS}L=`QabHINkYm-|k`yt;`(Y?|Iy
zT^<>-C|RS^oyk~A%~4pUW2w>7lWKLwjjcw^>gk!sh+CmZqd+af9$V6PBY3#L>=>7rRO1fa0CLec$Aix038dv&d+amNwz?c*yYP-?M
zL}tplKVf5xIaW$;xL=rU8D+ifL{bOP*(lxC-{6o^uKZdbEYpF_4RehukV;RQQii^A
z0c8igHnz5uf(XOMuA<-^Hj1$QH7V7!AhzSN&@hafvob_7Ti@)@3d
z74b?0Dh6(b{m#r#0>fkpRppW8Z$q$zWUqeEfIL)Oz0vxSJ{A
zyY^`oVC**-e<|WNtj~5BhGzE8k%lEWK1ScYX$>~*3AEHXUiV7C9e|AIu)r(W)`c0x
zkNf926m0~OzOKImqX6#DdnAI&0y>ca$LTFbQ2QYk=#j<9aj=Te8legcHi3a%fZ
zz;e3IgssY^Abh=CKz^PynOKe|)s-;jwVcbD*V6Y^rQoX&H?x{Q(my2u#(Gld%I`px
z{}Q5M?~p9MW<7b*YIzxjA0s3_K3XHQ1jKHM{_3~t*>ZFN+eJCq+3de`nP41~19ifz
zfXbZjA6nEpn#Bv{>lxD5#=I4AuOE;C0oZZfrx$y7`cOV_BZJ|I!u}~N%(NbV>R4O_
zU*UjhuP%GZK~*Ska?LaQEL}HHT{4G4UXrf&OvHG-hi-6HwH_Z$YK0!ApnRC
zxgm%`5H+&q-ha05YM}^6)Oq0t&)DH-gD_N==&cdO^5BMe=6)}zEyb&u;&NN-@a{_2
zqoKR^?cY+7enWrH0gCxX-c}D#v=R?LN^{x*ND|N~-3x>YKG~35FsLnFs>r|aLjT|c
zANCC93*(Nj@Z?-g=uu2+6)F8ZN(Ik7#98YXI+n1HZdUZ8)F0SM=1?pJ_q<~&Fp)))
zC^{npq*t2^JGJu%(eH^1>c*ElSseBruEUAull)LAC&r$+=o2A0+zU1Z~c?L
zXQE0kP(R6S7nTj1+-j5XIbr{;*GlY7Bl+VHXVopS-K?Ro4ZmusR|DNj%zKNV9
z;*MWCY)h9^w|EXM)o3YI|BU*1*eh2Je_xF_C88k110R!9xw9*-Mbzrt@+huhoV@9G
zqvbsqjyEu|l#W_^xzy&vJvwea*4&U<7%7P=&pV!;O7-eZ$SRha6v+D(a7_>t
zMA#43BM1YqaHPmI?rcFKO@OTm;DS744B#mU+rT_U$go;r%k9|*v
zNwPGkuJ+ETWC}ujPohBO?tSur?0mcgN{om`f{4HZDAh*AU?hRQ;!rehvE8x}W2}ys
zCbDnZLEvZE5iwBo=GxqvibOvVIX_*d9CopL!X53F;sLHt%8tHraW-A!T?f*LohkvsOj?KT6?VHg?*gxD=L-5
zY}8b9TMjgh?1V5m@!^q>!3rkyCQV*FZ)1L^g~2i{W24VgmW0etOW_dGU8zzl@Pg+j
z#-*Z4j_xlzFP
z)jQTS03iY9IQ83ZpRyP4-oK{gZr&j8I-2|N$#
z8;G@~M%t7Oz=SlCdg3%jXsxp_|B?t(>7mL*o(JWX8NZ~%T#KQr0R{JH)1yjG0i4+c
zUZKfVpgqoXGb&v3Uwlf|6?SCc@~Fvo%#+CYO(9y9u_KJKiY&Pt$Kx>hgeZ7Fn2_bN
zg@jf=8>f8j?I&i9penOH*y!E&@FKJAFjSu$6hI(22@4ZPfF>Gv%B6chaEb@wjm)r&J4Vp^u
z<7kB(wZ+``DpVbQ*&jE0%bT(HGO=nq(R?@z|8|6Y)=e@r1vq|*$Mbz9vjNX?&K2a8
z#4iLu*E+#IR2VRqzt6XEiLi3wwIj9i;6;whlcs?Puhn3NRi;jucwk}TIG1MgH>>k2
zvyGEcVgyXXpOgo5(Lb~;M7a^!PdM4^&&AHH`1mJrE$m_zmFRmZxW2(p^1~&@rE}t*
zVqdXoQh`?+6K6eIu;dDfM&JRke+VFL7ved!QU^wQfv!yp*Okc(r;owIyhn?AyE8=I
zSCpGy48TSUmh?X9nR@C4NVl{3rl6j3>K5H*jlmgdpxQr4co23(1QtbsGUa?Fx?K4T
z;x^5qmcUO@aHpb5=*e|PzcTdBG{4-n)5r=lP$icx{>DnUj^R6*rF!((?y#Ky-*@FR
z>%k;~9)%=s^^%$mYuFp&Q0$NKwOND3<(q>$D*JMR1Ef8GsVBky!Pkz-b{a8^Ev#CZ
zfTgS8o>|Ai$^FzpD$xuDOBrb9sh~D<9nbe&Rcr~C4DBG?Z{;dxE{x3a%vTzg&JXmXl}-1C69t$ZOvAj#r87MfEE{7hS;WA<*p-$_S<(fsYkLI5K;D2wBA+)
zwM>A>MyCIY5wKCJPpT~d3h7YjIe=w8g=Zg_etO#-vDg14_;_A7h}ctjHmHy03*F;94AE9BuJdR
zvR^V+*OT3Uqt8o=ssfv)IzI<5#g|7KOlCwy^mw->Y;!+DyABU!Z8|@Z!C(sbZ1V9d
z5I-OKqxw0+#F_N|2KPccmU(hyO4b-qJn<7gr`4m+^4o8;959xwj@gn*R&h1907s)r
z@W<@Ci18}eOgzrR(pXVLKZ~H8$XMg?DBc(q&A8bkZ9Ix#XL#&3s--dh65eqkOX{d%FEhSgQHk-v+}nr(7w{_xfHhgGhL!yFEbQ+
z*j_JVFuwDj!hN?|hJd^bo$-#$!`d9-a18SfRa_nh_H;Taerr!%Dq0>ve?;1<(VtGm
z93HwngapKVZxBLcWe_kIYbh&lDheQv*Nb=jYv?|4J>B
z1eZ(W1{wYR!7CvuJMNn;?n?C)^C|WuUNVeJ>}G^dW|NZSPu}j<&kR{$n{v!v)}kSO
z8knT#XBElJS)6}ov01EX*HUQEFqAoG97DgLLY8sk@ugt-Ovb!osZ_;-pp4>j(mvUO
zHcHVGZdtwM`R^JHLMKipqIGYkbIY?fa~C4`B;c!##6>BXD9v$$lJC~wfvK#@b{AW$
zZgdJdYEA)ecu0HwLlRRa6hs6_zq=$;+K}me0CqS#1xZVv-J`tPcEiEm4*e53mRS4F
zqXn1}(nXU8$|1!-SY*$1r#)t*yeX&ni|SZXZw#vv`A^9JVD-A2dE_setgU+c_I>z1
ze|;e1
z_kDr33i!AkuLw|+nLQ$4pgIWlu&CA91phB}y&+*C{wi#m7S|h8B2ujRK@OjQfK8PV
zHNsfcepksJ4hjHfMfwz@sKkf>0svfR%bPS!VH0oXvYk|Ee<;s6qT?!!h|ktGflvMU
zIZf7ZMA;L<0oX4P0oDxRzcoS_#2~9%JSPD)unewwF$jbM*8a32YO
zhI2$^31ge7sJhtR&b}X`Z~5oKBOaGPMR?$QhX=56XaX({t?EUK>4tVXavcHvo28ZqQcCWo-S|I85PTzJ8j=
z^<-37VHu6p_`UDmOH|+FsJjlMG0Jb+p(K>SS;3n9b|urdv0KHd~Ob~29zry|JVXP&ki24UZ?=CxtB|JI1##VKVQsQ2n^*hS*a_SxS
z#x_EgepLt=M^IY=acCb{fQE*b=Q%2nx6_(mW8X>IH&sfh%)Rnk?&CO29@VlT928iw
z|7T8(D*kxA89=+qCugEf*X^vdMr7mACf`f9WAx6^r1!ZTaKokKCh_(Wej-FR!7&r|
zhM8#}MOA{G_FMhRBN6DFGZPWkEvU!}1DqI{AJ=@YyXujFiAO_?N?oDM*bhzS(-FZ?
zlIVUz%0^hLBZVq_|Hy%zMW+K*&{=*S%#!%QW!F3WnF^-{LZrQ7Dklzt%Zmcv3ws7{
z4DsKz=aqu>Xk>5czPl!j9nR9O9G|CKZ(HL7$FTjST#*WwZ2Ys?JF%-nMg&fSv?yzU
zv?{@01r->vD+XDomAFIgxLR}A_7nhwBiVYR$V>Ay``gG@6_Z=hSxrOoX!fj$#i$m0
zvsUA_Rrni6NAD;vOIA8!3aFhQZ={!zBfoW!PJ~V7mgwyXnaRb#)uiDC%UNv#Vf2+g
zdBNfD^J&aAG`jD=S~CNAnI2RXAm6RC!_)9|xs=VRjs-zn`)VQLg>qMI)5>eO`+*!u
zq^5P|*v#W)QQh~{s%I%}9s(B!F{Q
z!f^sU7I4q?j|rPXO}*FhOK}4E7JRRy`5_cVAj8!VSa
z5;sieGLU+*0b>)K>A#_yu>fI(u6CQ6V`8Er08U;{ruOu%ds`Q1Y@r#
zIl*8^{(YvR(Nv!Y3Ym-9c3rA^_Ypz{frjUw5OgqM!T}60Z{{a!_@JJxB1s-~t`w#<
z9E-AzlaB+E4|s)b!=(?Hn3jQF`r~=`r;5`xgv*Stw$#?sr&B~pR=jZc;aU^({Tehe
zjWVKO=2*OY@>ItvBdr+mAFrtK5%H0S^(EY<+upeVPp59iq5SG~gH2g#CiQ1pYL*?G
z*%z5&`WmB2iE`@0>X?g~un>zhZd4zbe7>*iB}m+{HIEZUG*_Nm7LVM3TifovCGjGZ
z00XrQgr)3E48zM9Ju+bTLv^v}^<9b955%x_>s-SE+;!)#*-3;1G2=@wKq6j(1(^oe
za`r{kSV5Fiiq-Y&;o&_l!6QT)qMMMX!7S~LgF~Yc$Q0ypt2Jo%e?BKVMQ&}W_1w|lzuF=iyn*r>K>0Cq4U_LUh)L6b
zHKS_W!z;<&ggjkOq+PQ(6d9TJxpuh|U+5uK4L88srs=ylPZBr3J26GzO>mB6OT)4=
zXYGGvY=>Q8oPQK-$*aEJOMFQ^fBHFcrqtE<=_{0fE{1VZUt=o#Gq)*jJ7=$1bBkIU$d#HJs!)OJTF+u$!)-9cqi7Yia~}~-
zWELa#HY$eBEVGHT{AOHs2vG=c2NCtXj6Nu)z!|gvs7LauzMtCRGZcVK^S_SPa-n-t
z0=~I!%&yS9!eI4>?h3^Q(AO43_Ar=E==@>Pu!FaZNeP034>Yrf)gMtp%xK
zc@(^)#s{ln3lHA^57!ru*<+Eoq(nmPRJ~M*F3Z(EM@|htASO(F>OEgw)IKvdiFS!N
zyHOuj?t*^>IgN>9OOPRewPcP%L
zAEQ?{AX-1hE^9yw@i3SSyuL)HEbBJdeO}uSsauicASzx?4e-m77jFY?)^uvIrC?X$
z)ve@fMhqu7>AW(#D0*{G$iunEkcv
zbKcmpvY-F}05{R*-XGziv~t|BHU#571fSDvm3x}v25#YExFs}hEq?IFNq)eOqv+Ua
zVf348`?64=^pJh=9mpzA}1
zwcz=h{g5UZphK`&IVEgPn(MO8(_1YJ?Xg&|p%s|F2(9#U&}SEOHk8U5MIgS=4TET<
z-~(of)2s3vB7I|6YD40RcUKe(7|3K!fm9jE_&Jo;C*j+2PplJ8Pa=6&z^-;pmG5r4
zNxIb#HbBg&c~-d;mf>$Jrn@$Q>B*q>vI!=k3y2WM7z3~`XNvCEMBK3=;+-A`Yi(}Y
zs=;XAJIoUUEXhpH0}Ig7i$fVK3p<2WOF*EmbfBVeyeAV!mweax~vfR#dDWpQ@@
z&I?z^jIvm$TneEEkQrnrKKH;6)KBsUc1%PLBaW(Jt$m(@6jT
z*(MNm9NeT(qK0>yfIcFnV_=4@y=i{6{PYgEV&=>VR|yljsvMJEAtdBlpY+?Q@Y)tE
zA?~+y;2zV)0xkUe%&-xMIzF(8O6YBla2x&8U3W)i)ngv?3SZoqQttz(!{Lne%ek8daNa?=yt~+3JzM$DX`!ANPrKQ
z6}9{%F#X!^4A}awoXzEvi6`lQ
zjewV##&SkN0TB!=B;ldNRr+PYXS)M0O&}zay^pf!N5HK_OK5RWQaANS*u+aZw<=wd
zfVi(3=w1jcCF;HO>@XF34<%fFe|v~>dm7SgJTfovxmt_$3+7Kyrq@Xpd@Gh&pwOrO
z43dbIF@!zsqak_fwl?Z~5OqtAZoxkClGRf;k~medSi}pkI6uvG(YM4k4u*qu1Z``*
zEQ8H?(h`X$0fwYVl4mq4cQ+a+9wQ3+v6g|XSaMeRqRm$iRQX6#N;frA{lDb+90pLp-ZcYwo=g*61-pP*3d~%=b|d{jcAIvv_P+xQexFqy-sao
zF8DPF_U;gQB7^ALBMjwBpE$V<2(aRZ5$M@F)4eLOTE|sN7QM6DFjN@#{B;H_>;Bwo
z2BV*xhcy>HA?t7Ac<#_k6iDQEoqMyv@>%vYvt$2;e5@liN?b(KRzZ#}X9yXxVEnP1
z>HzTV;`amO)O_=Y2k*wOJBU#;y|6d}LfNunOM!Ucv$-PZ$e4R)et@{+WD}H{uhftC
ztA{s=jXaXJNcQBZAVgC+wNcS}BZbsrU^B8=x2vO}O)X5W+yM$o!17k6bzJhsZ%RPB
zlBobZ6PPfbd073_a3+)2qfH?_R^P)yS7jGf^X9(%Ki`;d!)on2!wF8@CK4_-H9#nD
zDZ&rc1%b^v%I)?!%OpbG65IR|Qys_y>_5~!L0?Qgi*9F{DbHyT@)B)<62iB|O^e6)
z+oDRPz#-Vn9}!eGM9Guf$sFKYx^#ukh6=iAO~D{s+Q<
zLC&DjYB}vDz8qudS)MW%Dl9k$dntJDI*!O23y|FXt>~Zekd+JPjt`*QSKA0r+r{X;)Blr{Ps)o
zKKn;B{Y=96^+gY6QIQGp{l1O6}?yQl`=;?08218$iKXtQ^|i|kOfcq{cccs~^~7zPNKz+yEY(^#3$o;h+%HtN*G@+!zIVK#-!DL*Nz
zT>A~~mR?YQ@3h?Uq6qJA=6KL3)ekyS=(HydNJWov+B{8V8gvifbuypR%@Zp7{L>Mg
zS)E@hq(v;gJQim(QpRLV(Zy@<%9tQ6aZz2l(S>z#$7=5`EhyyIr3`oJ*$8(lU%e@_}5
z6gu6XxdxNg{{?yGY=VkJBTJIP=95(`gFChL!XsLq1dQtEzwy@k+v>`Kc*>s>qIXxP
zSuRU|DrdsU3P}gM&7X(Y($*(bkDu1}6SA3InaykaAQ
zhNRV!%j0YVE1{>1xtkoyH|P{24Gvh5gPU6~gPXrQ^I`E!dDb(lHnLgj8Yi03*i
zCzxV|$qN8O($l2~+76v7wcA4e7*it1mJRt+$Ak>{bh4
zlrb{QKgQ7L<>OZCDCs?3aS*fYKHC8cEB%iSw(4>`+}iCx1DB`5FJOu;0z=pU00PsJBC2;-CU~C=FdgEDEz9eHHwuAzr6;}YFY0VvBlq(6
zf<{gXtK@vC)E=ybqhorV1RlUV^$0=S60
z0001Yi7?Z8L3Yl-{YQ;Mhx4&=C2?=qC1*B+C|>?F>s`JF=x;S!CcHbzi?lc<{F=H(&c~WV|K%8<(|vxwjQ?V~
z!2k0vqN3OMm_=x@qTkA0@W2E1)w&uhM`XqNJwIK_E%6^i#iD^m7Ey0CuE)0|m
zOklDp?gc-h-=vdzKM$-PPK8rqfrL5U47DEq8pZS)-m7Eki_v7Q_^g@rD$fNl5TV(e
z$sae!{Yt>`v93HD4?qv9s>MmU|H>8kfPYp1h+!bLOI(0%Z;0bXp45q2IXs|T9g)lo
z8A%Sb=>Zz{^;iP~fo2eVLH*5+^
z$@n_;{az*h-E#tVh1fJB$_Z9V|0!6Vm_Qb09gz`?OA!QS(iOiH>XFoE>}ez>TNEO}
zyyA2xaFp&bao3|_V?23VD#x;ns}!1HU?nthV3_82a)7~1K|IVh6OA&qru75V28$I`
njsRsnTIZ5)ovTKzCa`@Fd@+J_F2VDJ#1KRNRqQXn2Pgml#p~~t
literal 0
HcmV?d00001